160 lines
4.2 KiB
Go
160 lines
4.2 KiB
Go
package fs_test
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/influxdata/influxdb/pkg/fs"
|
|
)
|
|
|
|
func TestRenameFileWithReplacement(t *testing.T) {
|
|
// sample data for loading into files
|
|
sampleData1 := "this is some data"
|
|
sampleData2 := "we got some more data"
|
|
|
|
t.Run("exists", func(t *testing.T) {
|
|
oldpath := MustCreateTempFile(t, sampleData1)
|
|
newpath := MustCreateTempFile(t, sampleData2)
|
|
defer MustRemoveAll(oldpath)
|
|
defer MustRemoveAll(newpath)
|
|
|
|
oldContents := MustReadAllFile(oldpath)
|
|
newContents := MustReadAllFile(newpath)
|
|
|
|
if got, exp := oldContents, sampleData1; got != exp {
|
|
t.Fatalf("got contents %q, expected %q", got, exp)
|
|
} else if got, exp := newContents, sampleData2; got != exp {
|
|
t.Fatalf("got contents %q, expected %q", got, exp)
|
|
}
|
|
|
|
if err := fs.RenameFileWithReplacement(oldpath, newpath); err != nil {
|
|
t.Fatalf("ReplaceFileIfExists returned an error: %s", err)
|
|
}
|
|
|
|
if err := fs.SyncDir(filepath.Dir(oldpath)); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
// Contents of newpath will now be equivalent to oldpath' contents.
|
|
newContents = MustReadAllFile(newpath)
|
|
if newContents != oldContents {
|
|
t.Fatalf("contents for files differ: %q versus %q", newContents, oldContents)
|
|
}
|
|
|
|
// oldpath will be removed.
|
|
if MustFileExists(oldpath) {
|
|
t.Fatalf("file %q still exists, but it shouldn't", oldpath)
|
|
}
|
|
})
|
|
|
|
t.Run("not exists", func(t *testing.T) {
|
|
oldpath := MustCreateTempFile(t, sampleData1)
|
|
defer MustRemoveAll(oldpath)
|
|
|
|
oldContents := MustReadAllFile(oldpath)
|
|
if got, exp := oldContents, sampleData1; got != exp {
|
|
t.Fatalf("got contents %q, expected %q", got, exp)
|
|
}
|
|
|
|
root := filepath.Dir(oldpath)
|
|
newpath := filepath.Join(root, "foo")
|
|
if err := fs.RenameFileWithReplacement(oldpath, newpath); err != nil {
|
|
t.Fatalf("ReplaceFileIfExists returned an error: %s", err)
|
|
}
|
|
|
|
if err := fs.SyncDir(filepath.Dir(oldpath)); err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
// Contents of newpath will now be equivalent to oldpath's contents.
|
|
newContents := MustReadAllFile(newpath)
|
|
if newContents != oldContents {
|
|
t.Fatalf("contents for files differ: %q versus %q", newContents, oldContents)
|
|
}
|
|
|
|
// oldpath will be removed.
|
|
if MustFileExists(oldpath) {
|
|
t.Fatalf("file %q still exists, but it shouldn't", oldpath)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestCreateFileWithReplacement(t *testing.T) {
|
|
path := MustCreateTempFile(t, "sample data")
|
|
defer MustRemoveAll(path)
|
|
|
|
// should return an error if we CreateFile to the same path
|
|
_, err := fs.CreateFile(path)
|
|
if err == nil {
|
|
t.Fatalf("CreateFile did not return an error")
|
|
}
|
|
|
|
// contents of the file should be intact
|
|
contents := MustReadAllFile(path)
|
|
if got, exp := contents, "sample data"; got != exp {
|
|
t.Fatalf("got contents %q, expected %q", got, exp)
|
|
}
|
|
|
|
// running CreateFileWithReplacement on path should not return an error
|
|
if _, err = fs.CreateFileWithReplacement(path); err != nil {
|
|
t.Fatalf("CreateFileWithReplacement returned err: %v", err)
|
|
}
|
|
|
|
// the file at path should now be empty
|
|
contents = MustReadAllFile(path)
|
|
if contents != "" {
|
|
t.Fatalf("expected file to be empty but got: %v", contents)
|
|
}
|
|
|
|
}
|
|
|
|
// CreateTempFileOrFail creates a temporary file returning the path to the file.
|
|
func MustCreateTempFile(t testing.TB, data string) string {
|
|
t.Helper()
|
|
|
|
f, err := ioutil.TempFile("", "fs-test")
|
|
if err != nil {
|
|
t.Fatalf("failed to create temp file: %v", err)
|
|
} else if _, err := f.WriteString(data); err != nil {
|
|
t.Fatal(err)
|
|
} else if err := f.Close(); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
return f.Name()
|
|
}
|
|
|
|
func MustRemoveAll(path string) {
|
|
if err := os.RemoveAll(path); err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
|
|
// MustFileExists determines if a file exists, panicking if any error
|
|
// (other than one associated with the file not existing) is returned.
|
|
func MustFileExists(path string) bool {
|
|
_, err := os.Stat(path)
|
|
if err == nil {
|
|
return true
|
|
} else if os.IsNotExist(err) {
|
|
return false
|
|
}
|
|
panic(err)
|
|
}
|
|
|
|
// MustReadAllFile reads the contents of path, panicking if there is an error.
|
|
func MustReadAllFile(path string) string {
|
|
fd, err := os.Open(path)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer fd.Close()
|
|
|
|
data, err := ioutil.ReadAll(fd)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return string(data)
|
|
}
|