1
0
mirror of https://github.com/fuse-friends/fuse-native synced 2024-10-27 18:34:01 +00:00

Better unmount behavior on OSX + OSX-specific unmount tests

This commit is contained in:
Andrew Osheroff 2020-02-06 17:42:13 +01:00
parent 5b62bc5380
commit 98891fe157
3 changed files with 68 additions and 31 deletions

View File

@ -257,7 +257,7 @@ class Fuse extends Nanoresource {
static unmount (mnt, cb) { static unmount (mnt, cb) {
mnt = JSON.stringify(mnt) mnt = JSON.stringify(mnt)
const cmd = IS_OSX ? `diskutil umount ${mnt}` : `fusermount -uz ${mnt}` const cmd = IS_OSX ? `diskutil unmount force ${mnt}` : `fusermount -uz ${mnt}`
exec(cmd, err => { exec(cmd, err => {
if (err) return cb(err) if (err) return cb(err)
return cb(null) return cb(null)
@ -320,8 +320,11 @@ class Fuse extends Nanoresource {
_close (cb) { _close (cb) {
const self = this const self = this
Fuse.unmount(this.mnt, () => { Fuse.unmount(this.mnt, err => {
// Even if the unmount command fails, do the native unmount. if (err) {
err.unmountFailure = true
return cb(err)
}
nativeUnmount() nativeUnmount()
}) })

View File

@ -1,9 +1,13 @@
const createMountpoint = require('./fixtures/mnt') const os = require('os')
const fs = require('fs')
const tape = require('tape') const tape = require('tape')
const { spawnSync } = require('child_process') const { spawnSync, exec } = require('child_process')
const createMountpoint = require('./fixtures/mnt')
const Fuse = require('../') const Fuse = require('../')
const { unmount } = require('./helpers') const { unmount } = require('./helpers')
const simpleFS = require('./fixtures/simple-fs')
const mnt = createMountpoint() const mnt = createMountpoint()
@ -135,6 +139,56 @@ tape('mounting with mkdir option and a nonexistent mountpoint succeeds', functio
}) })
}) })
tape('(osx only) unmount with Finder open succeeds', function (t) {
if (os.platform() !== 'darwin') return t.end()
const fuse = new Fuse(mnt, simpleFS(), { force: true, debug: false })
fuse.mount(function (err) {
t.error(err, 'no error')
exec(`open ${mnt}`, err => {
t.error(err, 'no error')
setTimeout(() => {
fs.readdir(mnt, (err, list) => {
t.error(err, 'no error')
t.same(list, ['test'])
unmount(fuse, err => {
t.error(err, 'no error')
fs.readdir(mnt, (err, list) => {
t.error(err, 'no error')
t.same(list, [])
t.end()
})
})
})
}, 1000)
})
})
})
tape('(osx only) unmount with Terminal open succeeds', function (t) {
if (os.platform() !== 'darwin') return t.end()
const fuse = new Fuse(mnt, simpleFS(), { force: true, debug: false })
fuse.mount(function (err) {
t.error(err, 'no error')
exec(`open -a Terminal ${mnt}`, err => {
t.error(err, 'no error')
setTimeout(() => {
fs.readdir(mnt, (err, list) => {
t.error(err, 'no error')
t.same(list, ['test'])
unmount(fuse, err => {
t.error(err, 'no error')
fs.readdir(mnt, (err, list) => {
t.error(err, 'no error')
t.same(list, [])
t.end()
})
})
})
}, 1000)
})
})
})
tape('static unmounting', function (t) { tape('static unmounting', function (t) {
t.end() t.end()
}) })

View File

@ -6,38 +6,18 @@ const concat = require('concat-stream')
const Fuse = require('../') const Fuse = require('../')
const createMountpoint = require('./fixtures/mnt') const createMountpoint = require('./fixtures/mnt')
const stat = require('./fixtures/stat') const stat = require('./fixtures/stat')
const { unmount } = require('./helpers') const simpleFS = require('./fixtures/simple-fs')
const { unmount } = require('./helpers')
const mnt = createMountpoint() const mnt = createMountpoint()
tape('read', function (t) { tape('read', function (t) {
var ops = { const testFS = simpleFS({
force: true, release: function (path, fd) {
readdir: function (path, cb) {
if (path === '/') return process.nextTick(cb, null, ['test'])
return process.nextTick(cb, Fuse.ENOENT)
},
getattr: function (path, cb) {
if (path === '/') return process.nextTick(cb, null, stat({ mode: 'dir', size: 4096 }))
if (path === '/test') return process.nextTick(cb, null, stat({ mode: 'file', size: 11 }))
return process.nextTick(cb, Fuse.ENOENT)
},
open: function (path, flags, cb) {
return process.nextTick(cb, 0, 42)
},
release: function (path, fd, cb) {
t.same(fd, 42, 'fd was passed to release') t.same(fd, 42, 'fd was passed to release')
return process.nextTick(cb, 0)
},
read: function (path, fd, buf, len, pos, cb) {
var str = 'hello world'.slice(pos, pos + len)
if (!str) return process.nextTick(cb, 0)
buf.write(str)
return process.nextTick(cb, str.length)
} }
} })
const fuse = new Fuse(mnt, testFS, { debug: true })
const fuse = new Fuse(mnt, ops, { debug: true })
fuse.mount(function (err) { fuse.mount(function (err) {
t.error(err, 'no error') t.error(err, 'no error')