ash_graphql/test/update_test.exs
Riccardo Binetti 513c1ac68f
improvement!: port AshGraphql to Ash 3.0 (#123)
Step 1: update Ash

Step 2: mass rename Api to Domain

Step 3: Ash.Query.expr -> Ash.Expr.expr

Also change ref interpolation

Step 4: remove all warnings

Step 5: remove registries from tests

Step 6: fix filter

Step 7: private? -> !public?

Step 8: Ash.Calculation -> Ash.Resource.Calculation

Step 9: use depend_on_resources/1 -> resources/1

Step 10: add Domain to all resources

Step 11: use Ash module for all actions

Step 12: add public? true all around

Step 13: remove verbose? from options passed during Domain calls

Step 14: add simple_sat

Step 15: Ash.ErrorKind is no more, so remove code from errors

Step 16: sprinkle default_accept :* around tests

Step 17: replace Ash.Changeset.new/2 with Ash.Changeset.for_*

Step 18: calculation fixups

- Context is now a struct and arguments go under the arguments key
- Function based calculations receive a list of records
- Add a select to query-based loads
- select -> load

Step 19: pass the correct name to pass the policy in tests

Step 20: Ash.Query.new/2 is no more

Step 21: add AshGraphql.Resource.embedded? utility function

Use that instead of Ash.Type.embedded_type?(resource_or_type) since resources
are not types anymore

Step 22: handle struct + instance_of: Resource in unions

Resources are not type anymore so they need to be passed this way in unions

Step 23: ensure we only check GraphQL actions for pagination

All reads are now paginated by default, so this triggered a compilation error

Step 24: swap arguments for sort on calculations

Step 25: remove unused debug? option
2024-04-01 14:03:06 -04:00

328 lines
7.5 KiB
Elixir

defmodule AshGraphql.UpdateTest do
use ExUnit.Case, async: false
setup do
on_exit(fn ->
Application.delete_env(:ash_graphql, AshGraphql.Test.Domain)
try do
AshGraphql.TestHelpers.stop_ets()
rescue
_ ->
:ok
end
end)
end
test "an update works" do
post =
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar")
|> Ash.create!()
resp =
"""
mutation UpdatePost($id: ID!, $input: UpdatePostInput) {
updatePost(id: $id, input: $input) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post.id,
"input" => %{
"text" => "barbuz"
}
}
)
assert {:ok, %{data: %{"updatePost" => %{"errors" => [], "result" => %{"text" => "barbuz"}}}}} =
resp
end
test "an update with a managed relationship works" do
resp =
"""
mutation CreatePostWithComments($input: CreatePostWithCommentsInput) {
createPostWithComments(input: $input) {
result{
id
text
comments(sort:{field:TEXT}){
id
text
}
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"input" => %{
"text" => "foobar",
"comments" => [
%{"text" => "foobar"},
%{"text" => "barfoo"}
]
}
}
)
assert {:ok, result} = resp
refute Map.has_key?(result, :errors)
assert %{
data: %{
"createPostWithComments" => %{
"result" => %{
"id" => post_id,
"text" => "foobar",
"comments" => [
%{"id" => comment_id, "text" => "barfoo"},
%{"text" => "foobar"}
]
}
}
}
} = result
resp =
"""
mutation UpdatePostWithComments($id: ID!, $input: UpdatePostWithCommentsInput) {
updatePostWithComments(id: $id, input: $input) {
result{
comments(sort:{field:TEXT}){
id
text
}
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post_id,
"input" => %{
"comments" => [
%{"text" => "barfoonew", "id" => comment_id}
]
}
}
)
assert {:ok, result} = resp
refute Map.has_key?(result, :errors)
assert %{
data: %{
"updatePostWithComments" => %{
"result" => %{
"comments" => [%{"id" => ^comment_id, "text" => "barfoonew"}]
}
}
}
} = result
end
test "an update with a configured read action and no identity works" do
post =
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar", best: true)
|> Ash.create!()
resp =
"""
mutation UpdateBestPost($input: UpdateBestPostInput) {
updateBestPost(input: $input) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post.id,
"input" => %{
"text" => "barbuz"
}
}
)
assert {:ok,
%{data: %{"updateBestPost" => %{"errors" => [], "result" => %{"text" => "barbuz"}}}}} =
resp
end
test "an update with a configured read action and no identity works with an argument the same name as an attribute" do
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar", best: true)
|> Ash.create!()
resp =
"""
mutation UpdateBestPostArg($best: Boolean!, $input: UpdateBestPostArgInput) {
updateBestPostArg(best: $best, input: $input) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"best" => true,
"input" => %{
"text" => "barbuz"
}
}
)
assert {:ok,
%{
data: %{"updateBestPostArg" => %{"errors" => [], "result" => %{"text" => "barbuz"}}}
}} = resp
end
test "arguments are threaded properly" do
post =
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar", best: true)
|> Ash.create!()
resp =
"""
mutation UpdatePostConfirm($input: UpdatePostConfirmInput, $id: ID!) {
updatePostConfirm(input: $input, id: $id) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post.id,
"input" => %{
"text" => "foobar",
"confirmation" => "foobar2"
}
}
)
assert {:ok, result} = resp
assert %{
data: %{
"updatePostConfirm" => %{"result" => nil, "errors" => [%{"message" => message}]}
}
} = result
assert message =~ "confirmation did not match value"
end
test "root level error" do
Application.put_env(:ash_graphql, AshGraphql.Test.Domain,
graphql: [show_raised_errors?: true, root_level_errors?: true]
)
post =
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar", best: true)
|> Ash.create!()
resp =
"""
mutation UpdatePostConfirm($input: UpdatePostConfirmInput, $id: ID!) {
updatePostConfirm(input: $input, id: $id) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post.id,
"input" => %{
"text" => "foobar",
"confirmation" => "foobar2"
}
}
)
assert {:ok, result} = resp
assert %{errors: [%{message: message}]} = result
assert message =~ "confirmation did not match value"
end
test "referencing a hidden input is not allowed" do
post =
AshGraphql.Test.Post
|> Ash.Changeset.for_create(:create, text: "foobar")
|> Ash.create!()
resp =
"""
mutation UpdatePostWithHiddenInput($id: ID!, $input: UpdatePostWithHiddenInputInput) {
updatePostWithHiddenInput(id: $id, input: $input) {
result{
text
}
errors{
message
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema,
variables: %{
"id" => post.id,
"input" => %{
"score" => 10
}
}
)
assert {
:ok,
%{
errors: [
%{
message:
"Argument \"input\" has invalid value $input.\nIn field \"score\": Unknown field."
}
]
}
} =
resp
end
end