Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go-fuse
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go-fuse
Commits
66ff11b1
Commit
66ff11b1
authored
Jun 28, 2013
by
Han-Wen Nienhuys
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
unionfs: drop ThreadSanitizerSync from unionfs tests.
parent
f5e7830e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
46 additions
and
9 deletions
+46
-9
unionfs/unionfs_test.go
unionfs/unionfs_test.go
+46
-9
No files found.
unionfs/unionfs_test.go
View file @
66ff11b1
...
@@ -1081,6 +1081,47 @@ func TestUnionFsDropCache(t *testing.T) {
...
@@ -1081,6 +1081,47 @@ func TestUnionFsDropCache(t *testing.T) {
}
}
}
}
type
disappearingFS
struct
{
pathfs
.
FileSystem
normal
pathfs
.
FileSystem
nop
pathfs
.
FileSystem
visible
bool
visibleChan
chan
bool
}
func
(
d
*
disappearingFS
)
fs
()
pathfs
.
FileSystem
{
select
{
case
v
:=
<-
d
.
visibleChan
:
d
.
visible
=
v
if
v
{
d
.
FileSystem
=
d
.
normal
}
else
{
d
.
FileSystem
=
d
.
nop
}
default
:
}
return
d
.
FileSystem
}
func
(
d
*
disappearingFS
)
GetAttr
(
name
string
,
context
*
fuse
.
Context
)
(
a
*
fuse
.
Attr
,
s
fuse
.
Status
)
{
return
d
.
fs
()
.
GetAttr
(
name
,
context
)
}
func
(
d
*
disappearingFS
)
OpenDir
(
name
string
,
context
*
fuse
.
Context
)
([]
fuse
.
DirEntry
,
fuse
.
Status
)
{
return
d
.
fs
()
.
OpenDir
(
name
,
context
)
}
func
newDisappearingFS
(
fs
,
nop
pathfs
.
FileSystem
)
*
disappearingFS
{
return
&
disappearingFS
{
visibleChan
:
make
(
chan
bool
,
1
),
visible
:
true
,
normal
:
fs
,
nop
:
nop
,
FileSystem
:
fs
,
}
}
func
TestUnionFsDisappearing
(
t
*
testing
.
T
)
{
func
TestUnionFsDisappearing
(
t
*
testing
.
T
)
{
// This init is like setupUfs, but we want access to the
// This init is like setupUfs, but we want access to the
// writable Fs.
// writable Fs.
...
@@ -1101,9 +1142,10 @@ func TestUnionFsDisappearing(t *testing.T) {
...
@@ -1101,9 +1142,10 @@ func TestUnionFsDisappearing(t *testing.T) {
t
.
Fatalf
(
"Mkdir failed: %v"
,
err
)
t
.
Fatalf
(
"Mkdir failed: %v"
,
err
)
}
}
wrFs
:=
pathfs
.
NewLoopbackFileSystem
(
wd
+
"/rw"
)
wrFs
:=
newDisappearingFS
(
pathfs
.
NewLoopbackFileSystem
(
wd
+
"/rw"
),
pathfs
.
NewLoopbackFileSystem
(
"/dev/null"
))
var
fses
[]
pathfs
.
FileSystem
var
fses
[]
pathfs
.
FileSystem
fses
=
append
(
fses
,
wrFs
)
fses
=
append
(
fses
,
pathfs
.
NewLockingFileSystem
(
wrFs
)
)
fses
=
append
(
fses
,
pathfs
.
NewLoopbackFileSystem
(
wd
+
"/ro"
))
fses
=
append
(
fses
,
pathfs
.
NewLoopbackFileSystem
(
wd
+
"/ro"
))
ufs
:=
NewUnionFs
(
fses
,
testOpts
)
ufs
:=
NewUnionFs
(
fses
,
testOpts
)
...
@@ -1135,11 +1177,7 @@ func TestUnionFsDisappearing(t *testing.T) {
...
@@ -1135,11 +1177,7 @@ func TestUnionFsDisappearing(t *testing.T) {
t
.
Fatalf
(
"Remove failed: %v"
,
err
)
t
.
Fatalf
(
"Remove failed: %v"
,
err
)
}
}
state
.
ThreadSanitizerSync
()
wrFs
.
visibleChan
<-
false
// TODO - this is racy. Instead, have a custom FS that will
// switch based on input from a channel
fses
[
0
]
=
pathfs
.
NewLoopbackFileSystem
(
"/dev/null"
)
state
.
ThreadSanitizerSync
()
time
.
Sleep
((
3
*
entryTtl
)
/
2
)
time
.
Sleep
((
3
*
entryTtl
)
/
2
)
_
,
err
=
ioutil
.
ReadDir
(
wd
+
"/mnt"
)
_
,
err
=
ioutil
.
ReadDir
(
wd
+
"/mnt"
)
...
@@ -1155,8 +1193,7 @@ func TestUnionFsDisappearing(t *testing.T) {
...
@@ -1155,8 +1193,7 @@ func TestUnionFsDisappearing(t *testing.T) {
log
.
Println
(
"expected write failure:"
,
err
)
log
.
Println
(
"expected write failure:"
,
err
)
// Restore, and wait for caches to catch up.
// Restore, and wait for caches to catch up.
fses
[
0
]
=
pathfs
.
NewLoopbackFileSystem
(
wd
+
"/rw"
)
wrFs
.
visibleChan
<-
true
state
.
ThreadSanitizerSync
()
time
.
Sleep
((
3
*
entryTtl
)
/
2
)
time
.
Sleep
((
3
*
entryTtl
)
/
2
)
_
,
err
=
ioutil
.
ReadDir
(
wd
+
"/mnt"
)
_
,
err
=
ioutil
.
ReadDir
(
wd
+
"/mnt"
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment