aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/pleroma/user_test.exs21
-rw-r--r--test/pleroma/web/mastodon_api/controllers/account_controller_test.exs15
-rw-r--r--test/pleroma/web/mastodon_api/update_credentials_test.exs7
-rw-r--r--test/pleroma/web/twitter_api/twitter_api_test.exs14
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)