1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.MastodonAPI.MastoFEController do
6 use Pleroma.Web.ConnCase
11 import Pleroma.Factory
13 clear_config([:instance, :public])
15 test "put settings", %{conn: conn} do
20 |> assign(:user, user)
21 |> put("/api/web/settings", %{"data" => %{"programming" => "socks"}})
23 assert _result = json_response(conn, 200)
25 user = User.get_cached_by_ap_id(user.ap_id)
26 assert user.info.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 Config.put([: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 token = insert(:oauth_token)
70 |> assign(:user, token.user)
71 |> put_session(:oauth_token, token.token)
74 assert conn.status == 200
77 test "saves referer path to session", %{conn: conn, path: path} do
78 conn = get(conn, path)
79 return_to = Plug.Conn.get_session(conn, :return_to)
81 assert return_to == path