diff tests/test_tags.py @ 23:1f8854804795

Add tests for tags and fix a bug in the tag-finding code that was found by the tests.
author Augie Fackler <durin42@gmail.com>
date Wed, 08 Oct 2008 20:37:01 -0500
parents
children 9c481cae0428
line wrap: on
line diff
new file mode 100644
--- /dev/null
+++ b/tests/test_tags.py
@@ -0,0 +1,87 @@
+import os
+import shutil
+import tempfile
+import unittest
+
+from mercurial import hg
+from mercurial import node
+from mercurial import ui
+
+import test_util
+
+import svncommand
+
+class TestTags(unittest.TestCase):
+    def setUp(self):
+        self.oldwd = os.getcwd()
+        self.tmpdir = tempfile.mkdtemp('svnwrap_test')
+        self.repo_path = '%s/testrepo' % self.tmpdir
+        self.wc_path = '%s/testrepo_wc' % self.tmpdir
+
+    def tearDown(self):
+        shutil.rmtree(self.tmpdir)
+        os.chdir(self.oldwd)
+        
+    def _load_fixture_and_fetch(self, fixture_name, stupid=False):
+        return test_util.load_fixture_and_fetch(fixture_name, self.repo_path, 
+                                                self.wc_path, stupid=stupid)
+
+    def _test_tag_revision_info(self, repo):
+        self.assertEqual(node.hex(repo[0].node()),
+                         'a47d0ce778660a91c31bf2c21c448e9ee296ac90')
+        self.assertEqual(node.hex(repo['tip'].node()),
+                         'bf3767835b3b32ecc775a298c2fa27134dd91c11')
+        self.assertEqual(repo['tip'], repo[1])
+    
+    def test_tags(self, stupid=False):
+        repo = self._load_fixture_and_fetch('basic_tag_tests.svndump', 
+                                            stupid=stupid)
+        self._test_tag_revision_info(repo)
+        svncommand.generate_hg_tags(ui.ui(), self.wc_path)
+        repo = hg.repository(ui.ui(), self.wc_path)
+        self.assertEqual(repo['tip'].node(), repo['tag:tag_r3'].node())
+        self.assertEqual(repo['tip'].node(), repo['tag:copied_tag'].node())
+    
+    def test_tags_stupid(self):
+        self.test_tags(stupid=True)
+
+    def test_remove_tag(self, stupid=False):
+        repo = self._load_fixture_and_fetch('remove_tag_test.svndump', 
+                                            stupid=stupid)
+        self._test_tag_revision_info(repo)
+        svncommand.generate_hg_tags(ui.ui(), self.wc_path)
+        repo = hg.repository(ui.ui(), self.wc_path)
+        self.assertEqual(repo['tip'].node(), repo['tag:tag_r3'].node())
+        self.assert_('tag:copied_tag' not in repo.tags())
+    
+    def test_remove_tag_stupid(self):
+        self.test_remove_tag(stupid=True)
+
+    def test_rename_tag(self, stupid=False):
+        repo = self._load_fixture_and_fetch('rename_tag_test.svndump', 
+                                            stupid=stupid)
+        self._test_tag_revision_info(repo)
+        svncommand.generate_hg_tags(ui.ui(), self.wc_path)
+        repo = hg.repository(ui.ui(), self.wc_path)
+        self.assertEqual(repo['tip'].node(), repo['tag:tag_r3'].node())
+        self.assertEqual(repo['tip'].node(), repo['tag:other_tag_r3'].node())
+        self.assert_('tag:copied_tag' not in repo.tags())
+    
+    def test_rename_tag_stupid(self):
+        self.test_rename_tag(stupid=True)
+
+    def test_branch_from_tag(self, stupid=False):
+        repo = self._load_fixture_and_fetch('branch_from_tag.svndump', 
+                                            stupid=stupid)
+        svncommand.generate_hg_tags(ui.ui(), self.wc_path)
+        repo = hg.repository(ui.ui(), self.wc_path)
+        self.assertEqual(repo['tip'].node(), repo['branch_from_tag'].node())
+        self.assertEqual(repo[1].node(), repo['tag:tag_r3'].node())
+        self.assertEqual(repo['branch_from_tag'].parents()[0].node(), 
+                         repo['tag:copied_tag'].node())
+    
+    def test_branch_from_tag_stupid(self):
+        self.test_branch_from_tag(stupid=True)
+
+def suite():
+    return unittest.TestLoader().loadTestsFromTestCase(TestTags)