2020-02-12 00:51:05 +04:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-13 07:49:20 +01:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2020-02-12 00:51:05 +04:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.Web.TwitterAPI.ControllerTest do
|
2023-08-01 11:43:50 +01:00
|
|
|
use Pleroma.Web.ConnCase, async: false
|
2020-02-12 00:51:05 +04:00
|
|
|
|
|
|
|
alias Pleroma.Repo
|
|
|
|
alias Pleroma.User
|
|
|
|
alias Pleroma.Web.OAuth.Token
|
|
|
|
|
|
|
|
import Pleroma.Factory
|
|
|
|
|
|
|
|
describe "GET /api/account/confirm_email/:id/:token" do
|
|
|
|
setup do
|
|
|
|
{:ok, user} =
|
|
|
|
insert(:user)
|
2020-10-13 16:07:36 -05:00
|
|
|
|> User.confirmation_changeset(set_confirmation: false)
|
2020-02-12 00:51:05 +04:00
|
|
|
|> Repo.update()
|
|
|
|
|
2020-10-13 14:29:34 -05:00
|
|
|
refute user.is_confirmed
|
2020-02-12 00:51:05 +04:00
|
|
|
|
|
|
|
[user: user]
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it redirects to root url", %{conn: conn, user: user} do
|
|
|
|
conn = get(conn, "/api/account/confirm_email/#{user.id}/#{user.confirmation_token}")
|
|
|
|
|
|
|
|
assert 302 == conn.status
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it confirms the user account", %{conn: conn, user: user} do
|
|
|
|
get(conn, "/api/account/confirm_email/#{user.id}/#{user.confirmation_token}")
|
|
|
|
|
|
|
|
user = User.get_cached_by_id(user.id)
|
|
|
|
|
2020-10-13 14:29:34 -05:00
|
|
|
assert user.is_confirmed
|
2020-02-12 00:51:05 +04:00
|
|
|
refute user.confirmation_token
|
|
|
|
end
|
|
|
|
|
2023-01-12 21:14:42 +01:00
|
|
|
test "confirmation is requested twice", %{conn: conn, user: user} do
|
|
|
|
conn = get(conn, "/api/account/confirm_email/#{user.id}/#{user.confirmation_token}")
|
|
|
|
assert 302 == conn.status
|
|
|
|
|
|
|
|
conn = get(conn, "/api/account/confirm_email/#{user.id}/#{user.confirmation_token}")
|
|
|
|
assert 400 == conn.status
|
|
|
|
assert "Already verified email" == conn.resp_body
|
|
|
|
|
|
|
|
user = User.get_cached_by_id(user.id)
|
|
|
|
|
|
|
|
assert user.is_confirmed
|
|
|
|
refute user.confirmation_token
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it returns 400 if user cannot be found by id", %{conn: conn, user: user} do
|
2020-02-12 00:51:05 +04:00
|
|
|
conn = get(conn, "/api/account/confirm_email/0/#{user.confirmation_token}")
|
|
|
|
|
2023-01-12 21:14:42 +01:00
|
|
|
assert 400 == conn.status
|
2020-02-12 00:51:05 +04:00
|
|
|
end
|
|
|
|
|
2023-01-12 21:14:42 +01:00
|
|
|
test "it returns 400 if token is invalid", %{conn: conn, user: user} do
|
2020-02-12 00:51:05 +04:00
|
|
|
conn = get(conn, "/api/account/confirm_email/#{user.id}/wrong_token")
|
|
|
|
|
2023-01-12 21:14:42 +01:00
|
|
|
assert 400 == conn.status
|
2020-02-12 00:51:05 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET /api/oauth_tokens" do
|
|
|
|
setup do
|
|
|
|
token = insert(:oauth_token) |> Repo.preload(:user)
|
|
|
|
|
|
|
|
%{token: token}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "renders list", %{token: token} do
|
|
|
|
response =
|
|
|
|
build_conn()
|
|
|
|
|> assign(:user, token.user)
|
|
|
|
|> get("/api/oauth_tokens")
|
|
|
|
|
|
|
|
keys =
|
|
|
|
json_response(response, 200)
|
|
|
|
|> hd()
|
|
|
|
|> Map.keys()
|
|
|
|
|
|
|
|
assert keys -- ["id", "app_name", "valid_until"] == []
|
|
|
|
end
|
|
|
|
|
|
|
|
test "revoke token", %{token: token} do
|
|
|
|
response =
|
|
|
|
build_conn()
|
|
|
|
|> assign(:user, token.user)
|
|
|
|
|> delete("/api/oauth_tokens/#{token.id}")
|
|
|
|
|
|
|
|
tokens = Token.get_user_tokens(token.user)
|
|
|
|
|
|
|
|
assert tokens == []
|
|
|
|
assert response.status == 201
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|