コード例 #1
0
    def test__anonymize_data(self):
        """Anonymoze data in tables with pii fields"""

        # Setup
        def side_effect_get_pii(ht_meta):
            if ht_meta['ht'] == 'a':
                return ['a_fields']

        anonymized_table = pd.DataFrame({'a_fields': [1, 2, 3]})
        anonymized_another_table = pd.DataFrame({'a_fields': [4, 5, 6]})

        ht_mock = Mock()
        ht_mock.table_dict = {
            'a_table': (anonymized_table, {
                'ht': 'a'
            }),
            'another_table': (anonymized_another_table, {
                'ht': 'b'
            })
        }

        ht_mock._get_pii_fields.side_effect = side_effect_get_pii

        a_table = pd.DataFrame({'a_fields': [1, 2, 3]})
        another_table = Table(pd.DataFrame(), {'another': 'metadata'})
        tables = {
            'a_table': Table(a_table, {'some': 'metadata'}),
            'another_table': another_table,
        }

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.tables = tables
        data_navigator_mock.ht = ht_mock

        DataNavigator._anonymize_data(data_navigator_mock)

        # Asserts
        exp_call_args_list = [
            call({'ht': 'a'}),
            call({'ht': 'b'}),
        ]
        exp_a_table_dataframe = pd.DataFrame({'a_fields': [1, 2, 3]})
        exp_another_dataframe = pd.DataFrame()

        pd.testing.assert_frame_equal(tables['a_table'].data,
                                      exp_a_table_dataframe)
        pd.testing.assert_frame_equal(tables['another_table'].data,
                                      exp_another_dataframe)

        for arg_item in ht_mock._get_pii_fields.call_args_list:
            assert arg_item in exp_call_args_list
コード例 #2
0
    def test_transform_data_default_transformers(self):
        """transform_data with default transformers."""

        # Setup
        default_transformers = [
            'NumberTransformer', 'DTTransformer', 'CatTransformer'
        ]

        ht_mock = Mock()
        ht_mock.fit_transform.return_value = {'some': 'data'}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.DEFAULT_TRANSFORMERS = default_transformers
        data_navigator_mock.ht = ht_mock

        result = DataNavigator.transform_data(data_navigator_mock, None)

        # Asserts
        expect = {'some': 'data'}
        expect_transformers = [
            'NumberTransformer', 'DTTransformer', 'CatTransformer'
        ]

        assert result == expect

        ht_mock.fit_transform.assert_called_once_with(
            transformer_list=expect_transformers)
コード例 #3
0
    def test_get_meta_data(self):
        """Retrieve table meta"""

        # Setup
        tables = {'DEMO': Table(None, 'meta')}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.tables = tables

        result = DataNavigator.get_meta_data(data_navigator_mock, 'DEMO')

        # Asserts
        expect = 'meta'

        assert result == expect
コード例 #4
0
    def test_get_parents_no_parents(self):
        """No parents from the given table"""

        # Setup
        parents = {}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.parent_map = parents

        result = DataNavigator.get_parents(data_navigator_mock, 'DEMO')

        # Asserts
        expect = set()

        assert expect == result
コード例 #5
0
    def test_get_parents(self):
        """get_parents returns the relational parent of a table."""

        # Setup
        parents = {'DEMO': {'parent_a': 'foo'}}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.parent_map = parents

        result = DataNavigator.get_parents(data_navigator_mock, 'DEMO')

        # Asserts
        expect = {'parent_a': 'foo'}

        assert expect == result
コード例 #6
0
    def test_get_children_no_childrens(self):
        """No children from the given table"""

        # Setup
        childs = {}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.child_map = childs

        result = DataNavigator.get_children(data_navigator_mock, 'DEMO')

        # Asserts
        expect = set()

        assert expect == result
コード例 #7
0
    def test_get_children(self):
        """get_children returns the relational children of a table."""

        # Setup
        childs = {'DEMO': {'child_a': 'foo'}}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.child_map = childs

        result = DataNavigator.get_children(data_navigator_mock, 'DEMO')

        # Asserts
        expect = {'child_a': 'foo'}

        assert expect == result
コード例 #8
0
    def test_get_data(self):
        """Retrieve table data"""

        # Setup
        data = pd.DataFrame({'foo': [0, 1]})
        tables = {'DEMO': Table(data, 'meta')}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.tables = tables

        result = DataNavigator.get_data(data_navigator_mock, 'DEMO')

        # Asserts
        expect = pd.DataFrame({'foo': [0, 1]})

        pd.testing.assert_frame_equal(result, expect)
コード例 #9
0
    def test_update_mapping_when_no_item(self):
        """update_mapping when item is nothing"""

        # Setup

        # Run
        mapping = {}
        key = 'foo'
        value = 'tar'

        data_navigator_mock = Mock()

        result = DataNavigator.update_mapping(data_navigator_mock, mapping,
                                              key, value)

        # Asserts
        expect = {'foo': set(['tar'])}

        assert result == expect
コード例 #10
0
    def test___init__(self, ht_mock, anonymize_mock, relationships_mock):
        """__init__ without missing."""

        # Setup
        ht_mock.return_value = Mock()
        relationships_mock.return_value = 'foo', 'bar', 'tar'

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock._anonymize_data = anonymize_mock
        data_navigator_mock._get_relationships = relationships_mock

        DataNavigator('meta_filename', {'some': 'meta'}, {'a_table': 'table'})

        # Asserts
        ht_mock.assert_called_once_with('meta_filename', missing=None)

        data_navigator_mock._anonymize_data.assert_called_once_with()
        data_navigator_mock._get_relationships.assert_called_once_with(
            {'a_table': 'table'})
コード例 #11
0
    def test__get_relashionships(self):
        """_get_relashionships returns parents, children and foreign_keys dicts."""

        # Setup
        meta = {
            'fields': {
                'a_field': {
                    'name': 'a_field',
                    'ref': {
                        'table': 'DEMO_2',
                        'field': 'DEMO_2_ID'
                    }
                }
            }
        }

        tables = {'DEMO': Table('data', meta)}

        update_mock = Mock()
        update_mock.side_effect = ['child', 'parent']

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.update_mapping = update_mock

        result = DataNavigator._get_relationships(data_navigator_mock, tables)

        # Asserts
        expect = 'child', 'parent', {
            ('DEMO', 'DEMO_2'): ('DEMO_2_ID', 'a_field')
        }
        exp_args_list = [
            call({}, 'DEMO_2', 'DEMO'),
            call({}, 'DEMO', 'DEMO_2')
        ]

        assert result == expect
        update_mock.call_args_list == exp_args_list
コード例 #12
0
    def test_transform_data_with_transformers(self):
        """transform_data with transformers from parameters"""

        # Setup
        transformers = ['NumberTransformer', 'DTTransformer']

        ht_mock = Mock()
        ht_mock.fit_transform.return_value = {'some': 'data'}

        # Run
        data_navigator_mock = Mock()
        data_navigator_mock.ht = ht_mock

        result = DataNavigator.transform_data(data_navigator_mock,
                                              transformers=transformers)

        # Asserts
        expect = {'some': 'data'}
        expect_transformers = ['NumberTransformer', 'DTTransformer']

        assert result == expect

        ht_mock.fit_transform.assert_called_once_with(
            transformer_list=expect_transformers)