Mercurial > hgsubversion
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)