mirror of
https://github.com/graphql-python/graphene.git
synced 2024-11-14 13:46:54 +03:00
220 lines
5.5 KiB
Python
220 lines
5.5 KiB
Python
import pytest
|
|
|
|
import graphene
|
|
from graphene_django import DjangoConnectionField, DjangoNode, DjangoObjectType
|
|
from graphene_django.utils import DJANGO_FILTER_INSTALLED
|
|
|
|
from ...tests.models import Reporter
|
|
from ..middleware import DjangoDebugMiddleware
|
|
from ..types import DjangoDebug
|
|
|
|
|
|
class context(object):
|
|
pass
|
|
|
|
# from examples.starwars_django.models import Character
|
|
|
|
pytestmark = pytest.mark.django_db
|
|
|
|
|
|
def test_should_query_field():
|
|
r1 = Reporter(last_name='ABA')
|
|
r1.save()
|
|
r2 = Reporter(last_name='Griffin')
|
|
r2.save()
|
|
|
|
class ReporterType(DjangoNode, DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
|
|
class Query(graphene.ObjectType):
|
|
reporter = graphene.Field(ReporterType)
|
|
debug = graphene.Field(DjangoDebug, name='__debug')
|
|
|
|
def resolve_reporter(self, *args, **kwargs):
|
|
return Reporter.objects.first()
|
|
|
|
query = '''
|
|
query ReporterQuery {
|
|
reporter {
|
|
lastName
|
|
}
|
|
__debug {
|
|
sql {
|
|
rawSql
|
|
}
|
|
}
|
|
}
|
|
'''
|
|
expected = {
|
|
'reporter': {
|
|
'lastName': 'ABA',
|
|
},
|
|
'__debug': {
|
|
'sql': [{
|
|
'rawSql': str(Reporter.objects.order_by('pk')[:1].query)
|
|
}]
|
|
}
|
|
}
|
|
schema = graphene.Schema(query=Query, middlewares=[DjangoDebugMiddleware()])
|
|
result = schema.execute(query, context_value=context())
|
|
assert not result.errors
|
|
assert result.data == expected
|
|
|
|
|
|
def test_should_query_list():
|
|
r1 = Reporter(last_name='ABA')
|
|
r1.save()
|
|
r2 = Reporter(last_name='Griffin')
|
|
r2.save()
|
|
|
|
class ReporterType(DjangoNode, DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
|
|
class Query(graphene.ObjectType):
|
|
all_reporters = ReporterType.List()
|
|
debug = graphene.Field(DjangoDebug, name='__debug')
|
|
|
|
def resolve_all_reporters(self, *args, **kwargs):
|
|
return Reporter.objects.all()
|
|
|
|
query = '''
|
|
query ReporterQuery {
|
|
allReporters {
|
|
lastName
|
|
}
|
|
__debug {
|
|
sql {
|
|
rawSql
|
|
}
|
|
}
|
|
}
|
|
'''
|
|
expected = {
|
|
'allReporters': [{
|
|
'lastName': 'ABA',
|
|
}, {
|
|
'lastName': 'Griffin',
|
|
}],
|
|
'__debug': {
|
|
'sql': [{
|
|
'rawSql': str(Reporter.objects.all().query)
|
|
}]
|
|
}
|
|
}
|
|
schema = graphene.Schema(query=Query, middlewares=[DjangoDebugMiddleware()])
|
|
result = schema.execute(query, context_value=context())
|
|
assert not result.errors
|
|
assert result.data == expected
|
|
|
|
|
|
def test_should_query_connection():
|
|
r1 = Reporter(last_name='ABA')
|
|
r1.save()
|
|
r2 = Reporter(last_name='Griffin')
|
|
r2.save()
|
|
|
|
class ReporterType(DjangoNode, DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
|
|
class Query(graphene.ObjectType):
|
|
all_reporters = DjangoConnectionField(ReporterType)
|
|
debug = graphene.Field(DjangoDebug, name='__debug')
|
|
|
|
def resolve_all_reporters(self, *args, **kwargs):
|
|
return Reporter.objects.all()
|
|
|
|
query = '''
|
|
query ReporterQuery {
|
|
allReporters(first:1) {
|
|
edges {
|
|
node {
|
|
lastName
|
|
}
|
|
}
|
|
}
|
|
__debug {
|
|
sql {
|
|
rawSql
|
|
}
|
|
}
|
|
}
|
|
'''
|
|
expected = {
|
|
'allReporters': {
|
|
'edges': [{
|
|
'node': {
|
|
'lastName': 'ABA',
|
|
}
|
|
}]
|
|
},
|
|
}
|
|
schema = graphene.Schema(query=Query, middlewares=[DjangoDebugMiddleware()])
|
|
result = schema.execute(query, context_value=context())
|
|
assert not result.errors
|
|
assert result.data['allReporters'] == expected['allReporters']
|
|
assert 'COUNT' in result.data['__debug']['sql'][0]['rawSql']
|
|
query = str(Reporter.objects.all()[:1].query)
|
|
assert result.data['__debug']['sql'][1]['rawSql'] == query
|
|
|
|
|
|
@pytest.mark.skipif(not DJANGO_FILTER_INSTALLED,
|
|
reason="requires django-filter")
|
|
def test_should_query_connectionfilter():
|
|
from ...filter import DjangoFilterConnectionField
|
|
|
|
r1 = Reporter(last_name='ABA')
|
|
r1.save()
|
|
r2 = Reporter(last_name='Griffin')
|
|
r2.save()
|
|
|
|
class ReporterType(DjangoNode, DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
|
|
class Query(graphene.ObjectType):
|
|
all_reporters = DjangoFilterConnectionField(ReporterType)
|
|
debug = graphene.Field(DjangoDebug, name='__debug')
|
|
|
|
def resolve_all_reporters(self, *args, **kwargs):
|
|
return Reporter.objects.all()
|
|
|
|
query = '''
|
|
query ReporterQuery {
|
|
allReporters(first:1) {
|
|
edges {
|
|
node {
|
|
lastName
|
|
}
|
|
}
|
|
}
|
|
__debug {
|
|
sql {
|
|
rawSql
|
|
}
|
|
}
|
|
}
|
|
'''
|
|
expected = {
|
|
'allReporters': {
|
|
'edges': [{
|
|
'node': {
|
|
'lastName': 'ABA',
|
|
}
|
|
}]
|
|
},
|
|
}
|
|
schema = graphene.Schema(query=Query, middlewares=[DjangoDebugMiddleware()])
|
|
result = schema.execute(query, context_value=context())
|
|
assert not result.errors
|
|
assert result.data['allReporters'] == expected['allReporters']
|
|
assert 'COUNT' in result.data['__debug']['sql'][0]['rawSql']
|
|
query = str(Reporter.objects.all()[:1].query)
|
|
assert result.data['__debug']['sql'][1]['rawSql'] == query
|