ash/test/actions/side_load_test.exs

225 lines
4.6 KiB
Elixir
Raw Normal View History

2019-12-12 11:45:59 +13:00
defmodule Ash.Test.Actions.SideLoadTest do
2020-06-02 17:47:25 +12:00
@moduledoc false
use ExUnit.Case, async: false
2019-12-12 11:45:59 +13:00
2020-10-08 18:22:55 +13:00
require Ash.Query
2019-12-12 11:45:59 +13:00
defmodule Author do
2020-06-02 17:47:25 +12:00
@moduledoc false
use Ash.Resource,
data_layer: Ash.DataLayer.Ets,
authorizers: [
Ash.Test.Authorizer
]
ets do
private?(true)
end
2019-12-12 11:45:59 +13:00
actions do
read :read
create :create
2019-12-12 11:45:59 +13:00
end
attributes do
uuid_primary_key :id
2019-12-12 11:45:59 +13:00
attribute :name, :string
end
relationships do
2020-06-22 16:34:44 +12:00
has_many :posts, Ash.Test.Actions.SideLoadTest.Post, destination_field: :author_id
2019-12-12 11:45:59 +13:00
end
end
defmodule Post do
2020-06-02 17:47:25 +12:00
@moduledoc false
use Ash.Resource, data_layer: Ash.DataLayer.Ets
ets do
private?(true)
end
2019-12-12 11:45:59 +13:00
actions do
read :read
create :create
2019-12-12 11:45:59 +13:00
end
attributes do
uuid_primary_key :id
2019-12-12 11:45:59 +13:00
attribute :title, :string
attribute :contents, :string
end
relationships do
2020-06-22 16:34:44 +12:00
belongs_to :author, Author
2020-08-30 19:15:16 +12:00
many_to_many :categories, Ash.Test.Actions.SideLoadTest.Category,
through: Ash.Test.Actions.SideLoadTest.PostCategory,
destination_field_on_join_table: :category_id,
source_field_on_join_table: :post_id
end
end
defmodule PostCategory do
@moduledoc false
use Ash.Resource, data_layer: Ash.DataLayer.Ets
ets do
private?(true)
end
actions do
read :read
create :create
end
relationships do
belongs_to :post, Post, primary_key?: true, required?: true
belongs_to :category, Ash.Test.Actions.SideLoadTest.Category,
primary_key?: true,
required?: true
end
end
defmodule Category do
use Ash.Resource, data_layer: Ash.DataLayer.Ets
ets do
private?(true)
end
actions do
read :read
create :create
end
attributes do
uuid_primary_key :id
attribute :name, :string
end
relationships do
many_to_many :posts, Post,
through: PostCategory,
destination_field_on_join_table: :post_id,
source_field_on_join_table: :category_id
2019-12-12 11:45:59 +13:00
end
end
defmodule Api do
2020-06-02 17:47:25 +12:00
@moduledoc false
2019-12-12 11:45:59 +13:00
use Ash.Api
resources do
resource(Author)
resource(Post)
resource(Category)
resource(PostCategory)
end
2019-12-12 11:45:59 +13:00
end
setup do
start_supervised(
{Ash.Test.Authorizer,
strict_check: :authorized,
check: {:error, Ash.Error.Forbidden.exception([])},
strict_check_context: [:query]}
)
:ok
end
2020-07-12 18:25:53 +12:00
import Ash.Changeset
2019-12-12 11:45:59 +13:00
describe "side_loads" do
test "it allows sideloading related data" do
2020-07-12 18:25:53 +12:00
author =
Author
|> new(%{name: "zerg"})
2020-07-12 18:25:53 +12:00
|> Api.create!()
2019-12-12 11:45:59 +13:00
post1 =
2020-07-12 18:25:53 +12:00
Post
|> new(%{title: "post1"})
2020-07-12 18:25:53 +12:00
|> replace_relationship(:author, author)
|> Api.create!()
2019-12-12 11:45:59 +13:00
post2 =
2020-07-12 18:25:53 +12:00
Post
|> new(%{title: "post2"})
2020-07-12 18:25:53 +12:00
|> replace_relationship(:author, author)
|> Api.create!()
2019-12-12 11:45:59 +13:00
[author] =
Author
|> Ash.Query.load(posts: [:author])
2020-10-08 18:22:55 +13:00
|> Ash.Query.filter(posts.id == ^post1.id)
|> Api.read!(authorize?: true)
2019-12-12 11:45:59 +13:00
assert Enum.sort(Enum.map(author.posts, &Map.get(&1, :id))) ==
Enum.sort([post1.id, post2.id])
2019-12-20 17:19:34 +13:00
for post <- author.posts do
assert post.author.id == author.id
end
end
test "it allows sideloading many to many relationships" do
2020-07-12 18:25:53 +12:00
category1 =
Category
|> new(%{name: "lame"})
2020-07-12 18:25:53 +12:00
|> Api.create!()
category2 =
Category
|> new(%{name: "cool"})
2020-07-12 18:25:53 +12:00
|> Api.create!()
post =
2020-07-12 18:25:53 +12:00
Post
|> new(%{title: "post1"})
2020-07-12 18:25:53 +12:00
|> replace_relationship(:categories, [category1, category2])
|> Api.create!()
[post] =
Post
|> Ash.Query.load(:categories)
2020-10-08 18:22:55 +13:00
|> Ash.Query.filter(id == ^post.id)
|> Api.read!(authorize?: true)
assert [%{id: id1}, %{id: id2}] = post.categories
assert Enum.sort([category1.id, category2.id]) == Enum.sort([id1, id2])
end
test "it allows sideloading nested many to many relationships" do
2020-07-12 18:25:53 +12:00
category1 =
Category
|> new(%{name: "lame"})
2020-07-12 18:25:53 +12:00
|> Api.create!()
category2 =
Category
|> new(%{name: "cool"})
2020-07-12 18:25:53 +12:00
|> Api.create!()
post =
2020-07-12 18:25:53 +12:00
Post
|> new(%{title: "post1"})
2020-07-12 18:25:53 +12:00
|> replace_relationship(:categories, [category1, category2])
|> Api.create!()
[post] =
Post
|> Ash.Query.load(categories: :posts)
2020-10-08 18:22:55 +13:00
|> Ash.Query.filter(id == ^post.id)
|> Api.read!(authorize?: true)
post_id = post.id
assert [%{posts: [%{id: ^post_id}]}, %{posts: [%{id: ^post_id}]}] = post.categories
end
2019-12-12 11:45:59 +13:00
end
end