file_system_test.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. package fileSystem
  2. import (
  3. "testing"
  4. "time"
  5. )
  6. func TestSetAndGet(t *testing.T) {
  7. fs := New()
  8. setAndGet(fs, "/foobar", t)
  9. setAndGet(fs, "/foo/bar", t)
  10. setAndGet(fs, "/foo/foo/bar", t)
  11. }
  12. func TestListDirectory(t *testing.T) {
  13. fs := New()
  14. // create dir /foo
  15. // set key-value /foo/foo=bar
  16. fs.Set("/foo/foo", "bar", Permanent, 1, 1)
  17. // create dir /foo/fooDir
  18. // set key-value /foo/fooDir/foo=bar
  19. fs.Set("/foo/fooDir/foo", "bar", Permanent, 2, 1)
  20. e, err := fs.Get("/foo", false, 2, 1)
  21. if err != nil {
  22. t.Fatalf("%v", err)
  23. }
  24. if len(e.KVPairs) != 2 {
  25. t.Fatalf("wrong number of kv pairs [%d/2]", len(e.KVPairs))
  26. }
  27. if e.KVPairs[0].Key != "/foo/foo" || e.KVPairs[0].Value != "bar" {
  28. t.Fatalf("wrong kv [/foo/foo/ / %s] -> [bar / %s]", e.KVPairs[0].Key, e.KVPairs[0].Value)
  29. }
  30. if e.KVPairs[1].Key != "/foo/fooDir" || e.KVPairs[1].Dir != true {
  31. t.Fatalf("wrong kv [/foo/fooDir/ / %s] -> [true / %v]", e.KVPairs[1].Key, e.KVPairs[1].Dir)
  32. }
  33. // test hidden node
  34. // create dir /foo/_hidden
  35. // set key-value /foo/_hidden/foo -> bar
  36. fs.Set("/foo/_hidden/foo", "bar", Permanent, 3, 1)
  37. e, _ = fs.Get("/foo", false, 2, 1)
  38. if len(e.KVPairs) != 2 {
  39. t.Fatalf("hidden node is not hidden! %s", e.KVPairs[2].Key)
  40. }
  41. }
  42. func TestRemove(t *testing.T) {
  43. fs := New()
  44. fs.Set("/foo", "bar", Permanent, 1, 1)
  45. _, err := fs.Delete("/foo", false, 1, 1)
  46. if err != nil {
  47. t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
  48. }
  49. _, err = fs.Get("/foo", false, 1, 1)
  50. if err == nil || err.Error() != "Key Not Found" {
  51. t.Fatalf("can get the node after deletion")
  52. }
  53. fs.Set("/foo/bar", "bar", Permanent, 1, 1)
  54. fs.Set("/foo/car", "car", Permanent, 1, 1)
  55. fs.Set("/foo/dar/dar", "dar", Permanent, 1, 1)
  56. _, err = fs.Delete("/foo", false, 1, 1)
  57. if err == nil {
  58. t.Fatalf("should not be able to delete a directory without recursive")
  59. }
  60. _, err = fs.Delete("/foo", true, 1, 1)
  61. if err != nil {
  62. t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
  63. }
  64. _, err = fs.Get("/foo", false, 1, 1)
  65. if err == nil || err.Error() != "Key Not Found" {
  66. t.Fatalf("can get the node after deletion ")
  67. }
  68. }
  69. func TestExpire(t *testing.T) {
  70. fs := New()
  71. expire := time.Now().Add(time.Second)
  72. fs.Set("/foo", "bar", expire, 1, 1)
  73. _, err := fs.InternalGet("/foo", 1, 1)
  74. if err != nil {
  75. t.Fatalf("can not get the node")
  76. }
  77. time.Sleep(time.Second * 2)
  78. _, err = fs.InternalGet("/foo", 1, 1)
  79. if err == nil {
  80. t.Fatalf("can get the node after expiration time")
  81. }
  82. fs.Set("/foo", "bar", expire, 1, 1)
  83. time.Sleep(time.Millisecond * 50)
  84. _, err = fs.InternalGet("/foo", 1, 1)
  85. if err == nil {
  86. t.Fatalf("can get the node after expiration time")
  87. }
  88. expire = time.Now().Add(time.Second)
  89. fs.Set("/foo", "bar", expire, 1, 1)
  90. fs.Delete("/foo", false, 1, 1)
  91. }
  92. func setAndGet(fs *FileSystem, path string, t *testing.T) {
  93. _, err := fs.Set(path, "bar", Permanent, 1, 1)
  94. if err != nil {
  95. t.Fatalf("cannot set %s=bar [%s]", path, err.Error())
  96. }
  97. e, err := fs.Get(path, false, 1, 1)
  98. if err != nil {
  99. t.Fatalf("cannot get %s [%s]", path, err.Error())
  100. }
  101. if e.Value != "bar" {
  102. t.Fatalf("expect value of %s is bar [%s]", path, e.Value)
  103. }
  104. }