diff options
author | lain <lain@soykaf.club> | 2019-02-09 22:01:08 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2019-02-09 22:01:08 +0100 |
commit | f8388be9c69981958e9a96dce68fc39bdedb5cd3 (patch) | |
tree | 52c4bc943eaab9bd4a4e8ea700dd1b71299bad33 /test | |
parent | 99fd199bda8bd90cd3e8c69d54087531ddc02eac (diff) | |
download | pleroma-f8388be9c69981958e9a96dce68fc39bdedb5cd3.tar.gz pleroma-f8388be9c69981958e9a96dce68fc39bdedb5cd3.zip |
Do object insertion through Cachex
So we don't flood our postgres logs with errors. Should also make things
slightly faster.
Diffstat (limited to 'test')
-rw-r--r-- | test/object_test.exs | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/test/object_test.exs b/test/object_test.exs index 72194975d..ab6431012 100644 --- a/test/object_test.exs +++ b/test/object_test.exs @@ -57,4 +57,32 @@ defmodule Pleroma.ObjectTest do assert cached_object.data["type"] == "Tombstone" end end + + describe "insert_or_get" do + test "inserting the same object twice (by id) just returns the original object" do + data = %{data: %{"id" => Ecto.UUID.generate()}} + cng = Object.change(%Object{}, data) + {:ok, object} = Object.insert_or_get(cng) + {:ok, second_object} = Object.insert_or_get(cng) + + Cachex.clear(:object_cache) + {:ok, third_object} = Object.insert_or_get(cng) + + assert object == second_object + assert object == third_object + end + end + + describe "create" do + test "inserts an object for a given data set" do + data = %{"id" => Ecto.UUID.generate()} + + {:ok, object} = Object.create(data) + assert object.data["id"] == data["id"] + + # Works when doing it twice. + {:ok, object} = Object.create(data) + assert object.data["id"] == data["id"] + end + end end |