Exemple #1
0
    def testMultipleFinaliseGroup(self):
        test_db = ProvedDB(_TEST_CONFIG, 'json')
        for i in range(0, TEST_PAIR_PERIOD * TEST_PAIR_LENGTH, TEST_PAIR_PERIOD):
            for j in range(TEST_PAIR_PERIOD):
                val = str(i + j)
                test_db.create({val: val})

            for j in range(TEST_PAIR_PERIOD):
                check_group_hash = calculate_entry_hash([str(i + j), str(i + j)])
                existed, entries_length = test_db.get_finalised_group_entries_length(check_group_hash)
                self.assertEqual(False, existed, 'hash does exist')
                self.assertEqual(0, entries_length, 'hash entry index should be zero')

            check_hash_sum = calculate_submit_hash([[str(i + j), str(i + j)] for j in range(TEST_PAIR_PERIOD)])
            test_db.finalise(check_hash_sum)

        for i in range(0, TEST_PAIR_PERIOD * TEST_PAIR_LENGTH, TEST_PAIR_PERIOD):
            for j in range(TEST_PAIR_PERIOD):
                check_group_hash = calculate_entry_hash([str(i + j), str(i + j)])
                existed, entries_length = test_db.get_finalised_group_entries_length(check_group_hash)
                self.assertEqual(True, existed, 'hash does exist')
                self.assertEqual(TEST_PAIR_PERIOD, entries_length, 'hash entry index should not be zero')
                for k in range(TEST_PAIR_PERIOD):
                    entry_hash = test_db.get_finalised_group_entry(check_group_hash, k)
                    self.assertEqual(calculate_entry_hash([str(i + k), str(i + k)]),
                                     entry_hash,
                                     'hash should be the same')
Exemple #2
0
    def testSingleFinaliseGroup(self):
        test_db = ProvedDB(_TEST_CONFIG, 'json')
        test_key = 'show me the money'
        test_data = [{
            'testaaa': 'hash1'
        }, {
            'testbbb': 'hash2'
        }]
        test_db.create({test_key: test_data[0]})
        test_db.update({test_key: test_data[1]})

        for check_val in test_data:
            check_group_hash = calculate_entry_hash([test_key, check_val])
            existed, entries_length = test_db.get_finalised_group_entries_length(check_group_hash)
            self.assertEqual(False, existed, 'hash does exist')
            self.assertEqual(0, entries_length, 'hash entry index should be zero')

        check_hash_sum = calculate_submit_hash([[test_key, _] for _ in test_data])
        test_db.finalise(check_hash_sum)

        for check_val in test_data:
            check_group_hash = calculate_entry_hash([test_key, check_val])
            existed, entries_length = test_db.get_finalised_group_entries_length(check_group_hash)
            self.assertEqual(True, existed, 'hash does exist')
            self.assertEqual(len(test_data), entries_length, 'hash entry index should not be zero')
            for i in range(entries_length):
                entry_hash = test_db.get_finalised_group_entry(check_group_hash, i)
                self.assertEqual(calculate_entry_hash([test_key, test_data[i]]),
                                 entry_hash,
                                 'hash should be the same')
Exemple #3
0
    def testMultipleSubmitChecking(self):
        test_db = ProvedDB(_TEST_CONFIG, 'json')
        for i in range(0, TEST_PAIR_PERIOD * TEST_PAIR_LENGTH, TEST_PAIR_PERIOD):
            for j in range(TEST_PAIR_PERIOD):
                val = str(i + j)
                test_db.create({val: val})

        for i in range(0, TEST_PAIR_PERIOD * TEST_PAIR_LENGTH, TEST_PAIR_PERIOD):
            check_hash_sum = calculate_submit_hash([[str(i), str(i)],
                                                    [str(i + 1), str(i + 1)]])
            existed, finalised, entries_length = test_db.get_finalise_entries_length(check_hash_sum)
            self.assertEqual(True, existed, 'hash does exist')
            self.assertEqual(False, finalised, 'hash doesn finalise')
            self.assertEqual(2, entries_length, 'hash entry index should not be zero')
            test_db.finalise(check_hash_sum)

            existed, finalised, entries_length = test_db.get_finalise_entries_length(check_hash_sum)
            self.assertEqual(True, existed, 'hash does exist')
            self.assertEqual(True, finalised, 'hash doesn finalise')
            self.assertEqual(2, entries_length, 'hash entry index should not be zero')

            for j in range(entries_length):
                entry_hash = test_db.get_finalise_entry(check_hash_sum, j)
                self.assertEqual(calculate_entry_hash([str(i + j), str(i + j)]),
                                 entry_hash,
                                 'hash should be the same')
Exemple #4
0
    def testSingleEvent(self):
        private_node = SubmitAndRecordChainNode(config_path=_TEST_CONFIG,
                                                submit_hash_callback_objs=[],
                                                record_over_callback_objs=[],
                                                wait_time=1)
        private_node.start()
        test_db = ProvedDB(_TEST_CONFIG, 'json')
        test_data = [{'testaaa': 'hash1'}, {'testbbb': 'hash2'}]
        test_key = 'May the force be with you'
        test_db.create({test_key: test_data[0]})
        test_db.update({test_key: test_data[1]})

        gevent.sleep(1)
        check_hash_sum = calculate_submit_hash([[test_key, _]
                                                for _ in test_data])

        existed, finalised, entries_length = test_db.get_finalise_entries_length(
            check_hash_sum)
        self.assertEqual(True, existed, 'hash does exist')
        self.assertEqual(True, finalised, 'hash doesn finalise')
        self.assertEqual(2, entries_length,
                         'hash entry index should not be zero')

        for i in range(entries_length):
            entry_hash = test_db.get_finalise_entry(check_hash_sum, i)
            self.assertEqual(calculate_entry_hash([test_key, test_data[i]]),
                             entry_hash, 'hash should be the same')
        private_node.kill()
