mirror of
https://github.com/github/codeql.git
synced 2025-12-17 01:03:14 +01:00
124 lines
3.2 KiB
Python
124 lines
3.2 KiB
Python
import sys
|
|
from copy import deepcopy
|
|
|
|
from misc.codegen.lib import dbscheme
|
|
from misc.codegen.loaders.dbschemeloader import iterload
|
|
from misc.codegen.test.utils import *
|
|
|
|
|
|
@pytest.fixture
|
|
def load(tmp_path):
|
|
file = tmp_path / "test.dbscheme"
|
|
|
|
def ret(yml):
|
|
write(file, yml)
|
|
return list(iterload(file))
|
|
|
|
return ret
|
|
|
|
|
|
def test_load_empty(load):
|
|
assert load("") == []
|
|
|
|
|
|
def test_load_one_empty_table(load):
|
|
assert load("""
|
|
test_foos();
|
|
""") == [
|
|
dbscheme.Table(name="test_foos", columns=[])
|
|
]
|
|
|
|
|
|
def test_load_table_with_keyset(load):
|
|
assert load("""
|
|
#keyset[x, y,z]
|
|
test_foos();
|
|
""") == [
|
|
dbscheme.Table(name="test_foos", columns=[], keyset=dbscheme.KeySet(["x", "y", "z"]))
|
|
]
|
|
|
|
|
|
expected_columns = [
|
|
("int foo: int ref", dbscheme.Column(schema_name="foo", type="int", binding=False)),
|
|
(" int bar : int ref", dbscheme.Column(schema_name="bar", type="int", binding=False)),
|
|
("str baz_: str ref", dbscheme.Column(schema_name="baz", type="str", binding=False)),
|
|
("int x: @foo ref", dbscheme.Column(schema_name="x", type="@foo", binding=False)),
|
|
("int y: @foo", dbscheme.Column(schema_name="y", type="@foo", binding=True)),
|
|
("unique int z: @foo", dbscheme.Column(schema_name="z", type="@foo", binding=True)),
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize("column,expected", expected_columns)
|
|
def test_load_table_with_column(load, column, expected):
|
|
assert load(f"""
|
|
foos(
|
|
{column}
|
|
);
|
|
""") == [
|
|
dbscheme.Table(name="foos", columns=[deepcopy(expected)])
|
|
]
|
|
|
|
|
|
def test_load_table_with_multiple_columns(load):
|
|
columns = ",\n".join(c for c, _ in expected_columns)
|
|
expected = [deepcopy(e) for _, e in expected_columns]
|
|
assert load(f"""
|
|
foos(
|
|
{columns}
|
|
);
|
|
""") == [
|
|
dbscheme.Table(name="foos", columns=expected)
|
|
]
|
|
|
|
|
|
def test_load_table_with_multiple_columns_and_dir(load):
|
|
columns = ",\n".join(c for c, _ in expected_columns)
|
|
expected = [deepcopy(e) for _, e in expected_columns]
|
|
assert load(f"""
|
|
foos( //dir=foo/bar/baz
|
|
{columns}
|
|
);
|
|
""") == [
|
|
dbscheme.Table(name="foos", columns=expected, dir=pathlib.Path("foo/bar/baz"))
|
|
]
|
|
|
|
|
|
def test_load_multiple_table_with_columns(load):
|
|
tables = [f"table{i}({col});" for i, (col, _) in enumerate(expected_columns)]
|
|
expected = [dbscheme.Table(name=f"table{i}", columns=[deepcopy(e)]) for i, (_, e) in enumerate(expected_columns)]
|
|
assert load("\n".join(tables)) == expected
|
|
|
|
|
|
def test_union(load):
|
|
assert load("@foo = @bar | @baz | @bla;") == [
|
|
dbscheme.Union(lhs="@foo", rhs=["@bar", "@baz", "@bla"]),
|
|
]
|
|
|
|
|
|
def test_table_and_union(load):
|
|
assert load("""
|
|
foos();
|
|
|
|
@foo = @bar | @baz | @bla;""") == [
|
|
dbscheme.Table(name="foos", columns=[]),
|
|
dbscheme.Union(lhs="@foo", rhs=["@bar", "@baz", "@bla"]),
|
|
]
|
|
|
|
|
|
def test_comments_ignored(load):
|
|
assert load("""
|
|
// fake_table();
|
|
foos(/* x */unique /*y*/int/*
|
|
z
|
|
*/ id/* */: /* * */ @bar/*,
|
|
int ignored: int ref*/);
|
|
|
|
@foo = @bar | @baz | @bla; // | @xxx""") == [
|
|
dbscheme.Table(name="foos", columns=[dbscheme.Column(schema_name="id", type="@bar", binding=True)]),
|
|
dbscheme.Union(lhs="@foo", rhs=["@bar", "@baz", "@bla"]),
|
|
]
|
|
|
|
|
|
if __name__ == '__main__':
|
|
sys.exit(pytest.main([__file__] + sys.argv[1:]))
|