Fix KnownDirectives validator to support all directives

This commit is contained in:
Daniel Tschinder 2018-02-11 13:15:51 +01:00
parent d6add77540
commit 0c32982171
9 changed files with 221 additions and 51 deletions

View File

@ -266,9 +266,9 @@ class DocumentValidator
} }
} }
return $errors; return $errors;
} else {
return static::isValidLiteralValue($itemType, $valueNode);
} }
return static::isValidLiteralValue($itemType, $valueNode);
} }
// Input objects check each defined field and look for undefined fields. // Input objects check each defined field and look for undefined fields.
@ -278,6 +278,7 @@ class DocumentValidator
} }
$fields = $type->getFields(); $fields = $type->getFields();
$errors = []; $errors = [];
// Ensure every provided field is defined. // Ensure every provided field is defined.

View File

@ -1,10 +1,9 @@
<?php <?php
namespace GraphQL\Validator\Rules; namespace GraphQL\Validator\Rules;
use GraphQL\Error\Error; use GraphQL\Error\Error;
use GraphQL\Language\AST\DirectiveNode; use GraphQL\Language\AST\DirectiveNode;
use GraphQL\Language\AST\Node; use GraphQL\Language\AST\InputObjectTypeDefinitionNode;
use GraphQL\Language\AST\NodeKind; use GraphQL\Language\AST\NodeKind;
use GraphQL\Validator\ValidationContext; use GraphQL\Validator\ValidationContext;
use GraphQL\Type\Definition\DirectiveLocation; use GraphQL\Type\Definition\DirectiveLocation;
@ -40,8 +39,7 @@ class KnownDirectives extends AbstractValidationRule
)); ));
return ; return ;
} }
$appliedTo = $ancestors[count($ancestors) - 1]; $candidateLocation = $this->getDirectiveLocationForASTPath($ancestors);
$candidateLocation = $this->getLocationForAppliedNode($appliedTo);
if (!$candidateLocation) { if (!$candidateLocation) {
$context->reportError(new Error( $context->reportError(new Error(
@ -58,8 +56,9 @@ class KnownDirectives extends AbstractValidationRule
]; ];
} }
private function getLocationForAppliedNode(Node $appliedTo) private function getDirectiveLocationForASTPath(array $ancestors)
{ {
$appliedTo = $ancestors[count($ancestors) - 1];
switch ($appliedTo->kind) { switch ($appliedTo->kind) {
case NodeKind::OPERATION_DEFINITION: case NodeKind::OPERATION_DEFINITION:
switch ($appliedTo->operation) { switch ($appliedTo->operation) {
@ -72,6 +71,20 @@ class KnownDirectives extends AbstractValidationRule
case NodeKind::FRAGMENT_SPREAD: return DirectiveLocation::FRAGMENT_SPREAD; case NodeKind::FRAGMENT_SPREAD: return DirectiveLocation::FRAGMENT_SPREAD;
case NodeKind::INLINE_FRAGMENT: return DirectiveLocation::INLINE_FRAGMENT; case NodeKind::INLINE_FRAGMENT: return DirectiveLocation::INLINE_FRAGMENT;
case NodeKind::FRAGMENT_DEFINITION: return DirectiveLocation::FRAGMENT_DEFINITION; case NodeKind::FRAGMENT_DEFINITION: return DirectiveLocation::FRAGMENT_DEFINITION;
case NodeKind::SCHEMA_DEFINITION: return DirectiveLocation::SCHEMA;
case NodeKind::SCALAR_TYPE_DEFINITION: return DirectiveLocation::SCALAR;
case NodeKind::OBJECT_TYPE_DEFINITION: return DirectiveLocation::OBJECT;
case NodeKind::FIELD_DEFINITION: return DirectiveLocation::FIELD_DEFINITION;
case NodeKind::INTERFACE_TYPE_DEFINITION: return DirectiveLocation::IFACE;
case NodeKind::UNION_TYPE_DEFINITION: return DirectiveLocation::UNION;
case NodeKind::ENUM_TYPE_DEFINITION: return DirectiveLocation::ENUM;
case NodeKind::ENUM_VALUE_DEFINITION: return DirectiveLocation::ENUM_VALUE;
case NodeKind::INPUT_OBJECT_TYPE_DEFINITION: return DirectiveLocation::INPUT_OBJECT;
case NodeKind::INPUT_VALUE_DEFINITION:
$parentNode = $ancestors[count($ancestors) - 3];
return $parentNode instanceof InputObjectTypeDefinitionNode
? DirectiveLocation::INPUT_FIELD_DEFINITION
: DirectiveLocation::ARGUMENT_DEFINITION;
} }
} }
} }

View File

@ -1131,7 +1131,7 @@ class VisitorTest extends \PHPUnit_Framework_TestCase
{ {
$visited = []; $visited = [];
$typeInfo = new TypeInfo(TestCase::getDefaultSchema()); $typeInfo = new TypeInfo(TestCase::getTestSchema());
$ast = Parser::parse('{ human(id: 4) { name, pets { ... { name } }, unknown } }'); $ast = Parser::parse('{ human(id: 4) { name, pets { ... { name } }, unknown } }');
Visitor::visit($ast, Visitor::visitWithTypeInfo($typeInfo, [ Visitor::visit($ast, Visitor::visitWithTypeInfo($typeInfo, [
@ -1213,7 +1213,7 @@ class VisitorTest extends \PHPUnit_Framework_TestCase
public function testMaintainsTypeInfoDuringEdit() public function testMaintainsTypeInfoDuringEdit()
{ {
$visited = []; $visited = [];
$typeInfo = new TypeInfo(TestCase::getDefaultSchema()); $typeInfo = new TypeInfo(TestCase::getTestSchema());
$ast = Parser::parse( $ast = Parser::parse(
'{ human(id: 4) { name, pets }, alien }' '{ human(id: 4) { name, pets }, alien }'

View File

@ -615,7 +615,7 @@ class ArgumentsOfCorrectTypeTest extends TestCase
$this->expectPassesRule(new ArgumentsOfCorrectType(), ' $this->expectPassesRule(new ArgumentsOfCorrectType(), '
{ {
complicatedArgs { complicatedArgs {
stringListArgField(stringListArg: ["one", "two"]) stringListArgField(stringListArg: ["one", null, "two"])
} }
} }
'); ');

View File

@ -89,12 +89,16 @@ class KnownDirectivesTest extends TestCase
public function testWithWellPlacedDirectives() public function testWithWellPlacedDirectives()
{ {
$this->expectPassesRule(new KnownDirectives, ' $this->expectPassesRule(new KnownDirectives, '
query Foo { query Foo @onQuery {
name @include(if: true) name @include(if: true)
...Frag @include(if: true) ...Frag @include(if: true)
skippedField @skip(if: true) skippedField @skip(if: true)
...SkippedFrag @skip(if: true) ...SkippedFrag @skip(if: true)
} }
mutation Bar @onMutation {
someField
}
'); ');
} }
@ -105,16 +109,103 @@ class KnownDirectivesTest extends TestCase
{ {
$this->expectFailsRule(new KnownDirectives, ' $this->expectFailsRule(new KnownDirectives, '
query Foo @include(if: true) { query Foo @include(if: true) {
name @operationOnly name @onQuery
...Frag @operationOnly ...Frag @onQuery
}
mutation Bar @onQuery {
someField
} }
', [ ', [
$this->misplacedDirective('include', 'QUERY', 2, 17), $this->misplacedDirective('include', 'QUERY', 2, 17),
$this->misplacedDirective('operationOnly', 'FIELD', 3, 14), $this->misplacedDirective('onQuery', 'FIELD', 3, 14),
$this->misplacedDirective('operationOnly', 'FRAGMENT_SPREAD', 4, 17), $this->misplacedDirective('onQuery', 'FRAGMENT_SPREAD', 4, 17),
$this->misplacedDirective('onQuery', 'MUTATION', 7, 20),
]); ]);
} }
// within schema language
/**
* @it with well placed directives
*/
public function testWSLWithWellPlacedDirectives()
{
$this->expectPassesRule(new KnownDirectives, '
type MyObj implements MyInterface @onObject {
myField(myArg: Int @onArgumentDefinition): String @onFieldDefinition
}
scalar MyScalar @onScalar
interface MyInterface @onInterface {
myField(myArg: Int @onArgumentDefinition): String @onFieldDefinition
}
union MyUnion @onUnion = MyObj | Other
enum MyEnum @onEnum {
MY_VALUE @onEnumValue
}
input MyInput @onInputObject {
myField: Int @onInputFieldDefinition
}
schema @onSchema {
query: MyQuery
}
');
}
/**
* @it with misplaced directives
*/
public function testWSLWithMisplacedDirectives()
{
$this->expectFailsRule(new KnownDirectives, '
type MyObj implements MyInterface @onInterface {
myField(myArg: Int @onInputFieldDefinition): String @onInputFieldDefinition
}
scalar MyScalar @onEnum
interface MyInterface @onObject {
myField(myArg: Int @onInputFieldDefinition): String @onInputFieldDefinition
}
union MyUnion @onEnumValue = MyObj | Other
enum MyEnum @onScalar {
MY_VALUE @onUnion
}
input MyInput @onEnum {
myField: Int @onArgumentDefinition
}
schema @onObject {
query: MyQuery
}
',
[
$this->misplacedDirective('onInterface', 'OBJECT', 2, 43),
$this->misplacedDirective('onInputFieldDefinition', 'ARGUMENT_DEFINITION', 3, 30),
$this->misplacedDirective('onInputFieldDefinition', 'FIELD_DEFINITION', 3, 63),
$this->misplacedDirective('onEnum', 'SCALAR', 6, 25),
$this->misplacedDirective('onObject', 'INTERFACE', 8, 31),
$this->misplacedDirective('onInputFieldDefinition', 'ARGUMENT_DEFINITION', 9, 30),
$this->misplacedDirective('onInputFieldDefinition', 'FIELD_DEFINITION', 9, 63),
$this->misplacedDirective('onEnumValue', 'UNION', 12, 23),
$this->misplacedDirective('onScalar', 'ENUM', 14, 21),
$this->misplacedDirective('onUnion', 'ENUM_VALUE', 15, 20),
$this->misplacedDirective('onEnum', 'INPUT_OBJECT', 18, 23),
$this->misplacedDirective('onArgumentDefinition', 'INPUT_FIELD_DEFINITION', 19, 24),
$this->misplacedDirective('onObject', 'SCHEMA', 22, 16),
]
);
}
private function unknownDirective($directiveName, $line, $column) private function unknownDirective($directiveName, $line, $column)
{ {
return FormattedError::create( return FormattedError::create(

View File

@ -2,13 +2,11 @@
namespace GraphQL\Tests\Validator; namespace GraphQL\Tests\Validator;
use GraphQL\Error\FormattedError; use GraphQL\Error\FormattedError;
use GraphQL\Language\Source;
use GraphQL\Language\SourceLocation; use GraphQL\Language\SourceLocation;
use GraphQL\Schema; use GraphQL\Type\Schema;
use GraphQL\Type\Definition\InterfaceType; use GraphQL\Type\Definition\InterfaceType;
use GraphQL\Type\Definition\ObjectType; use GraphQL\Type\Definition\ObjectType;
use GraphQL\Type\Definition\Type; use GraphQL\Type\Definition\Type;
use GraphQL\Type\Definition\UnionType;
use GraphQL\Validator\Rules\OverlappingFieldsCanBeMerged; use GraphQL\Validator\Rules\OverlappingFieldsCanBeMerged;
class OverlappingFieldsCanBeMergedTest extends TestCase class OverlappingFieldsCanBeMergedTest extends TestCase
@ -445,7 +443,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
// type IntBox and the interface type NonNullStringBox1. While that // type IntBox and the interface type NonNullStringBox1. While that
// condition does not exist in the current schema, the schema could // condition does not exist in the current schema, the schema could
// expand in the future to allow this. Thus it is invalid. // expand in the future to allow this. Thus it is invalid.
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
...on IntBox { ...on IntBox {
@ -476,7 +474,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
// In this case `deepBox` returns `SomeBox` in the first usage, and // In this case `deepBox` returns `SomeBox` in the first usage, and
// `StringBox` in the second usage. These return types are not the same! // `StringBox` in the second usage. These return types are not the same!
// however this is valid because the return *shapes* are compatible. // however this is valid because the return *shapes* are compatible.
$this->expectPassesRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectPassesRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on SomeBox { ... on SomeBox {
@ -499,7 +497,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testDisallowsDifferingReturnTypesDespiteNoOverlap() public function testDisallowsDifferingReturnTypesDespiteNoOverlap()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -527,7 +525,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testDisallowsDifferingReturnTypeNullabilityDespiteNoOverlap() public function testDisallowsDifferingReturnTypeNullabilityDespiteNoOverlap()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on NonNullStringBox1 { ... on NonNullStringBox1 {
@ -555,7 +553,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testDisallowsDifferingReturnTypeListDespiteNoOverlap() public function testDisallowsDifferingReturnTypeListDespiteNoOverlap()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -582,7 +580,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
]); ]);
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -611,7 +609,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
public function testDisallowsDifferingSubfields() public function testDisallowsDifferingSubfields()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -645,7 +643,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testDisallowsDifferingDeepReturnTypesDespiteNoOverlap() public function testDisallowsDifferingDeepReturnTypesDespiteNoOverlap()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -681,7 +679,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testAllowsNonConflictingOverlapingTypes() public function testAllowsNonConflictingOverlapingTypes()
{ {
$this->expectPassesRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectPassesRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
... on IntBox { ... on IntBox {
@ -700,7 +698,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testSameWrappedScalarReturnTypes() public function testSameWrappedScalarReturnTypes()
{ {
$this->expectPassesRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectPassesRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
...on NonNullStringBox1 { ...on NonNullStringBox1 {
@ -719,7 +717,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testAllowsInlineTypelessFragments() public function testAllowsInlineTypelessFragments()
{ {
$this->expectPassesRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectPassesRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
a a
... { ... {
@ -734,7 +732,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testComparesDeepTypesIncludingList() public function testComparesDeepTypesIncludingList()
{ {
$this->expectFailsRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectFailsRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
connection { connection {
...edgeID ...edgeID
@ -773,7 +771,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
*/ */
public function testIgnoresUnknownTypes() public function testIgnoresUnknownTypes()
{ {
$this->expectPassesRuleWithSchema($this->getTestSchema(), new OverlappingFieldsCanBeMerged, ' $this->expectPassesRuleWithSchema($this->getSchema(), new OverlappingFieldsCanBeMerged, '
{ {
someBox { someBox {
...on UnknownType { ...on UnknownType {
@ -787,7 +785,7 @@ class OverlappingFieldsCanBeMergedTest extends TestCase
'); ');
} }
private function getTestSchema() private function getSchema()
{ {
$StringBox = null; $StringBox = null;
$IntBox = null; $IntBox = null;

View File

@ -1,7 +1,7 @@
<?php <?php
namespace GraphQL\Tests\Validator; namespace GraphQL\Tests\Validator;
use GraphQL\Schema; use GraphQL\Type\Schema;
use GraphQL\Type\Definition\ObjectType; use GraphQL\Type\Definition\ObjectType;
use GraphQL\Type\Definition\Type; use GraphQL\Type\Definition\Type;

View File

@ -1,15 +1,12 @@
<?php <?php
namespace GraphQL\Tests\Validator; namespace GraphQL\Tests\Validator;
use GraphQL\GraphQL;
use GraphQL\Language\Lexer;
use GraphQL\Language\Parser; use GraphQL\Language\Parser;
use GraphQL\Schema; use GraphQL\Type\Schema;
use GraphQL\Type\Definition\Directive; use GraphQL\Type\Definition\Directive;
use GraphQL\Type\Definition\EnumType; use GraphQL\Type\Definition\EnumType;
use GraphQL\Type\Definition\InputObjectType; use GraphQL\Type\Definition\InputObjectType;
use GraphQL\Type\Definition\InterfaceType; use GraphQL\Type\Definition\InterfaceType;
use GraphQL\Type\Definition\ListOfType;
use GraphQL\Type\Definition\ObjectType; use GraphQL\Type\Definition\ObjectType;
use GraphQL\Type\Definition\Type; use GraphQL\Type\Definition\Type;
use GraphQL\Type\Definition\UnionType; use GraphQL\Type\Definition\UnionType;
@ -20,7 +17,7 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase
/** /**
* @return Schema * @return Schema
*/ */
public static function getDefaultSchema() public static function getTestSchema()
{ {
$FurColor = null; $FurColor = null;
@ -276,20 +273,90 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase
'catOrDog' => ['type' => $CatOrDog], 'catOrDog' => ['type' => $CatOrDog],
'dogOrHuman' => ['type' => $DogOrHuman], 'dogOrHuman' => ['type' => $DogOrHuman],
'humanOrAlien' => ['type' => $HumanOrAlien], 'humanOrAlien' => ['type' => $HumanOrAlien],
'complicatedArgs' => ['type' => $ComplicatedArgs] 'complicatedArgs' => ['type' => $ComplicatedArgs],
] ]
]); ]);
$defaultSchema = new Schema([ $testSchema = new Schema([
'query' => $queryRoot, 'query' => $queryRoot,
'directives' => array_merge(GraphQL::getInternalDirectives(), [ 'directives' => [
Directive::includeDirective(),
Directive::skipDirective(),
new Directive([ new Directive([
'name' => 'operationOnly', 'name' => 'onQuery',
'locations' => [ 'QUERY' ], 'locations' => ['QUERY'],
]) ]),
]) new Directive([
'name' => 'onMutation',
'locations' => ['MUTATION'],
]),
new Directive([
'name' => 'onSubscription',
'locations' => ['SUBSCRIPTION'],
]),
new Directive([
'name' => 'onField',
'locations' => ['FIELD'],
]),
new Directive([
'name' => 'onFragmentDefinition',
'locations' => ['FRAGMENT_DEFINITION'],
]),
new Directive([
'name' => 'onFragmentSpread',
'locations' => ['FRAGMENT_SPREAD'],
]),
new Directive([
'name' => 'onInlineFragment',
'locations' => ['INLINE_FRAGMENT'],
]),
new Directive([
'name' => 'onSchema',
'locations' => ['SCHEMA'],
]),
new Directive([
'name' => 'onScalar',
'locations' => ['SCALAR'],
]),
new Directive([
'name' => 'onObject',
'locations' => ['OBJECT'],
]),
new Directive([
'name' => 'onFieldDefinition',
'locations' => ['FIELD_DEFINITION'],
]),
new Directive([
'name' => 'onArgumentDefinition',
'locations' => ['ARGUMENT_DEFINITION'],
]),
new Directive([
'name' => 'onInterface',
'locations' => ['INTERFACE'],
]),
new Directive([
'name' => 'onUnion',
'locations' => ['UNION'],
]),
new Directive([
'name' => 'onEnum',
'locations' => ['ENUM'],
]),
new Directive([
'name' => 'onEnumValue',
'locations' => ['ENUM_VALUE'],
]),
new Directive([
'name' => 'onInputObject',
'locations' => ['INPUT_OBJECT'],
]),
new Directive([
'name' => 'onInputFieldDefinition',
'locations' => ['INPUT_FIELD_DEFINITION'],
]),
],
]); ]);
return $defaultSchema; return $testSchema;
} }
function expectValid($schema, $rules, $queryString) function expectValid($schema, $rules, $queryString)
@ -313,12 +380,12 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase
function expectPassesRule($rule, $queryString) function expectPassesRule($rule, $queryString)
{ {
$this->expectValid($this->getDefaultSchema(), [$rule], $queryString); $this->expectValid($this->getTestSchema(), [$rule], $queryString);
} }
function expectFailsRule($rule, $queryString, $errors) function expectFailsRule($rule, $queryString, $errors)
{ {
return $this->expectInvalid($this->getDefaultSchema(), [$rule], $queryString, $errors); return $this->expectInvalid($this->getTestSchema(), [$rule], $queryString, $errors);
} }
function expectPassesRuleWithSchema($schema, $rule, $queryString) function expectPassesRuleWithSchema($schema, $rule, $queryString)
@ -333,11 +400,11 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase
function expectPassesCompleteValidation($queryString) function expectPassesCompleteValidation($queryString)
{ {
$this->expectValid($this->getDefaultSchema(), DocumentValidator::allRules(), $queryString); $this->expectValid($this->getTestSchema(), DocumentValidator::allRules(), $queryString);
} }
function expectFailsCompleteValidation($queryString, $errors) function expectFailsCompleteValidation($queryString, $errors)
{ {
$this->expectInvalid($this->getDefaultSchema(), DocumentValidator::allRules(), $queryString, $errors); $this->expectInvalid($this->getTestSchema(), DocumentValidator::allRules(), $queryString, $errors);
} }
} }

View File

@ -45,6 +45,6 @@ class ValidationTest extends TestCase
'locations' => [ ['line' => 1, 'column' => 2] ] 'locations' => [ ['line' => 1, 'column' => 2] ]
]; ];
$this->expectFailsCompleteValidation($query, [$expectedError]); $this->expectFailsCompleteValidation($query, [$expectedError]);
$this->expectValid($this->getDefaultSchema(), [], $query); $this->expectValid($this->getTestSchema(), [], $query);
} }
} }