diff options
| author | Maxim Filippov <colixer@gmail.com> | 2019-10-07 15:01:18 +0300 | 
|---|---|---|
| committer | Maxim Filippov <colixer@gmail.com> | 2019-10-07 15:39:07 +0300 | 
| commit | 7aceaa517be7b109a9acc15fb4914535b536b66c (patch) | |
| tree | 61f2d13f34cc5d14707dba41211529f76b1b6931 /test | |
| parent | 8dcc2f9f5ecbbc81bc026c85582695de4fbc1a0f (diff) | |
| download | pleroma-7aceaa517be7b109a9acc15fb4914535b536b66c.tar.gz pleroma-7aceaa517be7b109a9acc15fb4914535b536b66c.zip | |
Admin API: Reports, grouped by status
Diffstat (limited to 'test')
| -rw-r--r-- | test/web/admin_api/admin_api_controller_test.exs | 69 | 
1 files changed, 68 insertions, 1 deletions
| diff --git a/test/web/admin_api/admin_api_controller_test.exs b/test/web/admin_api/admin_api_controller_test.exs index cec3570eb..daa0631db 100644 --- a/test/web/admin_api/admin_api_controller_test.exs +++ b/test/web/admin_api/admin_api_controller_test.exs @@ -1461,7 +1461,74 @@ defmodule Pleroma.Web.AdminAPI.AdminAPIControllerTest do      end    end -  # +  describe "GET /api/pleroma/admin/grouped_reports" do +    setup %{conn: conn} do +      admin = insert(:user, info: %{is_admin: true}) +      [reporter, target_user] = insert_pair(:user) + +      date1 = (DateTime.to_unix(DateTime.utc_now()) + 1000) |> DateTime.from_unix!() +      date2 = (DateTime.to_unix(DateTime.utc_now()) + 2000) |> DateTime.from_unix!() +      date3 = (DateTime.to_unix(DateTime.utc_now()) + 3000) |> DateTime.from_unix!() + +      first_status = +        insert(:note_activity, user: target_user, data_attrs: %{"published" => date1}) + +      second_status = +        insert(:note_activity, user: target_user, data_attrs: %{"published" => date2}) + +      third_status = +        insert(:note_activity, user: target_user, data_attrs: %{"published" => date3}) + +      %{ +        conn: assign(conn, :user, admin), +        reporter: reporter, +        target_user: target_user, +        first_status: first_status, +        second_status: second_status, +        third_status: third_status +      } +    end + +    test "returns reports grouped by status", %{ +      conn: conn, +      reporter: reporter, +      target_user: target_user, +      first_status: first_status, +      second_status: second_status, +      third_status: third_status +    } do +      {:ok, %{id: _}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "status_ids" => [first_status.id, second_status.id, third_status.id] +        }) + +      {:ok, %{id: _}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "status_ids" => [first_status.id, second_status.id] +        }) + +      {:ok, %{id: _}} = +        CommonAPI.report(reporter, %{ +          "account_id" => target_user.id, +          "status_ids" => [first_status.id] +        }) + +      response = +        conn +        |> get("/api/pleroma/admin/grouped_reports") +        |> json_response(:ok) + +      assert length(response["reports"]) == 3 +      [third_group, second_group, first_group] = response["reports"] + +      assert length(third_group["reports"]) == 3 +      assert length(second_group["reports"]) == 2 +      assert length(first_group["reports"]) == 1 +    end +  end +    describe "POST /api/pleroma/admin/reports/:id/respond" do      setup %{conn: conn} do        admin = insert(:user, info: %{is_admin: true}) | 
