Skip to content

Commit

Permalink
Fix typing for isNonNullType
Browse files Browse the repository at this point in the history
= If a type is a non-null type, then the wrapped type must be nullable.

= Introduces `GraphQLNullableInputType` and `GraphQLNullableOutputType` to properly represent the result when `isNonNullType` is called on parameters of type `GraphQLInputType` or `GraphQLOutputType`.
  • Loading branch information
yaacovCR committed May 19, 2022
1 parent d9eda1f commit c526767
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 22 deletions.
2 changes: 2 additions & 0 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,8 @@ export type {
GraphQLAbstractType,
GraphQLWrappingType,
GraphQLNullableType,
GraphQLNullableInputType,
GraphQLNullableOutputType,
GraphQLNamedType,
GraphQLNamedInputType,
GraphQLNamedOutputType,
Expand Down
38 changes: 16 additions & 22 deletions src/type/definition.ts
Original file line number Diff line number Diff line change
Expand Up @@ -183,16 +183,16 @@ export function assertListType(type: unknown): GraphQLList<GraphQLType> {

export function isNonNullType(
type: GraphQLInputType,
): type is GraphQLNonNull<GraphQLInputType>;
): type is GraphQLNonNull<GraphQLNullableInputType>;
export function isNonNullType(
type: GraphQLOutputType,
): type is GraphQLNonNull<GraphQLOutputType>;
): type is GraphQLNonNull<GraphQLNullableOutputType>;
export function isNonNullType(
type: unknown,
): type is GraphQLNonNull<GraphQLType>;
): type is GraphQLNonNull<GraphQLNullableType>;
export function isNonNullType(
type: unknown,
): type is GraphQLNonNull<GraphQLType> {
): type is GraphQLNonNull<GraphQLNullableType> {
return instanceOf(type, GraphQLNonNull);
}

Expand All @@ -206,17 +206,15 @@ export function assertNonNullType(type: unknown): GraphQLNonNull<GraphQLType> {
/**
* These types may be used as input types for arguments and directives.
*/
export type GraphQLInputType =
export type GraphQLNullableInputType =
| GraphQLScalarType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLList<GraphQLInputType>
| GraphQLNonNull<
| GraphQLScalarType
| GraphQLEnumType
| GraphQLInputObjectType
| GraphQLList<GraphQLInputType>
>;
| GraphQLList<GraphQLInputType>;

export type GraphQLInputType =
| GraphQLNullableInputType
| GraphQLNonNull<GraphQLNullableInputType>;

export function isInputType(type: unknown): type is GraphQLInputType {
return (
Expand All @@ -237,21 +235,17 @@ export function assertInputType(type: unknown): GraphQLInputType {
/**
* These types may be used as output types as the result of fields.
*/
export type GraphQLOutputType =
export type GraphQLNullableOutputType =
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLList<GraphQLOutputType>
| GraphQLNonNull<
| GraphQLScalarType
| GraphQLObjectType
| GraphQLInterfaceType
| GraphQLUnionType
| GraphQLEnumType
| GraphQLList<GraphQLOutputType>
>;
| GraphQLList<GraphQLOutputType>;

export type GraphQLOutputType =
| GraphQLNullableOutputType
| GraphQLNonNull<GraphQLNullableOutputType>;

export function isOutputType(type: unknown): type is GraphQLOutputType {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/type/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,8 @@ export type {
GraphQLAbstractType,
GraphQLWrappingType,
GraphQLNullableType,
GraphQLNullableInputType,
GraphQLNullableOutputType,
GraphQLNamedType,
GraphQLNamedInputType,
GraphQLNamedOutputType,
Expand Down

0 comments on commit c526767

Please sign in to comment.