diff options
author | Roger Braun <roger@rogerbraun.net> | 2017-04-13 15:49:42 +0200 |
---|---|---|
committer | Roger Braun <roger@rogerbraun.net> | 2017-04-13 15:49:42 +0200 |
commit | f97c8e43792f76e84c436e75b0c0893d3c16d7d8 (patch) | |
tree | 5324b4fa1983e1e63b05687dae5865322577ad00 | |
parent | 4cac385411b743fce039e0ebe93ce27323e6f231 (diff) | |
download | pleroma-f97c8e43792f76e84c436e75b0c0893d3c16d7d8.tar.gz |
Add utility functions for objects and activities.
-rw-r--r-- | lib/pleroma/activity.ex | 12 | ||||
-rw-r--r-- | test/activity_test.exs | 18 | ||||
-rw-r--r-- | test/object_test.exs | 11 |
3 files changed, 41 insertions, 0 deletions
diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index c4efc6283..46568bb13 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -1,9 +1,21 @@ defmodule Pleroma.Activity do use Ecto.Schema + alias Pleroma.{Repo, Activity} + import Ecto.Query schema "activities" do field :data, :map timestamps() end + + def get_by_ap_id(ap_id) do + Repo.one(from activity in Activity, + where: fragment("? @> ?", activity.data, ^%{id: ap_id})) + end + + def all_by_object_ap_id(ap_id) do + Repo.all(from activity in Activity, + where: fragment("? @> ?", activity.data, ^%{object: %{id: ap_id}})) + end end diff --git a/test/activity_test.exs b/test/activity_test.exs new file mode 100644 index 000000000..ce6eb1545 --- /dev/null +++ b/test/activity_test.exs @@ -0,0 +1,18 @@ +defmodule Pleroma.ActivityTest do + use Pleroma.DataCase + import Pleroma.Factory + + test "returns an activity by it's AP id" do + activity = insert(:note_activity) + found_activity = Pleroma.Activity.get_by_ap_id(activity.data["id"]) + + assert activity == found_activity + end + + test "returns activities by it's objects AP ids" do + activity = insert(:note_activity) + [found_activity] = Pleroma.Activity.all_by_object_ap_id(activity.data["object"]["id"]) + + assert activity == found_activity + end +end diff --git a/test/object_test.exs b/test/object_test.exs new file mode 100644 index 000000000..3ffddbbc5 --- /dev/null +++ b/test/object_test.exs @@ -0,0 +1,11 @@ +defmodule Pleroma.ObjectTest do + use Pleroma.DataCase + import Pleroma.Factory + + test "returns an object by it's AP id" do + object = insert(:note) + found_object = Pleroma.Object.get_by_ap_id(object.data["id"]) + + assert object == found_object + end +end |