mirror of
https://github.com/retailcrm/graphql-php.git
synced 2024-11-23 21:36:05 +03:00
256 lines
6.4 KiB
PHP
256 lines
6.4 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace GraphQL\Tests\Executor;
|
|
|
|
use GraphQL\Executor\Executor;
|
|
use GraphQL\Language\Parser;
|
|
use GraphQL\Language\Source;
|
|
use GraphQL\Type\Definition\ObjectType;
|
|
use GraphQL\Type\Definition\Type;
|
|
use GraphQL\Type\Schema;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
/**
|
|
* Describe: Execute: handles directives
|
|
*/
|
|
class DirectivesTest extends TestCase
|
|
{
|
|
/** @var Schema */
|
|
private static $schema;
|
|
|
|
/** @var string[] */
|
|
private static $data;
|
|
|
|
/**
|
|
* @see it('basic query works')
|
|
*/
|
|
public function testWorksWithoutDirectives() : void
|
|
{
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b }'));
|
|
}
|
|
|
|
/**
|
|
* @param Source|string $doc
|
|
*
|
|
* @return mixed[]
|
|
*/
|
|
private function executeTestQuery($doc) : array
|
|
{
|
|
return Executor::execute(self::getSchema(), Parser::parse($doc), self::getData())->toArray();
|
|
}
|
|
|
|
private static function getSchema() : Schema
|
|
{
|
|
if (! self::$schema) {
|
|
self::$schema = new Schema([
|
|
'query' => new ObjectType([
|
|
'name' => 'TestType',
|
|
'fields' => [
|
|
'a' => ['type' => Type::string()],
|
|
'b' => ['type' => Type::string()],
|
|
],
|
|
]),
|
|
]);
|
|
}
|
|
|
|
return self::$schema;
|
|
}
|
|
|
|
/**
|
|
* @return string[]
|
|
*/
|
|
private static function getData() : array
|
|
{
|
|
return self::$data ?: (self::$data = [
|
|
'a' => 'a',
|
|
'b' => 'b',
|
|
]);
|
|
}
|
|
|
|
public function testWorksOnScalars() : void
|
|
{
|
|
// if true includes scalar
|
|
self::assertEquals(
|
|
['data' => ['a' => 'a', 'b' => 'b']],
|
|
$this->executeTestQuery('{ a, b @include(if: true) }')
|
|
);
|
|
|
|
// if false omits on scalar
|
|
self::assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery('{ a, b @include(if: false) }'));
|
|
|
|
// unless false includes scalar
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery('{ a, b @skip(if: false) }'));
|
|
|
|
// unless true omits scalar
|
|
self::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
|
|
}
|
|
';
|
|
self::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
|
|
}
|
|
';
|
|
self::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
|
|
}
|
|
';
|
|
self::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
|
|
}
|
|
';
|
|
self::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
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q));
|
|
|
|
// if true includes inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... on TestType @include(if: true) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q));
|
|
|
|
// unless false includes inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... on TestType @skip(if: false) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q));
|
|
|
|
// unless true includes inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... on TestType @skip(if: true) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::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
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q));
|
|
|
|
// if true includes anonymous inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... @include(if: true) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q));
|
|
|
|
// unless false includes anonymous inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... @skip(if: false) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a', 'b' => 'b']], $this->executeTestQuery($q));
|
|
|
|
// unless true includes anonymous inline fragment
|
|
$q = '
|
|
query Q {
|
|
a
|
|
... @skip(if: true) {
|
|
b
|
|
}
|
|
}
|
|
';
|
|
self::assertEquals(['data' => ['a' => 'a']], $this->executeTestQuery($q));
|
|
}
|
|
|
|
public function testWorksWithSkipAndIncludeDirectives() : void
|
|
{
|
|
// include and no skip
|
|
self::assertEquals(
|
|
['data' => ['a' => 'a', 'b' => 'b']],
|
|
$this->executeTestQuery('{ a, b @include(if: true) @skip(if: false) }')
|
|
);
|
|
|
|
// include and skip
|
|
self::assertEquals(
|
|
['data' => ['a' => 'a']],
|
|
$this->executeTestQuery('{ a, b @include(if: true) @skip(if: true) }')
|
|
);
|
|
|
|
// no include or skip
|
|
self::assertEquals(
|
|
['data' => ['a' => 'a']],
|
|
$this->executeTestQuery('{ a, b @include(if: false) @skip(if: false) }')
|
|
);
|
|
}
|
|
}
|