You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
here is how the ConsoleUserRoleId ConsoleUserId fields are described
static member ValidStringScalar<'t>(typeName, createValid : Validator<string, 't>, toString : 't -> string, ?description: string) (*: ScalarDefinition<string, 't>*) =
let createValid : string -> ValidationResult<'t> = createValid typeName
Define.WrappedScalar
(name = typeName,
coerceInput =
(function
| Variable e when e.ValueKind = JsonValueKind.String -> e.GetString() |> createValid |> Result.mapError ValidationErrors.toIGQLErrors
| InlineConstant (StringValue s) -> s |> createValid |> Result.mapError ValidationErrors.toIGQLErrors
| Variable e -> e.GetDeserializeError typeName
| InlineConstant value -> value.GetCoerceError typeName),
coerceOutput =
(function
| :? 't as x -> Some (toString x)
| :? string as s -> s |> Some
| _ -> raise <| System.NotSupportedException ()),
?description = description)
and this is how the PropertyIDType field is described
Define.WrappedScalar
(name = typeName,
coerceInput = (function
| Variable e when e.ValueKind = JsonValueKind.String -> e.GetString() |> PropertyId.ofString |> Ok
| InlineConstant (StringValue s) -> s |> PropertyId.ofString |> Ok
| Variable e -> e.GetDeserializeError typeName
| InlineConstant value -> value.GetCoerceError typeName),
coerceOutput =
(function
| :? PropertyId as x -> Some (PropertyId.toString x)
| :? string as s -> s |> Some
| _ -> raise <| System.NotSupportedException ()),
?description = Some "I of specific property")
{
"documentId": -1969558732,
"errors": [
{
"message": "Index was outside the bounds of the array."
}
]
}
the error occurs somewhere after propertyId conversion but before roleId because the debugger does not enter the conversion to roleId but correctly and without errors exits from propertyId.
Expected behavior
More useful error message
Actual behavior
An error that doesn't tell me anything that can help me.
Known workarounds
Most likely it will help to replace all custom types with standard ones, but it will not solve the problem with bad error message.
Related information
Operating system: Windows 11
Branch: master (Nuget 3.0.0-ci-10873959355)
The text was updated successfully, but these errors were encountered:
Hi @dim-37 . I could take a look into that. Can you provide the createValid function you're using? And, even better, surrounding code that makes reproducing your scenario more accurate?
Since you're using a wrapped scalar, if your custom validator is throwing an IndexOutOfRangeException somewhere, then this explains the response you're getting. So far, I'm not sure this is a library issue. Please also inspect (e.g. by logging) the property Exception in the produced GQLResponse so you can see exactly in the stack trace exactly where the exception is being thrown.
Description
I have a structure
and here's its description for graphql
here is how the ConsoleUserRoleId ConsoleUserId fields are described
and this is how the PropertyIDType field is described
here is the request
and this is the response I'm getting
the error occurs somewhere after propertyId conversion but before roleId because the debugger does not enter the conversion to roleId but correctly and without errors exits from propertyId.
Expected behavior
More useful error message
Actual behavior
An error that doesn't tell me anything that can help me.
Known workarounds
Most likely it will help to replace all custom types with standard ones, but it will not solve the problem with bad error message.
Related information
Operating system: Windows 11
Branch: master (Nuget 3.0.0-ci-10873959355)
The text was updated successfully, but these errors were encountered: