mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
206 lines
5.7 KiB
Python
206 lines
5.7 KiB
Python
|
#!/usr/bin/env python3
|
||
|
|
||
|
import pytest
|
||
|
import queue
|
||
|
import yaml
|
||
|
from validate import check_delete, check_update, check_insert
|
||
|
|
||
|
class TestEvtBasic(object):
|
||
|
|
||
|
@pytest.fixture(autouse=True)
|
||
|
def transact(self, request, hge_ctx):
|
||
|
print ("In setup method")
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/basic/setup.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
yield
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/basic/teardown.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
|
||
|
|
||
|
def test_basic(self,hge_ctx):
|
||
|
|
||
|
table = {"schema" : "hge_tests", "name": "test_t1"}
|
||
|
|
||
|
init_row = {"c1" : 1, "c2" : "hello"}
|
||
|
exp_ev_data = {
|
||
|
"old": None,
|
||
|
"new": init_row
|
||
|
}
|
||
|
check_insert(hge_ctx, "t1_all", table, init_row, exp_ev_data)
|
||
|
|
||
|
where_exp = {"c1": 1}
|
||
|
set_exp = {"c2" : "world"}
|
||
|
exp_ev_data = {
|
||
|
"old": init_row,
|
||
|
"new": {"c1" : 1, "c2" : "world"}
|
||
|
}
|
||
|
check_update(hge_ctx, "t1_all", table, init_row, where_exp, set_exp, exp_ev_data)
|
||
|
|
||
|
exp_ev_data = {
|
||
|
"old": {"c1" : 1, "c2" : "world"},
|
||
|
"new": None
|
||
|
}
|
||
|
check_delete(hge_ctx, "t1_all", table, where_exp, exp_ev_data)
|
||
|
|
||
|
|
||
|
def test_basic_dep(self,hge_ctx):
|
||
|
|
||
|
st_code, resp = hge_ctx.v1q({
|
||
|
"type": "run_sql",
|
||
|
"args": {
|
||
|
"sql": "alter table hge_tests.test_t1 drop column c1"
|
||
|
}
|
||
|
})
|
||
|
assert st_code == 400, resp
|
||
|
assert resp['code'] == "dependency-error", resp
|
||
|
|
||
|
|
||
|
|
||
|
@pytest.mark.usefixtures('hge_ctx')
|
||
|
class TestEvtSelCols:
|
||
|
|
||
|
@pytest.fixture(autouse=True)
|
||
|
def transact(self, request, hge_ctx):
|
||
|
print ("In setup method")
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/selected_cols/setup.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
yield
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/selected_cols/teardown.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
|
||
|
def test_selected_cols(self, hge_ctx):
|
||
|
|
||
|
table = {"schema" : "hge_tests", "name": "test_t1"}
|
||
|
|
||
|
init_row = {"c1" : 1, "c2" : "hello"}
|
||
|
exp_ev_data = {
|
||
|
"old": None,
|
||
|
"new": {"c2": "hello"}
|
||
|
}
|
||
|
check_insert(hge_ctx, "t1_all", table, init_row, exp_ev_data)
|
||
|
|
||
|
where_exp = {"c1": 1}
|
||
|
set_exp = {"c2" : "world"}
|
||
|
exp_ev_data = {
|
||
|
"old": {"c1" : 1},
|
||
|
"new": {"c1" : 1}
|
||
|
}
|
||
|
check_update(hge_ctx, "t1_all", table, init_row, where_exp, set_exp, exp_ev_data)
|
||
|
|
||
|
exp_ev_data = {
|
||
|
"old": {"c1" : 1, "c2" : "world"},
|
||
|
"new": None
|
||
|
}
|
||
|
check_delete(hge_ctx, "t1_all", table, where_exp, exp_ev_data)
|
||
|
|
||
|
|
||
|
def test_selected_cols_dep(self, hge_ctx):
|
||
|
|
||
|
st_code, resp = hge_ctx.v1q({
|
||
|
"type": "run_sql",
|
||
|
"args": {
|
||
|
"sql": "alter table hge_tests.test_t1 drop column c1"
|
||
|
}
|
||
|
})
|
||
|
assert st_code == 400, resp
|
||
|
assert resp['code'] == "dependency-error", resp
|
||
|
|
||
|
st_code, resp = hge_ctx.v1q({
|
||
|
"type": "run_sql",
|
||
|
"args": {
|
||
|
"sql": "alter table hge_tests.test_t1 drop column c2"
|
||
|
}
|
||
|
})
|
||
|
assert st_code == 400, resp
|
||
|
assert resp['code'] == "dependency-error", resp
|
||
|
|
||
|
st_code, resp = hge_ctx.v1q({
|
||
|
"type": "run_sql",
|
||
|
"args": {
|
||
|
"sql": "alter table hge_tests.test_t1 drop column c3"
|
||
|
}
|
||
|
})
|
||
|
assert st_code == 200, resp
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
class TestEvtEmptyCols:
|
||
|
|
||
|
@pytest.fixture(autouse=True)
|
||
|
def transact(self, request, hge_ctx):
|
||
|
print ("In setup method")
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/empty_cols/setup.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
yield
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/empty_cols/teardown.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
|
||
|
|
||
|
def test_empty_cols(self, hge_ctx):
|
||
|
|
||
|
table = {"schema" : "hge_tests", "name": "test_t1"}
|
||
|
|
||
|
init_row = {"c1" : 1, "c2" : "hello"}
|
||
|
exp_ev_data = {
|
||
|
"old": None,
|
||
|
"new": {}
|
||
|
}
|
||
|
check_insert(hge_ctx, "t1_all", table, init_row, exp_ev_data)
|
||
|
|
||
|
where_exp = {"c1": 1}
|
||
|
set_exp = {"c2" : "world"}
|
||
|
exp_ev_data = {
|
||
|
"old": {},
|
||
|
"new": {}
|
||
|
}
|
||
|
check_update(hge_ctx, "t1_all", table, init_row, where_exp, set_exp, exp_ev_data)
|
||
|
|
||
|
exp_ev_data = {
|
||
|
"old": {},
|
||
|
"new": None
|
||
|
}
|
||
|
check_delete(hge_ctx, "t1_all", table, where_exp, exp_ev_data)
|
||
|
|
||
|
|
||
|
class TestEvtInsertOnly:
|
||
|
|
||
|
@pytest.fixture(autouse=True)
|
||
|
def transact(self, request, hge_ctx):
|
||
|
print ("In setup method")
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/insert_only/setup.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
yield
|
||
|
st_code, resp = hge_ctx.v1q_f('queries/insert_only/teardown.yaml')
|
||
|
assert st_code == 200, resp
|
||
|
|
||
|
|
||
|
def test_insert_only(self, hge_ctx):
|
||
|
|
||
|
table = {"schema" : "hge_tests", "name": "test_t1"}
|
||
|
|
||
|
init_row = {"c1" : 1, "c2" : "hello"}
|
||
|
exp_ev_data = {
|
||
|
"old": None,
|
||
|
"new": init_row
|
||
|
}
|
||
|
check_insert(hge_ctx, "t1_all", table, init_row, exp_ev_data)
|
||
|
|
||
|
where_exp = {"c1": 1}
|
||
|
set_exp = {"c2" : "world"}
|
||
|
exp_ev_data = {
|
||
|
"old": init_row,
|
||
|
"new": {"c1" : 1, "c2" : "world"}
|
||
|
}
|
||
|
with pytest.raises(queue.Empty):
|
||
|
check_update(hge_ctx, "t1_all", table, init_row, where_exp, set_exp, exp_ev_data)
|
||
|
|
||
|
exp_ev_data = {
|
||
|
"old": {"c1" : 1, "c2" : "world"},
|
||
|
"new": None
|
||
|
}
|
||
|
with pytest.raises(queue.Empty):
|
||
|
check_delete(hge_ctx, "t1_all", table, where_exp, exp_ev_data)
|
||
|
|