file_system_test.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434
  1. package fileSystem
  2. import (
  3. "store"
  4. "testing"
  5. "time"
  6. )
  7. func TestCreateAndGet(t *testing.T) {
  8. fs := New()
  9. // this should create successfully
  10. createAndGet(fs, "/foobar", t)
  11. createAndGet(fs, "/foo/bar", t)
  12. createAndGet(fs, "/foo/foo/bar", t)
  13. // already exist, create should fail
  14. _, err := fs.Create("/foobar", "bar", Permanent, 1, 1)
  15. if err == nil {
  16. t.Fatal("Create should fail")
  17. }
  18. // meet file, create should fail
  19. _, err = fs.Create("/foo/bar/bar", "bar", Permanent, 2, 1)
  20. if err == nil {
  21. t.Fatal("Create should fail")
  22. }
  23. // create a directory
  24. _, err = fs.Create("/fooDir", "", Permanent, 3, 1)
  25. if err != nil {
  26. t.Fatal("Cannot create /fooDir")
  27. }
  28. e, err := fs.Get("/fooDir", false, false, 3, 1)
  29. if err != nil || e.Dir != true {
  30. t.Fatal("Cannot create /fooDir ")
  31. }
  32. // create a file under directory
  33. _, err = fs.Create("/fooDir/bar", "bar", Permanent, 4, 1)
  34. if err != nil {
  35. t.Fatal("Cannot create /fooDir/bar = bar")
  36. }
  37. }
  38. func TestUpdateFile(t *testing.T) {
  39. fs := New()
  40. _, err := fs.Create("/foo/bar", "bar", Permanent, 1, 1)
  41. if err != nil {
  42. t.Fatalf("cannot create %s=bar [%s]", "/foo/bar", err.Error())
  43. }
  44. _, err = fs.Update("/foo/bar", "barbar", Permanent, 2, 1)
  45. if err != nil {
  46. t.Fatalf("cannot update %s=barbar [%s]", "/foo/bar", err.Error())
  47. }
  48. e, err := fs.Get("/foo/bar", false, false, 2, 1)
  49. if err != nil {
  50. t.Fatalf("cannot get %s [%s]", "/foo/bar", err.Error())
  51. }
  52. if e.Value != "barbar" {
  53. t.Fatalf("expect value of %s is barbar [%s]", "/foo/bar", e.Value)
  54. }
  55. // create a directory, update its ttl, to see if it will be deleted
  56. _, err = fs.Create("/foo/foo", "", Permanent, 3, 1)
  57. if err != nil {
  58. t.Fatalf("cannot create dir [%s] [%s]", "/foo/foo", err.Error())
  59. }
  60. _, err = fs.Create("/foo/foo/foo1", "bar1", Permanent, 4, 1)
  61. if err != nil {
  62. t.Fatal("cannot create [%s]", err.Error())
  63. }
  64. _, err = fs.Create("/foo/foo/foo2", "", Permanent, 5, 1)
  65. if err != nil {
  66. t.Fatal("cannot create [%s]", err.Error())
  67. }
  68. _, err = fs.Create("/foo/foo/foo2/boo", "boo1", Permanent, 6, 1)
  69. if err != nil {
  70. t.Fatal("cannot create [%s]", err.Error())
  71. }
  72. expire := time.Now().Add(time.Second * 2)
  73. _, err = fs.Update("/foo/foo", "", expire, 7, 1)
  74. if err != nil {
  75. t.Fatalf("cannot update dir [%s] [%s]", "/foo/foo", err.Error())
  76. }
  77. // sleep 50ms, it should still reach the node
  78. time.Sleep(time.Microsecond * 50)
  79. e, err = fs.Get("/foo/foo", true, false, 7, 1)
  80. if err != nil || e.Key != "/foo/foo" {
  81. t.Fatalf("cannot get dir before expiration [%s]", err.Error())
  82. }
  83. if e.KVPairs[0].Key != "/foo/foo/foo1" || e.KVPairs[0].Value != "bar1" {
  84. t.Fatalf("cannot get sub node before expiration [%s]", err.Error())
  85. }
  86. if e.KVPairs[1].Key != "/foo/foo/foo2" || e.KVPairs[1].Dir != true {
  87. t.Fatalf("cannot get sub dir before expiration [%s]", err.Error())
  88. }
  89. /*if e.KVPairs[2].Key != "/foo/foo/foo2/boo" || e.KVPairs[2].Value != "boo1" {
  90. t.Fatalf("cannot get sub node of sub dir before expiration [%s]", err.Error())
  91. }*/
  92. // wait for expiration
  93. time.Sleep(time.Second * 3)
  94. e, err = fs.Get("/foo/foo", true, false, 7, 1)
  95. if err == nil {
  96. t.Fatal("still can get dir after expiration [%s]")
  97. }
  98. _, err = fs.Get("/foo/foo/foo1", true, false, 7, 1)
  99. if err == nil {
  100. t.Fatal("still can get sub node after expiration [%s]")
  101. }
  102. _, err = fs.Get("/foo/foo/foo2", true, false, 7, 1)
  103. if err == nil {
  104. t.Fatal("still can get sub dir after expiration [%s]")
  105. }
  106. _, err = fs.Get("/foo/foo/foo2/boo", true, false, 7, 1)
  107. if err == nil {
  108. t.Fatalf("still can get sub node of sub dir after expiration [%s]", err.Error())
  109. }
  110. }
  111. func TestListDirectory(t *testing.T) {
  112. fs := New()
  113. // create dir /foo
  114. // set key-value /foo/foo=bar
  115. fs.Create("/foo/foo", "bar", Permanent, 1, 1)
  116. // create dir /foo/fooDir
  117. // set key-value /foo/fooDir/foo=bar
  118. fs.Create("/foo/fooDir/foo", "bar", Permanent, 2, 1)
  119. e, err := fs.Get("/foo", true, false, 2, 1)
  120. if err != nil {
  121. t.Fatalf("%v", err)
  122. }
  123. if len(e.KVPairs) != 2 {
  124. t.Fatalf("wrong number of kv pairs [%d/2]", len(e.KVPairs))
  125. }
  126. if e.KVPairs[0].Key != "/foo/foo" || e.KVPairs[0].Value != "bar" {
  127. t.Fatalf("wrong kv [/foo/foo/ / %s] -> [bar / %s]", e.KVPairs[0].Key, e.KVPairs[0].Value)
  128. }
  129. if e.KVPairs[1].Key != "/foo/fooDir" || e.KVPairs[1].Dir != true {
  130. t.Fatalf("wrong kv [/foo/fooDir/ / %s] -> [true / %v]", e.KVPairs[1].Key, e.KVPairs[1].Dir)
  131. }
  132. if e.KVPairs[1].KVPairs[0].Key != "/foo/fooDir/foo" || e.KVPairs[1].KVPairs[0].Value != "bar" {
  133. t.Fatalf("wrong kv [/foo/fooDir/foo / %s] -> [bar / %v]", e.KVPairs[1].KVPairs[0].Key, e.KVPairs[1].KVPairs[0].Value)
  134. }
  135. // test hidden node
  136. // create dir /foo/_hidden
  137. // set key-value /foo/_hidden/foo -> bar
  138. fs.Create("/foo/_hidden/foo", "bar", Permanent, 3, 1)
  139. e, _ = fs.Get("/foo", false, false, 2, 1)
  140. if len(e.KVPairs) != 2 {
  141. t.Fatalf("hidden node is not hidden! %s", e.KVPairs[2].Key)
  142. }
  143. }
  144. func TestRemove(t *testing.T) {
  145. fs := New()
  146. fs.Create("/foo", "bar", Permanent, 1, 1)
  147. _, err := fs.Delete("/foo", false, 1, 1)
  148. if err != nil {
  149. t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
  150. }
  151. _, err = fs.Get("/foo", false, false, 1, 1)
  152. if err == nil || err.Error() != "Key Not Found" {
  153. t.Fatalf("can get the node after deletion")
  154. }
  155. fs.Create("/foo/bar", "bar", Permanent, 1, 1)
  156. fs.Create("/foo/car", "car", Permanent, 1, 1)
  157. fs.Create("/foo/dar/dar", "dar", Permanent, 1, 1)
  158. _, err = fs.Delete("/foo", false, 1, 1)
  159. if err == nil {
  160. t.Fatalf("should not be able to delete a directory without recursive")
  161. }
  162. _, err = fs.Delete("/foo", true, 1, 1)
  163. if err != nil {
  164. t.Fatalf("cannot delete %s [%s]", "/foo", err.Error())
  165. }
  166. _, err = fs.Get("/foo", false, false, 1, 1)
  167. if err == nil || err.Error() != "Key Not Found" {
  168. t.Fatalf("can get the node after deletion ")
  169. }
  170. }
  171. func TestExpire(t *testing.T) {
  172. fs := New()
  173. expire := time.Now().Add(time.Second)
  174. fs.Create("/foo", "bar", expire, 1, 1)
  175. _, err := fs.InternalGet("/foo", 1, 1)
  176. if err != nil {
  177. t.Fatalf("can not get the node")
  178. }
  179. time.Sleep(time.Second * 2)
  180. _, err = fs.InternalGet("/foo", 1, 1)
  181. if err == nil {
  182. t.Fatalf("can get the node after expiration time")
  183. }
  184. // test if we can reach the node before expiration
  185. expire = time.Now().Add(time.Second)
  186. fs.Create("/foo", "bar", expire, 1, 1)
  187. time.Sleep(time.Millisecond * 50)
  188. _, err = fs.InternalGet("/foo", 1, 1)
  189. if err != nil {
  190. t.Fatalf("cannot get the node before expiration", err.Error())
  191. }
  192. expire = time.Now().Add(time.Second)
  193. fs.Create("/foo", "bar", expire, 1, 1)
  194. _, err = fs.Delete("/foo", false, 1, 1)
  195. if err != nil {
  196. t.Fatalf("cannot delete the node before expiration", err.Error())
  197. }
  198. }
  199. func TestTestAndSet(t *testing.T) { // TODO prevValue == nil ?
  200. fs := New()
  201. fs.Create("/foo", "bar", Permanent, 1, 1)
  202. // test on wrong previous value
  203. _, err := fs.TestAndSet("/foo", "barbar", 0, "car", Permanent, 2, 1)
  204. if err == nil {
  205. t.Fatal("test and set should fail barbar != bar")
  206. }
  207. // test on value
  208. e, err := fs.TestAndSet("/foo", "bar", 0, "car", Permanent, 3, 1)
  209. if err != nil {
  210. t.Fatal("test and set should succeed bar == bar")
  211. }
  212. if e.PrevValue != "bar" || e.Value != "car" {
  213. t.Fatalf("[%v/%v] [%v/%v]", e.PrevValue, "bar", e.Value, "car")
  214. }
  215. // test on index
  216. e, err = fs.TestAndSet("/foo", "", 3, "bar", Permanent, 4, 1)
  217. if err != nil {
  218. t.Fatal("test and set should succeed index 3 == 3")
  219. }
  220. if e.PrevValue != "car" || e.Value != "bar" {
  221. t.Fatalf("[%v/%v] [%v/%v]", e.PrevValue, "car", e.Value, "bar")
  222. }
  223. //e, err = fs.TestAndSet("/foo", )
  224. }
  225. func TestWatch(t *testing.T) {
  226. fs := New()
  227. // watch at a deeper path
  228. c, _ := fs.WatcherHub.watch("/foo/foo/foo", false, 0)
  229. fs.Create("/foo/foo/foo", "bar", Permanent, 1, 1)
  230. e := nonblockingRetrive(c)
  231. if e.Key != "/foo/foo/foo" {
  232. t.Fatal("watch for Create node fails")
  233. }
  234. c, _ = fs.WatcherHub.watch("/foo/foo/foo", false, 0)
  235. fs.Update("/foo/foo/foo", "car", Permanent, 2, 1)
  236. e = nonblockingRetrive(c)
  237. if e.Key != "/foo/foo/foo" {
  238. t.Fatal("watch for Update node fails")
  239. }
  240. c, _ = fs.WatcherHub.watch("/foo/foo/foo", false, 0)
  241. fs.TestAndSet("/foo/foo/foo", "car", 0, "bar", Permanent, 3, 1)
  242. e = nonblockingRetrive(c)
  243. if e.Key != "/foo/foo/foo" {
  244. t.Fatal("watch for TestAndSet node fails")
  245. }
  246. c, _ = fs.WatcherHub.watch("/foo/foo/foo", false, 0)
  247. fs.Delete("/foo", true, 4, 1) //recursively delete
  248. e = nonblockingRetrive(c)
  249. if e.Key != "/foo" {
  250. t.Fatal("watch for Delete node fails")
  251. }
  252. // watch at a prefix
  253. c, _ = fs.WatcherHub.watch("/foo", true, 0)
  254. fs.Create("/foo/foo/boo", "bar", Permanent, 5, 1)
  255. e = nonblockingRetrive(c)
  256. if e.Key != "/foo/foo/boo" {
  257. t.Fatal("watch for Create subdirectory fails")
  258. }
  259. c, _ = fs.WatcherHub.watch("/foo", true, 0)
  260. fs.Update("/foo/foo/boo", "foo", Permanent, 6, 1)
  261. e = nonblockingRetrive(c)
  262. if e.Key != "/foo/foo/boo" {
  263. t.Fatal("watch for Update subdirectory fails")
  264. }
  265. c, _ = fs.WatcherHub.watch("/foo", true, 0)
  266. fs.TestAndSet("/foo/foo/boo", "foo", 0, "bar", Permanent, 7, 1)
  267. e = nonblockingRetrive(c)
  268. if e.Key != "/foo/foo/boo" {
  269. t.Fatal("watch for TestAndSet subdirectory fails")
  270. }
  271. c, _ = fs.WatcherHub.watch("/foo", true, 0)
  272. fs.Delete("/foo/foo/boo", false, 8, 1)
  273. e = nonblockingRetrive(c)
  274. if e.Key != "/foo/foo/boo" {
  275. t.Fatal("watch for Delete subdirectory fails")
  276. }
  277. }
  278. func createAndGet(fs *FileSystem, path string, t *testing.T) {
  279. _, err := fs.Create(path, "bar", Permanent, 1, 1)
  280. if err != nil {
  281. t.Fatalf("cannot create %s=bar [%s]", path, err.Error())
  282. }
  283. e, err := fs.Get(path, false, false, 1, 1)
  284. if err != nil {
  285. t.Fatalf("cannot get %s [%s]", path, err.Error())
  286. }
  287. if e.Value != "bar" {
  288. t.Fatalf("expect value of %s is bar [%s]", path, e.Value)
  289. }
  290. }
  291. func nonblockingRetrive(c <-chan *Event) *Event {
  292. select {
  293. case e := <-c:
  294. return e
  295. default:
  296. return nil
  297. }
  298. }
  299. func TestSort(t *testing.T) {
  300. fs := New()
  301. // simulating random creation
  302. keys := store.GenKeys(100, 5)
  303. //t.Log(keys)
  304. i := uint64(1)
  305. for _, k := range keys {
  306. _, err := fs.Create(k, "bar", Permanent, i, 1)
  307. if err != nil {
  308. t.Fatalf("create node[%s] failed", k, err.Error())
  309. }
  310. i++
  311. }
  312. e, err := fs.Get("/foo", true, true, i, 1)
  313. if err != nil {
  314. t.Fatalf("get dir nodes failed [%s]", err.Error())
  315. }
  316. for i, k := range e.KVPairs[:len(e.KVPairs)-1] {
  317. //t.Log(k)
  318. if k.Key >= e.KVPairs[i+1].Key {
  319. t.Fatalf("sort failed, [%s] should be placed after [%s]", k.Key, e.KVPairs[i+1].Key)
  320. }
  321. }
  322. }