store_test.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package store
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "testing"
  6. "time"
  7. )
  8. func TestStoreGetDelete(t *testing.T) {
  9. s := CreateStore(100)
  10. s.Set("foo", "bar", time.Unix(0, 0), 1)
  11. res, err := s.Get("foo")
  12. if err != nil {
  13. t.Fatalf("Unknown error")
  14. }
  15. var result Response
  16. json.Unmarshal(res, &result)
  17. if result.Value != "bar" {
  18. t.Fatalf("Cannot get stored value")
  19. }
  20. s.Delete("foo", 2)
  21. _, err = s.Get("foo")
  22. if err == nil {
  23. t.Fatalf("Got deleted value")
  24. }
  25. }
  26. func TestSaveAndRecovery(t *testing.T) {
  27. s := CreateStore(100)
  28. s.Set("foo", "bar", time.Unix(0, 0), 1)
  29. s.Set("foo2", "bar2", time.Now().Add(time.Second*5), 2)
  30. state, err := s.Save()
  31. if err != nil {
  32. t.Fatalf("Cannot Save %s", err)
  33. }
  34. newStore := CreateStore(100)
  35. // wait for foo2 expires
  36. time.Sleep(time.Second * 6)
  37. newStore.Recovery(state)
  38. res, err := newStore.Get("foo")
  39. var result Response
  40. json.Unmarshal(res, &result)
  41. if result.Value != "bar" {
  42. t.Fatalf("Recovery Fail")
  43. }
  44. res, err = newStore.Get("foo2")
  45. if err == nil {
  46. t.Fatalf("Get expired value")
  47. }
  48. s.Delete("foo", 3)
  49. }
  50. func TestExpire(t *testing.T) {
  51. fmt.Println(time.Now())
  52. fmt.Println("TEST EXPIRE")
  53. // test expire
  54. s := CreateStore(100)
  55. s.Set("foo", "bar", time.Now().Add(time.Second*1), 0)
  56. time.Sleep(2 * time.Second)
  57. _, err := s.Get("foo")
  58. if err == nil {
  59. t.Fatalf("Got expired value")
  60. }
  61. //test change expire time
  62. s.Set("foo", "bar", time.Now().Add(time.Second*10), 1)
  63. _, err = s.Get("foo")
  64. if err != nil {
  65. t.Fatalf("Cannot get Value")
  66. }
  67. s.Set("foo", "barbar", time.Now().Add(time.Second*1), 2)
  68. time.Sleep(2 * time.Second)
  69. _, err = s.Get("foo")
  70. if err == nil {
  71. t.Fatalf("Got expired value")
  72. }
  73. // test change expire to stable
  74. s.Set("foo", "bar", time.Now().Add(time.Second*1), 3)
  75. s.Set("foo", "bar", time.Unix(0, 0), 4)
  76. time.Sleep(2 * time.Second)
  77. _, err = s.Get("foo")
  78. if err != nil {
  79. t.Fatalf("Cannot get Value")
  80. }
  81. // test stable to expire
  82. s.Set("foo", "bar", time.Now().Add(time.Second*1), 5)
  83. time.Sleep(2 * time.Second)
  84. _, err = s.Get("foo")
  85. if err == nil {
  86. t.Fatalf("Got expired value")
  87. }
  88. // test set older node
  89. s.Set("foo", "bar", time.Now().Add(-time.Second*1), 6)
  90. _, err = s.Get("foo")
  91. if err == nil {
  92. t.Fatalf("Got expired value")
  93. }
  94. }