From a81e2919035151e18ec9abd2cc8758b18665fca8 Mon Sep 17 00:00:00 2001 From: Robert Schadek Date: Tue, 25 Jun 2019 08:57:26 +0100 Subject: [PATCH] toGraphqlJson updates --- README.md | 2 +- source/graphql/uda.d | 16 ++++++---------- source/graphql/validation/schemabased.d | 15 +++++++++++++++ 3 files changed, 22 insertions(+), 11 deletions(-) diff --git a/README.md b/README.md index 762bb895..cc893519 100644 --- a/README.md +++ b/README.md @@ -56,7 +56,7 @@ This graphql implementation is based on June 2018 spec. - [x] Directives - [x] Include - [x] Skip - - [ ] Custom + - [?] Custom (Requires changing the graphqld source) - [x] Enumerations - [x] Input Objects - [x] Mutations diff --git a/source/graphql/uda.d b/source/graphql/uda.d index 7505ce99..161f7569 100644 --- a/source/graphql/uda.d +++ b/source/graphql/uda.d @@ -161,16 +161,12 @@ template getUdaData(Type) { } template getUdaData(Type, string mem) { - //static if(isBuiltinType!(typeof(__traits(getMember, Type, mem)))) { - // enum getUdaData = GQLDUdaData.init; - //} else { - alias GQLDUdaDataAS = getGQLDUdaData!(Type, mem); - static if(GQLDUdaDataAS.length > 0) { - enum getUdaData = GQLDUdaDataAS[0]; - } else { - enum getUdaData = GQLDUdaData.init; - } - //} + alias GQLDUdaDataAS = getGQLDUdaData!(Type, mem); + static if(GQLDUdaDataAS.length > 0) { + enum getUdaData = GQLDUdaDataAS[0]; + } else { + enum getUdaData = GQLDUdaData.init; + } } unittest { diff --git a/source/graphql/validation/schemabased.d b/source/graphql/validation/schemabased.d index ad233c03..617bc2d3 100644 --- a/source/graphql/validation/schemabased.d +++ b/source/graphql/validation/schemabased.d @@ -747,3 +747,18 @@ unittest { test!void(str); } + +unittest { + string str = ` +{ + starships { + crew { + ... on Humanoid { + doesNotExist + } + } + } +}`; + + test!FieldDoesNotExist(str); +}