| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273 |
- package fileSystem
- import (
- "testing"
- "time"
- )
- func TestCreateAndGet(t *testing.T) {
- fs := New()
- // this should create successfully
- createAndGet(fs, "/foobar", t)
- createAndGet(fs, "/foo/bar", t)
- createAndGet(fs, "/foo/foo/bar", t)
- // already exist, create should fail
- _, err := fs.Create("/foobar", "bar", Permanent, 1, 1)
- if err == nil {
- t.Fatal("Create should fail")
- }
- // meet file, create should fail
- _, err = fs.Create("/foo/bar/bar", "bar", Permanent, 2, 1)
- if err == nil {
- t.Fatal("Create should fail")
- }
- // create a directory
- _, err = fs.Create("/fooDir", "", Permanent, 3, 1)
- if err != nil {
- t.Fatal("Cannot create /fooDir")
- }
- e, err := fs.Get("/fooDir", false, 3, 1)
- if err != nil || e.Dir != true {
- t.Fatal("Cannot create /fooDir ")
- }
- // create a file under directory
- _, err = fs.Create("/fooDir/bar", "bar", Permanent, 4, 1)
- if err != nil {
- t.Fatal("Cannot create /fooDir/bar = bar")
- }
- }
- func TestUpdateFile(t *testing.T) {
- fs := New()
- _, err := fs.Create("/foo/bar", "bar", Permanent, 1, 1)
- if err != nil {
- t.Fatalf("cannot update %s=bar [%s]", "/foo/bar", err.Error())
- }
- _, err = fs.Update("/foo/bar", "barbar", Permanent, 2, 1)
- if err != nil {
- t.Fatalf("cannot update %s=barbar [%s]", "/foo/bar", err.Error())
- }
- e, err := fs.Get("/foo/bar", false, 2, 1)
- if err != nil {
- t.Fatalf("cannot get %s [%s]", "/foo/bar", err.Error())
- }
- if e.Value != "barbar" {
- t.Fatalf("expect value of %s is barbar [%s]", "/foo/bar", e.Value)
- }
- }
- func TestListDirectory(t *testing.T) {
- fs := New()
- // create dir /foo
- // set key-value /foo/foo=bar
- fs.Create("/foo/foo", "bar", Permanent, 1, 1)
- // create dir /foo/fooDir
- // set key-value /foo/fooDir/foo=bar
- fs.Create("/foo/fooDir/foo", "bar", Permanent, 2, 1)
- e, err := fs.Get("/foo", true, 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)
- }
- if e.KVPairs[1].KVPairs[0].Key != "/foo/fooDir/foo" || e.KVPairs[1].KVPairs[0].Value != "bar" {
- t.Fatalf("wrong kv [/foo/fooDir/foo / %s] -> [bar / %v]", e.KVPairs[1].KVPairs[0].Key, e.KVPairs[1].KVPairs[0].Value)
- }
- // test hidden node
- // create dir /foo/_hidden
- // set key-value /foo/_hidden/foo -> bar
- fs.Create("/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) {
- fs := New()
- fs.Create("/foo", "bar", Permanent, 1, 1)
- _, err := fs.Delete("/foo", false, 1, 1)
- if err != nil {
- t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
- }
- _, err = fs.Get("/foo", false, 1, 1)
- if err == nil || err.Error() != "Key Not Found" {
- t.Fatalf("can get the node after deletion")
- }
- fs.Create("/foo/bar", "bar", Permanent, 1, 1)
- fs.Create("/foo/car", "car", Permanent, 1, 1)
- fs.Create("/foo/dar/dar", "dar", Permanent, 1, 1)
- _, err = fs.Delete("/foo", false, 1, 1)
- if err == nil {
- t.Fatalf("should not be able to delete a directory without recursive")
- }
- _, err = fs.Delete("/foo", true, 1, 1)
- if err != nil {
- t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
- }
- _, err = fs.Get("/foo", false, 1, 1)
- if err == nil || err.Error() != "Key Not Found" {
- t.Fatalf("can get the node after deletion ")
- }
- }
- func TestExpire(t *testing.T) {
- fs := New()
- expire := time.Now().Add(time.Second)
- fs.Create("/foo", "bar", expire, 1, 1)
- _, err := fs.InternalGet("/foo", 1, 1)
- if err != nil {
- t.Fatalf("can not get the node")
- }
- time.Sleep(time.Second * 2)
- _, err = fs.InternalGet("/foo", 1, 1)
- if err == nil {
- t.Fatalf("can get the node after expiration time")
- }
- fs.Create("/foo", "bar", expire, 1, 1)
- time.Sleep(time.Millisecond * 50)
- _, err = fs.InternalGet("/foo", 1, 1)
- if err == nil {
- t.Fatalf("can get the node after expiration time")
- }
- expire = time.Now().Add(time.Second)
- fs.Create("/foo", "bar", expire, 1, 1)
- fs.Delete("/foo", false, 1, 1)
- }
- func TestTestAndSet(t *testing.T) {
- fs := New()
- fs.Create("/foo", "bar", Permanent, 1, 1)
- // test on wrong previous value
- _, err := fs.TestAndSet("/foo", "barbar", 0, "car", Permanent, 2, 1)
- if err == nil {
- t.Fatal("test and set should fail barbar != bar")
- }
- // test on value
- e, err := fs.TestAndSet("/foo", "bar", 0, "car", Permanent, 3, 1)
- if err != nil {
- t.Fatal("test and set should succeed bar == bar")
- }
- if e.PrevValue != "bar" || e.Value != "car" {
- t.Fatalf("[%v/%v] [%v/%v]", e.PrevValue, "bar", e.Value, "car")
- }
- // test on index
- e, err = fs.TestAndSet("/foo", "", 3, "bar", Permanent, 4, 1)
- if err != nil {
- t.Fatal("test and set should succeed index 3 == 3")
- }
- if e.PrevValue != "car" || e.Value != "bar" {
- t.Fatalf("[%v/%v] [%v/%v]", e.PrevValue, "car", e.Value, "bar")
- }
- }
- func TestWatchRemove(t *testing.T) {
- fs := New()
- fs.Create("/foo/foo/foo", "bar", Permanent, 1, 1)
- // watch at a deeper path
- c, _ := fs.WatcherHub.watch("/foo/foo/foo", false, 0)
- fs.Delete("/foo", true, 2, 1)
- e := <-c
- if e.Key != "/foo" {
- t.Fatal("watch for delete fails")
- }
- fs.Create("/foo/foo/foo", "bar", Permanent, 3, 1)
- // watch at a prefix
- c, _ = fs.WatcherHub.watch("/foo", true, 0)
- fs.Delete("/foo/foo/foo", false, 4, 1)
- e = <-c
- if e.Key != "/foo/foo/foo" {
- t.Fatal("watch for delete fails")
- }
- }
- func createAndGet(fs *FileSystem, path string, t *testing.T) {
- _, err := fs.Create(path, "bar", Permanent, 1, 1)
- if err != nil {
- t.Fatalf("cannot create %s=bar [%s]", path, err.Error())
- }
- e, err := fs.Get(path, false, 1, 1)
- if err != nil {
- t.Fatalf("cannot get %s [%s]", path, err.Error())
- }
- if e.Value != "bar" {
- t.Fatalf("expect value of %s is bar [%s]", path, e.Value)
- }
- }
|