diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/config_test.exs | 46 | ||||
| -rw-r--r-- | test/report_note_test.exs | 16 | ||||
| -rw-r--r-- | test/support/factory.ex | 24 | ||||
| -rw-r--r-- | test/support/helpers.ex | 14 | ||||
| -rw-r--r-- | test/tasks/app_test.exs | 6 | ||||
| -rw-r--r-- | test/user/welcome_chat_massage_test.exs | 35 | ||||
| -rw-r--r-- | test/user_test.exs | 58 | ||||
| -rw-r--r-- | test/web/activity_pub/mrf/activity_expiration_policy_test.exs | 7 | ||||
| -rw-r--r-- | test/web/activity_pub/mrf/object_age_policy_test.exs | 42 | ||||
| -rw-r--r-- | test/web/activity_pub/mrf/simple_policy_test.exs | 60 | ||||
| -rw-r--r-- | test/web/activity_pub/transmogrifier/chat_message_test.exs | 18 | ||||
| -rw-r--r-- | test/web/activity_pub/transmogrifier_test.exs | 8 | ||||
| -rw-r--r-- | test/web/common_api/common_api_test.exs | 5 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/account_controller_test.exs | 29 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_test.exs | 3 | ||||
| -rw-r--r-- | test/web/oauth/app_test.exs | 11 | 
16 files changed, 362 insertions, 20 deletions
| diff --git a/test/config_test.exs b/test/config_test.exs index a46ab4302..1556e4237 100644 --- a/test/config_test.exs +++ b/test/config_test.exs @@ -28,6 +28,34 @@ defmodule Pleroma.ConfigTest do      assert Pleroma.Config.get([:azerty, :uiop], true) == true    end +  describe "nil values" do +    setup do +      Pleroma.Config.put(:lorem, nil) +      Pleroma.Config.put(:ipsum, %{dolor: [sit: nil]}) +      Pleroma.Config.put(:dolor, sit: %{amet: nil}) + +      on_exit(fn -> Enum.each(~w(lorem ipsum dolor)a, &Pleroma.Config.delete/1) end) +    end + +    test "get/1 with an atom for nil value" do +      assert Pleroma.Config.get(:lorem) == nil +    end + +    test "get/2 with an atom for nil value" do +      assert Pleroma.Config.get(:lorem, true) == nil +    end + +    test "get/1 with a list of keys for nil value" do +      assert Pleroma.Config.get([:ipsum, :dolor, :sit]) == nil +      assert Pleroma.Config.get([:dolor, :sit, :amet]) == nil +    end + +    test "get/2 with a list of keys for nil value" do +      assert Pleroma.Config.get([:ipsum, :dolor, :sit], true) == nil +      assert Pleroma.Config.get([:dolor, :sit, :amet], true) == nil +    end +  end +    test "get/1 when value is false" do      Pleroma.Config.put([:instance, :false_test], false)      Pleroma.Config.put([:instance, :nested], []) @@ -89,5 +117,23 @@ defmodule Pleroma.ConfigTest do      Pleroma.Config.put([:delete_me, :delete_me], hello: "world", world: "Hello")      Pleroma.Config.delete([:delete_me, :delete_me, :world])      assert Pleroma.Config.get([:delete_me, :delete_me]) == [hello: "world"] + +    assert Pleroma.Config.delete([:this_key_does_not_exist]) +    assert Pleroma.Config.delete([:non, :existing, :key]) +  end + +  test "fetch/1" do +    Pleroma.Config.put([:lorem], :ipsum) +    Pleroma.Config.put([:ipsum], dolor: :sit) + +    assert Pleroma.Config.fetch([:lorem]) == {:ok, :ipsum} +    assert Pleroma.Config.fetch(:lorem) == {:ok, :ipsum} +    assert Pleroma.Config.fetch([:ipsum, :dolor]) == {:ok, :sit} +    assert Pleroma.Config.fetch([:lorem, :ipsum]) == :error +    assert Pleroma.Config.fetch([:loremipsum]) == :error +    assert Pleroma.Config.fetch(:loremipsum) == :error + +    Pleroma.Config.delete([:lorem]) +    Pleroma.Config.delete([:ipsum])    end  end diff --git a/test/report_note_test.exs b/test/report_note_test.exs new file mode 100644 index 000000000..25c1d6a61 --- /dev/null +++ b/test/report_note_test.exs @@ -0,0 +1,16 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.ReportNoteTest do +  alias Pleroma.ReportNote +  use Pleroma.DataCase +  import Pleroma.Factory + +  test "create/3" do +    user = insert(:user) +    report = insert(:report_activity) +    assert {:ok, note} = ReportNote.create(user.id, report.id, "naughty boy") +    assert note.content == "naughty boy" +  end +end diff --git a/test/support/factory.ex b/test/support/factory.ex index 635d83650..486eda8da 100644 --- a/test/support/factory.ex +++ b/test/support/factory.ex @@ -297,6 +297,30 @@ defmodule Pleroma.Factory do      }    end +  def report_activity_factory(attrs \\ %{}) do +    user = attrs[:user] || insert(:user) +    activity = attrs[:activity] || insert(:note_activity) +    state = attrs[:state] || "open" + +    data = %{ +      "id" => Pleroma.Web.ActivityPub.Utils.generate_activity_id(), +      "actor" => user.ap_id, +      "type" => "Flag", +      "object" => [activity.actor, activity.data["id"]], +      "published" => DateTime.utc_now() |> DateTime.to_iso8601(), +      "to" => [], +      "cc" => [activity.actor], +      "context" => activity.data["context"], +      "state" => state +    } + +    %Pleroma.Activity{ +      data: data, +      actor: data["actor"], +      recipients: data["to"] ++ data["cc"] +    } +  end +    def oauth_app_factory do      %Pleroma.Web.OAuth.App{        client_name: sequence(:client_name, &"Some client #{&1}"), diff --git a/test/support/helpers.ex b/test/support/helpers.ex index 5cbf2e291..ecd4b1e18 100644 --- a/test/support/helpers.ex +++ b/test/support/helpers.ex @@ -17,9 +17,19 @@ defmodule Pleroma.Tests.Helpers do    defmacro clear_config(config_path, do: yield) do      quote do -      initial_setting = Config.get(unquote(config_path)) +      initial_setting = Config.fetch(unquote(config_path))        unquote(yield) -      on_exit(fn -> Config.put(unquote(config_path), initial_setting) end) + +      on_exit(fn -> +        case initial_setting do +          :error -> +            Config.delete(unquote(config_path)) + +          {:ok, value} -> +            Config.put(unquote(config_path), value) +        end +      end) +        :ok      end    end diff --git a/test/tasks/app_test.exs b/test/tasks/app_test.exs index b8f03566d..71a84ac8e 100644 --- a/test/tasks/app_test.exs +++ b/test/tasks/app_test.exs @@ -50,13 +50,13 @@ defmodule Mix.Tasks.Pleroma.AppTest do    defp assert_app(name, redirect, scopes) do      app = Repo.get_by(Pleroma.Web.OAuth.App, client_name: name) -    assert_received {:mix_shell, :info, [message]} +    assert_receive {:mix_shell, :info, [message]}      assert message == "#{name} successfully created:" -    assert_received {:mix_shell, :info, [message]} +    assert_receive {:mix_shell, :info, [message]}      assert message == "App client_id: #{app.client_id}" -    assert_received {:mix_shell, :info, [message]} +    assert_receive {:mix_shell, :info, [message]}      assert message == "App client_secret: #{app.client_secret}"      assert app.scopes == scopes diff --git a/test/user/welcome_chat_massage_test.exs b/test/user/welcome_chat_massage_test.exs new file mode 100644 index 000000000..fe26d6e4d --- /dev/null +++ b/test/user/welcome_chat_massage_test.exs @@ -0,0 +1,35 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.User.WelcomeChatMessageTest do +  use Pleroma.DataCase + +  alias Pleroma.Config +  alias Pleroma.User.WelcomeChatMessage + +  import Pleroma.Factory + +  setup do: clear_config([:welcome]) + +  describe "post_message/1" do +    test "send a chat welcome message" do +      welcome_user = insert(:user, name: "mewmew") +      user = insert(:user) + +      Config.put([:welcome, :chat_message, :enabled], true) +      Config.put([:welcome, :chat_message, :sender_nickname], welcome_user.nickname) + +      Config.put( +        [:welcome, :chat_message, :message], +        "Hello, welcome to Blob/Cat!" +      ) + +      {:ok, %Pleroma.Activity{} = activity} = WelcomeChatMessage.post_message(user) + +      assert user.ap_id in activity.recipients +      assert Pleroma.Object.normalize(activity).data["type"] == "ChatMessage" +      assert Pleroma.Object.normalize(activity).data["content"] == "Hello, welcome to Blob/Cat!" +    end +  end +end diff --git a/test/user_test.exs b/test/user_test.exs index 904cea536..b47405895 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -412,8 +412,36 @@ defmodule Pleroma.UserTest do        welcome_user = insert(:user)        Pleroma.Config.put([:welcome, :direct_message, :enabled], true)        Pleroma.Config.put([:welcome, :direct_message, :sender_nickname], welcome_user.nickname) -      Pleroma.Config.put([:welcome, :direct_message, :message], "Hello, this is a cool site") +      Pleroma.Config.put([:welcome, :direct_message, :message], "Hello, this is a direct message") +      cng = User.register_changeset(%User{}, @full_user_data) +      {:ok, registered_user} = User.register(cng) +      ObanHelpers.perform_all() + +      activity = Repo.one(Pleroma.Activity) +      assert registered_user.ap_id in activity.recipients +      assert Object.normalize(activity).data["content"] =~ "direct message" +      assert activity.actor == welcome_user.ap_id +    end + +    test "it sends a welcome chat message if it is set" do +      welcome_user = insert(:user) +      Pleroma.Config.put([:welcome, :chat_message, :enabled], true) +      Pleroma.Config.put([:welcome, :chat_message, :sender_nickname], welcome_user.nickname) +      Pleroma.Config.put([:welcome, :chat_message, :message], "Hello, this is a chat message") + +      cng = User.register_changeset(%User{}, @full_user_data) +      {:ok, registered_user} = User.register(cng) +      ObanHelpers.perform_all() + +      activity = Repo.one(Pleroma.Activity) +      assert registered_user.ap_id in activity.recipients +      assert Object.normalize(activity).data["content"] =~ "chat message" +      assert activity.actor == welcome_user.ap_id +    end + +    test "it sends a welcome email message if it is set" do +      welcome_user = insert(:user)        Pleroma.Config.put([:welcome, :email, :enabled], true)        Pleroma.Config.put([:welcome, :email, :sender], welcome_user.email) @@ -428,11 +456,6 @@ defmodule Pleroma.UserTest do        {:ok, registered_user} = User.register(cng)        ObanHelpers.perform_all() -      activity = Repo.one(Pleroma.Activity) -      assert registered_user.ap_id in activity.recipients -      assert Object.normalize(activity).data["content"] =~ "cool site" -      assert activity.actor == welcome_user.ap_id -        assert_email_sent(          from: {instance_name, welcome_user.email},          to: {registered_user.name, registered_user.email}, @@ -490,6 +513,29 @@ defmodule Pleroma.UserTest do        refute changeset.valid?      end +    test "it blocks blacklisted email domains" do +      clear_config([User, :email_blacklist], ["trolling.world"]) + +      # Block with match +      params = Map.put(@full_user_data, :email, "troll@trolling.world") +      changeset = User.register_changeset(%User{}, params) +      refute changeset.valid? + +      # Block with subdomain match +      params = Map.put(@full_user_data, :email, "troll@gnomes.trolling.world") +      changeset = User.register_changeset(%User{}, params) +      refute changeset.valid? + +      # Pass with different domains that are similar +      params = Map.put(@full_user_data, :email, "troll@gnomestrolling.world") +      changeset = User.register_changeset(%User{}, params) +      assert changeset.valid? + +      params = Map.put(@full_user_data, :email, "troll@trolling.world.us") +      changeset = User.register_changeset(%User{}, params) +      assert changeset.valid? +    end +      test "it sets the password_hash and ap_id" do        changeset = User.register_changeset(%User{}, @full_user_data) diff --git a/test/web/activity_pub/mrf/activity_expiration_policy_test.exs b/test/web/activity_pub/mrf/activity_expiration_policy_test.exs index 8babf49e7..f25cf8b12 100644 --- a/test/web/activity_pub/mrf/activity_expiration_policy_test.exs +++ b/test/web/activity_pub/mrf/activity_expiration_policy_test.exs @@ -7,11 +7,13 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do    alias Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicy    @id Pleroma.Web.Endpoint.url() <> "/activities/cofe" +  @local_actor Pleroma.Web.Endpoint.url() <> "/users/cofe"    test "adds `expires_at` property" do      assert {:ok, %{"type" => "Create", "expires_at" => expires_at}} =               ActivityExpirationPolicy.filter(%{                 "id" => @id, +               "actor" => @local_actor,                 "type" => "Create",                 "object" => %{"type" => "Note"}               }) @@ -25,6 +27,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do      assert {:ok, %{"type" => "Create", "expires_at" => ^expires_at}} =               ActivityExpirationPolicy.filter(%{                 "id" => @id, +               "actor" => @local_actor,                 "type" => "Create",                 "expires_at" => expires_at,                 "object" => %{"type" => "Note"} @@ -37,6 +40,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do      assert {:ok, %{"type" => "Create", "expires_at" => expires_at}} =               ActivityExpirationPolicy.filter(%{                 "id" => @id, +               "actor" => @local_actor,                 "type" => "Create",                 "expires_at" => too_distant_future,                 "object" => %{"type" => "Note"} @@ -49,6 +53,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do      assert {:ok, activity} =               ActivityExpirationPolicy.filter(%{                 "id" => "https://example.com/123", +               "actor" => "https://example.com/users/cofe",                 "type" => "Create",                 "object" => %{"type" => "Note"}               }) @@ -60,6 +65,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do      assert {:ok, activity} =               ActivityExpirationPolicy.filter(%{                 "id" => "https://example.com/123", +               "actor" => "https://example.com/users/cofe",                 "type" => "Follow"               }) @@ -68,6 +74,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.ActivityExpirationPolicyTest do      assert {:ok, activity} =               ActivityExpirationPolicy.filter(%{                 "id" => "https://example.com/123", +               "actor" => "https://example.com/users/cofe",                 "type" => "Create",                 "object" => %{"type" => "Cofe"}               }) diff --git a/test/web/activity_pub/mrf/object_age_policy_test.exs b/test/web/activity_pub/mrf/object_age_policy_test.exs index b0fb753bd..cf6acc9a2 100644 --- a/test/web/activity_pub/mrf/object_age_policy_test.exs +++ b/test/web/activity_pub/mrf/object_age_policy_test.exs @@ -38,6 +38,17 @@ defmodule Pleroma.Web.ActivityPub.MRF.ObjectAgePolicyTest do    end    describe "with reject action" do +    test "works with objects with empty to or cc fields" do +      Config.put([:mrf_object_age, :actions], [:reject]) + +      data = +        get_old_message() +        |> Map.put("cc", nil) +        |> Map.put("to", nil) + +      assert match?({:reject, _}, ObjectAgePolicy.filter(data)) +    end +      test "it rejects an old post" do        Config.put([:mrf_object_age, :actions], [:reject]) @@ -56,6 +67,21 @@ defmodule Pleroma.Web.ActivityPub.MRF.ObjectAgePolicyTest do    end    describe "with delist action" do +    test "works with objects with empty to or cc fields" do +      Config.put([:mrf_object_age, :actions], [:delist]) + +      data = +        get_old_message() +        |> Map.put("cc", nil) +        |> Map.put("to", nil) + +      {:ok, _u} = User.get_or_fetch_by_ap_id(data["actor"]) + +      {:ok, data} = ObjectAgePolicy.filter(data) + +      assert Visibility.get_visibility(%{data: data}) == "unlisted" +    end +      test "it delists an old post" do        Config.put([:mrf_object_age, :actions], [:delist]) @@ -80,6 +106,22 @@ defmodule Pleroma.Web.ActivityPub.MRF.ObjectAgePolicyTest do    end    describe "with strip_followers action" do +    test "works with objects with empty to or cc fields" do +      Config.put([:mrf_object_age, :actions], [:strip_followers]) + +      data = +        get_old_message() +        |> Map.put("cc", nil) +        |> Map.put("to", nil) + +      {:ok, user} = User.get_or_fetch_by_ap_id(data["actor"]) + +      {:ok, data} = ObjectAgePolicy.filter(data) + +      refute user.follower_address in data["to"] +      refute user.follower_address in data["cc"] +    end +      test "it strips followers collections from an old post" do        Config.put([:mrf_object_age, :actions], [:strip_followers]) diff --git a/test/web/activity_pub/mrf/simple_policy_test.exs b/test/web/activity_pub/mrf/simple_policy_test.exs index e842d8d8d..d7dde62c4 100644 --- a/test/web/activity_pub/mrf/simple_policy_test.exs +++ b/test/web/activity_pub/mrf/simple_policy_test.exs @@ -7,6 +7,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.SimplePolicyTest do    import Pleroma.Factory    alias Pleroma.Config    alias Pleroma.Web.ActivityPub.MRF.SimplePolicy +  alias Pleroma.Web.CommonAPI    setup do:            clear_config(:mrf_simple, @@ -15,6 +16,7 @@ defmodule Pleroma.Web.ActivityPub.MRF.SimplePolicyTest do              federated_timeline_removal: [],              report_removal: [],              reject: [], +            followers_only: [],              accept: [],              avatar_removal: [],              banner_removal: [], @@ -261,6 +263,64 @@ defmodule Pleroma.Web.ActivityPub.MRF.SimplePolicyTest do      end    end +  describe "when :followers_only" do +    test "is empty" do +      Config.put([:mrf_simple, :followers_only], []) +      {_, ftl_message} = build_ftl_actor_and_message() +      local_message = build_local_message() + +      assert SimplePolicy.filter(ftl_message) == {:ok, ftl_message} +      assert SimplePolicy.filter(local_message) == {:ok, local_message} +    end + +    test "has a matching host" do +      actor = insert(:user) +      following_user = insert(:user) +      non_following_user = insert(:user) + +      {:ok, _, _, _} = CommonAPI.follow(following_user, actor) + +      activity = %{ +        "actor" => actor.ap_id, +        "to" => [ +          "https://www.w3.org/ns/activitystreams#Public", +          following_user.ap_id, +          non_following_user.ap_id +        ], +        "cc" => [actor.follower_address, "http://foo.bar/qux"] +      } + +      dm_activity = %{ +        "actor" => actor.ap_id, +        "to" => [ +          following_user.ap_id, +          non_following_user.ap_id +        ], +        "cc" => [] +      } + +      actor_domain = +        activity +        |> Map.fetch!("actor") +        |> URI.parse() +        |> Map.fetch!(:host) + +      Config.put([:mrf_simple, :followers_only], [actor_domain]) + +      assert {:ok, new_activity} = SimplePolicy.filter(activity) +      assert actor.follower_address in new_activity["cc"] +      assert following_user.ap_id in new_activity["to"] +      refute "https://www.w3.org/ns/activitystreams#Public" in new_activity["to"] +      refute "https://www.w3.org/ns/activitystreams#Public" in new_activity["cc"] +      refute non_following_user.ap_id in new_activity["to"] +      refute non_following_user.ap_id in new_activity["cc"] + +      assert {:ok, new_dm_activity} = SimplePolicy.filter(dm_activity) +      assert new_dm_activity["to"] == [following_user.ap_id] +      assert new_dm_activity["cc"] == [] +    end +  end +    describe "when :accept" do      test "is empty" do        Config.put([:mrf_simple, :accept], []) diff --git a/test/web/activity_pub/transmogrifier/chat_message_test.exs b/test/web/activity_pub/transmogrifier/chat_message_test.exs index d6736dc3e..31274c067 100644 --- a/test/web/activity_pub/transmogrifier/chat_message_test.exs +++ b/test/web/activity_pub/transmogrifier/chat_message_test.exs @@ -124,6 +124,24 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier.ChatMessageTest do        {:ok, %Activity{} = _activity} = Transmogrifier.handle_incoming(data)      end +    test "it doesn't work for deactivated users" do +      data = +        File.read!("test/fixtures/create-chat-message.json") +        |> Poison.decode!() + +      _author = +        insert(:user, +          ap_id: data["actor"], +          local: false, +          last_refreshed_at: DateTime.utc_now(), +          deactivated: true +        ) + +      _recipient = insert(:user, ap_id: List.first(data["to"]), local: true) + +      assert {:error, _} = Transmogrifier.handle_incoming(data) +    end +      test "it inserts it and creates a chat" do        data =          File.read!("test/fixtures/create-chat-message.json") diff --git a/test/web/activity_pub/transmogrifier_test.exs b/test/web/activity_pub/transmogrifier_test.exs index 7d33feaf2..828964a36 100644 --- a/test/web/activity_pub/transmogrifier_test.exs +++ b/test/web/activity_pub/transmogrifier_test.exs @@ -163,6 +163,14 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do               end) =~ "[warn] Couldn't fetch \"https://404.site/whatever\", error: nil"      end +    test "it does not work for deactivated users" do +      data = File.read!("test/fixtures/mastodon-post-activity.json") |> Poison.decode!() + +      insert(:user, ap_id: data["actor"], deactivated: true) + +      assert {:error, _} = Transmogrifier.handle_incoming(data) +    end +      test "it works for incoming notices" do        data = File.read!("test/fixtures/mastodon-post-activity.json") |> Poison.decode!() diff --git a/test/web/common_api/common_api_test.exs b/test/web/common_api/common_api_test.exs index 313dda21b..4ba6232dc 100644 --- a/test/web/common_api/common_api_test.exs +++ b/test/web/common_api/common_api_test.exs @@ -458,6 +458,11 @@ defmodule Pleroma.Web.CommonAPITest do    end    describe "posting" do +    test "deactivated users can't post" do +      user = insert(:user, deactivated: true) +      assert {:error, _} = CommonAPI.post(user, %{status: "ye"}) +    end +      test "it supports explicit addressing" do        user = insert(:user)        user_two = insert(:user) diff --git a/test/web/mastodon_api/controllers/account_controller_test.exs b/test/web/mastodon_api/controllers/account_controller_test.exs index d390c3ce1..17a1e7d66 100644 --- a/test/web/mastodon_api/controllers/account_controller_test.exs +++ b/test/web/mastodon_api/controllers/account_controller_test.exs @@ -940,17 +940,32 @@ defmodule Pleroma.Web.MastodonAPI.AccountControllerTest do        assert refresh        assert scope == "read write follow" +      clear_config([User, :email_blacklist], ["example.org"]) + +      params = %{ +        username: "lain", +        email: "lain@example.org", +        password: "PlzDontHackLain", +        bio: "Test Bio", +        agreement: true +      } +        conn =          build_conn()          |> put_req_header("content-type", "multipart/form-data")          |> put_req_header("authorization", "Bearer " <> token) -        |> post("/api/v1/accounts", %{ -          username: "lain", -          email: "lain@example.org", -          password: "PlzDontHackLain", -          bio: "Test Bio", -          agreement: true -        }) +        |> post("/api/v1/accounts", params) + +      assert %{"error" => "{\"email\":[\"Invalid email\"]}"} = +               json_response_and_validate_schema(conn, 400) + +      Pleroma.Config.put([User, :email_blacklist], []) + +      conn = +        build_conn() +        |> put_req_header("content-type", "multipart/form-data") +        |> put_req_header("authorization", "Bearer " <> token) +        |> post("/api/v1/accounts", params)        %{          "access_token" => token, diff --git a/test/web/mastodon_api/mastodon_api_test.exs b/test/web/mastodon_api/mastodon_api_test.exs index c08be37d4..0c5a38bf6 100644 --- a/test/web/mastodon_api/mastodon_api_test.exs +++ b/test/web/mastodon_api/mastodon_api_test.exs @@ -17,8 +17,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPITest do      test "returns error when followed user is deactivated" do        follower = insert(:user)        user = insert(:user, local: true, deactivated: true) -      {:error, error} = MastodonAPI.follow(follower, user) -      assert error == :rejected +      assert {:error, _error} = MastodonAPI.follow(follower, user)      end      test "following for user" do diff --git a/test/web/oauth/app_test.exs b/test/web/oauth/app_test.exs index 899af648e..993a490e0 100644 --- a/test/web/oauth/app_test.exs +++ b/test/web/oauth/app_test.exs @@ -29,5 +29,16 @@ defmodule Pleroma.Web.OAuth.AppTest do        assert exist_app.id == app.id        assert exist_app.scopes == ["read", "write", "follow", "push"]      end + +    test "has unique client_id" do +      insert(:oauth_app, client_name: "", redirect_uris: "", client_id: "boop") + +      error = +        catch_error(insert(:oauth_app, client_name: "", redirect_uris: "", client_id: "boop")) + +      assert %Ecto.ConstraintError{} = error +      assert error.constraint == "apps_client_id_index" +      assert error.type == :unique +    end    end  end | 
