2
0

hashindex.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import hashlib
  2. import tempfile
  3. from attic.hashindex import NSIndex, ChunkIndex
  4. from attic.testsuite import AtticTestCase
  5. class HashIndexTestCase(AtticTestCase):
  6. def _generic_test(self, cls, make_value, sha):
  7. idx_name = tempfile.NamedTemporaryFile()
  8. idx = cls.create(idx_name.name)
  9. self.assert_equal(len(idx), 0)
  10. # Test set
  11. for x in range(100):
  12. idx[bytes('%-32d' % x, 'ascii')] = make_value(x)
  13. self.assert_equal(len(idx), 100)
  14. for x in range(100):
  15. self.assert_equal(idx[bytes('%-32d' % x, 'ascii')], make_value(x))
  16. # Test update
  17. for x in range(100):
  18. idx[bytes('%-32d' % x, 'ascii')] = make_value(x * 2)
  19. self.assert_equal(len(idx), 100)
  20. for x in range(100):
  21. self.assert_equal(idx[bytes('%-32d' % x, 'ascii')], make_value(x * 2))
  22. # Test delete
  23. for x in range(50):
  24. del idx[bytes('%-32d' % x, 'ascii')]
  25. self.assert_equal(len(idx), 50)
  26. del idx
  27. # Verify file contents
  28. with open(idx_name.name, 'rb') as fd:
  29. self.assert_equal(hashlib.sha256(fd.read()).hexdigest(), sha)
  30. # Make sure we can open the file
  31. idx = cls(idx_name.name)
  32. self.assert_equal(len(idx), 50)
  33. for x in range(50, 100):
  34. self.assert_equal(idx[bytes('%-32d' % x, 'ascii')], make_value(x * 2))
  35. idx.clear()
  36. self.assert_equal(len(idx), 0)
  37. del idx
  38. self.assert_equal(len(cls(idx_name.name)), 0)
  39. def test_nsindex(self):
  40. self._generic_test(NSIndex, lambda x: (x, x), '369a18ae6a52524eb2884a3c0fdc2824947edd017a2688c5d4d7b3510c245ab9')
  41. def test_chunkindex(self):
  42. self._generic_test(ChunkIndex, lambda x: (x, x, x), 'ed22e8a883400453c0ee79a06c54df72c994a54eeefdc6c0989efdc5ee6d07b7')