|
@ -29,10 +29,10 @@ OS_SYSTEM = test.constants.OS_SYSTEM |
|
|
# the list of TEST_FUNCTIONS defines which function will be really tested. |
|
|
# the list of TEST_FUNCTIONS defines which function will be really tested. |
|
|
# if you minimize the list you can check the specific test-function |
|
|
# if you minimize the list you can check the specific test-function |
|
|
TEST_FUNCTIONS = ["test_11ddl", "test_12catalog", |
|
|
TEST_FUNCTIONS = ["test_11ddl", "test_12catalog", |
|
|
"test_02getCsvSpec_data", "test_03getCsvSpec_tree", "test_04getCsvSpec_key", |
|
|
"test_02getCsvSpec_data", "test_03getCsvSpec_tree", "test_14getCsvSpec_key", |
|
|
"test_05getCsvSpec_conf", "test_06parseCsv"] |
|
|
"test_15getCsvSpec_conf", "test_06parseCsv"] |
|
|
TEST_FUNCTIONS = ["test_12catalog"] |
|
|
TEST_FUNCTIONS = ["test_11ddl", "test_12catalog", "test_14getCsvSpec_key", "test_15getCsvSpec_conf"] |
|
|
TEST_FUNCTIONS = ["test_11ddl"] |
|
|
TEST_FUNCTIONS = ["test_02getCsvSpec_data"] |
|
|
PROGRAM_NAME = "clean_workspace" |
|
|
PROGRAM_NAME = "clean_workspace" |
|
|
|
|
|
|
|
|
# with this variable you can switch prints on and off |
|
|
# with this variable you can switch prints on and off |
|
@ -142,7 +142,7 @@ class MyTestCase(unittest.TestCase): |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
return |
|
|
return |
|
|
job = basic.program.SimpleJob(PROGRAM_NAME) |
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
setattr(job.par, "tdtyp", "dir") |
|
|
setattr(job.par, "tdtyp", "dir") |
|
|
setattr(job.par, "tdsrc", "TC0001") |
|
|
setattr(job.par, "tdsrc", "TC0001") |
|
|
setattr(job.par, "tdname", "testspec") |
|
|
setattr(job.par, "tdname", "testspec") |
|
@ -183,7 +183,7 @@ class MyTestCase(unittest.TestCase): |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
return |
|
|
return |
|
|
job = test.testtools.getJob() |
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
# filename = os.path.join(job.conf["paths"]["testdata"], getattr(job.par, "tdsrc"), getattr(job.par, "tdname") + ".csv") |
|
|
# filename = os.path.join(job.conf["paths"]["testdata"], getattr(job.par, "tdsrc"), getattr(job.par, "tdname") + ".csv") |
|
|
""" |
|
|
""" |
|
|
a) data : like a table with data-array of key-value-pairs |
|
|
a) data : like a table with data-array of key-value-pairs |
|
@ -199,7 +199,7 @@ class MyTestCase(unittest.TestCase): |
|
|
] |
|
|
] |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
self.assertEqual(0, len(tdata)) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
cnttest += 1 |
|
|
cnttest += 1 |
|
|
if "malformated" in tests: |
|
|
if "malformated" in tests: |
|
|
malformat = "option;arg;;;;;" |
|
|
malformat = "option;arg;;;;;" |
|
@ -235,49 +235,55 @@ class MyTestCase(unittest.TestCase): |
|
|
"option:description;something;;;;;", |
|
|
"option:description;something;;;;;", |
|
|
"#;;;;;;" |
|
|
"#;;;;;;" |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_DATA, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
print(tdata) |
|
|
print(tdata) |
|
|
self.assertIn(D.CSV_BLOCK_OPTION, tdata) |
|
|
self.assertIn(D.CSV_BLOCK_OPTION, tdata) |
|
|
cnttest += 2 |
|
|
cnttest += 2 |
|
|
if D.CSV_BLOCK_STEP in tests: |
|
|
if D.CSV_BLOCK_STEP in tests: |
|
|
specLines = [ |
|
|
specLines = [ |
|
|
"step:1;testa;1;1;table:_lofts,action:import;;;;;", |
|
|
# "step:1;testa;1;1;table:_lofts,action:import;;;;;", |
|
|
|
|
|
"step:header;_nr;variant;data;program;comp;args;;;;;;", |
|
|
|
|
|
";1;testa;person:1;execute_testcase;testrest;action:import;;;;;", |
|
|
"#;;;;;;" |
|
|
"#;;;;;;" |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_DATA, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
print(tdata) |
|
|
print(tdata) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertIn(B.DATA_NODE_STEPS, tdata) |
|
|
self.assertIn(B.DATA_NODE_STEPS, tdata) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_STEPS], list) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_STEPS], dict) |
|
|
|
|
|
self.assertIsInstance(tdata[B.DATA_NODE_STEPS][B.DATA_NODE_DATA], list) |
|
|
cnttest += 3 |
|
|
cnttest += 3 |
|
|
for step in tdata[B.DATA_NODE_STEPS]: |
|
|
for step in tdata[B.DATA_NODE_STEPS][B.DATA_NODE_DATA]: |
|
|
print(step) |
|
|
print(step) |
|
|
self.assertEqual(hasattr(step, B.DATA_NODE_COMP), True) |
|
|
self.assertIn(B.DATA_NODE_COMP, step) |
|
|
# self.assertEqual(hasattr(step, B.ATTR_DATA_REF), True) |
|
|
self.assertIn(B.DATA_NODE_ARGS, step) |
|
|
self.assertEqual(hasattr(step, B.ATTR_STEP_ARGS), True) |
|
|
|
|
|
cnttest += 3 |
|
|
cnttest += 3 |
|
|
specLines = [ |
|
|
specLines = [ |
|
|
"step:1;testa;1;1;table:_lofts;action:export;;;;;", |
|
|
"step:header;_nr;variant;data;program;comp;args;;;;;;", |
|
|
"#;;;;;;" |
|
|
";1;testa;person:1;execute_testcase;testrest;action:import;var:xyz;;;;" |
|
|
] |
|
|
] |
|
|
tdata = {} |
|
|
tdata = {} |
|
|
tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_DATA, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
print(tdata) |
|
|
print(tdata) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertIn(B.DATA_NODE_STEPS, tdata) |
|
|
self.assertIn(B.DATA_NODE_STEPS, tdata) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_STEPS], list) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_STEPS], dict) |
|
|
self.assertEqual(2, len(tdata[B.DATA_NODE_STEPS][0].args)) |
|
|
self.assertEqual(2, len(tdata[B.DATA_NODE_STEPS][B.DATA_NODE_DATA][0][B.DATA_NODE_ARGS])) |
|
|
cnttest += 3 |
|
|
cnttest += 3 |
|
|
if B.DATA_NODE_TABLES in tests: |
|
|
text = f.buildCsv(job.m, job, tdata) |
|
|
|
|
|
spez = "_type;data\n"+self.stripDelimiter(specLines) |
|
|
|
|
|
self.assertEqual(spez, text) |
|
|
|
|
|
print(text) |
|
|
|
|
|
if B.DATA_NODE_TABLES in tdata: |
|
|
specLines = [ |
|
|
specLines = [ |
|
|
"table:testa:lofts;_nr;street;city;zip;state;beds;baths;sqft;type;price;latitude;longitude", |
|
|
"table:testa:lofts;_nr;street;city;zip;state;beds;baths;sqft;type;price;latitude;longitude", |
|
|
"testa:lofts;1;stra;town;12345;usa;4;1;50;house;111;45;8", |
|
|
"testa:lofts;1;stra;town;12345;usa;4;1;50;house;111;45;8", |
|
|
"#;;;;;;" |
|
|
"#;;;;;;" |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsvSpec(job.m, specLines, B.DATA_NODE_TABLES, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
print(tdata) |
|
|
print(tdata) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertIn(B.DATA_NODE_TABLES, tdata) |
|
|
self.assertIn(B.DATA_NODE_TABLES, tdata) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_TABLES], dict) |
|
|
self.assertIsInstance(tdata[B.DATA_NODE_TABLES], dict) |
|
|
cnttest += 3 |
|
|
cnttest += 3 |
|
@ -301,12 +307,24 @@ class MyTestCase(unittest.TestCase): |
|
|
"testrest:person;1;Brecht;Bert;10.02.98;m", |
|
|
"testrest:person;1;Brecht;Bert;10.02.98;m", |
|
|
"testrest:person,testcrmdb:person;2;Leon;Donna;28.09.42;f" |
|
|
"testrest:person,testcrmdb:person;2;Leon;Donna;28.09.42;f" |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_DATA, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_DATA) |
|
|
print(tdata) |
|
|
print(tdata) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
|
|
|
|
|
|
|
|
|
def stripDelimiter(self, lines): |
|
|
|
|
|
out = "" |
|
|
|
|
|
for l in lines: |
|
|
|
|
|
if len(l) > 0 and l[0:1] == "#": |
|
|
|
|
|
continue |
|
|
|
|
|
while len(l) > 1 and l[-1:] == ";": |
|
|
|
|
|
l = l[:-1] |
|
|
|
|
|
out += "\n" + l |
|
|
|
|
|
if len(out) > 0: |
|
|
|
|
|
out = out[1:] |
|
|
|
|
|
return out |
|
|
|
|
|
|
|
|
def test_03getCsvSpec_tree(self): |
|
|
def test_03getCsvSpec_tree(self): |
|
|
|
|
|
# TODO : Baumstruktur fuer properties |
|
|
global mymsg |
|
|
global mymsg |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
@ -330,16 +348,17 @@ class MyTestCase(unittest.TestCase): |
|
|
";Meldung_senden;Mock;1;cli;must:;;", |
|
|
";Meldung_senden;Mock;1;cli;must:;;", |
|
|
";Batche_starten_stopen;Mock;1;api;must:;;" |
|
|
";Batche_starten_stopen;Mock;1;api;must:;;" |
|
|
] |
|
|
] |
|
|
|
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_04getCsvSpec_key(self): |
|
|
def test_14getCsvSpec_key(self): |
|
|
global mymsg |
|
|
global mymsg |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
return |
|
|
return |
|
|
job = test.testtools.getJob() |
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
"""" |
|
|
"""" |
|
|
c) keys : as a tree - the rows must be unique identified by the first column |
|
|
c) keys : as a tree - the rows must be unique identified by the first column |
|
|
a_0 is keyword in CSV_HEADER_START |
|
|
a_0 is keyword in CSV_HEADER_START |
|
@ -353,8 +372,8 @@ class MyTestCase(unittest.TestCase): |
|
|
"#;;;;;;" |
|
|
"#;;;;;;" |
|
|
] |
|
|
] |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
tdata = f.parseCsv(job.m, specLines, D.CSV_SPECTYPE_CONF, {}, job) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_KEYS) |
|
|
self.assertEqual(0, len(tdata)) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
cnttest += 1 |
|
|
cnttest += 1 |
|
|
if "malformated" in tests: |
|
|
if "malformated" in tests: |
|
|
malformat = "table;key;;;;;" |
|
|
malformat = "table;key;;;;;" |
|
@ -373,9 +392,9 @@ class MyTestCase(unittest.TestCase): |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_KEYS) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_KEYS) |
|
|
print(str(tdata)) |
|
|
print(str(tdata)) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertEqual(1, len(tdata["_tables"])) |
|
|
self.assertEqual(1, len(tdata["_tables"])) |
|
|
self.assertEqual(4, len(tdata["_tables"]["capital"])) |
|
|
self.assertEqual(3, len(tdata["_tables"]["capital"])) |
|
|
self.assertEqual(3, len(tdata["_tables"]["capital"]["_keys"])) |
|
|
self.assertEqual(3, len(tdata["_tables"]["capital"]["_keys"])) |
|
|
cnttest += 4 |
|
|
cnttest += 4 |
|
|
specLines = [ |
|
|
specLines = [ |
|
@ -389,23 +408,22 @@ class MyTestCase(unittest.TestCase): |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_KEYS) |
|
|
tdata = f.parseCsv(job.m, job, specLines, D.CSV_SPECTYPE_KEYS) |
|
|
#tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_TREE) |
|
|
#tdata = f.parseCsvSpec(job.m, specLines, D.CSV_SPECTYPE_TREE) |
|
|
print(str(tdata)) |
|
|
print(str(tdata)) |
|
|
self.assertEqual(1, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertIn("capital", tdata["_tables"]) |
|
|
self.assertIn("capital", tdata["_tables"]) |
|
|
self.assertEqual(2, len(tdata["_tables"])) |
|
|
self.assertEqual(2, len(tdata["_tables"])) |
|
|
self.assertEqual(4, len(tdata["_tables"]["country"])) |
|
|
self.assertEqual(3, len(tdata["_tables"]["country"])) |
|
|
self.assertEqual(2, len(tdata["_tables"]["country"]["_keys"])) |
|
|
self.assertEqual(2, len(tdata["_tables"]["country"]["_keys"])) |
|
|
cnttest += 4 |
|
|
cnttest += 4 |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_05getCsvSpec_conf(self): |
|
|
def test_15getCsvSpec_conf(self): |
|
|
global mymsg |
|
|
global mymsg |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
actfunction = str(inspect.currentframe().f_code.co_name) |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
return |
|
|
return |
|
|
job = basic.program.SimpleJob(PROGRAM_NAME) |
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
# job = test.testtools.getJob() |
|
|
|
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
"""" |
|
|
"""" |
|
|
d) conf: |
|
|
d) conf: |
|
@ -421,11 +439,11 @@ class MyTestCase(unittest.TestCase): |
|
|
"#;;;;;;" |
|
|
"#;;;;;;" |
|
|
] |
|
|
] |
|
|
specLinesB = [ |
|
|
specLinesB = [ |
|
|
"_type;conf;;;;;;", |
|
|
"_type;conf", |
|
|
"table:lofts;_field;field;type;acceptance;key", |
|
|
"table:lofts;_field;field;type;acceptance;key", |
|
|
"lofts;street;a;str;;T:1", |
|
|
";street;a;str;;T:1", |
|
|
";city;b;str;;F:1", |
|
|
";city;b;str;;F:1", |
|
|
"#;;;;;;" |
|
|
"" |
|
|
] |
|
|
] |
|
|
tdata = f.parseCsv(job.m, job, specLinesA, D.CSV_SPECTYPE_CONF) |
|
|
tdata = f.parseCsv(job.m, job, specLinesA, D.CSV_SPECTYPE_CONF) |
|
|
self.assertEqual(2, len(tdata)) |
|
|
self.assertEqual(2, len(tdata)) |
|
@ -447,6 +465,7 @@ class MyTestCase(unittest.TestCase): |
|
|
returnLines = f.buildCsv(job.m, job, tdata, D.CSV_SPECTYPE_CONF) |
|
|
returnLines = f.buildCsv(job.m, job, tdata, D.CSV_SPECTYPE_CONF) |
|
|
print("returnLines:") |
|
|
print("returnLines:") |
|
|
print(returnLines) |
|
|
print(returnLines) |
|
|
|
|
|
self.assertEqual("\n".join(specLinesB), returnLines) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
MyTestCase.mymsg += "\n----- "+actfunction+" : "+str(cnttest) |
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -456,7 +475,7 @@ class MyTestCase(unittest.TestCase): |
|
|
cnttest = 0 |
|
|
cnttest = 0 |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
if actfunction not in TEST_FUNCTIONS: |
|
|
return |
|
|
return |
|
|
job = test.testtools.getJob() |
|
|
job = test.testtools.getWorkspaceJob(PROGRAM_NAME) |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
f = toolHandling.getFileTool(job, None, "csv") |
|
|
cm = basic.componentHandling.ComponentManager.getInstance(job) |
|
|
cm = basic.componentHandling.ComponentManager.getInstance(job) |
|
|
componentName = "testcrmdb" |
|
|
componentName = "testcrmdb" |
|
|