diff options
Diffstat (limited to 'test')
4 files changed, 57 insertions, 0 deletions
diff --git a/test/pleroma/user_test.exs b/test/pleroma/user_test.exs index 6f5bcab57..2cfd54d52 100644 --- a/test/pleroma/user_test.exs +++ b/test/pleroma/user_test.exs @@ -663,6 +663,16 @@ defmodule Pleroma.UserTest do assert user.is_confirmed end + + test "it sets 'accepts_newsletter'" do + params = Map.put_new(@full_user_data, :accepts_newsletter, true) + changeset = User.register_changeset(%User{}, params) + assert changeset.valid? + + {:ok, user} = Repo.insert(changeset) + + assert user.accepts_newsletter + end end describe "user registration, with :account_activation_required" do @@ -737,6 +747,17 @@ defmodule Pleroma.UserTest do end end + describe "update_changeset/2" do + test "it sets :accepts_newsletter" do + changeset = + %User{accepts_newsletter: false} + |> User.update_changeset(%{accepts_newsletter: true}) + + assert changeset.valid? + assert %User{accepts_newsletter: true} = Ecto.Changeset.apply_changes(changeset) + end + end + describe "get_or_fetch/1" do test "gets an existing user by nickname" do user = insert(:user) diff --git a/test/pleroma/web/mastodon_api/controllers/account_controller_test.exs b/test/pleroma/web/mastodon_api/controllers/account_controller_test.exs index a327c0d1d..3558394fd 100644 --- a/test/pleroma/web/mastodon_api/controllers/account_controller_test.exs +++ b/test/pleroma/web/mastodon_api/controllers/account_controller_test.exs @@ -1125,6 +1125,7 @@ defmodule Pleroma.Web.MastodonAPI.AccountControllerTest do assert user assert user.is_confirmed assert user.is_approved + refute user.accepts_newsletter end test "registers but does not log in with :account_activation_required", %{conn: conn} do @@ -1356,6 +1357,20 @@ defmodule Pleroma.Web.MastodonAPI.AccountControllerTest do assert json_response_and_validate_schema(res, 200) end + test "registration with accepts_newsletter", %{conn: conn, valid_params: valid_params} do + app_token = insert(:oauth_token, user: nil) + conn = put_req_header(conn, "authorization", "Bearer " <> app_token.token) + + res = + conn + |> put_req_header("content-type", "application/json") + |> Map.put(:remote_ip, {127, 0, 0, 9}) + |> post("/api/v1/accounts", Map.put(valid_params, :accepts_newsletter, true)) + + assert json_response_and_validate_schema(res, 200) + assert %User{accepts_newsletter: true} = Repo.get_by(User, email: "lain@example.org") + end + test "returns forbidden if token is invalid", %{conn: conn, valid_params: valid_params} do res = conn diff --git a/test/pleroma/web/mastodon_api/update_credentials_test.exs b/test/pleroma/web/mastodon_api/update_credentials_test.exs index cfbe6cf0e..21917e282 100644 --- a/test/pleroma/web/mastodon_api/update_credentials_test.exs +++ b/test/pleroma/web/mastodon_api/update_credentials_test.exs @@ -113,6 +113,13 @@ defmodule Pleroma.Web.MastodonAPI.UpdateCredentialsTest do assert user_data["pleroma"]["accepts_chat_messages"] == false end + test "updates the user's newsletter preference", %{user: user, conn: conn} do + conn = patch(conn, "/api/v1/accounts/update_credentials", %{accepts_newsletter: "true"}) + + assert json_response_and_validate_schema(conn, 200) + assert %User{accepts_newsletter: true} = User.get_by_id(user.id) + end + test "updates the user's allow_following_move", %{user: user, conn: conn} do assert user.allow_following_move == true diff --git a/test/pleroma/web/twitter_api/twitter_api_test.exs b/test/pleroma/web/twitter_api/twitter_api_test.exs index 85629be04..295a57d71 100644 --- a/test/pleroma/web/twitter_api/twitter_api_test.exs +++ b/test/pleroma/web/twitter_api/twitter_api_test.exs @@ -146,6 +146,20 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do assert user2.bio == expected_text end + test "it registers a new user with accepts_newsletter." do + data = %{ + :username => "lain", + :email => "lain@wired.jp", + :fullname => "lain iwakura", + :password => "bear", + :confirm => "bear", + :accepts_newsletter => true + } + + {:ok, user} = TwitterAPI.register_user(data) + assert user.accepts_newsletter + end + describe "register with one time token" do setup do: clear_config([:instance, :registrations_open], false) |