Skip to content

Commit

Permalink
Merge pull request #287 from tdakkota/fix/issue-286
Browse files Browse the repository at this point in the history
Fix incorrect (*mem.File).WriteAt
  • Loading branch information
0xmichalis authored Mar 20, 2021
2 parents b9650fb + 7b47fea commit bc94f58
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
2 changes: 1 addition & 1 deletion mem/file.go
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,7 @@ func (f *File) Write(b []byte) (n int, err error) {
tail = f.fileData.data[n+int(cur):]
}
if diff > 0 {
f.fileData.data = append(bytes.Repeat([]byte{00}, int(diff)), b...)
f.fileData.data = append(f.fileData.data, append(bytes.Repeat([]byte{00}, int(diff)), b...)...)
f.fileData.data = append(f.fileData.data, tail...)
} else {
f.fileData.data = append(f.fileData.data[:cur], b...)
Expand Down
51 changes: 51 additions & 0 deletions mem/file_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,57 @@ func TestFileDataModeRace(t *testing.T) {
}
}

// See https://github.com/spf13/afero/issues/286.
func TestFileWriteAt(t *testing.T) {
t.Parallel()

data := CreateFile("abc.txt")
f := NewFileHandle(data)

testData := []byte{1, 2, 3, 4, 5}
offset := len(testData)

// 5 zeros + testdata
_, err := f.WriteAt(testData, int64(offset))
if err != nil {
t.Fatal(err)
}

// 2 * testdata
_, err = f.WriteAt(testData, 0)
if err != nil {
t.Fatal(err)
}

// 3 * testdata
_, err = f.WriteAt(testData, int64(offset*2))
if err != nil {
t.Fatal(err)
}

// 3 * testdata + 5 zeros + testdata
_, err = f.WriteAt(testData, int64(offset*4))
if err != nil {
t.Fatal(err)
}

// 5 * testdata
_, err = f.WriteAt(testData, int64(offset*3))
if err != nil {
t.Fatal(err)
}

err = f.Close()
if err != nil {
t.Fatal(err)
}

expected := bytes.Repeat(testData, 5)
if !bytes.Equal(expected, data.data) {
t.Fatalf("expected: %v, got: %v", expected, data.data)
}
}

func TestFileDataIsDirRace(t *testing.T) {
t.Parallel()

Expand Down

0 comments on commit bc94f58

Please sign in to comment.