fd_test.exs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. ExUnit.start()
  2. defmodule Fd.Test do
  3. use ExUnit.Case, async: false
  4. require KVS
  5. import Record
  6. test "fd_test", kvs do
  7. assert "//erp" = :kvs_rocks.fd "//erp/orgs"
  8. assert "/erp" = :kvs_rocks.fd "/erp/orgs"
  9. end
  10. test "key_test", kvs do
  11. assert "//erp/orgs" = :kvs_rocks.key "/erp/orgs"
  12. assert "/erp/orgs" = :kvs_rocks.key "erp/orgs"
  13. end
  14. defrecord(:msg, id: [], body: [])
  15. setup do: (on_exit(fn -> :ok = :kvs.leave();:ok = :kvs.destroy() end);:kvs.join())
  16. setup kvs, do: [
  17. id0: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/duck") end, :lists.seq(1,10)),
  18. id1: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/luck") end, :lists.seq(1,10)),
  19. id2: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/truck") end, :lists.seq(1,10))]
  20. test "reader", kvs do
  21. ltop = Enum.at(kvs[:id1],0)
  22. dtop = Enum.at(kvs[:id0],0)
  23. ttop = Enum.at(kvs[:id2],0)
  24. assert KVS.reader(feed: "//crm/luck", count: 10, dir: 0, args: [], cache: {:msg, ^ltop, "//crm/luck"}) = :kvs.reader("/crm/luck")
  25. assert KVS.reader(feed: "//crm/duck", count: 10, dir: 0, args: [], cache: {:msg, ^dtop, "//crm/duck"}) = :kvs.reader("/crm/duck")
  26. assert KVS.reader(feed: "//crm/truck", count: 10, dir: 0, args: [], cache: {:msg, ^ttop, "//crm/truck"}) = :kvs.reader("/crm/truck")
  27. assert KVS.reader(feed: "//crm", count: 0, dir: 0, args: [], cache: {:msg, ^dtop, "//crm/duck"}) = :kvs.reader("/crm")
  28. assert KVS.reader(feed: "//noroute", count: 0, dir: 0, args: []) = :kvs.reader("/noroute")
  29. assert KVS.reader(feed: "//", count: 0, dir: 0, args: [], cache: {:msg, ^dtop, "//crm/duck"}) = :kvs.reader("/")
  30. assert KVS.reader(count: 0, dir: 0, args: []) = :kvs.reader([])
  31. end
  32. test "range", kvs do
  33. ltop = Enum.at(kvs[:id1],0)
  34. dtop = Enum.at(kvs[:id0],0)
  35. lbot = Enum.at(kvs[:id1],9)
  36. assert KVS.reader(feed: "//crm/luck", count: 10, dir: 0, args: [], cache: {:msg, ^ltop, "//crm/luck"}) = :kvs.top(:kvs.reader("/crm/luck"))
  37. assert KVS.reader(feed: "//crm", count: 0, dir: 0, args: [], cache: {:msg, ^dtop, "//crm/duck"}) = :kvs.top(:kvs.reader("/crm"))
  38. assert KVS.reader(feed: "//", count: 0, dir: 0, args: [], cache: {:msg, ^dtop, "//crm/duck"}) = :kvs.top(:kvs.reader("/"))
  39. assert KVS.reader(feed: "//crm/luck", count: 10, dir: 0, args: [], cache: {:msg, ^lbot, "//crm/luck"}) = :kvs.bot(:kvs.reader("/crm/luck"))
  40. assert KVS.reader(feed: "//crm", count: 0, dir: 0, args: [], cache: []) = :kvs.bot(:kvs.reader("/crm"))
  41. assert KVS.reader(feed: "//", count: 0, dir: 0, args: [], cache: []) = :kvs.bot(:kvs.reader("/"))
  42. end
  43. test "next", kvs do
  44. last = msg(id: Enum.at(kvs[:id1],9))
  45. r0 = KVS.reader(id: rid) = :kvs.save(:kvs.top(:kvs.reader("/crm/luck")))
  46. kvs[:id1] |> Enum.with_index
  47. |> Enum.each(fn {id,9} ->
  48. r = :kvs.load_reader(rid)
  49. r01 = :kvs.next(r)
  50. assert r1 = KVS.reader(feed: "//crm/luck", cache: c1, count: 10, dir: 0, args: [^last]) = r01
  51. assert KVS.reader(args: [], feed: "//crm/luck", cache: c1) = :kvs.save(r1)
  52. {id,i} ->
  53. v = msg(id: Enum.at(kvs[:id1],i))
  54. c = Enum.at(kvs[:id1],i+1)
  55. r = :kvs.load_reader(rid)
  56. assert r1 = KVS.reader(feed: "//crm/luck", cache: {:msg,^c,"//crm/luck"}, count: 10, dir: 0, args: [^v]) = :kvs.next(r)
  57. assert KVS.reader(args: [], feed: "//crm/luck", cache: {:msg,^c,"//crm/luck"}) = :kvs.save(r1)
  58. end)
  59. r = :kvs.load_reader(rid)
  60. assert r == :kvs.next(r)
  61. assert r == KVS.reader(:kvs.next(:kvs.bot(r)), args: [])
  62. end
  63. test "prev", kvs do
  64. out = Enum.at(kvs[:id0],9)
  65. KVS.reader(id: rid) = :kvs.save(:kvs.bot(:kvs.reader("/crm/luck")))
  66. ids = kvs[:id1] |> Enum.reverse
  67. ids |> Enum.with_index
  68. |> Enum.each(fn {id,9} ->
  69. r = :kvs.load_reader(rid)
  70. v = msg(id: Enum.at(ids, 9))
  71. assert r1 = KVS.reader(feed: "//crm/luck", cache: {:msg, ^out, "//crm/duck"}, count: 10, args: [^v]) = :kvs.prev(r)
  72. assert KVS.reader(args: [], feed: "//crm/luck", cache: c1) = :kvs.save(r1)
  73. {id,i} ->
  74. r = :kvs.load_reader(rid)
  75. v = msg(id: Enum.at(ids, i))
  76. c = Enum.at(ids, i+1)
  77. assert r1 = KVS.reader(feed: "//crm/luck", cache: {:msg, ^c, "//crm/luck"}, count: 10, args: [^v]) = :kvs.prev(r)
  78. assert KVS.reader(args: [], feed: "//crm/luck", cache: {:msg, ^c, "//crm/luck"}) = :kvs.save(r1)
  79. end)
  80. r = :kvs.load_reader(rid)
  81. assert r = :kvs.prev(r)
  82. assert r = KVS.reader(:kvs.prev(:kvs.top(r)), args: [])
  83. end
  84. test "prev to empty" do
  85. :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/aco") end, :lists.seq(1,2))
  86. all = :kvs.all("/aco")
  87. head = Enum.at(all,0)
  88. r = :kvs.bot(:kvs.reader("/aco"))
  89. r1 = KVS.reader(args: args) = :kvs.take(KVS.reader(r, args: 2, dir: 1))
  90. assert all == :lists.reverse(args)
  91. assert KVS.reader(args: [^head]) = :kvs.take(KVS.reader(r1, args: 1000, dir: 1))
  92. end
  93. @tag :skip # can`t manage this within current implementation. create correct keys!
  94. test "keys with feeds separator" do
  95. :kvs.append(msg(id: "1/1"), "/one/two")
  96. :kvs.append(msg(id: "1/2"), "/one/two")
  97. assert KVS.reader(cache: {:msg, _, "//one/two"}) = :kvs.reader("/one/two")
  98. end
  99. test "corrupted writers doesn't affect all" do
  100. prev = :kvs.all("/crm/duck")
  101. KVS.writer(cache: ch) = w = :kvs.writer("/crm/duck")
  102. w1 = KVS.writer(w, cache: {:msg, "unknown", "/corrupted"})
  103. :ok = :kvs_rocks.put(w1)
  104. w2 = :kvs.writer("/crm/duck")
  105. assert {:ok, ^w2} = :kvs.get(:writer, "/crm/duck")
  106. assert w1 == w2
  107. assert prev = :kvs.all("/crm/duck")
  108. {:ok,_} = :kvs.get(:writer, "/crm/duck")
  109. :ok = :kvs.delete(:writer, "/crm/duck")
  110. {:error, :not_found} = :kvs.get(:writer, "/crm/duck")
  111. assert prev = :kvs.all("/crm/duck")
  112. end
  113. defp log(x), do: IO.puts '#{inspect(x)}'
  114. defp log(m, x), do: IO.puts '#{m} #{inspect(x)}'
  115. end