Skip to content

Commit

Permalink
Add option to not include specifiedByUrl in introspection query
Browse files Browse the repository at this point in the history
  • Loading branch information
m14t committed Apr 29, 2020
1 parent 64e8150 commit 17d4ad3
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 2 deletions.
1 change: 1 addition & 0 deletions src/type/__tests__/introspection-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ describe('Introspection', () => {
const source = getIntrospectionQuery({
descriptions: false,
directiveIsRepeatable: true,
specifiedByUrl: true,
});

const result = graphqlSync({ schema, source });
Expand Down
5 changes: 4 additions & 1 deletion src/utilities/__tests__/buildClientSchema-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,10 @@ import { introspectionFromSchema } from '../introspectionFromSchema';
* returns that schema printed as SDL.
*/
function cycleIntrospection(sdlString: string): string {
const options = { directiveIsRepeatable: true };
const options = {
directiveIsRepeatable: true,
specifiedByUrl: true,
};

const serverSchema = buildSchema(sdlString);
const initialIntrospection = introspectionFromSchema(serverSchema, options);
Expand Down
12 changes: 12 additions & 0 deletions src/utilities/__tests__/getIntrospectionQuery-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -51,4 +51,16 @@ describe('getIntrospectionQuery', () => {
getIntrospectionQuery({ descriptions: false, schemaDescription: true }),
).to.not.match(/\bdescription\b/);
});

it('include "specifiedByUrl" field', () => {
expect(getIntrospectionQuery()).to.not.match(/\bspecifiedByUrl\b/);

expect(getIntrospectionQuery({ specifiedByUrl: true })).to.match(
/\bspecifiedByUrl\b/,
);

expect(getIntrospectionQuery({ specifiedByUrl: false })).to.not.match(
/\bspecifiedByUrl\b/,
);
});
});
4 changes: 4 additions & 0 deletions src/utilities/getIntrospectionQuery.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ export interface IntrospectionOptions {
// Default: true
descriptions: boolean;

// Whether to include `specifiedByUrl` in the introspection result.
// Default: false
specifiedByUrl?: boolean;

// Whether to include `isRepeatable` flag on directives.
// Default: false
directiveIsRepeatable?: boolean;
Expand Down
10 changes: 9 additions & 1 deletion src/utilities/getIntrospectionQuery.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@ export type IntrospectionOptions = {|
// Default: true
descriptions?: boolean,

// Whether to include `specifiedByUrl` in the introspection result.
// Default: false
specifiedByUrl?: boolean,

// Whether to include `isRepeatable` field on directives.
// Default: false
directiveIsRepeatable?: boolean,
Expand All @@ -19,12 +23,16 @@ export type IntrospectionOptions = {|
export function getIntrospectionQuery(options?: IntrospectionOptions): string {
const optionsWithDefault = {
descriptions: true,
specifiedByUrl: false,
directiveIsRepeatable: false,
schemaDescription: false,
...options,
};

const descriptions = optionsWithDefault.descriptions ? 'description' : '';
const specifiedByUrl = optionsWithDefault.specifiedByUrl
? 'specifiedByUrl'
: '';
const directiveIsRepeatable = optionsWithDefault.directiveIsRepeatable
? 'isRepeatable'
: '';
Expand Down Expand Up @@ -58,7 +66,7 @@ export function getIntrospectionQuery(options?: IntrospectionOptions): string {
kind
name
${descriptions}
specifiedByUrl
${specifiedByUrl}
fields(includeDeprecated: true) {
name
${descriptions}
Expand Down

0 comments on commit 17d4ad3

Please sign in to comment.