Passed
Push — mpeta ( b3f7e8...55fafe )
by Konstantinos
03:43
created

conftest.load_test_data_this()   A

Complexity

Conditions 2

Size

Total Lines 7
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 7
nop 1
dl 0
loc 7
rs 10
c 0
b 0
f 0
1
import os
2
import pytest
3
4
5
my_dir = os.path.dirname(os.path.realpath(__file__))
6
7
####### Files and folders
8
@pytest.fixture
9
def tests_root_dir():
10
    return my_dir
11
12
@pytest.fixture
13
def tests_data_root(tests_root_dir):
14
    return os.path.join(tests_root_dir, 'dts')
15
16
# Test data
17
@pytest.fixture
18
def sample_json(tests_data_root):
19
    return os.path.join(tests_data_root, 'sample-data.jsonlines')
20
21
@pytest.fixture
22
def sample_collaped_json(tests_data_root):
23
    return os.path.join(tests_data_root, 'sample-data-collapsed.jsonlines')
24
25
26
@pytest.fixture()
27
def test_json_data(sample_json):
28
    return {
29
        'file_path': sample_json,
30
        'nb_lines': 100,
31
        'attributes': {'flavors', 'name', 'medical', 'description', 'image_urls', 'parents', 'negatives', 'grow_info', '_id', 'type', 'image_paths', 'effects'},
32
    }
33
34
35
@pytest.fixture
36
def somagic():
37
    from so_magic import init_so_magic
38
    _ = init_so_magic()
39
    return _
40
41
42
@pytest.fixture
43
def data_manager():
44
    def getter():
45
        from so_magic.data import init_data_manager
46
        from so_magic.data.backend import init_engine
47
48
        data_manager = init_data_manager(init_engine(engine_type='pd'))
49
50
        datapoints_fact = data_manager.engine.backend.datapoints_factory
51
        cmd_fact = data_manager.engine.backend.command_factory
52
53
        # test 1
54
        from so_magic.data.datapoints.datapoints import DatapointsFactory
55
        from so_magic.data.backend.engine_command_factory import MagicCommandFactory
56
57
        assert isinstance(datapoints_fact, DatapointsFactory)
58
        assert isinstance(cmd_fact, MagicCommandFactory)
59
60
        subjects = [datapoints_fact.subject, cmd_fact, data_manager.phi_class.subject]
61
        assert len(set([id(x._observers) for x in subjects])) == len(subjects)
62
63
        assert datapoints_fact.subject._observers[0] == data_manager.engine.datapoints_manager
64
        assert cmd_fact._observers[0] == data_manager.commands_manager.command.accumulator
65
        assert data_manager.phi_class.subject._observers[0] == data_manager.built_phis
66
67
        print(f"DTP FCT OBS: [{', '.join(str(_) for _ in datapoints_fact.subject._observers)}]")
68
        print(f"CMD FCT OBS: [{', '.join(str(_) for _ in cmd_fact._observers)}]")
69
        print(f"PHIFUNC class OBS: [{', '.join(str(_) for _ in data_manager.phi_class.subject._observers)}]")
70
        assert all([len(x._observers) == 1 for x in subjects])
71
        return data_manager
72
73
    return getter
74
75
76
@pytest.fixture
77
def test_data_manager(data_manager):
78
    return data_manager()
79
80
81
@pytest.fixture
82
def load_test_data(test_data_manager, sample_json):
83
    def load_data(json_lines_formatted_file_path):
84
        cmd = test_data_manager.command.observations_command
85
        cmd.args = [json_lines_formatted_file_path]
86
        cmd.execute()
87
    return lambda: load_data(sample_json)
88
89
90
@pytest.fixture
91
def load_test_data_this(sample_collaped_json):
92
    def load_data(so_master, json_lines_formatted_file_path):
93
        cmd = so_master.command.observations_command
94
        cmd.args = [json_lines_formatted_file_path]
95
        cmd.execute()
96
    return lambda so_master_instance: load_data(so_master_instance, sample_collaped_json)
97