From 4c60f0ec516b14eadbefae7ed880210c226f2b84 Mon Sep 17 00:00:00 2001 From: Thomas Citharel Date: Wed, 30 May 2018 18:59:13 +0200 Subject: [PATCH] Add groups back Signed-off-by: Thomas Citharel --- js/src/components/Account/Account.vue | 2 + js/src/components/Group/Create.vue | 67 +++--- js/src/components/Group/GroupList.vue | 15 +- lib/eventos/actors/actor.ex | 23 ++- lib/eventos/actors/actors.ex | 27 ++- .../controllers/group_controller.ex | 72 +++---- lib/eventos_web/router.ex | 4 +- lib/eventos_web/views/actor_view.ex | 3 + lib/service/activity_pub/activity_pub.ex | 24 +-- ...0125159_add_avatar_and_banner_to_actor.exs | 17 ++ ...0152323_make_actor_public_key_nullable.exs | 15 ++ test/eventos/accounts/accounts_test.exs | 153 -------------- test/eventos/actors/actors_test.exs | 171 ++++++++++++++++ test/eventos/groups/groups_test.exs | 193 ------------------ test/support/factory.ex | 27 +-- 15 files changed, 349 insertions(+), 464 deletions(-) create mode 100644 priv/repo/migrations/20180530125159_add_avatar_and_banner_to_actor.exs create mode 100644 priv/repo/migrations/20180530152323_make_actor_public_key_nullable.exs delete mode 100644 test/eventos/accounts/accounts_test.exs delete mode 100644 test/eventos/groups/groups_test.exs diff --git a/js/src/components/Account/Account.vue b/js/src/components/Account/Account.vue index 1106be577..81f1cf7e2 100644 --- a/js/src/components/Account/Account.vue +++ b/js/src/components/Account/Account.vue @@ -4,6 +4,7 @@ + @@ -40,6 +41,7 @@ + diff --git a/js/src/components/Group/Create.vue b/js/src/components/Group/Create.vue index d68b7d576..03c36a4bf 100644 --- a/js/src/components/Group/Create.vue +++ b/js/src/components/Group/Create.vue @@ -6,15 +6,23 @@ + + + @@ -22,34 +30,34 @@ - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + Create group @@ -72,9 +80,10 @@ return { e1: 0, group: { - title: '', - description: '', - category: null, + preferred_username: '', + name: '', + summary: '', + // category: null, }, categories: [], }; diff --git a/js/src/components/Group/GroupList.vue b/js/src/components/Group/GroupList.vue index 2fa196244..8b90307d0 100644 --- a/js/src/components/Group/GroupList.vue +++ b/js/src/components/Group/GroupList.vue @@ -14,21 +14,20 @@ - {{ group.title }} + {{ group.username }}
- {{ group.startDate | formatDate }} à {{ group.location }}
-

{{ group.description }}

+

{{ group.summary }}

Organisé par {{ group.organizer.username }}

lockJoin - Explore + Explore Delete
@@ -53,10 +52,14 @@ this.fetchData(); }, methods: { + username_with_domain(actor) { + return actor.username + (actor.domain === null ? '' : `@${actor.domain}`) + }, fetchData() { eventFetch('/groups', this.$store) .then(response => response.json()) .then((data) => { + console.log(data); this.loading = false; this.groups = data.data; }); @@ -67,8 +70,8 @@ .then(response => response.json()) .then(() => router.push('/groups')); }, - viewEvent(id) { - this.$router.push({ name: 'Group', params: { id } }) + viewActor(actor) { + this.$router.push({ name: 'Account', params: { name: this.username_with_domain(actor) } }) }, joinGroup(id) { const router = this.$router; diff --git a/lib/eventos/actors/actor.ex b/lib/eventos/actors/actor.ex index 20d161451..92f3acce3 100644 --- a/lib/eventos/actors/actor.ex +++ b/lib/eventos/actors/actor.ex @@ -64,6 +64,8 @@ defmodule Eventos.Actors.Actor do field :private_key, :string field :manually_approves_followers, :boolean, default: false field :suspended, :boolean, default: false + field :avatar_url, :string + field :banner_url, :string many_to_many :followers, Actor, join_through: Follower has_many :organized_events, Event, [foreign_key: :organizer_actor_id] many_to_many :memberships, Actor, join_through: Member @@ -75,7 +77,7 @@ defmodule Eventos.Actors.Actor do @doc false def changeset(%Actor{} = actor, attrs) do actor - |> Ecto.Changeset.cast(attrs, [:url, :outbox_url, :inbox_url, :following_url, :followers_url, :type, :name, :domain, :summary, :preferred_username, :public_key, :private_key, :manually_approves_followers, :suspended]) + |> Ecto.Changeset.cast(attrs, [:url, :outbox_url, :inbox_url, :shared_inbox_url, :following_url, :followers_url, :type, :name, :domain, :summary, :preferred_username, :public_key, :private_key, :manually_approves_followers, :suspended, :avatar_url, :banner_url]) |> validate_required([:preferred_username, :public_key, :suspended, :url]) |> unique_constraint(:prefered_username, name: :actors_preferred_username_domain_index) end @@ -91,8 +93,8 @@ defmodule Eventos.Actors.Actor do def remote_actor_creation(params) do changes = %Actor{} - |> Ecto.Changeset.cast(params, [:url, :outbox_url, :inbox_url, :following_url, :followers_url, :type, :name, :domain, :summary, :preferred_username, :public_key, :manually_approves_followers]) - |> validate_required([:url, :outbox_url, :inbox_url, :type, :name, :domain, :summary, :preferred_username, :public_key]) + |> Ecto.Changeset.cast(params, [:url, :outbox_url, :inbox_url, :shared_inbox_url, :following_url, :followers_url, :type, :name, :domain, :summary, :preferred_username, :public_key, :manually_approves_followers, :avatar_url, :banner_url]) + |> validate_required([:url, :outbox_url, :inbox_url, :type, :name, :domain, :preferred_username, :public_key]) |> unique_constraint(:preferred_username, name: :actors_preferred_username_domain_index) |> validate_length(:summary, max: 5000) |> validate_length(:preferred_username, max: 100) @@ -103,6 +105,21 @@ defmodule Eventos.Actors.Actor do changes end + def group_creation(%Actor{} = actor, params) do + actor + |> Ecto.Changeset.cast(params, [:url, :outbox_url, :inbox_url, :shared_inbox_url, :type, :name, :domain, :summary, :preferred_username, :avatar_url, :banner_url]) + |> put_change(:outbox_url, "#{EventosWeb.Endpoint.url()}/@#{params["prefered_username"]}/outbox") + |> put_change(:inbox_url, "#{EventosWeb.Endpoint.url()}/@#{params["prefered_username"]}/inbox") + |> put_change(:shared_inbox_url, "#{EventosWeb.Endpoint.url()}/inbox") + |> put_change(:url, "#{EventosWeb.Endpoint.url()}/@#{params["prefered_username"]}") + |> put_change(:domain, nil) + |> put_change(:type, "Group") + |> validate_required([:url, :outbox_url, :inbox_url, :type, :name, :preferred_username]) + |> validate_length(:summary, max: 5000) + |> validate_length(:preferred_username, max: 100) + |> put_change(:local, true) + end + def get_or_fetch_by_url(url) do if user = Actors.get_actor_by_url(url) do user diff --git a/lib/eventos/actors/actors.ex b/lib/eventos/actors/actors.ex index 1e1748a52..067928159 100644 --- a/lib/eventos/actors/actors.ex +++ b/lib/eventos/actors/actors.ex @@ -126,6 +126,31 @@ defmodule Eventos.Actors do "acct:#{actor_to_local_name_and_domain(actor)}" end + @doc """ + List the groups + """ + def list_groups do + Repo.all(from a in Actor, where: a.type == "Group") + end + + @doc """ + Creates a group. + + ## Examples + + iex> create_group(%{field: value}) + {:ok, %Actor{}} + + iex> create_group(%{field: bad_value}) + {:error, %Ecto.Changeset{}} + + """ + def create_group(attrs \\ %{}) do + %Actor{} + |> Actor.group_creation(attrs) + |> Repo.insert() + end + alias Eventos.Actors.User @doc """ @@ -151,7 +176,7 @@ defmodule Eventos.Actors do def insert_or_update_actor(data) do cs = Actor.remote_actor_creation(data) - Repo.insert(cs, on_conflict: [set: [public_key: data.public_key]], conflict_target: [:preferred_username, :domain]) + Repo.insert(cs, on_conflict: [set: [public_key: data.public_key, avatar_url: data.avatar_url, banner: data.banner_url, name: data.name]], conflict_target: [:preferred_username, :domain]) end # def increase_event_count(%Actor{} = actor) do diff --git a/lib/eventos_web/controllers/group_controller.ex b/lib/eventos_web/controllers/group_controller.ex index b1a6d9f1c..6393fb9e7 100644 --- a/lib/eventos_web/controllers/group_controller.ex +++ b/lib/eventos_web/controllers/group_controller.ex @@ -1,46 +1,26 @@ -#defmodule EventosWeb.GroupController do -# @moduledoc """ -# Controller for Groups -# """ -# use EventosWeb, :controller -# -# alias Eventos.Actors -# alias Eventos.Actors.Actor -# -# action_fallback EventosWeb.FallbackController -# -# def index(conn, _params) do -# groups = Actors.list_groups() -# render(conn, "index.json", groups: groups) -# end -# -# def create(conn, %{"group" => group_params}) do -# group_params = Map.put(group_params, "url", "h") -# with {:ok, %Group{} = group} <- Actors.create_group(group_params) do -# conn -# |> put_status(:created) -# |> put_resp_header("location", group_path(conn, :show, group)) -# |> render("show_simple.json", group: group) -# end -# end -# -# def show(conn, %{"id" => id}) do -# group = Actors.get_group_full!(id) -# render(conn, "show.json", group: group) -# end -# -# def update(conn, %{"id" => id, "group" => group_params}) do -# group = Actors.get_group!(id) -# -# with {:ok, %Actor{} = group} <- Actors.update_group(group, group_params) do -# render(conn, "show_simple.json", group: group) -# end -# end -# -# def delete(conn, %{"id" => id}) do -# group = Actors.get_group!(id) -# with {:ok, %Actor{}} <- Actors.delete_group(group) do -# send_resp(conn, :no_content, "") -# end -# end -#end +defmodule EventosWeb.GroupController do + @moduledoc """ + Controller for Groups + """ + use EventosWeb, :controller + + alias Eventos.Actors + alias Eventos.Actors.Actor + + action_fallback EventosWeb.FallbackController + + def index(conn, _params) do + groups = Actors.list_groups() + render(conn, EventosWeb.ActorView, "index.json", actors: groups) + end + + def create(conn, %{"group" => group_params}) do + with actor_admin = Guardian.Plug.current_resource(conn).actor, + {:ok, %Actor{} = group} <- Actors.create_group(group_params) do + conn + |> put_status(:created) + |> put_resp_header("location", actor_path(conn, :show, group)) + |> render(EventosWeb.ActorView, "acccount_basic.json", actor: group) + end + end +end diff --git a/lib/eventos_web/router.ex b/lib/eventos_web/router.ex index 620c02658..a41406eba 100644 --- a/lib/eventos_web/router.ex +++ b/lib/eventos_web/router.ex @@ -37,7 +37,7 @@ defmodule EventosWeb.Router do post "/users", UserController, :register post "/login", UserSessionController, :sign_in - #resources "/groups", GroupController, only: [:index, :show] + get "/groups", GroupController, :index get "/events", EventController, :index get "/events/search/:name", EventController, :search get "/events/:username/:slug", EventController, :show @@ -79,7 +79,7 @@ defmodule EventosWeb.Router do resources "/participant", ParticipantController resources "/bots", BotController, except: [:new, :edit, :show] #resources "/requests", EventRequestController - #resources "/groups", GroupController, except: [:index, :show] + post "/groups", GroupController, :create #post "/groups/:id/request", GroupRequestController, :create_for_group resources "/members", MemberController #resources "/requests", GroupRequestController diff --git a/lib/eventos_web/views/actor_view.ex b/lib/eventos_web/views/actor_view.ex index 788d9e07b..998a35b1a 100644 --- a/lib/eventos_web/views/actor_view.ex +++ b/lib/eventos_web/views/actor_view.ex @@ -27,6 +27,7 @@ defmodule EventosWeb.ActorView do # public_key: actor.public_key, suspended: actor.suspended, url: actor.url, + avatar: actor.avatar_url, } end @@ -40,6 +41,8 @@ defmodule EventosWeb.ActorView do # public_key: actor.public_key, suspended: actor.suspended, url: actor.url, + avatar: actor.avatar_url, + banner: actor.banner_url, organized_events: render_many(actor.organized_events, EventView, "event_for_actor.json") } end diff --git a/lib/service/activity_pub/activity_pub.ex b/lib/service/activity_pub/activity_pub.ex index 9a645c447..c9f928169 100644 --- a/lib/service/activity_pub/activity_pub.ex +++ b/lib/service/activity_pub/activity_pub.ex @@ -249,21 +249,6 @@ defmodule Eventos.Service.ActivityPub do end def user_data_from_user_object(data) do - Logger.debug("user_data_from_user_object") - Logger.debug(inspect data) - avatar = - data["icon"]["url"] && - %{ - "type" => "Image", - "url" => [%{"href" => data["icon"]["url"]}] - } - - banner = - data["image"]["url"] && - %{ - "type" => "Image", - "url" => [%{"href" => data["image"]["url"]}] - } name = if String.trim(data["name"]) === "" do data["preferredUsername"] else @@ -275,9 +260,9 @@ defmodule Eventos.Service.ActivityPub do info: %{ "ap_enabled" => true, "source_data" => data, - "banner" => banner }, - avatar: avatar, + avatar_url: data["icon"]["url"], + banner_url: data["image"]["url"], name: name, preferred_username: data["preferredUsername"], follower_address: data["followers"], @@ -287,12 +272,15 @@ defmodule Eventos.Service.ActivityPub do outbox_url: data["outbox"], following_url: data["following"], followers_url: data["followers"], - shared_inbox_url: data["sharedInbox"], + shared_inbox_url: data["endpoints"]["sharedInbox"], domain: URI.parse(data["id"]).host, manually_approves_followers: data["manuallyApprovesFollowers"], type: data["type"], } + Logger.debug("user_data_from_user_object") + Logger.debug(inspect user_data) + {:ok, user_data} end diff --git a/priv/repo/migrations/20180530125159_add_avatar_and_banner_to_actor.exs b/priv/repo/migrations/20180530125159_add_avatar_and_banner_to_actor.exs new file mode 100644 index 000000000..27ce9b36a --- /dev/null +++ b/priv/repo/migrations/20180530125159_add_avatar_and_banner_to_actor.exs @@ -0,0 +1,17 @@ +defmodule Eventos.Repo.Migrations.AddAvatarAndBannerToActor do + use Ecto.Migration + + def up do + alter table(:actors) do + add :avatar_url, :string + add :banner_url, :string + end + end + + def down do + alter table(:actors) do + remove :avatar_url + remove :banner_url + end + end +end diff --git a/priv/repo/migrations/20180530152323_make_actor_public_key_nullable.exs b/priv/repo/migrations/20180530152323_make_actor_public_key_nullable.exs new file mode 100644 index 000000000..645715b08 --- /dev/null +++ b/priv/repo/migrations/20180530152323_make_actor_public_key_nullable.exs @@ -0,0 +1,15 @@ +defmodule Eventos.Repo.Migrations.MakeActorPublicKeyNullable do + use Ecto.Migration + + def up do + alter table(:actors) do + modify :public_key, :text, null: true + end + end + + def down do + alter table(:actors) do + modify :public_key, :text, null: false + end + end +end diff --git a/test/eventos/accounts/accounts_test.exs b/test/eventos/accounts/accounts_test.exs deleted file mode 100644 index fcfc4bde0..000000000 --- a/test/eventos/accounts/accounts_test.exs +++ /dev/null @@ -1,153 +0,0 @@ -defmodule Eventos.AccountsTest do - use Eventos.DataCase - - alias Eventos.Accounts - - describe "accounts" do - alias Eventos.Accounts.Account - - @valid_attrs %{description: "some description", display_name: "some display_name", domain: "some domain", private_key: "some private_key", public_key: "some public_key", suspended: true, uri: "some uri", url: "some url", username: "some username"} - @update_attrs %{description: "some updated description", display_name: "some updated display_name", domain: "some updated domain", private_key: "some updated private_key", public_key: "some updated public_key", suspended: false, uri: "some updated uri", url: "some updated url", username: "some updated username"} - @invalid_attrs %{description: nil, display_name: nil, domain: nil, private_key: nil, public_key: nil, suspended: nil, uri: nil, url: nil, username: nil} - - def account_fixture(attrs \\ %{}) do - {:ok, account} = - attrs - |> Enum.into(@valid_attrs) - |> Accounts.create_account() - - account - end - - test "list_accounts/0 returns all accounts" do - account = account_fixture() - assert Accounts.list_accounts() == [account] - end - - test "get_account!/1 returns the account with given id" do - account = account_fixture() - assert Accounts.get_account!(account.id) == account - end - - test "create_account/1 with valid data creates a account" do - assert {:ok, %Account{} = account} = Accounts.create_account(@valid_attrs) - assert account.description == "some description" - assert account.display_name == "some display_name" - assert account.domain == "some domain" - assert account.private_key == "some private_key" - assert account.public_key == "some public_key" - assert account.suspended - assert account.uri == "some uri" - assert account.url == "some url" - assert account.username == "some username" - end - - test "create_account/1 with invalid data returns error changeset" do - assert {:error, %Ecto.Changeset{}} = Accounts.create_account(@invalid_attrs) - end - - test "update_account/2 with valid data updates the account" do - account = account_fixture() - assert {:ok, account} = Accounts.update_account(account, @update_attrs) - assert %Account{} = account - assert account.description == "some updated description" - assert account.display_name == "some updated display_name" - assert account.domain == "some updated domain" - assert account.private_key == "some updated private_key" - assert account.public_key == "some updated public_key" - refute account.suspended - assert account.uri == "some updated uri" - assert account.url == "some updated url" - assert account.username == "some updated username" - end - - test "update_account/2 with invalid data returns error changeset" do - account = account_fixture() - assert {:error, %Ecto.Changeset{}} = Accounts.update_account(account, @invalid_attrs) - assert account == Accounts.get_account!(account.id) - end - - test "delete_account/1 deletes the account" do - account = account_fixture() - assert {:ok, %Account{}} = Accounts.delete_account(account) - assert_raise Ecto.NoResultsError, fn -> Accounts.get_account!(account.id) end - end - - test "change_account/1 returns a account changeset" do - account = account_fixture() - assert %Ecto.Changeset{} = Accounts.change_account(account) - end - end - - describe "users" do - alias Eventos.Accounts.{User, Account} - - @account_valid_attrs %{description: "some description", display_name: "some display_name", domain: "some domain", private_key: "some private_key", public_key: "some public_key", suspended: true, uri: "some uri", url: "some url", username: "some username"} - @valid_attrs %{email: "foo@bar.tld", password_hash: "some password_hash", role: 42} - @update_attrs %{email: "foo@fighters.tld", password_hash: "some updated password_hash", role: 43} - @invalid_attrs %{email: nil, password_hash: nil, role: nil} - - def user_fixture(attrs \\ %{}) do - {:ok, account} = - attrs - |> Enum.into(@account_valid_attrs) - |> Accounts.create_account() - valid_attrs_with_account_id = Map.put(@valid_attrs, :account_id, account.id) - {:ok, user} = - attrs - |> Enum.into(valid_attrs_with_account_id) - |> Accounts.create_user() - - user - end - - test "list_users/0 returns all users" do - user = user_fixture() - assert Accounts.list_users() == [user] - end - - test "get_user!/1 returns the user with given id" do - user = user_fixture() - assert Accounts.get_user!(user.id) == user - end - - test "create_user/1 with valid data creates a user" do - {:ok, %Account{} = account} = Accounts.create_account(@account_valid_attrs) - attrs = Map.put(@valid_attrs, :account_id, account.id) - assert {:ok, %User{} = user} = Accounts.create_user(attrs) - assert user.email == "foo@bar.tld" - assert user.password_hash == "some password_hash" - assert user.role == 42 - end - - test "create_user/1 with invalid data returns error changeset" do - assert {:error, %Ecto.Changeset{}} = Accounts.create_user(@invalid_attrs) - end - - test "update_user/2 with valid data updates the user" do - user = user_fixture() - assert {:ok, user} = Accounts.update_user(user, @update_attrs) - assert %User{} = user - assert user.email == "foo@fighters.tld" - assert user.password_hash == "some updated password_hash" - assert user.role == 43 - end - - test "update_user/2 with invalid data returns error changeset" do - user = user_fixture() - assert {:error, %Ecto.Changeset{}} = Accounts.update_user(user, @invalid_attrs) - assert user == Accounts.get_user!(user.id) - end - - test "delete_user/1 deletes the user" do - user = user_fixture() - assert {:ok, %User{}} = Accounts.delete_user(user) - assert_raise Ecto.NoResultsError, fn -> Accounts.get_user!(user.id) end - end - - test "change_user/1 returns a user changeset" do - user = user_fixture() - assert %Ecto.Changeset{} = Accounts.change_user(user) - end - end -end diff --git a/test/eventos/actors/actors_test.exs b/test/eventos/actors/actors_test.exs index 556a99640..048b9b7c2 100644 --- a/test/eventos/actors/actors_test.exs +++ b/test/eventos/actors/actors_test.exs @@ -3,6 +3,177 @@ defmodule Eventos.ActorsTest do alias Eventos.Actors + describe "actors" do + alias Eventos.Actors.Actor + + @valid_attrs %{description: "some description", display_name: "some display_name", domain: "some domain", private_key: "some private_key", public_key: "some public_key", suspended: true, uri: "some uri", url: "some url", username: "some username"} + @update_attrs %{description: "some updated description", display_name: "some updated display_name", domain: "some updated domain", private_key: "some updated private_key", public_key: "some updated public_key", suspended: false, uri: "some updated uri", url: "some updated url", username: "some updated username"} + @invalid_attrs %{description: nil, display_name: nil, domain: nil, private_key: nil, public_key: nil, suspended: nil, uri: nil, url: nil, username: nil} + + def actor_fixture(attrs \\ %{}) do + {:ok, actor} = + attrs + |> Enum.into(@valid_attrs) + |> Actors.create_actor() + + actor + end + + test "list_actors/0 returns all actors" do + actor = actor_fixture() + assert Actors.list_actors() == [actor] + end + + test "get_actor!/1 returns the actor with given id" do + actor = actor_fixture() + assert Actors.get_actor!(actor.id) == actor + end + + test "create_actor/1 with valid data creates a actor" do + assert {:ok, %Actor{} = actor} = Actors.create_actor(@valid_attrs) + assert actor.description == "some description" + assert actor.display_name == "some display_name" + assert actor.domain == "some domain" + assert actor.private_key == "some private_key" + assert actor.public_key == "some public_key" + assert actor.suspended + assert actor.uri == "some uri" + assert actor.url == "some url" + assert actor.username == "some username" + end + + test "create_actor/1 with invalid data returns error changeset" do + assert {:error, %Ecto.Changeset{}} = Actors.create_actor(@invalid_attrs) + end + + test "update_actor/2 with valid data updates the actor" do + actor = actor_fixture() + assert {:ok, actor} = Actors.update_actor(actor, @update_attrs) + assert %Actor{} = actor + assert actor.description == "some updated description" + assert actor.display_name == "some updated display_name" + assert actor.domain == "some updated domain" + assert actor.private_key == "some updated private_key" + assert actor.public_key == "some updated public_key" + refute actor.suspended + assert actor.uri == "some updated uri" + assert actor.url == "some updated url" + assert actor.username == "some updated username" + end + + test "update_actor/2 with invalid data returns error changeset" do + actor = actor_fixture() + assert {:error, %Ecto.Changeset{}} = Actors.update_actor(actor, @invalid_attrs) + assert actor == Actors.get_actor!(actor.id) + end + + test "delete_actor/1 deletes the actor" do + actor = actor_fixture() + assert {:ok, %Actor{}} = Actors.delete_actor(actor) + assert_raise Ecto.NoResultsError, fn -> Actors.get_actor!(actor.id) end + end + + test "change_actor/1 returns a actor changeset" do + actor = actor_fixture() + assert %Ecto.Changeset{} = Actors.change_actor(actor) + end + end + + describe "users" do + alias Eventos.Actors.{User, Actor} + + @actor_valid_attrs %{description: "some description", display_name: "some display_name", domain: "some domain", private_key: "some private_key", public_key: "some public_key", suspended: true, uri: "some uri", url: "some url", username: "some username"} + @valid_attrs %{email: "foo@bar.tld", password_hash: "some password_hash", role: 42} + @update_attrs %{email: "foo@fighters.tld", password_hash: "some updated password_hash", role: 43} + @invalid_attrs %{email: nil, password_hash: nil, role: nil} + + def user_fixture(attrs \\ %{}) do + {:ok, actor} = + attrs + |> Enum.into(@actor_valid_attrs) + |> Actors.create_actor() + valid_attrs_with_actor_id = Map.put(@valid_attrs, :actor_id, actor.id) + {:ok, user} = + attrs + |> Enum.into(valid_attrs_with_actor_id) + |> Actors.create_user() + + user + end + + test "list_users/0 returns all users" do + user = user_fixture() + assert Actors.list_users() == [user] + end + + test "get_user!/1 returns the user with given id" do + user = user_fixture() + assert Actors.get_user!(user.id) == user + end + + test "create_user/1 with valid data creates a user" do + {:ok, %Actor{} = actor} = Actors.create_actor(@actor_valid_attrs) + attrs = Map.put(@valid_attrs, :actor_id, actor.id) + assert {:ok, %User{} = user} = Actors.create_user(attrs) + assert user.email == "foo@bar.tld" + assert user.password_hash == "some password_hash" + assert user.role == 42 + end + + test "create_user/1 with invalid data returns error changeset" do + assert {:error, %Ecto.Changeset{}} = Actors.create_user(@invalid_attrs) + end + + test "update_user/2 with valid data updates the user" do + user = user_fixture() + assert {:ok, user} = Actors.update_user(user, @update_attrs) + assert %User{} = user + assert user.email == "foo@fighters.tld" + assert user.password_hash == "some updated password_hash" + assert user.role == 43 + end + + test "update_user/2 with invalid data returns error changeset" do + user = user_fixture() + assert {:error, %Ecto.Changeset{}} = Actors.update_user(user, @invalid_attrs) + assert user == Actors.get_user!(user.id) + end + + test "delete_user/1 deletes the user" do + user = user_fixture() + assert {:ok, %User{}} = Actors.delete_user(user) + assert_raise Ecto.NoResultsError, fn -> Actors.get_user!(user.id) end + end + + test "change_user/1 returns a user changeset" do + user = user_fixture() + assert %Ecto.Changeset{} = Actors.change_user(user) + end + end + + describe "groups" do + + alias Eventos.Actors + alias Eventos.Actors.Actor + + @valid_attrs %{summary: "some description", suspended: true, preferred_username: "some-title", name: "Some Title"} + @update_attrs %{summary: "some updated description", suspended: false, preferred_username: "some-updated-title", name: "Some Updated Title"} + @invalid_attrs %{summary: nil, suspended: nil, preferred_username: nil, name: nil} + + test "create_group/1 with valid data creates a group" do + assert {:ok, %Actor{} = group} = Actors.create_group(@valid_attrs) + assert group.summary == "some description" + refute group.suspended + assert group.preferred_username == "some-title" + end + + test "create_group/1 with invalid data returns error changeset" do + assert {:error, %Ecto.Changeset{}} = Actors.create_group(@invalid_attrs) + end + end + + alias Eventos.Actors + describe "bots" do alias Eventos.Actors.Bot diff --git a/test/eventos/groups/groups_test.exs b/test/eventos/groups/groups_test.exs deleted file mode 100644 index 03cd64255..000000000 --- a/test/eventos/groups/groups_test.exs +++ /dev/null @@ -1,193 +0,0 @@ -defmodule Eventos.GroupsTest do - use Eventos.DataCase - - alias Eventos.Groups - - describe "groups" do - alias Eventos.Groups.Group - - @valid_attrs %{description: "some description", suspended: true, title: "some title", uri: "some uri", url: "some url"} - @update_attrs %{description: "some updated description", suspended: false, title: "some updated title", uri: "some updated uri", url: "some updated url"} - @invalid_attrs %{description: nil, suspended: nil, title: nil, uri: nil, url: nil} - - def group_fixture(attrs \\ %{}) do - {:ok, group} = - attrs - |> Enum.into(@valid_attrs) - |> Groups.create_group() - - group - end - - test "list_groups/0 returns all groups" do - group = group_fixture() - assert Groups.list_groups() == [group] - end - - test "get_group!/1 returns the group with given id" do - group = group_fixture() - assert Groups.get_group!(group.id) == group - end - - test "create_group/1 with valid data creates a group" do - assert {:ok, %Group{} = group} = Groups.create_group(@valid_attrs) - assert group.description == "some description" - assert group.suspended - assert group.title == "some title" - assert group.uri == "some uri" - assert group.url == "some url" - end - - test "create_group/1 with invalid data returns error changeset" do - assert {:error, %Ecto.Changeset{}} = Groups.create_group(@invalid_attrs) - end - - test "update_group/2 with valid data updates the group" do - group = group_fixture() - assert {:ok, group} = Groups.update_group(group, @update_attrs) - assert %Group{} = group - assert group.description == "some updated description" - refute group.suspended - assert group.title == "some updated title" - assert group.uri == "some updated uri" - assert group.url == "some updated url" - end - - test "update_group/2 with invalid data returns error changeset" do - group = group_fixture() - assert {:error, %Ecto.Changeset{}} = Groups.update_group(group, @invalid_attrs) - assert group == Groups.get_group!(group.id) - end - - test "delete_group/1 deletes the group" do - group = group_fixture() - assert {:ok, %Group{}} = Groups.delete_group(group) - assert_raise Ecto.NoResultsError, fn -> Groups.get_group!(group.id) end - end - - test "change_group/1 returns a group changeset" do - group = group_fixture() - assert %Ecto.Changeset{} = Groups.change_group(group) - end - end -# -# describe "members" do -# alias Eventos.Groups.Member -# -# @valid_attrs %{role: 42} -# @update_attrs %{role: 43} -# @invalid_attrs %{role: nil} -# -# def member_fixture(attrs \\ %{}) do -# {:ok, member} = -# attrs -# |> Enum.into(@valid_attrs) -# |> Groups.create_member() -# -# member -# end -# -# test "list_members/0 returns all members" do -# member = member_fixture() -# assert Groups.list_members() == [member] -# end -# -# test "get_member!/1 returns the member with given id" do -# member = member_fixture() -# assert Groups.get_member!(member.id) == member -# end -# -# test "create_member/1 with valid data creates a member" do -# assert {:ok, %Member{} = member} = Groups.create_member(@valid_attrs) -# assert member.role == 42 -# end -# -# test "create_member/1 with invalid data returns error changeset" do -# assert {:error, %Ecto.Changeset{}} = Groups.create_member(@invalid_attrs) -# end -# -# test "update_member/2 with valid data updates the member" do -# member = member_fixture() -# assert {:ok, member} = Groups.update_member(member, @update_attrs) -# assert %Member{} = member -# assert member.role == 43 -# end -# -# test "update_member/2 with invalid data returns error changeset" do -# member = member_fixture() -# assert {:error, %Ecto.Changeset{}} = Groups.update_member(member, @invalid_attrs) -# assert member == Groups.get_member!(member.id) -# end -# -# test "delete_member/1 deletes the member" do -# member = member_fixture() -# assert {:ok, %Member{}} = Groups.delete_member(member) -# assert_raise Ecto.NoResultsError, fn -> Groups.get_member!(member.id) end -# end -# -# test "change_member/1 returns a member changeset" do -# member = member_fixture() -# assert %Ecto.Changeset{} = Groups.change_member(member) -# end -# end -# -# describe "requests" do -# alias Eventos.Groups.Request -# -# @valid_attrs %{state: 42} -# @update_attrs %{state: 43} -# @invalid_attrs %{state: nil} -# -# def request_fixture(attrs \\ %{}) do -# {:ok, request} = -# attrs -# |> Enum.into(@valid_attrs) -# |> Groups.create_request() -# -# request -# end -# -# test "list_requests/0 returns all requests" do -# request = request_fixture() -# assert Groups.list_requests() == [request] -# end -# -# test "get_request!/1 returns the request with given id" do -# request = request_fixture() -# assert Groups.get_request!(request.id) == request -# end -# -# test "create_request/1 with valid data creates a request" do -# assert {:ok, %Request{} = request} = Groups.create_request(@valid_attrs) -# assert request.state == 42 -# end -# -# test "create_request/1 with invalid data returns error changeset" do -# assert {:error, %Ecto.Changeset{}} = Groups.create_request(@invalid_attrs) -# end -# -# test "update_request/2 with valid data updates the request" do -# request = request_fixture() -# assert {:ok, request} = Groups.update_request(request, @update_attrs) -# assert %Request{} = request -# assert request.state == 43 -# end -# -# test "update_request/2 with invalid data returns error changeset" do -# request = request_fixture() -# assert {:error, %Ecto.Changeset{}} = Groups.update_request(request, @invalid_attrs) -# assert request == Groups.get_request!(request.id) -# end -# -# test "delete_request/1 deletes the request" do -# request = request_fixture() -# assert {:ok, %Request{}} = Groups.delete_request(request) -# assert_raise Ecto.NoResultsError, fn -> Groups.get_request!(request.id) end -# end -# -# test "change_request/1 returns a request changeset" do -# request = request_fixture() -# assert %Ecto.Changeset{} = Groups.change_request(request) -# end -# end -end diff --git a/test/support/factory.ex b/test/support/factory.ex index dcc8a7311..2d15551aa 100644 --- a/test/support/factory.ex +++ b/test/support/factory.ex @@ -6,19 +6,19 @@ defmodule Eventos.Factory do use ExMachina.Ecto, repo: Eventos.Repo def user_factory do - %Eventos.Accounts.User{ + %Eventos.Actors.User{ password_hash: "Jane Smith", email: sequence(:email, &"email-#{&1}@example.com"), role: 0, - account: build(:account) + actor: build(:actor) } end - def account_factory do + def actor_factory do {:ok, {_, pubkey}} = RsaEx.generate_keypair("4096") username = sequence("thomas") - %Eventos.Accounts.Account{ - username: username, + %Eventos.Actors.Actor{ + preferred_username: username, domain: nil, public_key: pubkey, url: EventosWeb.Endpoint.url() <> "/@#{username}" @@ -46,7 +46,7 @@ defmodule Eventos.Factory do end def event_factory do - account = build(:account) + actor = build(:actor) slug = sequence("my-event") %Eventos.Events.Event{ @@ -55,10 +55,10 @@ defmodule Eventos.Factory do description: "My desc", begins_on: nil, ends_on: nil, - organizer_account: account, + organizer_actor: actor, category: build(:category), address: build(:address), - url: EventosWeb.Endpoint.url() <> "/@" <> account.username <> "/" <> slug + url: EventosWeb.Endpoint.url() <> "/@" <> actor.username <> "/" <> slug } end @@ -78,12 +78,13 @@ defmodule Eventos.Factory do end def group_factory do - %Eventos.Groups.Group{ - title: sequence("My Group"), - description: "My group", + username = sequence("My Group") + %Eventos.Actors.Actor{ + preferred_username: username, + summary: "My group", suspended: false, - url: "https://", - address: build(:address) + url: EventosWeb.Endpoint.url() <> "/@#{username}", + type: "Group", } end end