123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- ExUnit.start()
- defmodule St.Test do
- use ExUnit.Case, async: false
- import Record
- require KVS
- defrecord(:msg, id: [], body: [])
- setup do: (on_exit(fn -> :ok = :kvs.leave();:ok = :kvs_rocks.destroy() end);:kvs.join())
- setup kvs, do: [
- ids: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), :feed) end, :lists.seq(1,10)),
- id0: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/personal/Реєстратор А1/in/directory/duck") end, :lists.seq(1,10)),
- id1: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/personal/Реєстратор А1/in/mail") end, :lists.seq(1,10)),
- id2: :lists.map(fn _ -> :kvs.append(msg(id: :kvs.seq([],[])), "/crm/personal/Реєстратор А1/in/doc") end, :lists.seq(1,10))]
- test "take-ø", kvs do
- r = KVS.reader() = :kvs.reader("/empty-feed")
- assert r1 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(r, args: 1))
- assert r1 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(r, args: 1, dir: 1))
- assert r2 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.next(r)
- assert r3 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.prev(r)
- assert r1 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(r, args: 100))
- assert r1 = KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(r, args: 100, dir: 1))
- KVS.reader(id: rid) = :kvs.save(r1)
- assert rs1 = KVS.reader(id: rid) = :kvs.load_reader(rid)
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(rs1, args: 5))
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(rs1, args: 5, dir: 1))
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.next(rs1)
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.prev(rs1)
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(rs1, args: 0))
- assert KVS.reader(feed: "//empty-feed", args: []) = :kvs.take(KVS.reader(rs1, args: 0, dir: 1))
- end
- test "take-0", kvs do
- feed = "//crm/personal/Реєстратор А1/in/doc"
- assert r = KVS.reader(id: rid, args: []) = :kvs.reader("/crm/personal/Реєстратор А1/in/doc")
- assert KVS.reader(id: ^rid, feed: ^feed, args: []) = :kvs.take(KVS.reader(r, args: 0, dir: 0))
- assert KVS.reader(id: ^rid, feed: ^feed, args: []) = :kvs.take(KVS.reader(r, args: -1, dir: 0))
-
- assert r1 = KVS.reader(id: ^rid, feed: ^feed, args: a01) = :kvs.take(KVS.reader(r, args: 10, dir: 0))
- assert kvs[:id2] |> Enum.map(&msg(id: &1)) == a01
- assert KVS.reader(id: ^rid, feed: ^feed, args: []) = :kvs.take(KVS.reader(r1, args: 10, dir: 0))
- assert KVS.reader(id: ^rid, feed: ^feed, args: af) = :kvs.take(KVS.reader(r, args: 100, dir: 0))
- assert kvs[:id2] |> Enum.map(&msg(id: &1)) == af
- assert r2 = KVS.reader(id: ^rid, feed: ^feed, args: a03) = :kvs.take(KVS.reader(r, args: 3, dir: 0))
- assert Enum.take(kvs[:id2],3) |> Enum.map(&msg(id: &1)) == a03
- assert KVS.reader(id: ^rid, feed: ^feed, args: a07) = :kvs.take(KVS.reader(r2, args: 7, dir: 0))
- assert Enum.drop(kvs[:id2],3) |> Enum.map(&msg(id: &1)) == a07
- assert KVS.reader(id: ^rid, feed: ^feed, args: a17) = :kvs.take(KVS.reader(r2, args: 100, dir: 0))
- assert Enum.drop(kvs[:id2],3) |> Enum.map(&msg(id: &1)) == a17
- end
- test "take-1", kvs do
- feed = "//crm/personal/Реєстратор А1/in/mail"
- top = Enum.at(kvs[:id1],0)
- bot = Enum.at(kvs[:id1],9)
- tpm = Enum.take(kvs[:id1],1) |> Enum.map(&msg(id: &1))
- assert r = KVS.reader(id: rid, args: [], cache: {:msg, ^top, ^feed}, count: 10) = :kvs.reader("/crm/personal/Реєстратор А1/in/mail")
- assert r = :kvs.top(r)
- assert KVS.reader(id: ^rid, feed: ^feed, args: ^tpm, dir: 1) = :kvs.take(KVS.reader(r, args: 1, dir: 1))
- assert KVS.reader(id: ^rid, feed: ^feed, args: ^tpm, dir: 1) = :kvs.take(KVS.reader(r, args: 100, dir: 1))
- assert r1 = KVS.reader(feed: ^feed, count: 10, args: [], cache: {:msg,^bot,^feed}) = :kvs.bot(r)
-
- assert r2 = KVS.reader(feed: ^feed, count: 10, args: a01) = :kvs.take(KVS.reader(r1, args: 5, dir: 1))
- x01 = Enum.drop(kvs[:id1],5) |> Enum.map(&msg(id: &1)) |> Enum.reverse
- assert x01 == a01
- assert r3 = KVS.reader(feed: ^feed, count: 10, args: a02) = :kvs.take(KVS.reader(r2, args: 10, dir: 1))
- x02 = Enum.take(kvs[:id1],5) |> Enum.map(&msg(id: &1)) |> Enum.reverse
- assert x02 == a02
- assert KVS.reader(feed: ^feed, count: 10, args: []) = :kvs.take(KVS.reader(r3, args: 20, dir: 1))
- end
- test "drop", kvs do
- feed = "/feed"
- assert r = KVS.reader(id: rid, args: []) = :kvs.save(:kvs.reader(:feed))
- assert r1 = KVS.reader(id: ^rid, feed: ^feed, args: []) = :kvs.drop(KVS.reader(r, args: 10, dir: 0))
- kvs[:ids] |> Enum.map(&msg(id: &1))
- |> Enum.each(&assert(
- KVS.reader(id: rid, feed: ^feed, args: [], cache: &1) =
- :kvs.save(:kvs.drop(KVS.reader(:kvs.load_reader(rid), args: 1, dir: 0)))))
- assert r2 = KVS.reader(id: ^rid, feed: ^feed, args: [], cache: c1) = :kvs.drop(KVS.reader(r, args: 1, dir: 0))
- assert {:msg, Enum.at(kvs[:ids], 1), feed} == c1
- assert KVS.reader(id: ^rid, feed: ^feed, args: [], cache: c2) = :kvs.drop(KVS.reader(r2, args: 5, dir: 0))
- assert {:msg, Enum.at(kvs[:ids], 6), feed} == c2
- assert KVS.reader(id: ^rid, feed: ^feed, args: []) = :kvs.drop(KVS.reader(r1, args: 100))
- end
- test "feed",kvs do
- docs = :kvs.all("/crm/personal/Реєстратор А1/in/doc")
- ducks = :kvs.all("/crm/personal/Реєстратор А1/in/directory/duck")
- mail = :kvs.all("/crm/personal/Реєстратор А1/in/mail")
- total = :kvs.all("/crm/personal/Реєстратор А1/in")
- assert ducks++docs++mail == total
- assert docs = :kvs.feed("/crm/personal/Реєстратор А1/in/doc")
- assert ducks = :kvs.feed("/crm/personal/Реєстратор А1/in/directory/duck")
- assert mail = :kvs.feed("/crm/personal/Реєстратор А1/in/mail")
- assert total = :kvs.feed("/crm/personal/Реєстратор А1/in")
- assert :kvs.feed("/crm/personal/Реєстратор А1/in/directory/duck")
- ++ :kvs.feed("/crm/personal/Реєстратор А1/in/doc")
- ++ :kvs.feed("/crm/personal/Реєстратор А1/in/mail") == :kvs.feed("/crm/personal/Реєстратор А1/in")
- end
- defp log(x), do: IO.puts '#{inspect(x)}'
- defp log(m, x), do: IO.puts '#{m} #{inspect(x)}'
- end
|