assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b }')); } public function testWorksOnScalars() : void { // if true includes scalar $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b @include(if: true) }')); // if false omits on scalar $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery('{ a, b @include(if: false) }')); // unless false includes scalar $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b @skip(if: false) }')); // unless true omits scalar $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery('{ a, b @skip(if: true) }')); } public function testWorksOnFragmentSpreads() : void { // if false omits fragment spread $q = ' query Q { a ...Frag @include(if: false) } fragment Frag on TestType { b } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); // if true includes fragment spread $q = ' query Q { a ...Frag @include(if: true) } fragment Frag on TestType { b } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless false includes fragment spread $q = ' query Q { a ...Frag @skip(if: false) } fragment Frag on TestType { b } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless true omits fragment spread $q = ' query Q { a ...Frag @skip(if: true) } fragment Frag on TestType { b } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); } public function testWorksOnInlineFragment() : void { // if false omits inline fragment $q = ' query Q { a ... on TestType @include(if: false) { b } } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); // if true includes inline fragment $q = ' query Q { a ... on TestType @include(if: true) { b } } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless false includes inline fragment $q = ' query Q { a ... on TestType @skip(if: false) { b } } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless true includes inline fragment $q = ' query Q { a ... on TestType @skip(if: true) { b } } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); } public function testWorksOnAnonymousInlineFragment() : void { // if false omits anonymous inline fragment $q = ' query Q { a ... @include(if: false) { b } } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); // if true includes anonymous inline fragment $q = ' query Q { a ... @include(if: true) { b } } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless false includes anonymous inline fragment $q = ' query Q { a ... @skip(if: false) { b } } '; $this->assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q)); // unless true includes anonymous inline fragment $q = ' query Q { a ... @skip(if: true) { b } } '; $this->assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q)); } public function testWorksWithSkipAndIncludeDirectives() : void { // include and no skip $this->assertEquals( ['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b @include(if: true) @skip(if: false) }') ); // include and skip $this->assertEquals( ['data' => ['a' => 'a']], $this->executeTestQuery('{ a, b @include(if: true) @skip(if: true) }') ); // no include or skip $this->assertEquals( ['data' => ['a' => 'a']], $this->executeTestQuery('{ a, b @include(if: false) @skip(if: false) }') ); } private static $schema; private static $data; private static function getSchema() { if (!self::$schema) { self::$schema = new Schema([ 'query' => new ObjectType([ 'name' => 'TestType', 'fields' => [ 'a' => ['type' => Type::string()], 'b' => ['type' => Type::string()] ] ]) ]); } return self::$schema; } private static function getData() { return self::$data ?: (self::$data = [ 'a' => 'a', 'b' => 'b' ]); } private function executeTestQuery($doc) { return Executor::execute(self::getSchema(), Parser::parse($doc), self::getData())->toArray(); } }