| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
 | defmodule Pleroma.Web.ActivityPub.ObjectValidatorTest do
  use Pleroma.DataCase
  alias Pleroma.Web.ActivityPub.ObjectValidator
  alias Pleroma.Web.ActivityPub.ObjectValidators.LikeValidator
  alias Pleroma.Web.ActivityPub.Utils
  alias Pleroma.Web.CommonAPI
  import Pleroma.Factory
  describe "likes" do
    setup do
      user = insert(:user)
      {:ok, post_activity} = CommonAPI.post(user, %{"status" => "uguu"})
      valid_like = %{
        "to" => [user.ap_id],
        "cc" => [],
        "type" => "Like",
        "id" => Utils.generate_activity_id(),
        "object" => post_activity.data["object"],
        "actor" => user.ap_id,
        "context" => "a context"
      }
      %{valid_like: valid_like, user: user, post_activity: post_activity}
    end
    test "returns ok when called in the ObjectValidator", %{valid_like: valid_like} do
      {:ok, object, _meta} = ObjectValidator.validate(valid_like, [])
      assert "id" in Map.keys(object)
    end
    test "is valid for a valid object", %{valid_like: valid_like} do
      assert LikeValidator.cast_and_validate(valid_like).valid?
    end
    test "sets the 'to' field to the object actor if no recipients are given", %{
      valid_like: valid_like,
      user: user
    } do
      without_recipients =
        valid_like
        |> Map.delete("to")
      {:ok, object, _meta} = ObjectValidator.validate(without_recipients, [])
      assert object["to"] == [user.ap_id]
    end
    test "sets the context field to the context of the object if no context is given", %{
      valid_like: valid_like,
      post_activity: post_activity
    } do
      without_context =
        valid_like
        |> Map.delete("context")
      {:ok, object, _meta} = ObjectValidator.validate(without_context, [])
      assert object["context"] == post_activity.data["context"]
    end
    test "it errors when the actor is missing or not known", %{valid_like: valid_like} do
      without_actor = Map.delete(valid_like, "actor")
      refute LikeValidator.cast_and_validate(without_actor).valid?
      with_invalid_actor = Map.put(valid_like, "actor", "invalidactor")
      refute LikeValidator.cast_and_validate(with_invalid_actor).valid?
    end
    test "it errors when the object is missing or not known", %{valid_like: valid_like} do
      without_object = Map.delete(valid_like, "object")
      refute LikeValidator.cast_and_validate(without_object).valid?
      with_invalid_object = Map.put(valid_like, "object", "invalidobject")
      refute LikeValidator.cast_and_validate(with_invalid_object).valid?
    end
    test "it errors when the actor has already like the object", %{
      valid_like: valid_like,
      user: user,
      post_activity: post_activity
    } do
      _like = CommonAPI.favorite(user, post_activity.id)
      refute LikeValidator.cast_and_validate(valid_like).valid?
    end
    test "it works when actor or object are wrapped in maps", %{valid_like: valid_like} do
      wrapped_like =
        valid_like
        |> Map.put("actor", %{"id" => valid_like["actor"]})
        |> Map.put("object", %{"id" => valid_like["object"]})
      validated = LikeValidator.cast_and_validate(wrapped_like)
      assert validated.valid?
      assert {:actor, valid_like["actor"]} in validated.changes
      assert {:object, valid_like["object"]} in validated.changes
    end
  end
end
 |