diff options
author | Máximo Cuadros <mcuadros@gmail.com> | 2016-10-19 12:44:17 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-10-19 12:44:17 +0200 |
commit | 7bd4f1d2b796de5c86466b40eaa561d4fd27931b (patch) | |
tree | 8699f5ff6df8cb3fbdf8d2b9df0adf975c60d542 /utils/fs/os_test.go | |
parent | c56b22fc73d0ca3c4d44872e8b16370e041dcd92 (diff) | |
download | go-git-7bd4f1d2b796de5c86466b40eaa561d4fd27931b.tar.gz |
utils: fs.TempFile (#88)
* utils: fs generic TestSuite
* fs: fs.TempFile
* utils: fs small changes requested
* utils: fs, test fs.Create overwriting files
Diffstat (limited to 'utils/fs/os_test.go')
-rw-r--r-- | utils/fs/os_test.go | 142 |
1 files changed, 9 insertions, 133 deletions
diff --git a/utils/fs/os_test.go b/utils/fs/os_test.go index ea06970..e70c19b 100644 --- a/utils/fs/os_test.go +++ b/utils/fs/os_test.go @@ -1,148 +1,24 @@ package fs import ( - "io" "io/ioutil" "os" - "testing" . "gopkg.in/check.v1" ) -func Test(t *testing.T) { TestingT(t) } - -type OSSuite struct{} - -var _ = Suite(&OSSuite{}) - -func (s *OSSuite) TestCreate(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("foo") - c.Assert(err, IsNil) - c.Assert(f.Filename(), Equals, "foo") -} - -func (s *OSSuite) TestCreateDepth(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("bar/foo") - c.Assert(err, IsNil) - c.Assert(f.Filename(), Equals, "bar/foo") -} - -func (s *OSSuite) TestCreateAndWrite(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("foo") - c.Assert(err, IsNil) - l, err := f.Write([]byte("foo")) - c.Assert(l, Equals, 3) - c.Assert(err, IsNil) - - f.Seek(0, io.SeekStart) - wrote, err := ioutil.ReadAll(f) - c.Assert(err, IsNil) - c.Assert(wrote, DeepEquals, []byte("foo")) -} - -func (s *OSSuite) TestCreateClose(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("foo") - c.Assert(err, IsNil) - c.Assert(f.IsClosed(), Equals, false) - - f.Write([]byte("foo")) - c.Assert(f.Close(), IsNil) - - wrote, _ := ioutil.ReadFile(f.(*OSFile).file.Name()) - c.Assert(wrote, DeepEquals, []byte("foo")) - - c.Assert(f.IsClosed(), Equals, true) -} - -func (s *OSSuite) TestReadDirAndDir(c *C) { - path := getTempDir() - client := NewOS(path) - - files := []string{"foo", "bar", "qux/baz", "qux/qux"} - for _, name := range files { - f, err := client.Create(name) - c.Assert(err, IsNil) - c.Assert(f.Close(), IsNil) - } - - info, err := client.ReadDir("/") - c.Assert(err, IsNil) - c.Assert(info, HasLen, 3) - - info, err = client.ReadDir("/qux") - c.Assert(err, IsNil) - c.Assert(info, HasLen, 2) - - qux := client.Dir("/qux") - info, err = qux.ReadDir("/") - c.Assert(err, IsNil) - c.Assert(info, HasLen, 2) +type OSSuite struct { + FilesystemSuite + path string } -func (s *OSSuite) TestRename(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("foo") - c.Assert(err, IsNil) - c.Assert(f.Close(), IsNil) - - err = client.Rename("foo", "bar") - c.Assert(err, IsNil) - - foo, err := client.Stat("foo") - c.Assert(foo, IsNil) - c.Assert(err, NotNil) +var _ = Suite(&OSSuite{}) - bar, err := client.Stat("bar") - c.Assert(bar, NotNil) - c.Assert(err, IsNil) +func (s *OSSuite) SetUpTest(c *C) { + s.path, _ = ioutil.TempDir(os.TempDir(), "go-git-os-fs-test") + s.FilesystemSuite.fs = NewOS(s.path) } - -func (s *OSSuite) TestOpenAndStat(c *C) { - path := getTempDir() - client := NewOS(path) - - f, err := client.Create("foo") - c.Assert(err, IsNil) - c.Assert(f.Close(), IsNil) - - foo, err := client.Open("foo") - c.Assert(foo, NotNil) - c.Assert(foo.Filename(), Equals, "foo") - c.Assert(err, IsNil) - - stat, err := client.Stat("foo") - c.Assert(stat, NotNil) +func (s *OSSuite) TearDownTest(c *C) { + err := os.RemoveAll(s.path) c.Assert(err, IsNil) - c.Assert(stat.Name(), Equals, "foo") -} - -func (s *OSSuite) TestJoin(c *C) { - path := getTempDir() - client := NewOS(path) - c.Assert(client.Join("foo", "bar"), Equals, "foo/bar") -} - -func (s *OSSuite) TestBase(c *C) { - path := getTempDir() - client := NewOS(path) - c.Assert(client.Base(), Equals, path) -} - -func getTempDir() string { - dir, _ := ioutil.TempDir(os.TempDir(), "--OSClientTest--") - return dir } |