ash_graphql/test/attribute_test.exs

143 lines
3.8 KiB
Elixir
Raw Permalink Normal View History

defmodule AshGraphql.AttributeTest do
use ExUnit.Case, async: false
setup do
on_exit(fn ->
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-02 07:03:06 +13:00
Application.delete_env(:ash_graphql, AshGraphql.Test.Domain)
try do
AshGraphql.TestHelpers.stop_ets()
rescue
_ ->
:ok
end
end)
end
test ":uuid arguments are mapped to ID type" do
{:ok, %{data: data}} =
"""
query {
__type(name: "SimpleCreatePostInput") {
inputFields {
name
type {
kind
name
ofType {
kind
name
}
}
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
author_id_field =
data["__type"]["inputFields"]
|> Enum.find(fn field -> field["name"] == "authorId" end)
assert author_id_field["type"]["name"] == "ID"
end
test "nested maps with constraints create types for nested maps" do
assert {:ok,
%{
data: %{
"__type" => %{
"fields" => [
%{
"name" => "bam",
"type" => %{
"kind" => "OBJECT",
"name" => "ConstrainedMapBam",
"ofType" => nil
}
},
%{
"name" => "baz",
"type" => %{"kind" => "SCALAR", "name" => "Int", "ofType" => nil}
},
%{
"name" => "fooBar",
"type" => %{
"kind" => "NON_NULL",
"name" => nil,
"ofType" => %{"kind" => "SCALAR", "name" => "String"}
}
}
]
}
}
}} =
"""
query {
__type(name: "ConstrainedMap") {
fields {
name
type {
kind
name
ofType {
kind
name
}
}
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
assert {:ok,
%{
data: %{
"__type" => %{
"inputFields" => [
%{
"name" => "bam",
"type" => %{
"kind" => "INPUT_OBJECT",
"name" => "ConstrainedMapBamInput",
"ofType" => nil
}
},
%{
"name" => "baz",
"type" => %{"kind" => "SCALAR", "name" => "Int", "ofType" => nil}
},
%{
"name" => "fooBar",
"type" => %{
"kind" => "NON_NULL",
"name" => nil,
"ofType" => %{"kind" => "SCALAR", "name" => "String"}
}
}
]
}
}
}} =
"""
query {
__type(name: "ConstrainedMapInput") {
inputFields {
name
type {
kind
name
ofType {
kind
name
}
}
}
}
}
"""
|> Absinthe.run(AshGraphql.Test.Schema)
end
end