aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-03-21 17:53:20 +0100
committerRoger Braun <roger@rogerbraun.net>2017-03-21 17:53:20 +0100
commit9a8850eb9ec9eba9350fcb6aadf70fd966623c94 (patch)
tree12bef929051c5e998107cbae06e6216aa634bf58 /test
parent8de523c8aec19e999334753b5a982fff00d1f44c (diff)
downloadpleroma-9a8850eb9ec9eba9350fcb6aadf70fd966623c94.tar.gz
Basic status creation and retrieval.
Diffstat (limited to 'test')
-rw-r--r--test/builders/user_builder.ex17
-rw-r--r--test/support/builders/activity_builder.ex37
-rw-r--r--test/support/builders/user_builder.ex18
-rw-r--r--test/user_test.exs26
-rw-r--r--test/web/activity_pub/activity_pub_test.exs10
-rw-r--r--test/web/twitter_api/representers/activity_representer_test.exs39
-rw-r--r--test/web/twitter_api/twitter_api_controller_test.exs11
-rw-r--r--test/web/twitter_api/twitter_api_test.exs31
8 files changed, 180 insertions, 9 deletions
diff --git a/test/builders/user_builder.ex b/test/builders/user_builder.ex
new file mode 100644
index 000000000..6a9495e5a
--- /dev/null
+++ b/test/builders/user_builder.ex
@@ -0,0 +1,17 @@
+defmodule Pleroma.Builders.UserBuilder do
+ alias Pleroma.{User, Repo}
+
+ def build do
+ %User{
+ email: "test@example.org",
+ name: "Test Name",
+ nickname: "testname",
+ password_hash: Comeonin.Pbkdf2.hashpwsalt("test"),
+ bio: "A tester.",
+ }
+ end
+
+ def insert do
+ Repo.insert(build())
+ end
+end
diff --git a/test/support/builders/activity_builder.ex b/test/support/builders/activity_builder.ex
new file mode 100644
index 000000000..0b7f79c5f
--- /dev/null
+++ b/test/support/builders/activity_builder.ex
@@ -0,0 +1,37 @@
+defmodule Pleroma.Builders.ActivityBuilder do
+ alias Pleroma.Builders.UserBuilder
+ alias Pleroma.Web.ActivityPub.ActivityPub
+ alias Pleroma.User
+
+ def public_and_non_public do
+ {:ok, user} = UserBuilder.insert
+ public = %{
+ "id" => 1,
+ "actor" => user.ap_id,
+ "to" => ["https://www.w3.org/ns/activitystreams#Public"],
+ "object" => %{
+ "type" => "Note",
+ "content" => "test"
+ }
+ }
+
+ non_public = %{
+ "id" => 2,
+ "actor" => user.ap_id,
+ "to" => [],
+ "object" => %{
+ "type" => "Note",
+ "content" => "test"
+ }
+ }
+
+ {:ok, public} = ActivityPub.insert(public)
+ {:ok, non_public} = ActivityPub.insert(non_public)
+
+ %{
+ public: public,
+ non_public: non_public,
+ user: user
+ }
+ end
+end
diff --git a/test/support/builders/user_builder.ex b/test/support/builders/user_builder.ex
new file mode 100644
index 000000000..0028d42e0
--- /dev/null
+++ b/test/support/builders/user_builder.ex
@@ -0,0 +1,18 @@
+defmodule Pleroma.Builders.UserBuilder do
+ alias Pleroma.{User, Repo}
+
+ def build do
+ %User{
+ email: "test@example.org",
+ name: "Test Name",
+ nickname: "testname",
+ password_hash: Comeonin.Pbkdf2.hashpwsalt("test"),
+ bio: "A tester.",
+ ap_id: "some id"
+ }
+ end
+
+ def insert do
+ Repo.insert(build())
+ end
+end
diff --git a/test/user_test.exs b/test/user_test.exs
new file mode 100644
index 000000000..30e414437
--- /dev/null
+++ b/test/user_test.exs
@@ -0,0 +1,26 @@
+defmodule Pleroma.UserTest do
+ alias Pleroma.Builders.UserBuilder
+ alias Pleroma.User
+ use Pleroma.DataCase
+
+ test "ap_id returns the activity pub id for the user" do
+ host =
+ Application.get_env(:pleroma, Pleroma.Web.Endpoint)
+ |> Keyword.fetch!(:url)
+ |> Keyword.fetch!(:host)
+
+ user = UserBuilder.build
+
+ expected_ap_id = "https://#{host}/users/#{user.nickname}"
+
+ assert expected_ap_id == User.ap_id(user)
+ end
+
+ test "ap_followers returns the followers collection for the user" do
+ user = UserBuilder.build
+
+ expected_followers_collection = "#{User.ap_id(user)}/followers"
+
+ assert expected_followers_collection == User.ap_followers(user)
+ end
+end
diff --git a/test/web/activity_pub/activity_pub_test.exs b/test/web/activity_pub/activity_pub_test.exs
index 1b4b121b3..5ea2d40f1 100644
--- a/test/web/activity_pub/activity_pub_test.exs
+++ b/test/web/activity_pub/activity_pub_test.exs
@@ -2,6 +2,7 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
use Pleroma.DataCase
alias Pleroma.Web.ActivityPub.ActivityPub
alias Pleroma.Activity
+ alias Pleroma.Builders.{UserBuilder, ActivityBuilder}
describe "insertion" do
test "inserts a given map into the activity database" do
@@ -14,4 +15,13 @@ defmodule Pleroma.Web.ActivityPub.ActivityPubTest do
end
end
+ describe "fetch activities" do
+ test "retrieves all public activities" do
+ %{user: user, public: public} = ActivityBuilder.public_and_non_public
+
+ activities = ActivityPub.fetch_public_activities
+ assert length(activities) == 1
+ assert Enum.at(activities, 0) == public
+ end
+ end
end
diff --git a/test/web/twitter_api/representers/activity_representer_test.exs b/test/web/twitter_api/representers/activity_representer_test.exs
new file mode 100644
index 000000000..b34d3b787
--- /dev/null
+++ b/test/web/twitter_api/representers/activity_representer_test.exs
@@ -0,0 +1,39 @@
+defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
+ use Pleroma.DataCase
+ alias Pleroma.{User, Activity}
+ alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ActivityRepresenter}
+ alias Pleroma.Builders.UserBuilder
+
+ test "an activity" do
+ {:ok, user} = UserBuilder.insert
+ content = "Some content"
+ activity = %Activity{
+ id: 1,
+ data: %{
+ "type" => "Create",
+ "to" => [
+ User.ap_followers(user),
+ "https://www.w3.org/ns/activitystreams#Public"
+ ],
+ "actor" => User.ap_id(user),
+ "object" => %{
+ "type" => "Note",
+ "content" => content
+ }
+ }
+ }
+
+
+ expected_status = %{
+ "id" => activity.id,
+ "user" => UserRepresenter.to_map(user),
+ "is_local" => true,
+ "attentions" => [],
+ "statusnet_html" => content,
+ "text" => content,
+ "is_post_verb" => true
+ }
+
+ assert ActivityRepresenter.to_map(activity, %{user: user}) == expected_status
+ end
+end
diff --git a/test/web/twitter_api/twitter_api_controller_test.exs b/test/web/twitter_api/twitter_api_controller_test.exs
index 118ef932d..81f1e893e 100644
--- a/test/web/twitter_api/twitter_api_controller_test.exs
+++ b/test/web/twitter_api/twitter_api_controller_test.exs
@@ -1,7 +1,7 @@
defmodule Pleroma.Web.TwitterAPI.ControllerTest do
use Pleroma.Web.ConnCase
- alias Pleroma.{User, Repo}
alias Pleroma.Web.TwitterAPI.Representers.UserRepresenter
+ alias Pleroma.Builders.UserBuilder
describe "POST /api/account/verify_credentials" do
setup [:valid_user]
@@ -20,14 +20,7 @@ defmodule Pleroma.Web.TwitterAPI.ControllerTest do
end
defp valid_user(_context) do
- user = %User{
- email: "test@example.org",
- name: "Test Name",
- nickname: "testname",
- password_hash: Comeonin.Pbkdf2.hashpwsalt("test"),
- bio: "A tester."
- }
- user = Repo.insert!(user)
+ { :ok, user } = UserBuilder.insert
[user: user]
end
diff --git a/test/web/twitter_api/twitter_api_test.exs b/test/web/twitter_api/twitter_api_test.exs
new file mode 100644
index 000000000..aecf09969
--- /dev/null
+++ b/test/web/twitter_api/twitter_api_test.exs
@@ -0,0 +1,31 @@
+defmodule Pleroma.Web.TwitterAPI.TwitterAPITest do
+ use Pleroma.DataCase
+ alias Pleroma.Builders.{UserBuilder, ActivityBuilder}
+ alias Pleroma.Web.TwitterAPI.TwitterAPI
+ alias Pleroma.{Activity, User}
+ alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ActivityRepresenter}
+ alias Pleroma.Web.ActivityPub.ActivityPub
+
+ test "create a status" do
+ user = UserBuilder.build
+ input = %{
+ status: "Hello again."
+ }
+
+ { :ok, activity = %Activity{} } = TwitterAPI.create_status(user, input)
+
+ assert get_in(activity.data, [:object, :content]) == "Hello again."
+ assert get_in(activity.data, [:object, :type]) == "Note"
+ assert get_in(activity.data, [:actor]) == User.ap_id(user)
+ assert Enum.member?(get_in(activity.data, [:to]), User.ap_followers(user))
+ assert Enum.member?(get_in(activity.data, [:to]), "https://www.w3.org/ns/activitystreams#Public")
+ end
+
+ test "fetch public activities" do
+ %{ public: activity, user: user } = ActivityBuilder.public_and_non_public
+ statuses = TwitterAPI.fetch_public_statuses()
+
+ assert length(statuses) == 1
+ assert Enum.at(statuses, 0) == ActivityRepresenter.to_map(activity, %{user: user})
+ end
+end