Commit be264094 authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

Cleanup test FOPEN_KEEP_CACHE to be more idiomatic.

Check for kernel version before trying notify.

Change-Id: I6b241dd53377d4aa43b109b981f3941d2ad8dbb4
parent ebe08a81
...@@ -59,51 +59,48 @@ func setupCacheTest(t *testing.T) (string, *pathfs.PathNodeFs, func()) { ...@@ -59,51 +59,48 @@ func setupCacheTest(t *testing.T) (string, *pathfs.PathNodeFs, func()) {
} }
} }
func TestCacheFs(t *testing.T) { func TestFopenKeepCache(t *testing.T) {
wd, pathfs, clean := setupCacheTest(t) wd, pathfs, clean := setupCacheTest(t)
defer clean() defer clean()
content1 := "hello" before := "before"
content2 := "qqqq" after := "after"
err := ioutil.WriteFile(wd+"/orig/file.txt", []byte(content1), 0644) if err := ioutil.WriteFile(wd+"/orig/file.txt", []byte(before), 0644); err != nil {
if err != nil {
t.Fatalf("WriteFile failed: %v", err) t.Fatalf("WriteFile failed: %v", err)
} }
c, err := ioutil.ReadFile(wd + "/mnt/file.txt") c, err := ioutil.ReadFile(wd + "/mnt/file.txt")
if err != nil { if err != nil {
t.Fatalf("ReadFile failed: %v", err) t.Fatalf("ReadFile: %v", err)
} } else if string(c) != before {
t.Fatalf("ReadFile: got %q, want %q", c, before)
if string(c) != "hello" {
t.Fatalf("expect 'hello' %q", string(c))
} }
err = ioutil.WriteFile(wd+"/orig/file.txt", []byte(content2), 0644) if err := ioutil.WriteFile(wd+"/orig/file.txt", []byte(after), 0644); err != nil {
if err != nil { t.Fatalf("WriteFile: %v", err)
t.Fatalf("WriteFile failed: %v", err)
} }
c, err = ioutil.ReadFile(wd + "/mnt/file.txt") c, err = ioutil.ReadFile(wd + "/mnt/file.txt")
if err != nil { if err != nil {
t.Fatalf("ReadFile failed: %v", err) t.Fatalf("ReadFile: %v", err)
} else if string(c) != before {
t.Fatalf("ReadFile: got %q, want cached %q", c, before)
} }
if string(c) != "hello" { if minor := pathfs.Connector().Server().KernelSettings().Minor; minor < 12 {
t.Fatalf("Page cache skipped: expect 'hello' %q", string(c)) t.Skip("protocol v%d has no notify support.", minor)
} }
code := pathfs.EntryNotify("", "file.txt") code := pathfs.EntryNotify("", "file.txt")
if !code.Ok() { if !code.Ok() {
t.Errorf("Entry notify failed: %v", code) t.Errorf("EntryNotify: %v", code)
} }
c, err = ioutil.ReadFile(wd + "/mnt/file.txt") c, err = ioutil.ReadFile(wd + "/mnt/file.txt")
if err != nil { if err != nil {
t.Fatalf("ReadFile failed: %v", err) t.Fatalf("ReadFile: %v", err)
} } else if string(c) != after {
if string(c) != string(content2) { t.Fatalf("ReadFile: got %q after notify, want %q", c, after)
t.Fatalf("Mismatch after notify expect '%s' %q", content2, string(c))
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment