1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Web.AdminAPI.OAuthAppControllerTest do
6 use Pleroma.Web.ConnCase, async: true
7 use Oban.Testing, repo: Pleroma.Repo
15 admin = insert(:user, is_admin: true)
16 token = insert(:oauth_admin_token, user: admin)
20 |> assign(:user, admin)
21 |> assign(:token, token)
23 {:ok, %{admin: admin, token: token, conn: conn}}
26 describe "POST /api/pleroma/admin/oauth_app" do
27 test "errors", %{conn: conn} do
30 |> put_req_header("content-type", "application/json")
31 |> post("/api/pleroma/admin/oauth_app", %{})
32 |> json_response_and_validate_schema(400)
35 "error" => "Missing field: name. Missing field: redirect_uris."
39 test "success", %{conn: conn} do
40 base_url = Web.base_url()
41 app_name = "Trusted app"
45 |> put_req_header("content-type", "application/json")
46 |> post("/api/pleroma/admin/oauth_app", %{
48 redirect_uris: base_url
50 |> json_response_and_validate_schema(200)
56 "redirect_uri" => ^base_url,
61 test "with trusted", %{conn: conn} do
62 base_url = Web.base_url()
63 app_name = "Trusted app"
67 |> put_req_header("content-type", "application/json")
68 |> post("/api/pleroma/admin/oauth_app", %{
70 redirect_uris: base_url,
73 |> json_response_and_validate_schema(200)
79 "redirect_uri" => ^base_url,
85 describe "GET /api/pleroma/admin/oauth_app" do
87 app = insert(:oauth_app)
91 test "list", %{conn: conn} do
94 |> get("/api/pleroma/admin/oauth_app")
95 |> json_response_and_validate_schema(200)
97 assert %{"apps" => apps, "count" => count, "page_size" => _} = response
99 assert length(apps) == count
102 test "with page size", %{conn: conn} do
108 |> get("/api/pleroma/admin/oauth_app?page_size=#{page_size}")
109 |> json_response_and_validate_schema(200)
111 assert %{"apps" => apps, "count" => _, "page_size" => ^page_size} = response
113 assert length(apps) == page_size
116 test "search by client name", %{conn: conn, app: app} do
119 |> get("/api/pleroma/admin/oauth_app?name=#{app.client_name}")
120 |> json_response_and_validate_schema(200)
122 assert %{"apps" => [returned], "count" => _, "page_size" => _} = response
124 assert returned["client_id"] == app.client_id
125 assert returned["name"] == app.client_name
128 test "search by client id", %{conn: conn, app: app} do
131 |> get("/api/pleroma/admin/oauth_app?client_id=#{app.client_id}")
132 |> json_response_and_validate_schema(200)
134 assert %{"apps" => [returned], "count" => _, "page_size" => _} = response
136 assert returned["client_id"] == app.client_id
137 assert returned["name"] == app.client_name
140 test "only trusted", %{conn: conn} do
141 app = insert(:oauth_app, trusted: true)
145 |> get("/api/pleroma/admin/oauth_app?trusted=true")
146 |> json_response_and_validate_schema(200)
148 assert %{"apps" => [returned], "count" => _, "page_size" => _} = response
150 assert returned["client_id"] == app.client_id
151 assert returned["name"] == app.client_name
155 describe "DELETE /api/pleroma/admin/oauth_app/:id" do
156 test "with id", %{conn: conn} do
157 app = insert(:oauth_app)
161 |> delete("/api/pleroma/admin/oauth_app/" <> to_string(app.id))
162 |> json_response_and_validate_schema(:no_content)
164 assert response == ""
167 test "with non existance id", %{conn: conn} do
170 |> delete("/api/pleroma/admin/oauth_app/0")
171 |> json_response_and_validate_schema(:bad_request)
173 assert response == ""
177 describe "PATCH /api/pleroma/admin/oauth_app/:id" do
178 test "with id", %{conn: conn} do
179 app = insert(:oauth_app)
181 name = "another name"
182 url = "https://example.com"
185 website = "http://website.com"
189 |> put_req_header("content-type", "application/json")
190 |> patch("/api/pleroma/admin/oauth_app/#{id}", %{
197 |> json_response_and_validate_schema(200)
201 "client_secret" => _,
204 "redirect_uri" => ^url,
206 "website" => ^website
210 test "without id", %{conn: conn} do
213 |> put_req_header("content-type", "application/json")
214 |> patch("/api/pleroma/admin/oauth_app/0")
215 |> json_response_and_validate_schema(:bad_request)
217 assert response == ""