1 defmodule Pleroma.Web.TwitterAPI.ControllerTest do
2 use Pleroma.Web.ConnCase
3 alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ActivityRepresenter}
4 alias Pleroma.Builders.UserBuilder
5 alias Pleroma.{Repo, Activity}
7 describe "POST /api/account/verify_credentials" do
9 test "without valid credentials", %{conn: conn} do
10 conn = post conn, "/api/account/verify_credentials.json"
11 assert json_response(conn, 403) == %{"error" => "Invalid credentials."}
14 test "with credentials", %{conn: conn, user: user} do
16 |> with_credentials(user.nickname, "test")
17 |> post("/api/account/verify_credentials.json")
19 assert json_response(conn, 200) == UserRepresenter.to_map(user)
23 describe "POST /statuses/update.json" do
25 test "without valid credentials", %{conn: conn} do
26 conn = post conn, "/api/statuses/update.json"
27 assert json_response(conn, 403) == %{"error" => "Invalid credentials."}
30 test "with credentials", %{conn: conn, user: user} do
32 |> with_credentials(user.nickname, "test")
33 |> post("/api/statuses/update.json", %{ status: "Nice meme." })
35 assert json_response(conn, 200) == ActivityRepresenter.to_map(Repo.one(Activity), %{user: user})
39 defp valid_user(_context) do
40 { :ok, user } = UserBuilder.insert
44 defp with_credentials(conn, username, password) do
45 header_content = "Basic " <> Base.encode64("#{username}:#{password}")
46 put_req_header(conn, "authorization", header_content)