Add mutation test
This commit is contained in:
parent
91967ceb21
commit
0af01b4a48
|
|
@ -1,8 +1,6 @@
|
||||||
import io
|
import io
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from django.apps import apps
|
|
||||||
from graphene_django.filter import DjangoFilterConnectionField
|
|
||||||
from graphql_relay.node.node import from_global_id
|
from graphql_relay.node.node import from_global_id
|
||||||
|
|
||||||
"""Script defined to create helper functions for graphql schema."""
|
"""Script defined to create helper functions for graphql schema."""
|
||||||
|
|
|
||||||
|
|
@ -10,6 +10,8 @@
|
||||||
from django.contrib.sessions.middleware import SessionMiddleware
|
from django.contrib.sessions.middleware import SessionMiddleware
|
||||||
from django.test import TestCase, RequestFactory
|
from django.test import TestCase, RequestFactory
|
||||||
from graphene.test import Client
|
from graphene.test import Client
|
||||||
|
from graphql_relay import to_global_id
|
||||||
|
|
||||||
from api.schema import schema
|
from api.schema import schema
|
||||||
from core.factories import UserFactory
|
from core.factories import UserFactory
|
||||||
from users.factories import SchoolClassFactory
|
from users.factories import SchoolClassFactory
|
||||||
|
|
@ -32,7 +34,7 @@ class UserSettingTests(TestCase):
|
||||||
request.session.save()
|
request.session.save()
|
||||||
self.client = Client(schema=schema, context_value=request)
|
self.client = Client(schema=schema, context_value=request)
|
||||||
|
|
||||||
def make_request(self, class_id):
|
def make_mutation(self, class_id):
|
||||||
mutation = '''
|
mutation = '''
|
||||||
mutation UpdateSettings($input: UpdateSettingInput!) {
|
mutation UpdateSettings($input: UpdateSettingInput!) {
|
||||||
updateSetting(input: $input) {
|
updateSetting(input: $input) {
|
||||||
|
|
@ -46,11 +48,11 @@ class UserSettingTests(TestCase):
|
||||||
|
|
||||||
return self.client.execute(mutation, variables={
|
return self.client.execute(mutation, variables={
|
||||||
'input': {
|
'input': {
|
||||||
'id': class_id
|
'id': to_global_id('SchoolClassNode', class_id)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
def test_selects_first_class_on_first_call(self):
|
def make_query(self):
|
||||||
query = '''
|
query = '''
|
||||||
query MeQuery {
|
query MeQuery {
|
||||||
me {
|
me {
|
||||||
|
|
@ -62,27 +64,33 @@ class UserSettingTests(TestCase):
|
||||||
}
|
}
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
return self.client.execute(query)
|
||||||
|
|
||||||
|
def test_selects_first_class_on_first_call(self):
|
||||||
|
result = self.make_query()
|
||||||
first_class = self.user.school_classes.first()
|
first_class = self.user.school_classes.first()
|
||||||
result = self.client.execute(query)
|
|
||||||
self.assertIsNone(result.get('errors'))
|
self.assertIsNone(result.get('errors'))
|
||||||
self.assertEqual(result.get('data').get('me').get('selectedClass').get('name'), first_class.name)
|
self.assertEqual(result.get('data').get('me').get('selectedClass').get('name'), first_class.name)
|
||||||
|
|
||||||
def test_returns_selected_class(self):
|
def test_returns_selected_class(self):
|
||||||
query = '''
|
|
||||||
query MeQuery {
|
|
||||||
me {
|
|
||||||
selectedClass {
|
|
||||||
name
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
'''
|
|
||||||
|
|
||||||
selected_class = self.user.school_classes.all()[1]
|
selected_class = self.user.school_classes.all()[1]
|
||||||
setting = UserSetting.objects.create(user=self.user, selected_class=selected_class)
|
setting = UserSetting.objects.create(user=self.user, selected_class=selected_class)
|
||||||
setting.save()
|
setting.save()
|
||||||
result = self.client.execute(query)
|
result = self.make_query()
|
||||||
self.assertIsNone(result.get('errors'))
|
self.assertIsNone(result.get('errors'))
|
||||||
self.assertEqual(result.get('data').get('me').get('selectedClass').get('name'),
|
self.assertEqual(result.get('data').get('me').get('selectedClass').get('name'),
|
||||||
selected_class.name)
|
selected_class.name)
|
||||||
|
|
||||||
|
def test_user_can_select_class(self):
|
||||||
|
|
||||||
|
selected_class = self.user.school_classes.first()
|
||||||
|
setting = UserSetting.objects.create(user=self.user, selected_class=selected_class)
|
||||||
|
setting.save()
|
||||||
|
|
||||||
|
selected_class = self.user.school_classes.all()[1]
|
||||||
|
mutation_result = self.make_mutation(selected_class.pk)
|
||||||
|
self.assertIsNone(mutation_result.get('errors'))
|
||||||
|
query_result = self.make_query()
|
||||||
|
self.assertIsNone(query_result.get('errors'))
|
||||||
|
self.assertEqual(query_result.get('data').get('me').get('selectedClass').get('name'),
|
||||||
|
selected_class.name)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue