2018-09-18 09:21:57 +03:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
import json
|
|
|
|
import queue
|
2018-09-20 04:46:03 +03:00
|
|
|
import yaml
|
|
|
|
|
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_connection_init
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
def test_init_without_payload(hge_ctx):
|
2018-10-28 21:27:49 +03:00
|
|
|
if hge_ctx.hge_key is not None:
|
|
|
|
pytest.skip("Payload is needed when access key is set")
|
2018-09-20 04:46:03 +03:00
|
|
|
obj = {
|
|
|
|
'type': 'connection_init'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'connection_ack', ev
|
|
|
|
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_connection_init
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
def test_init(hge_ctx):
|
2018-10-28 21:27:49 +03:00
|
|
|
payload = {}
|
|
|
|
if hge_ctx.hge_key is not None:
|
|
|
|
payload = {
|
|
|
|
'headers' : {
|
|
|
|
'X-Hasura-Access-Key': hge_ctx.hge_key
|
|
|
|
}
|
|
|
|
}
|
2018-09-20 04:46:03 +03:00
|
|
|
obj = {
|
|
|
|
'type': 'connection_init',
|
2018-10-28 21:27:49 +03:00
|
|
|
'payload': payload,
|
2018-09-20 04:46:03 +03:00
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'connection_ack', ev
|
2018-09-18 09:21:57 +03:00
|
|
|
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
class TestSubscriptionBasic(object):
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def transact(self, request, hge_ctx):
|
2018-09-20 04:46:03 +03:00
|
|
|
self.dir = 'queries/subscriptions/basic'
|
|
|
|
st_code, resp = hge_ctx.v1q_f(self.dir + '/setup.yaml')
|
2018-09-18 09:21:57 +03:00
|
|
|
assert st_code == 200, resp
|
|
|
|
yield
|
2018-09-20 04:46:03 +03:00
|
|
|
st_code, resp = hge_ctx.v1q_f(self.dir + '/teardown.yaml')
|
2018-09-18 09:21:57 +03:00
|
|
|
assert st_code == 200, resp
|
|
|
|
|
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_connection_error
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
def test_connection_error(self, hge_ctx):
|
|
|
|
hge_ctx.ws.send("test")
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'connection_error', ev
|
|
|
|
|
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_start
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
def test_start(self, hge_ctx):
|
|
|
|
query = """
|
|
|
|
subscription {
|
2018-10-26 14:57:33 +03:00
|
|
|
hge_tests_test_t1(order_by: {c1: desc}, limit: 1) {
|
2018-09-18 09:21:57 +03:00
|
|
|
c1,
|
|
|
|
c2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
obj = {
|
|
|
|
'id': '1',
|
|
|
|
'payload': {
|
|
|
|
'query': query
|
|
|
|
},
|
|
|
|
'type': 'start'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_data
|
|
|
|
'''
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'data' and ev['id'] == '1', ev
|
|
|
|
|
|
|
|
'''
|
|
|
|
Refer https://github.com/apollographql/subscriptions-transport-ws/blob/01e0b2b65df07c52f5831cce5c858966ba095993/src/server.ts#L306
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
@pytest.mark.skip(reason="refer https://github.com/hasura/graphql-engine/pull/387#issuecomment-421343098")
|
|
|
|
def test_start_duplicate(self, hge_ctx):
|
|
|
|
self.test_start(hge_ctx)
|
|
|
|
|
|
|
|
def test_stop_without_id(self, hge_ctx):
|
|
|
|
obj = {
|
|
|
|
'type': 'stop'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'connection_error', ev
|
|
|
|
|
|
|
|
'''
|
|
|
|
Refer https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_stop
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
def test_stop(self, hge_ctx):
|
|
|
|
obj = {
|
|
|
|
'type': 'stop',
|
|
|
|
'id': '1'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
2018-09-20 04:46:03 +03:00
|
|
|
with pytest.raises(queue.Empty):
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
2018-09-18 09:21:57 +03:00
|
|
|
|
|
|
|
def test_start_after_stop(self, hge_ctx):
|
|
|
|
self.test_start(hge_ctx)
|
2018-09-20 04:46:03 +03:00
|
|
|
self.test_stop(hge_ctx)
|
2018-09-18 09:21:57 +03:00
|
|
|
|
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_complete
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-18 09:21:57 +03:00
|
|
|
def test_complete(self, hge_ctx):
|
|
|
|
query = """
|
|
|
|
query {
|
2018-10-26 14:57:33 +03:00
|
|
|
hge_tests_test_t1(order_by: {c1: desc}, limit: 1) {
|
2018-09-18 09:21:57 +03:00
|
|
|
c1,
|
|
|
|
c2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
obj = {
|
|
|
|
'id': '2',
|
|
|
|
'payload': {
|
|
|
|
'query': query
|
|
|
|
},
|
|
|
|
'type': 'start'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'data' and ev['id'] == '2', ev
|
|
|
|
# Check for complete type
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'complete' and ev['id'] == '2', ev
|
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
|
|
|
|
class TestSubscriptionLiveQueries(object):
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def transact(self, request, hge_ctx):
|
|
|
|
self.dir = 'queries/subscriptions/live_queries'
|
|
|
|
st_code, resp = hge_ctx.v1q_f(self.dir + '/setup.yaml')
|
|
|
|
assert st_code == 200, resp
|
|
|
|
yield
|
|
|
|
st_code, resp = hge_ctx.v1q_f(self.dir + '/teardown.yaml')
|
|
|
|
assert st_code == 200, resp
|
|
|
|
|
|
|
|
def test_live_queries(self, hge_ctx):
|
|
|
|
'''
|
|
|
|
Create connection using connection_init
|
|
|
|
'''
|
2018-10-28 21:27:49 +03:00
|
|
|
payload = {}
|
|
|
|
if hge_ctx.hge_key is not None:
|
|
|
|
payload = {
|
|
|
|
'headers' : {
|
|
|
|
'X-Hasura-Access-Key': hge_ctx.hge_key
|
|
|
|
}
|
|
|
|
}
|
2018-09-18 09:21:57 +03:00
|
|
|
obj = {
|
2018-10-28 21:27:49 +03:00
|
|
|
'type': 'connection_init',
|
|
|
|
'payload' : payload
|
2018-09-20 04:46:03 +03:00
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'connection_ack', ev
|
|
|
|
|
|
|
|
with open(self.dir + "/steps.yaml") as c:
|
|
|
|
conf = yaml.load(c)
|
|
|
|
|
|
|
|
query = """
|
|
|
|
subscription {
|
2018-10-26 14:57:33 +03:00
|
|
|
hge_tests_test_t2(order_by: {c1: desc}, limit: 1) {
|
2018-09-20 04:46:03 +03:00
|
|
|
c1,
|
|
|
|
c2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
obj = {
|
|
|
|
'id': 'live',
|
|
|
|
'payload': {
|
|
|
|
'query': query
|
|
|
|
},
|
|
|
|
'type': 'start'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'data' and ev['id'] == obj['id'], ev
|
2018-10-30 12:21:58 +03:00
|
|
|
assert ev['payload']['data'] == {'hge_tests_test_t2': []}, ev['payload']['data']
|
2018-09-20 04:46:03 +03:00
|
|
|
|
|
|
|
assert isinstance(conf, list) == True, 'Not an list'
|
|
|
|
for index, step in enumerate(conf):
|
|
|
|
obj = {
|
2018-10-30 12:21:58 +03:00
|
|
|
'id': '{}'.format(index + 1),
|
2018-09-20 04:46:03 +03:00
|
|
|
'payload': {
|
|
|
|
'query': step['query']
|
|
|
|
},
|
|
|
|
'type': 'start'
|
|
|
|
}
|
|
|
|
if 'variables' in step and step['variables']:
|
|
|
|
obj['payload']['variables'] = json.loads(step['variables'])
|
|
|
|
|
|
|
|
expected_resp = json.loads(step['response'])
|
|
|
|
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'data' and ev['id'] == obj['id'], ev
|
|
|
|
assert ev['payload']['data'] == expected_resp, ev['payload']['data']
|
|
|
|
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'complete' and ev['id'] == obj['id'], ev
|
|
|
|
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
|
|
|
assert ev['type'] == 'data' and ev['id'] == 'live', ev
|
|
|
|
assert ev['payload']['data'] == {
|
2018-10-30 12:21:58 +03:00
|
|
|
'hge_tests_test_t2': expected_resp[step['name']]['returning'] if 'returning' in expected_resp[
|
|
|
|
step['name']] else []
|
2018-09-20 04:46:03 +03:00
|
|
|
}, ev['payload']['data']
|
|
|
|
|
|
|
|
# stop live operation
|
|
|
|
obj = {
|
|
|
|
'id': 'live',
|
|
|
|
'type': 'stop'
|
2018-09-18 09:21:57 +03:00
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
with pytest.raises(queue.Empty):
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|
2018-09-20 04:46:03 +03:00
|
|
|
|
2018-10-30 12:21:58 +03:00
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
'''
|
|
|
|
Refer: https://github.com/apollographql/subscriptions-transport-ws/blob/master/PROTOCOL.md#gql_connection_terminate
|
|
|
|
'''
|
2018-10-30 12:21:58 +03:00
|
|
|
|
|
|
|
|
2018-09-20 04:46:03 +03:00
|
|
|
def test_connection_terminate(hge_ctx):
|
|
|
|
obj = {
|
|
|
|
'type': 'connection_terminate'
|
|
|
|
}
|
|
|
|
hge_ctx.ws.send(json.dumps(obj))
|
|
|
|
with pytest.raises(queue.Empty):
|
|
|
|
ev = hge_ctx.get_ws_event(3)
|