summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/test_verify.py168
1 files changed, 168 insertions, 0 deletions
diff --git a/tests/test_verify.py b/tests/test_verify.py
index 5393b4c..a9e7a5e 100644
--- a/tests/test_verify.py
+++ b/tests/test_verify.py
@@ -49,6 +49,12 @@ class NonExistingFileVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(os.path.join(self.dir, 'test'), None),
(True, []))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA('test', 0, {})
+ self.assertRaises(gemato.exceptions.ManifestInvalidPath,
+ gemato.verify.update_entry_for_path,
+ os.path.join(self.dir, 'test'), e)
+
class DirectoryVerificationTest(unittest.TestCase):
def setUp(self):
@@ -85,6 +91,12 @@ class DirectoryVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.dir, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.dir), 0, {})
+ self.assertRaises(gemato.exceptions.ManifestInvalidPath,
+ gemato.verify.update_entry_for_path, self.dir, e)
+
class CharacterDeviceVerificationTest(unittest.TestCase):
def setUp(self):
@@ -118,6 +130,12 @@ class CharacterDeviceVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.path, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ self.assertRaises(gemato.exceptions.ManifestInvalidPath,
+ gemato.verify.update_entry_for_path, self.path, e)
+
class NamedPipeVerificationTest(unittest.TestCase):
def setUp(self):
@@ -157,6 +175,12 @@ class NamedPipeVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.path, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ self.assertRaises(gemato.exceptions.ManifestInvalidPath,
+ gemato.verify.update_entry_for_path, self.path, e)
+
class UNIXSocketVerificationTest(unittest.TestCase):
def setUp(self):
@@ -199,6 +223,12 @@ class UNIXSocketVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.path, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ self.assertRaises(gemato.exceptions.ManifestInvalidPath,
+ gemato.verify.update_entry_for_path, self.path, e)
+
class EmptyFileVerificationTest(unittest.TestCase):
def setUp(self):
@@ -306,6 +336,78 @@ class EmptyFileVerificationTest(unittest.TestCase):
gemato.verify.verify_path, self.path, e,
expected_dev=st.st_dev)
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 0)
+ self.assertDictEqual(e.checksums, {})
+
+ def test_update_with_hashes(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e, ['MD5', 'SHA1'])
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 0)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': 'd41d8cd98f00b204e9800998ecf8427e',
+ 'SHA1': 'da39a3ee5e6b4b0d3255bfef95601890afd80709',
+ })
+
+ def test_update_with_hashes_from_manifest(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {'MD5': '', 'SHA1': ''})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 0)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': 'd41d8cd98f00b204e9800998ecf8427e',
+ 'SHA1': 'da39a3ee5e6b4b0d3255bfef95601890afd80709',
+ })
+
+ def test_update_cross_filesystem(self):
+ try:
+ st = os.stat('/proc')
+ except OSError:
+ raise unittest.SkipTest('Unable to stat /proc')
+
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ self.assertRaises(gemato.exceptions.ManifestCrossDevice,
+ gemato.verify.update_entry_for_path, self.path, e,
+ expected_dev=st.st_dev)
+
+ def test_update_MISC(self):
+ e = gemato.manifest.ManifestEntryMISC(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 0)
+ self.assertDictEqual(e.checksums, {})
+
+ def test_update_OPTIONAL(self):
+ e = gemato.manifest.ManifestEntryOPTIONAL(
+ os.path.basename(self.path))
+ self.assertRaises(AssertionError,
+ gemato.verify.update_entry_for_path, self.path, e)
+
+ def test_update_IGNORE(self):
+ e = gemato.manifest.ManifestEntryIGNORE(
+ os.path.basename(self.path))
+ self.assertRaises(AssertionError,
+ gemato.verify.update_entry_for_path, self.path, e)
+
+ def test_update_AUX(self):
+ e = gemato.manifest.ManifestEntryAUX(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path,
+ os.path.join('files', os.path.basename(self.path)))
+ self.assertEqual(e.size, 0)
+ self.assertDictEqual(e.checksums, {})
+
+
class NonEmptyFileVerificationTest(unittest.TestCase):
def setUp(self):
@@ -390,6 +492,36 @@ class NonEmptyFileVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.path, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 43)
+ self.assertDictEqual(e.checksums, {})
+
+ def test_update_with_hashes(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e, ['MD5', 'SHA1'])
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 43)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': '9e107d9d372bb6826bd81d3542a419d6',
+ 'SHA1': '2fd4e1c67a2d28fced849ee1bb76e7391b93eb12',
+ })
+
+ def test_update_with_hashes_from_manifest(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {'MD5': '', 'SHA1': ''})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, 43)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': '9e107d9d372bb6826bd81d3542a419d6',
+ 'SHA1': '2fd4e1c67a2d28fced849ee1bb76e7391b93eb12',
+ })
+
class SymbolicLinkVerificationTest(NonEmptyFileVerificationTest):
"""
@@ -538,6 +670,36 @@ class ProcFileVerificationTest(unittest.TestCase):
self.assertEqual(gemato.verify.verify_path(self.path, None),
(False, [('__exists__', False, True)]))
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, self.size)
+ self.assertDictEqual(e.checksums, {})
+
+ def test_update_with_hashes(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ gemato.verify.update_entry_for_path(self.path, e, ['MD5', 'SHA1'])
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, self.size)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': self.md5,
+ 'SHA1': self.sha1,
+ })
+
+ def test_update_with_hashes_from_manifest(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {'MD5': '', 'SHA1': ''})
+ gemato.verify.update_entry_for_path(self.path, e)
+ self.assertEqual(e.path, os.path.basename(self.path))
+ self.assertEqual(e.size, self.size)
+ self.assertDictEqual(e.checksums, {
+ 'MD5': self.md5,
+ 'SHA1': self.sha1,
+ })
+
class UnreadableFileVerificationTest(unittest.TestCase):
def setUp(self):
@@ -562,6 +724,12 @@ class UnreadableFileVerificationTest(unittest.TestCase):
self.assertRaises(OSError, gemato.verify.verify_path,
os.path.join(self.dir, e.path), e)
+ def test_update(self):
+ e = gemato.manifest.ManifestEntryDATA(
+ os.path.basename(self.path), 0, {})
+ self.assertRaises(OSError,
+ gemato.verify.update_entry_for_path, self.path, e)
+
class EntryCompatibilityVerificationTest(unittest.TestCase):
def test_matching_entry(self):