2020-09-16 04:26:10 +00:00
|
|
|
import math
|
2019-02-21 12:04:08 +00:00
|
|
|
import os
|
|
|
|
|
2020-09-16 04:26:10 +00:00
|
|
|
import pytest
|
2019-02-21 12:04:08 +00:00
|
|
|
from helpers.cluster import ClickHouseCluster
|
2020-09-07 01:05:30 +00:00
|
|
|
from helpers.dictionary import Field, Row, Dictionary, DictionaryStructure, Layout
|
2020-09-16 04:26:10 +00:00
|
|
|
from helpers.external_sources import SourceMongo, SourceMongoURI, SourceHTTP, SourceHTTPS, SourceCassandra
|
|
|
|
from helpers.external_sources import SourceMySQL, SourceClickHouse, SourceFile, SourceExecutableCache, \
|
|
|
|
SourceExecutableHashed
|
2020-06-03 15:07:37 +00:00
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
SCRIPT_DIR = os.path.dirname(os.path.realpath(__file__))
|
2019-09-17 13:35:19 +00:00
|
|
|
dict_configs_path = os.path.join(SCRIPT_DIR, 'configs/dictionaries')
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
FIELDS = {
|
|
|
|
"simple": [
|
2019-02-22 10:55:12 +00:00
|
|
|
Field("KeyField", 'UInt64', is_key=True, default_value_for_get=9999999),
|
|
|
|
Field("UInt8_", 'UInt8', default_value_for_get=55),
|
|
|
|
Field("UInt16_", 'UInt16', default_value_for_get=66),
|
|
|
|
Field("UInt32_", 'UInt32', default_value_for_get=77),
|
|
|
|
Field("UInt64_", 'UInt64', default_value_for_get=88),
|
|
|
|
Field("Int8_", 'Int8', default_value_for_get=-55),
|
|
|
|
Field("Int16_", 'Int16', default_value_for_get=-66),
|
|
|
|
Field("Int32_", 'Int32', default_value_for_get=-77),
|
|
|
|
Field("Int64_", 'Int64', default_value_for_get=-88),
|
|
|
|
Field("UUID_", 'UUID', default_value_for_get='550e8400-0000-0000-0000-000000000000'),
|
|
|
|
Field("Date_", 'Date', default_value_for_get='2018-12-30'),
|
|
|
|
Field("DateTime_", 'DateTime', default_value_for_get='2018-12-30 00:00:00'),
|
|
|
|
Field("String_", 'String', default_value_for_get='hi'),
|
|
|
|
Field("Float32_", 'Float32', default_value_for_get=555.11),
|
|
|
|
Field("Float64_", 'Float64', default_value_for_get=777.11),
|
2019-02-24 17:45:10 +00:00
|
|
|
Field("ParentKeyField", "UInt64", default_value_for_get=444, hierarchical=True)
|
2019-02-21 12:04:08 +00:00
|
|
|
],
|
|
|
|
"complex": [
|
2019-02-22 10:55:12 +00:00
|
|
|
Field("KeyField1", 'UInt64', is_key=True, default_value_for_get=9999999),
|
|
|
|
Field("KeyField2", 'String', is_key=True, default_value_for_get='xxxxxxxxx'),
|
|
|
|
Field("UInt8_", 'UInt8', default_value_for_get=55),
|
|
|
|
Field("UInt16_", 'UInt16', default_value_for_get=66),
|
|
|
|
Field("UInt32_", 'UInt32', default_value_for_get=77),
|
|
|
|
Field("UInt64_", 'UInt64', default_value_for_get=88),
|
|
|
|
Field("Int8_", 'Int8', default_value_for_get=-55),
|
|
|
|
Field("Int16_", 'Int16', default_value_for_get=-66),
|
|
|
|
Field("Int32_", 'Int32', default_value_for_get=-77),
|
|
|
|
Field("Int64_", 'Int64', default_value_for_get=-88),
|
|
|
|
Field("UUID_", 'UUID', default_value_for_get='550e8400-0000-0000-0000-000000000000'),
|
|
|
|
Field("Date_", 'Date', default_value_for_get='2018-12-30'),
|
|
|
|
Field("DateTime_", 'DateTime', default_value_for_get='2018-12-30 00:00:00'),
|
|
|
|
Field("String_", 'String', default_value_for_get='hi'),
|
|
|
|
Field("Float32_", 'Float32', default_value_for_get=555.11),
|
|
|
|
Field("Float64_", 'Float64', default_value_for_get=777.11),
|
2019-02-21 12:04:08 +00:00
|
|
|
],
|
|
|
|
"ranged": [
|
|
|
|
Field("KeyField1", 'UInt64', is_key=True),
|
|
|
|
Field("KeyField2", 'Date', is_range_key=True),
|
|
|
|
Field("StartDate", 'Date', range_hash_type='min'),
|
|
|
|
Field("EndDate", 'Date', range_hash_type='max'),
|
2019-02-22 10:55:12 +00:00
|
|
|
Field("UInt8_", 'UInt8', default_value_for_get=55),
|
|
|
|
Field("UInt16_", 'UInt16', default_value_for_get=66),
|
|
|
|
Field("UInt32_", 'UInt32', default_value_for_get=77),
|
|
|
|
Field("UInt64_", 'UInt64', default_value_for_get=88),
|
|
|
|
Field("Int8_", 'Int8', default_value_for_get=-55),
|
|
|
|
Field("Int16_", 'Int16', default_value_for_get=-66),
|
|
|
|
Field("Int32_", 'Int32', default_value_for_get=-77),
|
|
|
|
Field("Int64_", 'Int64', default_value_for_get=-88),
|
|
|
|
Field("UUID_", 'UUID', default_value_for_get='550e8400-0000-0000-0000-000000000000'),
|
|
|
|
Field("Date_", 'Date', default_value_for_get='2018-12-30'),
|
|
|
|
Field("DateTime_", 'DateTime', default_value_for_get='2018-12-30 00:00:00'),
|
|
|
|
Field("String_", 'String', default_value_for_get='hi'),
|
|
|
|
Field("Float32_", 'Float32', default_value_for_get=555.11),
|
|
|
|
Field("Float64_", 'Float64', default_value_for_get=777.11),
|
2019-02-21 12:04:08 +00:00
|
|
|
]
|
2019-09-17 13:35:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
VALUES = {
|
|
|
|
"simple": [
|
|
|
|
[1, 22, 333, 4444, 55555, -6, -77,
|
2020-02-06 12:18:19 +00:00
|
|
|
-888, -999, '550e8400-e29b-41d4-a716-446655440003',
|
|
|
|
'1973-06-28', '1985-02-28 23:43:25', 'hello', 22.543, 3332154213.4, 0],
|
2019-09-17 13:35:19 +00:00
|
|
|
[2, 3, 4, 5, 6, -7, -8,
|
2020-02-06 12:18:19 +00:00
|
|
|
-9, -10, '550e8400-e29b-41d4-a716-446655440002',
|
|
|
|
'1978-06-28', '1986-02-28 23:42:25', 'hello', 21.543, 3222154213.4, 1]
|
2019-09-17 13:35:19 +00:00
|
|
|
],
|
|
|
|
"complex": [
|
|
|
|
[1, 'world', 22, 333, 4444, 55555, -6,
|
2020-02-06 12:18:19 +00:00
|
|
|
-77, -888, -999, '550e8400-e29b-41d4-a716-446655440003',
|
|
|
|
'1973-06-28', '1985-02-28 23:43:25',
|
|
|
|
'hello', 22.543, 3332154213.4],
|
2019-09-17 13:35:19 +00:00
|
|
|
[2, 'qwerty2', 52, 2345, 6544, 9191991, -2,
|
2020-02-06 12:18:19 +00:00
|
|
|
-717, -81818, -92929, '550e8400-e29b-41d4-a716-446655440007',
|
|
|
|
'1975-09-28', '2000-02-28 23:33:24',
|
|
|
|
'my', 255.543, 3332221.44]
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2019-09-17 13:35:19 +00:00
|
|
|
],
|
|
|
|
"ranged": [
|
|
|
|
[1, '2019-02-10', '2019-02-01', '2019-02-28',
|
2020-02-06 12:18:19 +00:00
|
|
|
22, 333, 4444, 55555, -6, -77, -888, -999,
|
|
|
|
'550e8400-e29b-41d4-a716-446655440003',
|
|
|
|
'1973-06-28', '1985-02-28 23:43:25', 'hello',
|
|
|
|
22.543, 3332154213.4],
|
2019-09-17 13:35:19 +00:00
|
|
|
[2, '2019-04-10', '2019-04-01', '2019-04-28',
|
2020-02-06 12:18:19 +00:00
|
|
|
11, 3223, 41444, 52515, -65, -747, -8388, -9099,
|
|
|
|
'550e8400-e29b-41d4-a716-446655440004',
|
|
|
|
'1973-06-29', '2002-02-28 23:23:25', '!!!!',
|
|
|
|
32.543, 3332543.4]
|
2019-09-17 13:35:19 +00:00
|
|
|
]
|
2019-02-21 12:04:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
LAYOUTS = [
|
2020-05-19 20:12:10 +00:00
|
|
|
Layout("flat"),
|
2019-02-21 12:04:08 +00:00
|
|
|
Layout("hashed"),
|
2019-02-21 16:43:21 +00:00
|
|
|
Layout("cache"),
|
2019-02-21 12:04:08 +00:00
|
|
|
Layout("complex_key_hashed"),
|
|
|
|
Layout("complex_key_cache"),
|
2020-05-03 12:55:22 +00:00
|
|
|
Layout("range_hashed"),
|
2020-05-12 15:00:08 +00:00
|
|
|
Layout("direct"),
|
|
|
|
Layout("complex_key_direct")
|
2019-02-21 12:04:08 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
SOURCES = [
|
2020-05-26 19:21:18 +00:00
|
|
|
SourceCassandra("Cassandra", "localhost", "9043", "cassandra1", "9042", "", ""),
|
2019-02-25 10:45:22 +00:00
|
|
|
SourceMongo("MongoDB", "localhost", "27018", "mongo1", "27017", "root", "clickhouse"),
|
2020-05-19 20:12:10 +00:00
|
|
|
SourceMongoURI("MongoDB_URI", "localhost", "27018", "mongo1", "27017", "root", "clickhouse"),
|
2019-02-21 12:04:08 +00:00
|
|
|
SourceMySQL("MySQL", "localhost", "3308", "mysql1", "3306", "root", "clickhouse"),
|
2019-02-21 16:43:21 +00:00
|
|
|
SourceClickHouse("RemoteClickHouse", "localhost", "9000", "clickhouse1", "9000", "default", ""),
|
|
|
|
SourceClickHouse("LocalClickHouse", "localhost", "9000", "node", "9000", "default", ""),
|
|
|
|
SourceFile("File", "localhost", "9000", "node", "9000", "", ""),
|
|
|
|
SourceExecutableHashed("ExecutableHashed", "localhost", "9000", "node", "9000", "", ""),
|
|
|
|
SourceExecutableCache("ExecutableCache", "localhost", "9000", "node", "9000", "", ""),
|
2019-02-22 10:55:12 +00:00
|
|
|
SourceHTTP("SourceHTTP", "localhost", "9000", "clickhouse1", "9000", "", ""),
|
|
|
|
SourceHTTPS("SourceHTTPS", "localhost", "9000", "clickhouse1", "9000", "", ""),
|
2019-02-21 12:04:08 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
DICTIONARIES = []
|
|
|
|
|
|
|
|
cluster = None
|
|
|
|
node = None
|
|
|
|
|
2020-09-16 04:26:10 +00:00
|
|
|
|
2019-09-17 13:35:19 +00:00
|
|
|
def get_dict(source, layout, fields, suffix_name=''):
|
|
|
|
global dict_configs_path
|
|
|
|
|
|
|
|
structure = DictionaryStructure(layout, fields)
|
|
|
|
dict_name = source.name + "_" + layout.name + '_' + suffix_name
|
|
|
|
dict_path = os.path.join(dict_configs_path, dict_name + '.xml')
|
|
|
|
dictionary = Dictionary(dict_name, structure, source, dict_path, "table_" + dict_name, fields)
|
|
|
|
dictionary.generate_config()
|
|
|
|
return dictionary
|
2019-05-28 20:17:30 +00:00
|
|
|
|
2020-06-22 13:10:25 +00:00
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
def setup_module(module):
|
|
|
|
global DICTIONARIES
|
|
|
|
global cluster
|
|
|
|
global node
|
2019-09-17 13:35:19 +00:00
|
|
|
global dict_configs_path
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for f in os.listdir(dict_configs_path):
|
|
|
|
os.remove(os.path.join(dict_configs_path, f))
|
|
|
|
|
|
|
|
for layout in LAYOUTS:
|
|
|
|
for source in SOURCES:
|
2019-02-21 16:43:21 +00:00
|
|
|
if source.compatible_with_layout(layout):
|
2020-01-28 10:58:37 +00:00
|
|
|
DICTIONARIES.append(get_dict(source, layout, FIELDS[layout.layout_type]))
|
2019-02-21 16:43:21 +00:00
|
|
|
else:
|
|
|
|
print "Source", source.name, "incompatible with layout", layout.name
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2020-08-12 08:55:04 +00:00
|
|
|
cluster = ClickHouseCluster(__file__)
|
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
main_configs = []
|
2020-08-12 08:55:04 +00:00
|
|
|
main_configs.append(os.path.join('configs', 'disable_ssl_verification.xml'))
|
|
|
|
|
|
|
|
cluster.add_instance('clickhouse1', main_configs=main_configs)
|
|
|
|
|
|
|
|
dictionaries = []
|
2019-02-21 12:04:08 +00:00
|
|
|
for fname in os.listdir(dict_configs_path):
|
2020-08-12 08:55:04 +00:00
|
|
|
dictionaries.append(os.path.join(dict_configs_path, fname))
|
|
|
|
|
2020-09-16 04:26:10 +00:00
|
|
|
node = cluster.add_instance('node', main_configs=main_configs, dictionaries=dictionaries, with_mysql=True,
|
|
|
|
with_mongo=True, with_redis=True, with_cassandra=True)
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2019-05-28 20:17:30 +00:00
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
@pytest.fixture(scope="module")
|
|
|
|
def started_cluster():
|
|
|
|
try:
|
|
|
|
cluster.start()
|
2020-09-07 01:05:30 +00:00
|
|
|
for dictionary in DICTIONARIES:
|
2019-02-21 12:04:08 +00:00
|
|
|
print "Preparing", dictionary.name
|
2019-02-21 16:43:21 +00:00
|
|
|
dictionary.prepare_source(cluster)
|
2019-02-21 12:04:08 +00:00
|
|
|
print "Prepared"
|
|
|
|
|
|
|
|
yield cluster
|
|
|
|
|
|
|
|
finally:
|
|
|
|
cluster.shutdown()
|
|
|
|
|
|
|
|
|
2020-01-28 10:58:37 +00:00
|
|
|
def get_dictionaries(fold, total_folds, all_dicts):
|
|
|
|
chunk_len = int(math.ceil(len(all_dicts) / float(total_folds)))
|
|
|
|
if chunk_len * fold >= len(all_dicts):
|
|
|
|
return []
|
2020-09-16 04:26:10 +00:00
|
|
|
return all_dicts[fold * chunk_len: (fold + 1) * chunk_len]
|
2020-01-28 10:58:37 +00:00
|
|
|
|
|
|
|
|
2020-06-22 13:10:25 +00:00
|
|
|
def remove_mysql_dicts():
|
|
|
|
"""
|
|
|
|
We have false-positive race condition in our openSSL version.
|
|
|
|
MySQL dictionary use OpenSSL, so to prevent known failure we
|
|
|
|
disable tests for these dictionaries.
|
|
|
|
|
|
|
|
Read of size 8 at 0x7b3c00005dd0 by thread T61 (mutexes: write M1010349240585225536):
|
|
|
|
#0 EVP_CIPHER_mode <null> (clickhouse+0x13b2223b)
|
|
|
|
#1 do_ssl3_write <null> (clickhouse+0x13a137bc)
|
|
|
|
#2 ssl3_write_bytes <null> (clickhouse+0x13a12387)
|
|
|
|
#3 ssl3_write <null> (clickhouse+0x139db0e6)
|
|
|
|
#4 ssl_write_internal <null> (clickhouse+0x139eddce)
|
|
|
|
#5 SSL_write <null> (clickhouse+0x139edf20)
|
|
|
|
#6 ma_tls_write <null> (clickhouse+0x139c7557)
|
|
|
|
#7 ma_pvio_tls_write <null> (clickhouse+0x139a8f59)
|
|
|
|
#8 ma_pvio_write <null> (clickhouse+0x139a8488)
|
|
|
|
#9 ma_net_real_write <null> (clickhouse+0x139a4e2c)
|
|
|
|
#10 ma_net_write_command <null> (clickhouse+0x139a546d)
|
|
|
|
#11 mthd_my_send_cmd <null> (clickhouse+0x13992546)
|
|
|
|
#12 mysql_close_slow_part <null> (clickhouse+0x13999afd)
|
|
|
|
#13 mysql_close <null> (clickhouse+0x13999071)
|
|
|
|
#14 mysqlxx::Connection::~Connection() <null> (clickhouse+0x1370f814)
|
|
|
|
#15 mysqlxx::Pool::~Pool() <null> (clickhouse+0x13715a7b)
|
|
|
|
|
|
|
|
TODO remove this when open ssl will be fixed or thread sanitizer will be suppressed
|
|
|
|
"""
|
|
|
|
|
2020-09-16 04:26:10 +00:00
|
|
|
# global DICTIONARIES
|
|
|
|
# DICTIONARIES = [d for d in DICTIONARIES if not d.name.startswith("MySQL")]
|
2020-06-22 13:10:25 +00:00
|
|
|
|
|
|
|
|
2020-01-28 10:58:37 +00:00
|
|
|
@pytest.mark.parametrize("fold", list(range(10)))
|
|
|
|
def test_simple_dictionaries(started_cluster, fold):
|
2020-06-22 13:10:25 +00:00
|
|
|
if node.is_built_with_thread_sanitizer():
|
|
|
|
remove_mysql_dicts()
|
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
fields = FIELDS["simple"]
|
2019-09-17 13:35:19 +00:00
|
|
|
values = VALUES["simple"]
|
|
|
|
data = [Row(fields, vals) for vals in values]
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2020-01-28 10:58:37 +00:00
|
|
|
all_simple_dicts = [d for d in DICTIONARIES if d.structure.layout.layout_type == "simple"]
|
|
|
|
simple_dicts = get_dictionaries(fold, 10, all_simple_dicts)
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2020-01-28 10:58:37 +00:00
|
|
|
print "Length of dicts:", len(simple_dicts)
|
2019-02-21 12:04:08 +00:00
|
|
|
for dct in simple_dicts:
|
|
|
|
dct.load_data(data)
|
|
|
|
|
|
|
|
node.query("system reload dictionaries")
|
2019-02-22 12:13:55 +00:00
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
queries_with_answers = []
|
|
|
|
for dct in simple_dicts:
|
|
|
|
for row in data:
|
|
|
|
for field in fields:
|
|
|
|
if not field.is_key:
|
2019-02-22 10:55:12 +00:00
|
|
|
for query in dct.get_select_get_queries(field, row):
|
|
|
|
queries_with_answers.append((query, row.get_value_by_name(field.name)))
|
|
|
|
|
|
|
|
for query in dct.get_select_has_queries(field, row):
|
|
|
|
queries_with_answers.append((query, 1))
|
|
|
|
|
|
|
|
for query in dct.get_select_get_or_default_queries(field, row):
|
|
|
|
queries_with_answers.append((query, field.default_value_for_get))
|
2019-02-24 17:45:10 +00:00
|
|
|
for query in dct.get_hierarchical_queries(data[0]):
|
|
|
|
queries_with_answers.append((query, [1]))
|
|
|
|
|
|
|
|
for query in dct.get_hierarchical_queries(data[1]):
|
|
|
|
queries_with_answers.append((query, [2, 1]))
|
|
|
|
|
|
|
|
for query in dct.get_is_in_queries(data[0], data[1]):
|
|
|
|
queries_with_answers.append((query, 0))
|
|
|
|
|
|
|
|
for query in dct.get_is_in_queries(data[1], data[0]):
|
|
|
|
queries_with_answers.append((query, 1))
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for query, answer in queries_with_answers:
|
|
|
|
print query
|
2019-02-24 17:45:10 +00:00
|
|
|
if isinstance(answer, list):
|
|
|
|
answer = str(answer).replace(' ', '')
|
2019-02-21 12:04:08 +00:00
|
|
|
assert node.query(query) == str(answer) + '\n'
|
|
|
|
|
2019-05-28 20:17:30 +00:00
|
|
|
|
2020-03-16 14:59:11 +00:00
|
|
|
@pytest.mark.parametrize("fold", list(range(10)))
|
|
|
|
def test_complex_dictionaries(started_cluster, fold):
|
2020-06-22 13:10:25 +00:00
|
|
|
if node.is_built_with_thread_sanitizer():
|
|
|
|
remove_mysql_dicts()
|
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
fields = FIELDS["complex"]
|
2019-09-17 13:35:19 +00:00
|
|
|
values = VALUES["complex"]
|
|
|
|
data = [Row(fields, vals) for vals in values]
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2020-03-16 14:59:11 +00:00
|
|
|
all_complex_dicts = [d for d in DICTIONARIES if d.structure.layout.layout_type == "complex"]
|
|
|
|
complex_dicts = get_dictionaries(fold, 10, all_complex_dicts)
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for dct in complex_dicts:
|
|
|
|
dct.load_data(data)
|
|
|
|
|
|
|
|
node.query("system reload dictionaries")
|
2019-02-22 12:13:55 +00:00
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
queries_with_answers = []
|
|
|
|
for dct in complex_dicts:
|
|
|
|
for row in data:
|
|
|
|
for field in fields:
|
|
|
|
if not field.is_key:
|
2019-02-22 10:55:12 +00:00
|
|
|
for query in dct.get_select_get_queries(field, row):
|
|
|
|
queries_with_answers.append((query, row.get_value_by_name(field.name)))
|
|
|
|
|
|
|
|
for query in dct.get_select_has_queries(field, row):
|
|
|
|
queries_with_answers.append((query, 1))
|
|
|
|
|
|
|
|
for query in dct.get_select_get_or_default_queries(field, row):
|
|
|
|
queries_with_answers.append((query, field.default_value_for_get))
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for query, answer in queries_with_answers:
|
|
|
|
print query
|
|
|
|
assert node.query(query) == str(answer) + '\n'
|
|
|
|
|
2019-05-28 20:17:30 +00:00
|
|
|
|
2020-03-16 14:59:11 +00:00
|
|
|
@pytest.mark.parametrize("fold", list(range(10)))
|
|
|
|
def test_ranged_dictionaries(started_cluster, fold):
|
2020-06-22 13:10:25 +00:00
|
|
|
if node.is_built_with_thread_sanitizer():
|
|
|
|
remove_mysql_dicts()
|
|
|
|
|
2019-02-21 12:04:08 +00:00
|
|
|
fields = FIELDS["ranged"]
|
2019-09-17 13:35:19 +00:00
|
|
|
values = VALUES["ranged"]
|
|
|
|
data = [Row(fields, vals) for vals in values]
|
2019-02-21 12:04:08 +00:00
|
|
|
|
2020-03-16 14:59:11 +00:00
|
|
|
all_ranged_dicts = [d for d in DICTIONARIES if d.structure.layout.layout_type == "ranged"]
|
|
|
|
ranged_dicts = get_dictionaries(fold, 10, all_ranged_dicts)
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for dct in ranged_dicts:
|
|
|
|
dct.load_data(data)
|
|
|
|
|
|
|
|
node.query("system reload dictionaries")
|
|
|
|
|
|
|
|
queries_with_answers = []
|
|
|
|
for dct in ranged_dicts:
|
|
|
|
for row in data:
|
|
|
|
for field in fields:
|
|
|
|
if not field.is_key and not field.is_range:
|
2019-02-22 10:55:12 +00:00
|
|
|
for query in dct.get_select_get_queries(field, row):
|
|
|
|
queries_with_answers.append((query, row.get_value_by_name(field.name)))
|
2019-02-21 12:04:08 +00:00
|
|
|
|
|
|
|
for query, answer in queries_with_answers:
|
|
|
|
print query
|
|
|
|
assert node.query(query) == str(answer) + '\n'
|