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

Testing tweaks.

parent ca8d62a1
...@@ -22,9 +22,13 @@ func (f *MutableDataFile) String() string { ...@@ -22,9 +22,13 @@ func (f *MutableDataFile) String() string {
return "MutableDataFile" return "MutableDataFile"
} }
func (f *MutableDataFile) Read(buf []byte, off int64) (r ReadResult) { func (f *MutableDataFile) Read(buf []byte, off int64) ReadResult {
r.Data = f.data[off : off+int64(len(buf))] end := int(off)+len(buf)
return r if end > len(f.data) {
end = len(f.data)
}
return ReadResult{Data: f.data[off:end]}
} }
func (f *MutableDataFile) Write(d []byte, off int64) (uint32, Status) { func (f *MutableDataFile) Write(d []byte, off int64) (uint32, Status) {
...@@ -32,9 +36,11 @@ func (f *MutableDataFile) Write(d []byte, off int64) (uint32, Status) { ...@@ -32,9 +36,11 @@ func (f *MutableDataFile) Write(d []byte, off int64) (uint32, Status) {
if int(end) > len(f.data) { if int(end) > len(f.data) {
data := make([]byte, len(f.data), end) data := make([]byte, len(f.data), end)
copy(data, f.data) copy(data, f.data)
f.data = data f.data = data[:end]
} }
copy(f.data[off:end], d) copy(f.data[off:end], d)
f.Attr.Size = uint64(len(f.data))
return uint32(end - off), OK return uint32(end - off), OK
} }
...@@ -80,6 +86,7 @@ func (f *MutableDataFile) Chmod(perms uint32) Status { ...@@ -80,6 +86,7 @@ func (f *MutableDataFile) Chmod(perms uint32) Status {
//////////////// ////////////////
// This FS only supports a single r/w file called "/file".
type FSetAttrFs struct { type FSetAttrFs struct {
DefaultFileSystem DefaultFileSystem
file *MutableDataFile file *MutableDataFile
...@@ -146,6 +153,22 @@ func setupFAttrTest(t *testing.T, fs FileSystem) (dir string, clean func()) { ...@@ -146,6 +153,22 @@ func setupFAttrTest(t *testing.T, fs FileSystem) (dir string, clean func()) {
} }
} }
func TestDataReadLarge(t *testing.T) {
fs := &FSetAttrFs{}
dir, clean := setupFAttrTest(t, fs)
defer clean()
content := RandomData(385*1023)
fn := dir + "/file"
err := ioutil.WriteFile(fn, []byte(content), 0644)
CheckSuccess(err)
back, err := ioutil.ReadFile(fn)
CheckSuccess(err)
CompareSlices(t, back, content)
}
func TestFSetAttr(t *testing.T) { func TestFSetAttr(t *testing.T) {
fs := &FSetAttrFs{} fs := &FSetAttrFs{}
dir, clean := setupFAttrTest(t, fs) dir, clean := setupFAttrTest(t, fs)
...@@ -192,3 +215,4 @@ func TestFSetAttr(t *testing.T) { ...@@ -192,3 +215,4 @@ func TestFSetAttr(t *testing.T) {
} }
// TODO - test chown if run as root. // TODO - test chown if run as root.
} }
...@@ -21,7 +21,6 @@ var _ = log.Println ...@@ -21,7 +21,6 @@ var _ = log.Println
//////////////// ////////////////
// state for our testcase, mostly constants // state for our testcase, mostly constants
const contents string = "ABC"
const mode uint32 = 0757 const mode uint32 = 0757
type testCase struct { type testCase struct {
...@@ -121,6 +120,7 @@ func TestTouch(t *testing.T) { ...@@ -121,6 +120,7 @@ func TestTouch(t *testing.T) {
ts := NewTestCase(t) ts := NewTestCase(t)
defer ts.Cleanup() defer ts.Cleanup()
contents := []byte{1,2,3}
err := ioutil.WriteFile(ts.origFile, []byte(contents), 0700) err := ioutil.WriteFile(ts.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
err = os.Chtimes(ts.mountFile, time.Unix(42, 0), time.Unix(43, 0)) err = os.Chtimes(ts.mountFile, time.Unix(42, 0), time.Unix(43, 0))
...@@ -138,7 +138,8 @@ func TestReadThrough(t *testing.T) { ...@@ -138,7 +138,8 @@ func TestReadThrough(t *testing.T) {
ts := NewTestCase(t) ts := NewTestCase(t)
defer ts.Cleanup() defer ts.Cleanup()
err := ioutil.WriteFile(ts.origFile, []byte(contents), 0700) content := RandomData(125)
err := ioutil.WriteFile(ts.origFile, content, 0700)
CheckSuccess(err) CheckSuccess(err)
err = os.Chmod(ts.mountFile, os.FileMode(mode)) err = os.Chmod(ts.mountFile, os.FileMode(mode))
...@@ -158,16 +159,14 @@ func TestReadThrough(t *testing.T) { ...@@ -158,16 +159,14 @@ func TestReadThrough(t *testing.T) {
var buf [1024]byte var buf [1024]byte
slice := buf[:] slice := buf[:]
n, err := f.Read(slice) n, err := f.Read(slice)
CompareSlices(t, slice[:n], content)
if len(slice[:n]) != len(contents) {
t.Errorf("Content error %v", slice)
}
} }
func TestRemove(t *testing.T) { func TestRemove(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
...@@ -188,10 +187,11 @@ func TestWriteThrough(t *testing.T) { ...@@ -188,10 +187,11 @@ func TestWriteThrough(t *testing.T) {
CheckSuccess(err) CheckSuccess(err)
defer f.Close() defer f.Close()
n, err := f.WriteString(contents) content := RandomData(125)
n, err := f.Write(content)
CheckSuccess(err) CheckSuccess(err)
if n != len(contents) { if n != len(content) {
t.Errorf("Write mismatch: %v of %v", n, len(contents)) t.Errorf("Write mismatch: %v of %v", n, len(content))
} }
fi, err := os.Lstat(tc.origFile) fi, err := os.Lstat(tc.origFile)
...@@ -207,9 +207,7 @@ func TestWriteThrough(t *testing.T) { ...@@ -207,9 +207,7 @@ func TestWriteThrough(t *testing.T) {
slice := buf[:] slice := buf[:]
n, err = f.Read(slice) n, err = f.Read(slice)
CheckSuccess(err) CheckSuccess(err)
if string(slice[:n]) != contents { CompareSlices(t, slice[:n], content)
t.Errorf("write contents error. Got: %v, expect: %v", string(slice[:n]), contents)
}
} }
func TestMkdirRmdir(t *testing.T) { func TestMkdirRmdir(t *testing.T) {
...@@ -232,7 +230,8 @@ func TestLinkCreate(t *testing.T) { ...@@ -232,7 +230,8 @@ func TestLinkCreate(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) content := RandomData(125)
err := ioutil.WriteFile(tc.origFile, content, 0700)
CheckSuccess(err) CheckSuccess(err)
err = os.Mkdir(tc.origSubdir, 0777) err = os.Mkdir(tc.origSubdir, 0777)
CheckSuccess(err) CheckSuccess(err)
...@@ -256,10 +255,7 @@ func TestLinkCreate(t *testing.T) { ...@@ -256,10 +255,7 @@ func TestLinkCreate(t *testing.T) {
} }
readback, err := ioutil.ReadFile(mountSubfile) readback, err := ioutil.ReadFile(mountSubfile)
CheckSuccess(err) CheckSuccess(err)
CompareSlices(t, readback, content)
if string(readback) != contents {
t.Errorf("Content error: got %q want %q", string(readback), contents)
}
err = os.Remove(tc.mountFile) err = os.Remove(tc.mountFile)
CheckSuccess(err) CheckSuccess(err)
...@@ -274,9 +270,9 @@ func TestLinkExisting(t *testing.T) { ...@@ -274,9 +270,9 @@ func TestLinkExisting(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
c := "hello" c := RandomData(5)
err := ioutil.WriteFile(tc.orig+"/file1", []byte(c), 0644) err := ioutil.WriteFile(tc.orig+"/file1", c, 0644)
CheckSuccess(err) CheckSuccess(err)
err = os.Link(tc.orig+"/file1", tc.orig+"/file2") err = os.Link(tc.orig+"/file1", tc.orig+"/file2")
CheckSuccess(err) CheckSuccess(err)
...@@ -291,11 +287,9 @@ func TestLinkExisting(t *testing.T) { ...@@ -291,11 +287,9 @@ func TestLinkExisting(t *testing.T) {
t.Errorf("linked files should have identical inodes %v %v", s1.Ino, s2.Ino) t.Errorf("linked files should have identical inodes %v %v", s1.Ino, s2.Ino)
} }
c1, err := ioutil.ReadFile(tc.mnt + "/file1") back, err := ioutil.ReadFile(tc.mnt + "/file1")
CheckSuccess(err) CheckSuccess(err)
if string(c1) != c { CompareSlices(t, back, c)
t.Errorf("Content mismatch relative to original.")
}
} }
// Deal correctly with hard links implied by matching client inode // Deal correctly with hard links implied by matching client inode
...@@ -329,6 +323,7 @@ func TestSymlink(t *testing.T) { ...@@ -329,6 +323,7 @@ func TestSymlink(t *testing.T) {
defer tc.Cleanup() defer tc.Cleanup()
t.Log("testing symlink/readlink.") t.Log("testing symlink/readlink.")
contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
...@@ -359,7 +354,7 @@ func TestRename(t *testing.T) { ...@@ -359,7 +354,7 @@ func TestRename(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
t.Log("Testing rename.") contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
sd := tc.mnt + "/testRename" sd := tc.mnt + "/testRename"
...@@ -438,6 +433,7 @@ func TestAccess(t *testing.T) { ...@@ -438,6 +433,7 @@ func TestAccess(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
err = os.Chmod(tc.origFile, 0) err = os.Chmod(tc.origFile, 0)
...@@ -476,7 +472,7 @@ func TestReaddir(t *testing.T) { ...@@ -476,7 +472,7 @@ func TestReaddir(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
t.Log("Testing readdir.") contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
err = os.Mkdir(tc.origSubdir, 0777) err = os.Mkdir(tc.origSubdir, 0777)
...@@ -509,7 +505,7 @@ func TestFSync(t *testing.T) { ...@@ -509,7 +505,7 @@ func TestFSync(t *testing.T) {
tc := NewTestCase(t) tc := NewTestCase(t)
defer tc.Cleanup() defer tc.Cleanup()
t.Log("Testing fsync.") contents := []byte{1,2,3}
err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700) err := ioutil.WriteFile(tc.origFile, []byte(contents), 0700)
CheckSuccess(err) CheckSuccess(err)
...@@ -518,9 +514,9 @@ func TestFSync(t *testing.T) { ...@@ -518,9 +514,9 @@ func TestFSync(t *testing.T) {
CheckSuccess(err) CheckSuccess(err)
// How to really test fsync ? // How to really test fsync ?
errNo := syscall.Fsync(int(f.Fd())) err = syscall.Fsync(int(f.Fd()))
if errNo != nil { if err != nil {
t.Errorf("fsync returned %v", errNo) t.Errorf("fsync returned: %v", err)
} }
f.Close() f.Close()
} }
...@@ -538,14 +534,11 @@ func TestReadZero(t *testing.T) { ...@@ -538,14 +534,11 @@ func TestReadZero(t *testing.T) {
} }
} }
func TestReadLarge(t *testing.T) { func RandomData(size int) []byte {
ts := NewTestCase(t)
defer ts.Cleanup()
// Make blocks that are not period on 1024 bytes, so we can // Make blocks that are not period on 1024 bytes, so we can
// catch errors due to misalignments. // catch errors due to misalignments.
block := make([]byte, 1023) block := make([]byte, 1023)
content := make([]byte, 385*1023) content := make([]byte, size)
for i := range block { for i := range block {
block[i] = byte(i) block[i] = byte(i)
} }
...@@ -559,22 +552,35 @@ func TestReadLarge(t *testing.T) { ...@@ -559,22 +552,35 @@ func TestReadLarge(t *testing.T) {
copy(content[start:], block) copy(content[start:], block)
start += len(block) start += len(block)
} }
return content
}
func CompareSlices(t *testing.T, got, want []byte) {
if len(got) != len(want) {
t.Errorf("content length: got %d want %d", len(got), len(want))
}
for i := range want {
if i >= len(got) {
break
}
if want[i] != got[i] {
t.Errorf("content mismatch byte %d, got %d want %d.", i, got[i], want[i])
break
}
}
}
func TestReadLarge(t *testing.T) {
ts := NewTestCase(t)
defer ts.Cleanup()
content := RandomData(385*1023)
err := ioutil.WriteFile(ts.origFile, []byte(content), 0644) err := ioutil.WriteFile(ts.origFile, []byte(content), 0644)
CheckSuccess(err) CheckSuccess(err)
back, err := ioutil.ReadFile(ts.mountFile) back, err := ioutil.ReadFile(ts.mountFile)
CheckSuccess(err) CheckSuccess(err)
if len(back) != len(content) { CompareSlices(t, back, content)
t.Errorf("content length: got %d want %d", len(back), len(content))
}
for i := range content {
if content[i] != back[i] {
t.Errorf("content mismatch byte %d, got %d want %d.", i, back[i], content[i])
break
}
}
} }
func randomLengthString(length int) string { func randomLengthString(length int) string {
......
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