diff options
author | Jakob Unterwurzacher | 2021-07-29 20:39:50 +0200 |
---|---|---|
committer | Jakob Unterwurzacher | 2021-07-29 20:39:50 +0200 |
commit | 0ca302f12aa8be391d6b8e7081b5c75fbec2e872 (patch) | |
tree | bdf36873bb3a7cfc6cc5a3c14f63dede7d33c2a0 /tests | |
parent | e83b79b4c2e8619f0f9622bbafc39d04eeced3f0 (diff) |
fusefrontend: implement fsync on directories
Fixes https://github.com/rfjakob/gocryptfs/issues/587
Diffstat (limited to 'tests')
-rw-r--r-- | tests/defaults/main_test.go | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/tests/defaults/main_test.go b/tests/defaults/main_test.go index b356f41..2513860 100644 --- a/tests/defaults/main_test.go +++ b/tests/defaults/main_test.go @@ -11,6 +11,7 @@ import ( "runtime" "strings" "sync" + "syscall" "testing" "github.com/rfjakob/gocryptfs/tests/test_helpers" @@ -394,3 +395,30 @@ func TestMaxlen(t *testing.T) { t.Errorf("wrong output: %s", string(out)) } } + +func TestFsync(t *testing.T) { + fileName := test_helpers.DefaultPlainDir + "/" + t.Name() + ".file" + fileFD, err := syscall.Creat(fileName, 0600) + if err != nil { + t.Fatal(err) + } + defer syscall.Close(fileFD) + dirName := test_helpers.DefaultPlainDir + "/" + t.Name() + ".dir" + if err := os.Mkdir(dirName, 0700); err != nil { + t.Fatal(err) + } + dirFD, err := syscall.Open(dirName, syscall.O_RDONLY, 0) + if err != nil { + t.Fatal(err) + } + defer syscall.Close(dirFD) + + err = syscall.Fsync(dirFD) + if err != nil { + t.Fatal(err) + } + err = syscall.Fsync(fileFD) + if err != nil { + t.Fatal(err) + } +} |