2018-12-23 21:11:29 +01:00
|
|
|
# Pleroma: A lightweight social networking server
|
2019-01-09 13:54:37 +01:00
|
|
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
2018-12-23 21:11:29 +01:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2017-09-09 13:15:01 +02:00
|
|
|
defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do
|
|
|
|
use Pleroma.Web.ConnCase
|
|
|
|
|
2019-03-05 03:52:23 +01:00
|
|
|
alias Ecto.Changeset
|
2019-08-13 23:12:37 +02:00
|
|
|
alias Pleroma.Config
|
2019-02-10 22:57:38 +01:00
|
|
|
alias Pleroma.Notification
|
2019-03-05 03:52:23 +01:00
|
|
|
alias Pleroma.Repo
|
2019-08-14 20:42:21 +02:00
|
|
|
alias Pleroma.Tests.ObanHelpers
|
2019-03-05 03:52:23 +01:00
|
|
|
alias Pleroma.User
|
|
|
|
alias Pleroma.Web.CommonAPI
|
2019-09-26 05:53:42 +02:00
|
|
|
|
|
|
|
import Pleroma.Factory
|
2019-07-16 23:44:50 +02:00
|
|
|
import Swoosh.TestAssertions
|
2019-09-26 05:53:42 +02:00
|
|
|
import Tesla.Mock
|
2018-12-03 19:37:55 +01:00
|
|
|
|
|
|
|
setup do
|
|
|
|
mock(fn env -> apply(HttpRequestMock, :request, [env]) end)
|
|
|
|
:ok
|
|
|
|
end
|
2017-09-09 13:15:01 +02:00
|
|
|
|
2019-08-19 17:34:29 +02:00
|
|
|
clear_config([:instance, :public])
|
|
|
|
clear_config([:rich_media, :enabled])
|
|
|
|
|
2018-09-01 23:34:15 +02:00
|
|
|
test "getting a list of mutes", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
other_user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, user} = User.mute(user, other_user)
|
|
|
|
|
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/mutes")
|
|
|
|
|
|
|
|
other_user_id = to_string(other_user.id)
|
|
|
|
assert [%{"id" => ^other_user_id}] = json_response(conn, 200)
|
|
|
|
end
|
|
|
|
|
2017-11-03 08:51:17 +01:00
|
|
|
test "getting a list of blocks", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
other_user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, user} = User.block(user, other_user)
|
|
|
|
|
2018-03-30 15:01:53 +02:00
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/blocks")
|
2017-11-03 08:51:17 +01:00
|
|
|
|
2017-11-10 17:18:19 +01:00
|
|
|
other_user_id = to_string(other_user.id)
|
2017-11-03 08:51:17 +01:00
|
|
|
assert [%{"id" => ^other_user_id}] = json_response(conn, 200)
|
|
|
|
end
|
|
|
|
|
2018-09-01 23:34:15 +02:00
|
|
|
test "unimplemented follow_requests, blocks, domain blocks" do
|
2017-09-14 18:30:05 +02:00
|
|
|
user = insert(:user)
|
|
|
|
|
2018-09-01 23:34:15 +02:00
|
|
|
["blocks", "domain_blocks", "follow_requests"]
|
2018-03-30 15:01:53 +02:00
|
|
|
|> Enum.each(fn endpoint ->
|
|
|
|
conn =
|
|
|
|
build_conn()
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/#{endpoint}")
|
2017-09-14 18:30:05 +02:00
|
|
|
|
|
|
|
assert [] = json_response(conn, 200)
|
|
|
|
end)
|
|
|
|
end
|
2017-09-16 10:42:24 +02:00
|
|
|
|
2017-09-17 13:09:49 +02:00
|
|
|
test "returns the favorites of a user", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
other_user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, _} = CommonAPI.post(other_user, %{"status" => "bla"})
|
|
|
|
{:ok, activity} = CommonAPI.post(other_user, %{"status" => "traps are happy"})
|
|
|
|
|
|
|
|
{:ok, _, _} = CommonAPI.favorite(activity.id, user)
|
|
|
|
|
2019-01-13 16:17:47 +01:00
|
|
|
first_conn =
|
2018-03-30 15:01:53 +02:00
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/favourites")
|
2017-09-17 13:09:49 +02:00
|
|
|
|
2019-01-13 16:17:47 +01:00
|
|
|
assert [status] = json_response(first_conn, 200)
|
2017-10-31 17:57:26 +01:00
|
|
|
assert status["id"] == to_string(activity.id)
|
2019-01-13 16:17:47 +01:00
|
|
|
|
2019-01-16 05:09:01 +01:00
|
|
|
assert [{"link", _link_header}] =
|
2019-01-13 16:17:47 +01:00
|
|
|
Enum.filter(first_conn.resp_headers, fn element -> match?({"link", _}, element) end)
|
|
|
|
|
|
|
|
# Honours query params
|
|
|
|
{:ok, second_activity} =
|
|
|
|
CommonAPI.post(other_user, %{
|
|
|
|
"status" =>
|
|
|
|
"Trees Are Never Sad Look At Them Every Once In Awhile They're Quite Beautiful."
|
|
|
|
})
|
|
|
|
|
|
|
|
{:ok, _, _} = CommonAPI.favorite(second_activity.id, user)
|
|
|
|
|
|
|
|
last_like = status["id"]
|
|
|
|
|
|
|
|
second_conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/favourites?since_id=#{last_like}")
|
|
|
|
|
|
|
|
assert [second_status] = json_response(second_conn, 200)
|
|
|
|
assert second_status["id"] == to_string(second_activity.id)
|
|
|
|
|
|
|
|
third_conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/favourites?limit=0")
|
|
|
|
|
|
|
|
assert [] = json_response(third_conn, 200)
|
2017-09-17 13:09:49 +02:00
|
|
|
end
|
2017-11-11 23:27:09 +01:00
|
|
|
|
2018-02-12 09:33:01 +01:00
|
|
|
test "get instance information", %{conn: conn} do
|
2019-03-26 16:13:24 +01:00
|
|
|
conn = get(conn, "/api/v1/instance")
|
|
|
|
assert result = json_response(conn, 200)
|
|
|
|
|
2019-08-13 23:12:37 +02:00
|
|
|
email = Config.get([:instance, :email])
|
2019-03-26 16:13:24 +01:00
|
|
|
# Note: not checking for "max_toot_chars" since it's optional
|
|
|
|
assert %{
|
2019-03-26 16:18:36 +01:00
|
|
|
"uri" => _,
|
|
|
|
"title" => _,
|
|
|
|
"description" => _,
|
|
|
|
"version" => _,
|
2019-04-10 12:57:41 +02:00
|
|
|
"email" => from_config_email,
|
2019-03-26 16:18:36 +01:00
|
|
|
"urls" => %{
|
|
|
|
"streaming_api" => _
|
|
|
|
},
|
|
|
|
"stats" => _,
|
|
|
|
"thumbnail" => _,
|
|
|
|
"languages" => _,
|
2019-05-21 08:13:10 +02:00
|
|
|
"registrations" => _,
|
2019-10-02 00:16:29 +02:00
|
|
|
"poll_limits" => _,
|
|
|
|
"upload_limit" => _,
|
|
|
|
"avatar_upload_limit" => _,
|
|
|
|
"background_upload_limit" => _,
|
|
|
|
"banner_upload_limit" => _
|
2019-03-26 16:18:36 +01:00
|
|
|
} = result
|
2019-04-10 12:57:41 +02:00
|
|
|
|
|
|
|
assert email == from_config_email
|
2019-03-26 16:13:24 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
test "get instance stats", %{conn: conn} do
|
2017-11-30 14:59:44 +01:00
|
|
|
user = insert(:user, %{local: true})
|
2019-01-17 17:16:02 +01:00
|
|
|
|
|
|
|
user2 = insert(:user, %{local: true})
|
|
|
|
{:ok, _user2} = User.deactivate(user2, !user2.info.deactivated)
|
|
|
|
|
2019-01-16 09:07:46 +01:00
|
|
|
insert(:user, %{local: false, nickname: "u@peer1.com"})
|
|
|
|
insert(:user, %{local: false, nickname: "u@peer2.com"})
|
2017-11-30 14:59:44 +01:00
|
|
|
|
2019-07-15 21:47:23 +02:00
|
|
|
{:ok, _} = CommonAPI.post(user, %{"status" => "cofe"})
|
2017-11-30 14:59:44 +01:00
|
|
|
|
2019-01-22 15:12:53 +01:00
|
|
|
# Stats should count users with missing or nil `info.deactivated` value
|
|
|
|
|
|
|
|
{:ok, _user} =
|
2019-09-24 14:50:07 +02:00
|
|
|
user.id
|
|
|
|
|> User.get_cached_by_id()
|
|
|
|
|> User.update_info(&Changeset.change(&1, %{deactivated: nil}))
|
2019-01-22 15:12:53 +01:00
|
|
|
|
2019-08-14 17:59:33 +02:00
|
|
|
Pleroma.Stats.force_update()
|
2018-01-14 07:28:35 +01:00
|
|
|
|
2019-01-16 09:07:46 +01:00
|
|
|
conn = get(conn, "/api/v1/instance")
|
|
|
|
|
|
|
|
assert result = json_response(conn, 200)
|
|
|
|
|
|
|
|
stats = result["stats"]
|
|
|
|
|
|
|
|
assert stats
|
2019-01-17 17:16:02 +01:00
|
|
|
assert stats["user_count"] == 1
|
2019-01-16 09:07:46 +01:00
|
|
|
assert stats["status_count"] == 1
|
|
|
|
assert stats["domain_count"] == 2
|
|
|
|
end
|
|
|
|
|
|
|
|
test "get peers", %{conn: conn} do
|
|
|
|
insert(:user, %{local: false, nickname: "u@peer1.com"})
|
|
|
|
insert(:user, %{local: false, nickname: "u@peer2.com"})
|
|
|
|
|
2019-08-14 17:59:33 +02:00
|
|
|
Pleroma.Stats.force_update()
|
2019-01-16 09:07:46 +01:00
|
|
|
|
|
|
|
conn = get(conn, "/api/v1/instance/peers")
|
2017-11-30 14:59:44 +01:00
|
|
|
|
|
|
|
assert result = json_response(conn, 200)
|
|
|
|
|
2019-01-16 09:07:46 +01:00
|
|
|
assert ["peer1.com", "peer2.com"] == Enum.sort(result)
|
2017-11-30 14:59:44 +01:00
|
|
|
end
|
2018-12-16 12:15:34 +01:00
|
|
|
|
|
|
|
test "put settings", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> put("/api/web/settings", %{"data" => %{"programming" => "socks"}})
|
|
|
|
|
2019-01-16 05:09:01 +01:00
|
|
|
assert _result = json_response(conn, 200)
|
2018-12-16 12:15:34 +01:00
|
|
|
|
|
|
|
user = User.get_cached_by_ap_id(user.ap_id)
|
|
|
|
assert user.info.settings == %{"programming" => "socks"}
|
|
|
|
end
|
2019-01-07 14:45:33 +01:00
|
|
|
|
2019-03-07 03:29:42 +01:00
|
|
|
describe "link headers" do
|
|
|
|
test "preserves parameters in link headers", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
other_user = insert(:user)
|
|
|
|
|
|
|
|
{:ok, activity1} =
|
|
|
|
CommonAPI.post(other_user, %{
|
|
|
|
"status" => "hi @#{user.nickname}",
|
|
|
|
"visibility" => "public"
|
|
|
|
})
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-03-07 03:29:42 +01:00
|
|
|
{:ok, activity2} =
|
|
|
|
CommonAPI.post(other_user, %{
|
|
|
|
"status" => "hi @#{user.nickname}",
|
|
|
|
"visibility" => "public"
|
|
|
|
})
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-03-07 03:29:42 +01:00
|
|
|
notification1 = Repo.get_by(Notification, activity_id: activity1.id)
|
|
|
|
notification2 = Repo.get_by(Notification, activity_id: activity2.id)
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-03-07 03:29:42 +01:00
|
|
|
conn =
|
2019-03-28 10:39:10 +01:00
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
2019-03-07 03:29:42 +01:00
|
|
|
|> get("/api/v1/notifications", %{media_only: true})
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-03-07 03:29:42 +01:00
|
|
|
assert [link_header] = get_resp_header(conn, "link")
|
|
|
|
assert link_header =~ ~r/media_only=true/
|
2019-03-25 22:19:57 +01:00
|
|
|
assert link_header =~ ~r/min_id=#{notification2.id}/
|
2019-03-07 03:29:42 +01:00
|
|
|
assert link_header =~ ~r/max_id=#{notification1.id}/
|
2019-03-28 10:39:10 +01:00
|
|
|
end
|
2019-03-07 03:29:42 +01:00
|
|
|
end
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-01 12:17:57 +02:00
|
|
|
describe "custom emoji" do
|
|
|
|
test "with tags", %{conn: conn} do
|
|
|
|
[emoji | _body] =
|
2019-03-28 10:39:10 +01:00
|
|
|
conn
|
2019-04-01 12:17:57 +02:00
|
|
|
|> get("/api/v1/custom_emojis")
|
|
|
|
|> json_response(200)
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-01 12:17:57 +02:00
|
|
|
assert Map.has_key?(emoji, "shortcode")
|
|
|
|
assert Map.has_key?(emoji, "static_url")
|
|
|
|
assert Map.has_key?(emoji, "tags")
|
|
|
|
assert is_list(emoji["tags"])
|
2019-06-30 01:05:28 +02:00
|
|
|
assert Map.has_key?(emoji, "category")
|
2019-04-01 12:17:57 +02:00
|
|
|
assert Map.has_key?(emoji, "url")
|
|
|
|
assert Map.has_key?(emoji, "visible_in_picker")
|
2019-03-28 10:39:10 +01:00
|
|
|
end
|
2019-04-01 12:17:57 +02:00
|
|
|
end
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
describe "index/2 redirections" do
|
|
|
|
setup %{conn: conn} do
|
|
|
|
session_opts = [
|
|
|
|
store: :cookie,
|
|
|
|
key: "_test",
|
|
|
|
signing_salt: "cooldude"
|
|
|
|
]
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
conn =
|
2019-03-28 10:39:10 +01:00
|
|
|
conn
|
2019-04-06 01:36:42 +02:00
|
|
|
|> Plug.Session.call(Plug.Session.init(session_opts))
|
|
|
|
|> fetch_session()
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test_path = "/web/statuses/test"
|
|
|
|
%{conn: conn, path: test_path}
|
|
|
|
end
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test "redirects not logged-in users to the login page", %{conn: conn, path: path} do
|
|
|
|
conn = get(conn, path)
|
2019-03-28 10:39:10 +01:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
assert conn.status == 302
|
|
|
|
assert redirected_to(conn) == "/web/login"
|
2019-03-28 10:39:10 +01:00
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-07-29 18:17:22 +02:00
|
|
|
test "redirects not logged-in users to the login page on private instances", %{
|
|
|
|
conn: conn,
|
|
|
|
path: path
|
|
|
|
} do
|
2019-08-13 23:12:37 +02:00
|
|
|
Config.put([:instance, :public], false)
|
2019-07-29 18:17:22 +02:00
|
|
|
|
|
|
|
conn = get(conn, path)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-07-29 18:17:22 +02:00
|
|
|
assert conn.status == 302
|
|
|
|
assert redirected_to(conn) == "/web/login"
|
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test "does not redirect logged in users to the login page", %{conn: conn, path: path} do
|
|
|
|
token = insert(:oauth_token)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, token.user)
|
|
|
|
|> put_session(:oauth_token, token.token)
|
|
|
|
|> get(path)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
assert conn.status == 200
|
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test "saves referer path to session", %{conn: conn, path: path} do
|
|
|
|
conn = get(conn, path)
|
|
|
|
return_to = Plug.Conn.get_session(conn, :return_to)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
assert return_to == path
|
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test "redirects to the saved path after log in", %{conn: conn, path: path} do
|
|
|
|
app = insert(:oauth_app, client_name: "Mastodon-Local", redirect_uris: ".")
|
|
|
|
auth = insert(:oauth_authorization, app: app)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> put_session(:return_to, path)
|
|
|
|
|> get("/web/login", %{code: auth.token})
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
assert conn.status == 302
|
|
|
|
assert redirected_to(conn) == path
|
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
test "redirects to the getting-started page when referer is not present", %{conn: conn} do
|
|
|
|
app = insert(:oauth_app, client_name: "Mastodon-Local", redirect_uris: ".")
|
|
|
|
auth = insert(:oauth_authorization, app: app)
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
conn = get(conn, "/web/login", %{code: auth.token})
|
2019-04-12 04:21:32 +02:00
|
|
|
|
2019-04-06 01:36:42 +02:00
|
|
|
assert conn.status == 302
|
|
|
|
assert redirected_to(conn) == "/web/getting-started"
|
|
|
|
end
|
2019-04-12 04:21:32 +02:00
|
|
|
end
|
2019-05-13 20:35:45 +02:00
|
|
|
|
2019-07-16 23:44:50 +02:00
|
|
|
describe "POST /auth/password, with valid parameters" do
|
|
|
|
setup %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
conn = post(conn, "/auth/password?email=#{user.email}")
|
|
|
|
%{conn: conn, user: user}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it returns 204", %{conn: conn} do
|
|
|
|
assert json_response(conn, :no_content)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it creates a PasswordResetToken record for user", %{user: user} do
|
|
|
|
token_record = Repo.get_by(Pleroma.PasswordResetToken, user_id: user.id)
|
|
|
|
assert token_record
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it sends an email to user", %{user: user} do
|
2019-08-14 20:42:21 +02:00
|
|
|
ObanHelpers.perform_all()
|
2019-07-16 23:44:50 +02:00
|
|
|
token_record = Repo.get_by(Pleroma.PasswordResetToken, user_id: user.id)
|
|
|
|
|
|
|
|
email = Pleroma.Emails.UserEmail.password_reset_email(user, token_record.token)
|
2019-08-13 23:12:37 +02:00
|
|
|
notify_email = Config.get([:instance, :notify_email])
|
|
|
|
instance_name = Config.get([:instance, :name])
|
2019-07-16 23:44:50 +02:00
|
|
|
|
|
|
|
assert_email_sent(
|
|
|
|
from: {instance_name, notify_email},
|
|
|
|
to: {user.name, user.email},
|
|
|
|
html_body: email.html_body
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "POST /auth/password, with invalid parameters" do
|
|
|
|
setup do
|
|
|
|
user = insert(:user)
|
|
|
|
{:ok, user: user}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it returns 404 when user is not found", %{conn: conn, user: user} do
|
|
|
|
conn = post(conn, "/auth/password?email=nonexisting_#{user.email}")
|
|
|
|
assert conn.status == 404
|
2019-07-17 20:09:31 +02:00
|
|
|
assert conn.resp_body == ""
|
2019-07-16 23:44:50 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
test "it returns 400 when user is not local", %{conn: conn, user: user} do
|
|
|
|
{:ok, user} = Repo.update(Changeset.change(user, local: false))
|
|
|
|
conn = post(conn, "/auth/password?email=#{user.email}")
|
|
|
|
assert conn.status == 400
|
2019-07-17 20:09:31 +02:00
|
|
|
assert conn.resp_body == ""
|
2019-07-16 23:44:50 +02:00
|
|
|
end
|
|
|
|
end
|
2019-07-28 22:30:10 +02:00
|
|
|
|
2019-09-06 20:50:00 +02:00
|
|
|
describe "DELETE /auth/sign_out" do
|
|
|
|
test "redirect to root page", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
conn =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> delete("/auth/sign_out")
|
|
|
|
|
|
|
|
assert conn.status == 302
|
|
|
|
assert redirected_to(conn) == "/"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "empty_array, stubs for mastodon api" do
|
|
|
|
test "GET /api/v1/accounts/:id/identity_proofs", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
res =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/accounts/#{user.id}/identity_proofs")
|
|
|
|
|> json_response(200)
|
|
|
|
|
|
|
|
assert res == []
|
|
|
|
end
|
|
|
|
|
|
|
|
test "GET /api/v1/endorsements", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
res =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/endorsements")
|
|
|
|
|> json_response(200)
|
|
|
|
|
|
|
|
assert res == []
|
|
|
|
end
|
|
|
|
|
|
|
|
test "GET /api/v1/trends", %{conn: conn} do
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
res =
|
|
|
|
conn
|
|
|
|
|> assign(:user, user)
|
|
|
|
|> get("/api/v1/trends")
|
|
|
|
|> json_response(200)
|
|
|
|
|
|
|
|
assert res == []
|
|
|
|
end
|
|
|
|
end
|
2017-09-09 13:15:01 +02:00
|
|
|
end
|