# Pleroma: A lightweight social networking server # Copyright © 2017-2021 Pleroma Authors # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.TwitterAPI.ControllerTest do use Pleroma.Web.ConnCase, async: true 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) |> User.confirmation_changeset(set_confirmation: false) |> Repo.update() refute user.is_confirmed [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) assert user.is_confirmed refute user.confirmation_token end 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 conn = get(conn, "/api/account/confirm_email/0/#{user.confirmation_token}") assert 400 == conn.status end test "it returns 400 if token is invalid", %{conn: conn, user: user} do conn = get(conn, "/api/account/confirm_email/#{user.id}/wrong_token") assert 400 == conn.status 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