ash_graphql/test/enum_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

84 lines
2.3 KiB
Elixir

defmodule AshGraphql.EnumTest do
use ExUnit.Case, async: false
setup do
on_exit(fn ->
Application.delete_env(:ash_graphql, AshGraphql.Test.Domain)
AshGraphql.TestHelpers.stop_ets()
end)
end
test "enum without value descriptions returns a nil description" do
{:ok, %{data: data}} =
"""
query {
__type(name: "StatusEnum") {
enumValues {
name
description
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
assert %{"name" => "CLOSED", "description" => nil} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "CLOSED" end)
assert %{"name" => "OPEN", "description" => nil} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "OPEN" end)
end
test "Ash.Type.Enum value descriptions are used as description source" do
{:ok, %{data: data}} =
"""
query {
__type(name: "EnumWithAshDescription") {
enumValues {
name
description
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
assert %{"name" => "FIZZ", "description" => "A fizz"} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "FIZZ" end)
assert %{"name" => "BUZZ", "description" => "A buzz"} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "BUZZ" end)
end
test "graphql_describe_enum_value/1 overrides Ash.Type.Enum descriptions" do
{:ok, %{data: data}} =
"""
query {
__type(name: "EnumWithAshGraphqlDescription") {
enumValues {
name
description
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
assert %{"name" => "FOO", "description" => "A foo"} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "FOO" end)
assert %{"name" => "BAR", "description" => "A bar"} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "BAR" end)
assert %{"name" => "NO_DESCRIPTION", "description" => nil} =
data["__type"]["enumValues"]
|> Enum.find(fn value -> value["name"] == "NO_DESCRIPTION" end)
end
end