|
@@ -12,17 +12,59 @@ func TestSetAndGet(t *testing.T) {
|
|
|
setAndGet(fs, "/foo/foo/bar", t)
|
|
setAndGet(fs, "/foo/foo/bar", t)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+func TestListDirectory(t *testing.T) {
|
|
|
|
|
+ fs := New()
|
|
|
|
|
+
|
|
|
|
|
+ // create dir /foo
|
|
|
|
|
+ // set key-value /foo/foo=bar
|
|
|
|
|
+ fs.Set("/foo/foo", "bar", Permanent, 1, 1)
|
|
|
|
|
+
|
|
|
|
|
+ // create dir /foo/fooDir
|
|
|
|
|
+ // set key-value /foo/fooDir/foo=bar
|
|
|
|
|
+ fs.Set("/foo/fooDir/foo", "bar", Permanent, 2, 1)
|
|
|
|
|
+
|
|
|
|
|
+ e, err := fs.Get("/foo", false, 2, 1)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Fatalf("%v", err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if len(e.KVPairs) != 2 {
|
|
|
|
|
+ t.Fatalf("wrong number of kv pairs [%d/2]", len(e.KVPairs))
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if e.KVPairs[0].Key != "/foo/foo" || e.KVPairs[0].Value != "bar" {
|
|
|
|
|
+ t.Fatalf("wrong kv [/foo/foo/ / %s] -> [bar / %s]", e.KVPairs[0].Key, e.KVPairs[0].Value)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if e.KVPairs[1].Key != "/foo/fooDir" || e.KVPairs[1].Dir != true {
|
|
|
|
|
+ t.Fatalf("wrong kv [/foo/fooDir/ / %s] -> [true / %v]", e.KVPairs[1].Key, e.KVPairs[1].Dir)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // test hidden node
|
|
|
|
|
+
|
|
|
|
|
+ // create dir /foo/_hidden
|
|
|
|
|
+ // set key-value /foo/_hidden/foo -> bar
|
|
|
|
|
+ fs.Set("/foo/_hidden/foo", "bar", Permanent, 3, 1)
|
|
|
|
|
+
|
|
|
|
|
+ e, _ = fs.Get("/foo", false, 2, 1)
|
|
|
|
|
+
|
|
|
|
|
+ if len(e.KVPairs) != 2 {
|
|
|
|
|
+ t.Fatalf("hidden node is not hidden! %s", e.KVPairs[2].Key)
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
func TestRemove(t *testing.T) {
|
|
func TestRemove(t *testing.T) {
|
|
|
fs := New()
|
|
fs := New()
|
|
|
|
|
|
|
|
fs.Set("/foo", "bar", Permanent, 1, 1)
|
|
fs.Set("/foo", "bar", Permanent, 1, 1)
|
|
|
- err := fs.Delete("/foo", false, 1, 1)
|
|
|
|
|
|
|
+ _, err := fs.Delete("/foo", false, 1, 1)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
|
|
t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- _, err = fs.InternalGet("/foo", 1, 1)
|
|
|
|
|
|
|
+ _, err = fs.Get("/foo", false, 1, 1)
|
|
|
|
|
|
|
|
if err == nil || err.Error() != "Key Not Found" {
|
|
if err == nil || err.Error() != "Key Not Found" {
|
|
|
t.Fatalf("can get the node after deletion")
|
|
t.Fatalf("can get the node after deletion")
|
|
@@ -32,19 +74,19 @@ func TestRemove(t *testing.T) {
|
|
|
fs.Set("/foo/car", "car", Permanent, 1, 1)
|
|
fs.Set("/foo/car", "car", Permanent, 1, 1)
|
|
|
fs.Set("/foo/dar/dar", "dar", Permanent, 1, 1)
|
|
fs.Set("/foo/dar/dar", "dar", Permanent, 1, 1)
|
|
|
|
|
|
|
|
- err = fs.Delete("/foo", false, 1, 1)
|
|
|
|
|
|
|
+ _, err = fs.Delete("/foo", false, 1, 1)
|
|
|
|
|
|
|
|
if err == nil {
|
|
if err == nil {
|
|
|
t.Fatalf("should not be able to delete a directory without recursive")
|
|
t.Fatalf("should not be able to delete a directory without recursive")
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- err = fs.Delete("/foo", true, 1, 1)
|
|
|
|
|
|
|
+ _, err = fs.Delete("/foo", true, 1, 1)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
|
|
t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- _, err = fs.InternalGet("/foo", 1, 1)
|
|
|
|
|
|
|
+ _, err = fs.Get("/foo", false, 1, 1)
|
|
|
|
|
|
|
|
if err == nil || err.Error() != "Key Not Found" {
|
|
if err == nil || err.Error() != "Key Not Found" {
|
|
|
t.Fatalf("can get the node after deletion ")
|
|
t.Fatalf("can get the node after deletion ")
|
|
@@ -90,25 +132,19 @@ func TestExpire(t *testing.T) {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func setAndGet(fs *FileSystem, path string, t *testing.T) {
|
|
func setAndGet(fs *FileSystem, path string, t *testing.T) {
|
|
|
- err := fs.Set(path, "bar", Permanent, 1, 1)
|
|
|
|
|
|
|
+ _, err := fs.Set(path, "bar", Permanent, 1, 1)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
t.Fatalf("cannot set %s=bar [%s]", path, err.Error())
|
|
t.Fatalf("cannot set %s=bar [%s]", path, err.Error())
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- n, err := fs.InternalGet(path, 1, 1)
|
|
|
|
|
|
|
+ e, err := fs.Get(path, false, 1, 1)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
t.Fatalf("cannot get %s [%s]", path, err.Error())
|
|
t.Fatalf("cannot get %s [%s]", path, err.Error())
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- value, err := n.Read()
|
|
|
|
|
-
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- t.Fatalf("cannot read %s [%s]", path, err.Error())
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- if value != "bar" {
|
|
|
|
|
- t.Fatalf("expect value of %s is bar [%s]", path, value)
|
|
|
|
|
|
|
+ if e.Value != "bar" {
|
|
|
|
|
+ t.Fatalf("expect value of %s is bar [%s]", path, e.Value)
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|