Move single used schemas to operation schema
This commit is contained in:
parent
2efc00b3cf
commit
dda65f7799
21 changed files with 402 additions and 604 deletions
|
|
@ -1,141 +0,0 @@
|
|||
# Pleroma: A lightweight social networking server
|
||||
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||
# SPDX-License-Identifier: AGPL-3.0-only
|
||||
|
||||
defmodule Pleroma.Web.ApiSpec.AccountOperationTest do
|
||||
use Pleroma.Web.ConnCase
|
||||
|
||||
alias Pleroma.Web.ApiSpec
|
||||
alias Pleroma.Web.ApiSpec.Schemas.Account
|
||||
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateRequest
|
||||
alias Pleroma.Web.ApiSpec.Schemas.AccountCreateResponse
|
||||
alias Pleroma.Web.ApiSpec.Schemas.AccountRelationshipsResponse
|
||||
alias Pleroma.Web.ApiSpec.Schemas.AccountUpdateCredentialsRequest
|
||||
|
||||
import OpenApiSpex.TestAssertions
|
||||
import Pleroma.Factory
|
||||
|
||||
test "Account example matches schema" do
|
||||
api_spec = ApiSpec.spec()
|
||||
schema = Account.schema()
|
||||
assert_schema(schema.example, "Account", api_spec)
|
||||
end
|
||||
|
||||
test "AccountCreateRequest example matches schema" do
|
||||
api_spec = ApiSpec.spec()
|
||||
schema = AccountCreateRequest.schema()
|
||||
assert_schema(schema.example, "AccountCreateRequest", api_spec)
|
||||
end
|
||||
|
||||
test "AccountCreateResponse example matches schema" do
|
||||
api_spec = ApiSpec.spec()
|
||||
schema = AccountCreateResponse.schema()
|
||||
assert_schema(schema.example, "AccountCreateResponse", api_spec)
|
||||
end
|
||||
|
||||
test "AccountUpdateCredentialsRequest example matches schema" do
|
||||
api_spec = ApiSpec.spec()
|
||||
schema = AccountUpdateCredentialsRequest.schema()
|
||||
assert_schema(schema.example, "AccountUpdateCredentialsRequest", api_spec)
|
||||
end
|
||||
|
||||
test "AccountController produces a AccountCreateResponse", %{conn: conn} do
|
||||
api_spec = ApiSpec.spec()
|
||||
app_token = insert(:oauth_token, user: nil)
|
||||
|
||||
json =
|
||||
conn
|
||||
|> put_req_header("authorization", "Bearer " <> app_token.token)
|
||||
|> put_req_header("content-type", "application/json")
|
||||
|> post(
|
||||
"/api/v1/accounts",
|
||||
%{
|
||||
username: "foo",
|
||||
email: "bar@example.org",
|
||||
password: "qwerty",
|
||||
agreement: true
|
||||
}
|
||||
)
|
||||
|> json_response(200)
|
||||
|
||||
assert_schema(json, "AccountCreateResponse", api_spec)
|
||||
end
|
||||
|
||||
test "AccountUpdateCredentialsRequest produces an Account", %{conn: conn} do
|
||||
api_spec = ApiSpec.spec()
|
||||
token = insert(:oauth_token, scopes: ["read", "write"])
|
||||
|
||||
json =
|
||||
conn
|
||||
|> put_req_header("authorization", "Bearer " <> token.token)
|
||||
|> put_req_header("content-type", "application/json")
|
||||
|> patch(
|
||||
"/api/v1/accounts/update_credentials",
|
||||
%{
|
||||
hide_followers_count: "true",
|
||||
hide_follows_count: "true",
|
||||
skip_thread_containment: "true",
|
||||
hide_follows: "true",
|
||||
pleroma_settings_store: %{"pleroma-fe" => %{"key" => "val"}},
|
||||
note: "foobar",
|
||||
fields_attributes: [%{name: "foo", value: "bar"}]
|
||||
}
|
||||
)
|
||||
|> json_response(200)
|
||||
|
||||
assert_schema(json, "Account", api_spec)
|
||||
end
|
||||
|
||||
test "AccountRelationshipsResponse example matches schema" do
|
||||
api_spec = ApiSpec.spec()
|
||||
schema = AccountRelationshipsResponse.schema()
|
||||
assert_schema(schema.example, "AccountRelationshipsResponse", api_spec)
|
||||
end
|
||||
|
||||
test "/api/v1/accounts/relationships produces AccountRelationshipsResponse", %{
|
||||
conn: conn
|
||||
} do
|
||||
token = insert(:oauth_token, scopes: ["read", "write"])
|
||||
other_user = insert(:user)
|
||||
{:ok, _user} = Pleroma.User.follow(token.user, other_user)
|
||||
api_spec = ApiSpec.spec()
|
||||
|
||||
assert [relationship] =
|
||||
conn
|
||||
|> put_req_header("authorization", "Bearer " <> token.token)
|
||||
|> get("/api/v1/accounts/relationships?id=#{other_user.id}")
|
||||
|> json_response(:ok)
|
||||
|
||||
assert_schema([relationship], "AccountRelationshipsResponse", api_spec)
|
||||
end
|
||||
|
||||
test "/api/v1/accounts/:id produces Account", %{
|
||||
conn: conn
|
||||
} do
|
||||
user = insert(:user)
|
||||
api_spec = ApiSpec.spec()
|
||||
|
||||
assert resp =
|
||||
conn
|
||||
|> get("/api/v1/accounts/#{user.id}")
|
||||
|> json_response(:ok)
|
||||
|
||||
assert_schema(resp, "Account", api_spec)
|
||||
end
|
||||
|
||||
test "/api/v1/accounts/:id/statuses produces StatusesResponse", %{
|
||||
conn: conn
|
||||
} do
|
||||
user = insert(:user)
|
||||
Pleroma.Web.CommonAPI.post(user, %{"status" => "foobar"})
|
||||
|
||||
api_spec = ApiSpec.spec()
|
||||
|
||||
assert resp =
|
||||
conn
|
||||
|> get("/api/v1/accounts/#{user.id}/statuses")
|
||||
|> json_response(:ok)
|
||||
|
||||
assert_schema(resp, "StatusesResponse", api_spec)
|
||||
end
|
||||
end
|
||||
|
|
@ -4,8 +4,6 @@
|
|||
|
||||
defmodule Pleroma.Web.MastodonAPI.CustomEmojiControllerTest do
|
||||
use Pleroma.Web.ConnCase, async: true
|
||||
alias Pleroma.Web.ApiSpec
|
||||
import OpenApiSpex.TestAssertions
|
||||
|
||||
test "with tags", %{conn: conn} do
|
||||
assert resp =
|
||||
|
|
@ -21,6 +19,5 @@ defmodule Pleroma.Web.MastodonAPI.CustomEmojiControllerTest do
|
|||
assert Map.has_key?(emoji, "category")
|
||||
assert Map.has_key?(emoji, "url")
|
||||
assert Map.has_key?(emoji, "visible_in_picker")
|
||||
assert_schema(emoji, "CustomEmoji", ApiSpec.spec())
|
||||
end
|
||||
end
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue