Commit b685f92c authored by Brian Tiger Chow's avatar Brian Tiger Chow

test(fsrepo): InitIdempotence, NilRemoval, ReopeningDisallowed

parent ece9ed09
...@@ -15,6 +15,18 @@ func testRepoPath(p string, t *testing.T) string { ...@@ -15,6 +15,18 @@ func testRepoPath(p string, t *testing.T) string {
return name return name
} }
func TestInitIdempotence(t *testing.T) {
path := testRepoPath("", t)
for i := 0; i < 10; i++ {
AssertNil(Init(path, &config.Config{}), t, "multiple calls to init should succeed")
}
}
func TestRemove(t *testing.T) {
path := testRepoPath("foo", t)
AssertNil(Remove(path), t, "should be able to remove after closed")
}
func TestCannotRemoveIfOpen(t *testing.T) { func TestCannotRemoveIfOpen(t *testing.T) {
path := testRepoPath("TestCannotRemoveIfOpen", t) path := testRepoPath("TestCannotRemoveIfOpen", t)
AssertNil(Init(path, &config.Config{}), t, "should initialize successfully") AssertNil(Init(path, &config.Config{}), t, "should initialize successfully")
...@@ -25,6 +37,18 @@ func TestCannotRemoveIfOpen(t *testing.T) { ...@@ -25,6 +37,18 @@ func TestCannotRemoveIfOpen(t *testing.T) {
AssertNil(Remove(path), t, "should be able to remove after closed") AssertNil(Remove(path), t, "should be able to remove after closed")
} }
func TestCannotBeReopened(t *testing.T) {
path := testRepoPath("", t)
AssertNil(Init(path, &config.Config{}), t)
r := At(path)
AssertNil(r.Open(), t)
AssertNil(r.Close(), t)
AssertErr(r.Open(), t, "shouldn't be possible to re-open the repo")
// mutable state is the enemy. Take Close() as an opportunity to reduce
// entropy. Callers ought to start fresh with a new handle by calling `At`.
}
func TestCanManageReposIndependently(t *testing.T) { func TestCanManageReposIndependently(t *testing.T) {
pathA := testRepoPath("a", t) pathA := testRepoPath("a", t)
pathB := testRepoPath("b", t) pathB := testRepoPath("b", t)
......
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