diff options
| author | lain <lain@soykaf.club> | 2020-07-29 11:27:26 +0000 | 
|---|---|---|
| committer | lain <lain@soykaf.club> | 2020-07-29 11:27:26 +0000 | 
| commit | 79f9ddd8b725519f719219b70b8dd8558d5212cf (patch) | |
| tree | 24f6940744d9d832ea3ab2747e7d1c2fe890fb3a /test/web/mastodon_api/controllers | |
| parent | 93dbba9b8a5aacbbf43a45a07e27b328579eabf8 (diff) | |
| parent | f688c8df82b955b50552b3198ddc153a716451c2 (diff) | |
| download | pleroma-79f9ddd8b725519f719219b70b8dd8558d5212cf.tar.gz pleroma-79f9ddd8b725519f719219b70b8dd8558d5212cf.zip | |
Merge branch 'by-approval' into 'develop'
Registrations "by approval" mode
Closes #1931
See merge request pleroma/pleroma!2757
Diffstat (limited to 'test/web/mastodon_api/controllers')
| -rw-r--r-- | test/web/mastodon_api/controllers/account_controller_test.exs | 70 | ||||
| -rw-r--r-- | test/web/mastodon_api/controllers/instance_controller_test.exs | 1 | 
2 files changed, 71 insertions, 0 deletions
| diff --git a/test/web/mastodon_api/controllers/account_controller_test.exs b/test/web/mastodon_api/controllers/account_controller_test.exs index c304487ea..e6b283aab 100644 --- a/test/web/mastodon_api/controllers/account_controller_test.exs +++ b/test/web/mastodon_api/controllers/account_controller_test.exs @@ -904,6 +904,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountControllerTest do      end      setup do: clear_config([:instance, :account_activation_required]) +    setup do: clear_config([:instance, :account_approval_required])      test "Account registration via Application", %{conn: conn} do        conn = @@ -968,6 +969,75 @@ defmodule Pleroma.Web.MastodonAPI.AccountControllerTest do        assert token_from_db.user.confirmation_pending      end +    test "Account registration via app with account_approval_required", %{conn: conn} do +      Pleroma.Config.put([:instance, :account_approval_required], true) + +      conn = +        conn +        |> put_req_header("content-type", "application/json") +        |> post("/api/v1/apps", %{ +          client_name: "client_name", +          redirect_uris: "urn:ietf:wg:oauth:2.0:oob", +          scopes: "read, write, follow" +        }) + +      assert %{ +               "client_id" => client_id, +               "client_secret" => client_secret, +               "id" => _, +               "name" => "client_name", +               "redirect_uri" => "urn:ietf:wg:oauth:2.0:oob", +               "vapid_key" => _, +               "website" => nil +             } = json_response_and_validate_schema(conn, 200) + +      conn = +        post(conn, "/oauth/token", %{ +          grant_type: "client_credentials", +          client_id: client_id, +          client_secret: client_secret +        }) + +      assert %{"access_token" => token, "refresh_token" => refresh, "scope" => scope} = +               json_response(conn, 200) + +      assert token +      token_from_db = Repo.get_by(Token, token: token) +      assert token_from_db +      assert refresh +      assert scope == "read write follow" + +      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, +          reason: "I'm a cool dude, bro" +        }) + +      %{ +        "access_token" => token, +        "created_at" => _created_at, +        "scope" => ^scope, +        "token_type" => "Bearer" +      } = json_response_and_validate_schema(conn, 200) + +      token_from_db = Repo.get_by(Token, token: token) +      assert token_from_db +      token_from_db = Repo.preload(token_from_db, :user) +      assert token_from_db.user + +      assert token_from_db.user.confirmation_pending +      assert token_from_db.user.approval_pending + +      assert token_from_db.user.registration_reason == "I'm a cool dude, bro" +    end +      test "returns error when user already registred", %{conn: conn, valid_params: valid_params} do        _user = insert(:user, email: "lain@example.org")        app_token = insert(:oauth_token, user: nil) diff --git a/test/web/mastodon_api/controllers/instance_controller_test.exs b/test/web/mastodon_api/controllers/instance_controller_test.exs index cc880d82c..6a9ccd979 100644 --- a/test/web/mastodon_api/controllers/instance_controller_test.exs +++ b/test/web/mastodon_api/controllers/instance_controller_test.exs @@ -27,6 +27,7 @@ defmodule Pleroma.Web.MastodonAPI.InstanceControllerTest do               "thumbnail" => _,               "languages" => _,               "registrations" => _, +             "approval_required" => _,               "poll_limits" => _,               "upload_limit" => _,               "avatar_upload_limit" => _, | 
