mirror of
https://github.com/graphql-python/graphene-django.git
synced 2024-11-29 13:03:44 +03:00
0b103417f9
added support for querying a model with objects that may be a proxy model, fixed and added tests a few style changes
55 lines
1.2 KiB
Python
55 lines
1.2 KiB
Python
from py.test import raises
|
|
|
|
from ..registry import Registry
|
|
from ..types import DjangoObjectType
|
|
from .models import Reporter
|
|
|
|
|
|
def test_should_raise_if_no_model():
|
|
with raises(Exception) as excinfo:
|
|
class Character1(DjangoObjectType):
|
|
pass
|
|
assert 'valid Django Model' in str(excinfo.value)
|
|
|
|
|
|
def test_should_raise_if_model_is_invalid():
|
|
with raises(Exception) as excinfo:
|
|
class Character2(DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = 1
|
|
assert 'valid Django Model' in str(excinfo.value)
|
|
|
|
|
|
def test_should_map_fields_correctly():
|
|
class ReporterType2(DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
registry = Registry()
|
|
fields = list(ReporterType2._meta.fields.keys())
|
|
assert fields[:-2] == [
|
|
'id',
|
|
'first_name',
|
|
'last_name',
|
|
'email',
|
|
'pets',
|
|
'a_choice',
|
|
'reporter_type'
|
|
]
|
|
|
|
assert sorted(fields[-2:]) == [
|
|
'articles',
|
|
'films',
|
|
]
|
|
|
|
|
|
def test_should_map_only_few_fields():
|
|
class Reporter2(DjangoObjectType):
|
|
|
|
class Meta:
|
|
model = Reporter
|
|
only_fields = ('id', 'email')
|
|
|
|
assert list(Reporter2._meta.fields.keys()) == ['id', 'email']
|