Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
jacobsa-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
jacobsa-fuse
Commits
4b0c3778
Commit
4b0c3778
authored
Mar 20, 2015
by
Aaron Jacobs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
FlushFSTest.CloseReports_MultipleTimes_OverlappingFileHandles
parent
a8648b28
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
56 additions
and
1 deletion
+56
-1
samples/flushfs/flush_fs_test.go
samples/flushfs/flush_fs_test.go
+56
-1
No files found.
samples/flushfs/flush_fs_test.go
View file @
4b0c3778
...
...
@@ -265,7 +265,62 @@ func (t *FlushFSTest) CloseReports_MultipleTimes_NonOverlappingFileHandles() {
}
func
(
t
*
FlushFSTest
)
CloseReports_MultipleTimes_OverlappingFileHandles
()
{
AssertTrue
(
false
,
"TODO"
)
var
n
int
var
err
error
// Open the file with two handles.
f1
,
err
:=
os
.
OpenFile
(
path
.
Join
(
t
.
Dir
,
"foo"
),
os
.
O_WRONLY
,
0
)
AssertEq
(
nil
,
err
)
f2
,
err
:=
os
.
OpenFile
(
path
.
Join
(
t
.
Dir
,
"foo"
),
os
.
O_WRONLY
,
0
)
AssertEq
(
nil
,
err
)
defer
func
()
{
if
f1
!=
nil
{
ExpectEq
(
nil
,
f1
.
Close
())
}
if
f2
!=
nil
{
ExpectEq
(
nil
,
f2
.
Close
())
}
}()
// Write some contents with each handle.
n
,
err
=
f1
.
Write
([]
byte
(
"taco"
))
AssertEq
(
nil
,
err
)
AssertEq
(
4
,
n
)
n
,
err
=
f2
.
Write
([]
byte
(
"p"
))
AssertEq
(
nil
,
err
)
AssertEq
(
1
,
n
)
// At this point, no flushes or fsyncs should have happened.
AssertThat
(
t
.
getFlushes
(),
ElementsAre
())
AssertThat
(
t
.
getFsyncs
(),
ElementsAre
())
// Close one handle. The current contents should be flushed.
err
=
f1
.
Close
()
f1
=
nil
AssertEq
(
nil
,
err
)
AssertThat
(
t
.
getFlushes
(),
ElementsAre
(
"paco"
))
AssertThat
(
t
.
getFsyncs
(),
ElementsAre
())
// Write some more contents via the other handle. Again, no further flushes.
n
,
err
=
f2
.
Write
([]
byte
(
"orp"
))
AssertEq
(
nil
,
err
)
AssertEq
(
3
,
n
)
AssertThat
(
t
.
getFlushes
(),
ElementsAre
(
"paco"
))
AssertThat
(
t
.
getFsyncs
(),
ElementsAre
())
// Close the handle. Now the new contents should be flushed.
err
=
f2
.
Close
()
f2
=
nil
AssertEq
(
nil
,
err
)
AssertThat
(
t
.
getFlushes
(),
ElementsAre
(
"paco"
,
"porp"
))
AssertThat
(
t
.
getFsyncs
(),
ElementsAre
())
}
func
(
t
*
FlushFSTest
)
CloseError
()
{
...
...
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