Exemple #5
0
    def testMultipleEvent(self):
        self._record_over_hashes = []
        test_hash_mgr = RecordHash(_TEST_CONFIG)
        private_node = BaseChainNode(config_path=_TEST_CONFIG,
                                     submit_hash_callback_objs=[],
                                     record_over_callback_objs=[self],
                                     wait_time=1)
        private_node.start()
        check_hashes = []
        for i in range(0, TEST_PAIR_PERIOD * TEST_PAIR_LENGTH,
                       TEST_PAIR_PERIOD):
            for j in range(TEST_PAIR_PERIOD):
                val = str(i + j)
                hash_val = calculate_entry_hash([val, val])
                test_hash_mgr.record(hash_val)
                check_hashes.append(hash_val)

        private_node.join(4)
        self.assertEqual(check_hashes, self._record_over_hashes,
                         'data should be the same')
Exemple #6
0
    def testBehaior(self):
        private_node = SubmitAndRecordChainNode(config_path=_TEST_CONFIG,
                                                submit_hash_callback_objs=[],
                                                record_over_callback_objs=[],
                                                wait_time=1)
        private_node.start()
        test_db = ProvedDB(_TEST_CONFIG, 'json')
        # setting key val
        test_db.create({'my_key1': 'key1_data_01'})
        test_db.create({'my_key2': 'key1_data_01'})

        test_db.create({'my_key3': 'key1_data_01'})
        test_db.create({'my_key4': 'key1_data_01'})

        test_db.create({'my_key5': 'key1_data_01'})
        # check all entry
        test_db.check_all_entries()
        val = test_db.retrieve('my_key2')
        self.assertEqual(True, test_db.check_entry('my_key2', val),
                         'should pass')

        gevent.sleep(1)
        # check finalised data
        check_hash = calculate_entry_hash(['my_key3', 'key1_data_01'])
        existed, entries_length = test_db.get_finalised_group_entries_length(
            check_hash)
        self.assertEqual(True, existed, 'should be pass')
        all_check_hash = [
            test_db.get_finalised_group_entry(check_hash, i)
            for i in range(entries_length)
        ]
        self.assertEqual(True, check_hash in all_check_hash, 'should pass')

        check_hash_sum = calculate_submit_hash_from_group(all_check_hash)
        existed, finalised, entries_length = test_db.get_finalise_entries_length(
            check_hash_sum)
        self.assertEqual(True, existed, 'hash does exist')
        self.assertEqual(True, finalised, 'hash doesn finalise')
        self.assertEqual(2, entries_length,
                         'hash entry index should not be zero')

        double_check_hashes = [
            test_db.get_finalise_entry(check_hash_sum, i)
            for i in range(entries_length)
        ]
        self.assertEqual(double_check_hashes, all_check_hash, 'should pass')

        check_hash = calculate_entry_hash(['my_key5', 'key1_data_01'])
        existed, entries_length = test_db.get_finalised_group_entries_length(
            check_hash)
        self.assertEqual(False, existed, 'should be pass')

        # Test again
        test_db.update({'my_key5': 'key1_data_02'})
        gevent.sleep(1)

        check_hash = calculate_entry_hash(['my_key5', 'key1_data_01'])
        existed, entries_length = test_db.get_finalised_group_entries_length(
            check_hash)
        self.assertEqual(True, existed, 'should be pass')

        all_check_hash = [
            test_db.get_finalised_group_entry(check_hash, i)
            for i in range(entries_length)
        ]
        self.assertEqual(True, check_hash in all_check_hash, 'should pass')

        check_hash_sum = calculate_submit_hash_from_group(all_check_hash)
        existed, finalised, entries_length = test_db.get_finalise_entries_length(
            check_hash_sum)
        self.assertEqual(True, existed, 'hash does exist')
        self.assertEqual(True, finalised, 'hash doesn finalise')
        self.assertEqual(2, entries_length,
                         'hash entry index should not be zero')

        double_check_hashes = [
            test_db.get_finalise_entry(check_hash_sum, i)
            for i in range(entries_length)
        ]
        self.assertEqual(double_check_hashes, all_check_hash, 'should pass')

        #        # setting key val again
        test_db.delete('my_key2')
        test_db.create({'my_key6': 'key1_data_01'})
        # Test again
        test_db.update({'my_key6': 'key1_data_02'})

        gevent.sleep(1)
        check_hash = calculate_entry_hash(['my_key6', 'key1_data_01'])
        existed, entries_length = test_db.get_finalised_group_entries_length(
            check_hash)
        self.assertEqual(True, existed, 'should be pass')

        all_check_hash = [
            test_db.get_finalised_group_entry(check_hash, i)
            for i in range(entries_length)
        ]
        self.assertEqual(True, check_hash in all_check_hash, 'should pass')

        check_hash_sum = calculate_submit_hash_from_group(all_check_hash)
        existed, finalised, entries_length = test_db.get_finalise_entries_length(
            check_hash_sum)
        self.assertEqual(True, existed, 'hash does exist')
        self.assertEqual(True, finalised, 'hash doesn finalise')
        self.assertEqual(2, entries_length,
                         'hash entry index should not be zero')

        double_check_hashes = [
            test_db.get_finalise_entry(check_hash_sum, i)
            for i in range(entries_length)
        ]
        self.assertEqual(double_check_hashes, all_check_hash, 'should pass')

        private_node.kill()
 def hash_entry(self, input_vals):
     return calculate_entry_hash(input_vals)