|  | @@ -15,47 +15,47 @@ class Test(unittest.TestCase):
 | 
											
												
													
														|  |          self.store_path = os.path.join(self.tmpdir, 'store')
 |  |          self.store_path = os.path.join(self.tmpdir, 'store')
 | 
											
												
													
														|  |          self.keychain = '/tmp/_test_dedupstore.keychain'
 |  |          self.keychain = '/tmp/_test_dedupstore.keychain'
 | 
											
												
													
														|  |          if not os.path.exists(self.keychain):
 |  |          if not os.path.exists(self.keychain):
 | 
											
												
													
														|  | -            self.dedupestore('keychain', 'generate')
 |  | 
 | 
											
												
													
														|  | -        self.dedupestore('init', self.store_path)
 |  | 
 | 
											
												
													
														|  | 
 |  | +            self.darc('keychain', 'generate')
 | 
											
												
													
														|  | 
 |  | +        self.darc('init', self.store_path)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def tearDown(self):
 |  |      def tearDown(self):
 | 
											
												
													
														|  |          shutil.rmtree(self.tmpdir)
 |  |          shutil.rmtree(self.tmpdir)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    def dedupestore(self, *args, **kwargs):
 |  | 
 | 
											
												
													
														|  | 
 |  | +    def darc(self, *args, **kwargs):
 | 
											
												
													
														|  |          exit_code = kwargs.get('exit_code', 0)
 |  |          exit_code = kwargs.get('exit_code', 0)
 | 
											
												
													
														|  |          args = ['--keychain', self.keychain] + list(args)
 |  |          args = ['--keychain', self.keychain] + list(args)
 | 
											
												
													
														|  |          self.assertEqual(exit_code, self.archiver.run(args))
 |  |          self.assertEqual(exit_code, self.archiver.run(args))
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def create_src_archive(self, name):
 |  |      def create_src_archive(self, name):
 | 
											
												
													
														|  |          src_dir = os.path.join(os.getcwd(), os.path.dirname(__file__))
 |  |          src_dir = os.path.join(os.getcwd(), os.path.dirname(__file__))
 | 
											
												
													
														|  | -        self.dedupestore('create', self.store_path + '::' + name, src_dir)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('create', self.store_path + '::' + name, src_dir)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def test_basic_functionality(self):
 |  |      def test_basic_functionality(self):
 | 
											
												
													
														|  |          self.create_src_archive('test')
 |  |          self.create_src_archive('test')
 | 
											
												
													
														|  | -        self.dedupestore('list', self.store_path)
 |  | 
 | 
											
												
													
														|  | -        self.dedupestore('list', self.store_path + '::test')
 |  | 
 | 
											
												
													
														|  | -        self.dedupestore('info', self.store_path + '::test')
 |  | 
 | 
											
												
													
														|  | -        self.dedupestore('verify', self.store_path + '::test')
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('list', self.store_path)
 | 
											
												
													
														|  | 
 |  | +        self.darc('list', self.store_path + '::test')
 | 
											
												
													
														|  | 
 |  | +        self.darc('info', self.store_path + '::test')
 | 
											
												
													
														|  | 
 |  | +        self.darc('verify', self.store_path + '::test')
 | 
											
												
													
														|  |          dest_dir = os.path.join(self.tmpdir, 'dest')
 |  |          dest_dir = os.path.join(self.tmpdir, 'dest')
 | 
											
												
													
														|  | -        self.dedupestore('extract', self.store_path + '::test', dest_dir)
 |  | 
 | 
											
												
													
														|  | -        self.dedupestore('delete', self.store_path + '::test')
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('extract', self.store_path + '::test', dest_dir)
 | 
											
												
													
														|  | 
 |  | +        self.darc('delete', self.store_path + '::test')
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def test_corrupted_store(self):
 |  |      def test_corrupted_store(self):
 | 
											
												
													
														|  |          self.create_src_archive('test')
 |  |          self.create_src_archive('test')
 | 
											
												
													
														|  | -        self.dedupestore('verify', self.store_path + '::test')
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('verify', self.store_path + '::test')
 | 
											
												
													
														|  |          fd = open(os.path.join(self.tmpdir, 'store', 'bands', '0', '0'), 'r+')
 |  |          fd = open(os.path.join(self.tmpdir, 'store', 'bands', '0', '0'), 'r+')
 | 
											
												
													
														|  |          fd.seek(1000)
 |  |          fd.seek(1000)
 | 
											
												
													
														|  |          fd.write('X')
 |  |          fd.write('X')
 | 
											
												
													
														|  |          fd.close()
 |  |          fd.close()
 | 
											
												
													
														|  | -        self.dedupestore('verify', self.store_path + '::test', exit_code=1)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('verify', self.store_path + '::test', exit_code=1)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      def test_symlinks(self):
 |  |      def test_symlinks(self):
 | 
											
												
													
														|  |          testdir = os.path.join(self.tmpdir, 'linktest')
 |  |          testdir = os.path.join(self.tmpdir, 'linktest')
 | 
											
												
													
														|  |          os.mkdir(testdir)
 |  |          os.mkdir(testdir)
 | 
											
												
													
														|  |          os.symlink('/tmp/somewhere', os.path.join(testdir, 'link'))
 |  |          os.symlink('/tmp/somewhere', os.path.join(testdir, 'link'))
 | 
											
												
													
														|  | -        self.dedupestore('create', self.store_path + '::symlinktest', testdir)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('create', self.store_path + '::symlinktest', testdir)
 | 
											
												
													
														|  |          dest_dir = os.path.join(self.tmpdir, 'dest')
 |  |          dest_dir = os.path.join(self.tmpdir, 'dest')
 | 
											
												
													
														|  | -        self.dedupestore('extract', self.store_path + '::symlinktest', dest_dir)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        self.darc('extract', self.store_path + '::symlinktest', dest_dir)
 | 
											
												
													
														|  |          dest = os.path.join(dest_dir, testdir[1:])
 |  |          dest = os.path.join(dest_dir, testdir[1:])
 | 
											
												
													
														|  |          self.assertEqual(os.path.islink(os.path.join(dest, 'link')), True)
 |  |          self.assertEqual(os.path.islink(os.path.join(dest, 'link')), True)
 | 
											
												
													
														|  |          self.assertEqual(os.readlink(os.path.join(dest, 'link')), '/tmp/somewhere')
 |  |          self.assertEqual(os.readlink(os.path.join(dest, 'link')), '/tmp/somewhere')
 |