1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.MastodonAPI.MastoFEControllerTest do
6 use Pleroma.Web.ConnCase
10 import Pleroma.Factory
12 setup do: clear_config([:instance, :public])
14 test "put settings", %{conn: conn} do
19 |> assign(:user, user)
20 |> assign(:token, insert(:oauth_token, user: user, scopes: ["write:accounts"]))
21 |> put("/api/web/settings", %{"data" => %{"programming" => "socks"}})
23 assert %{} = json_response(conn, 200)
25 user = User.get_cached_by_ap_id(user.ap_id)
26 assert user.mastofe_settings == %{"programming" => "socks"}
29 describe "index/2 redirections" do
30 setup %{conn: conn} do
34 signing_salt: "cooldude"
39 |> Plug.Session.call(Plug.Session.init(session_opts))
42 test_path = "/web/statuses/test"
43 %{conn: conn, path: test_path}
46 test "redirects not logged-in users to the login page", %{conn: conn, path: path} do
47 conn = get(conn, path)
49 assert conn.status == 302
50 assert redirected_to(conn) == "/web/login"
53 test "redirects not logged-in users to the login page on private instances", %{
57 clear_config([:instance, :public], false)
59 conn = get(conn, path)
61 assert conn.status == 302
62 assert redirected_to(conn) == "/web/login"
65 test "does not redirect logged in users to the login page", %{conn: conn, path: path} do
66 {:ok, app} = Pleroma.Web.MastodonAPI.AuthController.local_mastofe_app()
67 token = insert(:oauth_token, app: app, scopes: ["read"])
71 |> assign(:user, token.user)
72 |> assign(:token, token)
75 assert conn.status == 200
78 test "saves referer path to session", %{conn: conn, path: path} do
79 conn = get(conn, path)
80 return_to = Plug.Conn.get_session(conn, :return_to)
82 assert return_to == path