Пример #1
0
 def test_unversion_root_add_new_root(self):
     builder = BranchBuilder(self.get_transport().clone("foo"))
     builder.start_series()
     builder.build_snapshot("rev-1", None, [("add", ("", "TREE_ROOT", "directory", ""))])
     builder.build_snapshot("rev-2", None, [("unversion", "TREE_ROOT"), ("add", ("", "my-root", "directory", ""))])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree("rev-2")
     self.assertTreeShape([(u"", "my-root", "directory")], rev_tree)
Пример #2
0
 def test_empty_flush(self):
     """A flush with no actions before it is a no-op."""
     builder = BranchBuilder(self.get_transport().clone("foo"))
     builder.start_series()
     builder.build_snapshot("rev-1", None, [("add", ("", "TREE_ROOT", "directory", ""))])
     builder.build_snapshot("rev-2", None, [("flush", None)])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree("rev-2")
     self.assertTreeShape([(u"", "TREE_ROOT", "directory")], rev_tree)
 def test_empty_flush(self):
     """A flush with no actions before it is a no-op."""
     builder = BranchBuilder(self.get_transport().clone('foo'))
     builder.start_series()
     builder.build_snapshot('rev-1', None,
                            [('add', ('', 'TREE_ROOT', 'directory', ''))])
     builder.build_snapshot('rev-2', None, [('flush', None)])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree('rev-2')
     self.assertTreeShape([(u'', 'TREE_ROOT', 'directory')], rev_tree)
Пример #4
0
 def makeRepo(self, tree_contents):
     branch = Branch.open(self.repository_path)
     branch.get_config().set_user_option("create_signatures", "never")
     builder = BranchBuilder(branch=branch)
     actions = [('add', ('', 'tree-root', 'directory', None))]
     actions += [
         ('add', (path, path + '-id', 'file', content))
         for (path, content) in tree_contents]
     builder.build_snapshot(
         None, None, actions, committer='Joe Foo <*****@*****.**>',
             message=u'<The commit message>')
 def test_unversion_root_add_new_root(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     builder.start_series()
     builder.build_snapshot('rev-1', None,
                            [('add', ('', 'TREE_ROOT', 'directory', ''))])
     builder.build_snapshot('rev-2', None,
                            [('unversion', 'TREE_ROOT'),
                             ('add', ('', 'my-root', 'directory', ''))])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree('rev-2')
     self.assertTreeShape([(u'', 'my-root', 'directory')], rev_tree)
Пример #6
0
 def makeRepo(self, tree_contents):
     branch = Branch.open(self.repository_path)
     branch.get_config().set_user_option("create_signatures", "never")
     builder = BranchBuilder(branch=branch)
     actions = [('add', ('', 'tree-root', 'directory', None))]
     actions += [
         ('add', (path, path + '-id', 'file', content))
         for (path, content) in tree_contents]
     builder.build_snapshot(
         None, None, actions, committer='Joe Foo <*****@*****.**>',
             message=u'<The commit message>')
Пример #7
0
 def test_ghost_mainline_history(self):
     builder = BranchBuilder(self.get_transport().clone("foo"))
     builder.start_series()
     try:
         builder.build_snapshot(
             "tip", ["ghost"], [("add", ("", "ROOT_ID", "directory", ""))], allow_leftmost_as_ghost=True
         )
     finally:
         builder.finish_series()
     b = builder.get_branch()
     b.lock_read()
     self.addCleanup(b.unlock)
     self.assertEqual(("ghost",), b.repository.get_graph().get_parent_map(["tip"])["tip"])
 def test_ghost_mainline_history(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     builder.start_series()
     try:
         builder.build_snapshot('tip', ['ghost'],
                                [('add', ('', 'ROOT_ID', 'directory', ''))],
                                allow_leftmost_as_ghost=True)
     finally:
         builder.finish_series()
     b = builder.get_branch()
     b.lock_read()
     self.addCleanup(b.unlock)
     self.assertEqual(
         ('ghost', ),
         b.repository.get_graph().get_parent_map(['tip'])['tip'])
Пример #9
0
 def test_kind_change(self):
     """It's possible to change the kind of an entry in a single snapshot
     with a bit of help from the 'flush' action.
     """
     builder = BranchBuilder(self.get_transport().clone("foo"))
     builder.start_series()
     builder.build_snapshot(
         "A-id", None, [("add", (u"", "a-root-id", "directory", None)), ("add", (u"a", "a-id", "file", "content\n"))]
     )
     builder.build_snapshot(
         "B-id", None, [("unversion", "a-id"), ("flush", None), ("add", (u"a", "a-id", "directory", None))]
     )
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree("B-id")
     self.assertTreeShape([(u"", "a-root-id", "directory"), (u"a", "a-id", "directory")], rev_tree)
Пример #10
0
 def build_a_rev(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     rev_id1 = builder.build_snapshot('A-id', None,
         [('add', ('', 'a-root-id', 'directory', None)),
          ('add', ('a', 'a-id', 'file', 'contents'))])
     self.assertEqual('A-id', rev_id1)
     return builder
 def test_kind_change(self):
     """It's possible to change the kind of an entry in a single snapshot
     with a bit of help from the 'flush' action.
     """
     builder = BranchBuilder(self.get_transport().clone('foo'))
     builder.start_series()
     builder.build_snapshot('A-id', None,
                            [('add', (u'', 'a-root-id', 'directory', None)),
                             ('add', (u'a', 'a-id', 'file', 'content\n'))])
     builder.build_snapshot('B-id', None,
                            [('unversion', 'a-id'), ('flush', None),
                             ('add', (u'a', 'a-id', 'directory', None))])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree('B-id')
     self.assertTreeShape([(u'', 'a-root-id', 'directory'),
                           (u'a', 'a-id', 'directory')], rev_tree)
 def build_a_rev(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     rev_id1 = builder.build_snapshot(
         'A-id', None, [('add', ('', 'a-root-id', 'directory', None)),
                        ('add', ('a', 'a-id', 'file', 'contents'))])
     self.assertEqual('A-id', rev_id1)
     return builder
Пример #13
0
 def build_a_rev(self):
     builder = BranchBuilder(self.get_transport().clone("foo"))
     rev_id1 = builder.build_snapshot(
         "A-id", None, [("add", ("", "a-root-id", "directory", None)), ("add", ("a", "a-id", "file", "contents"))]
     )
     self.assertEqual("A-id", rev_id1)
     return builder
Пример #14
0
 def test_commit_message_default(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     rev_id = builder.build_snapshot(None, None,
         [('add', (u'', None, 'directory', None))])
     branch = builder.get_branch()
     rev = branch.repository.get_revision(rev_id)
     self.assertEqual(u'commit 1', rev.message)
 def test_commit_message_default(self):
     builder = BranchBuilder(self.get_transport().clone('foo'))
     rev_id = builder.build_snapshot(None, None,
                                     [('add',
                                       (u'', None, 'directory', None))])
     branch = builder.get_branch()
     rev = branch.repository.get_revision(rev_id)
     self.assertEqual(u'commit 1', rev.message)
Пример #16
0
 def test_commit_message_callback(self):
     builder = BranchBuilder(self.get_transport().clone("foo"))
     rev_id = builder.build_snapshot(
         None, None, [("add", (u"", None, "directory", None))], message_callback=lambda x: u"Foo"
     )
     branch = builder.get_branch()
     rev = branch.repository.get_revision(rev_id)
     self.assertEqual(u"Foo", rev.message)
 def test_pivot_root(self):
     """It's possible (albeit awkward) to move an existing dir to the root
     in a single snapshot by using unversion then flush then add.
     """
     builder = BranchBuilder(self.get_transport().clone('foo'))
     builder.start_series()
     builder.build_snapshot('A-id', None,
                            [('add', (u'', 'orig-root', 'directory', None)),
                             ('add',
                              (u'dir', 'dir-id', 'directory', None))])
     builder.build_snapshot(
         'B-id',
         None,
         [
             ('unversion',
              'orig-root'),  # implicitly unversions all children
             ('flush', None),
             ('add', (u'', 'dir-id', 'directory', None))
         ])
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree('B-id')
     self.assertTreeShape([(u'', 'dir-id', 'directory')], rev_tree)
Пример #18
0
 def test_pivot_root(self):
     """It's possible (albeit awkward) to move an existing dir to the root
     in a single snapshot by using unversion then flush then add.
     """
     builder = BranchBuilder(self.get_transport().clone("foo"))
     builder.start_series()
     builder.build_snapshot(
         "A-id",
         None,
         [("add", (u"", "orig-root", "directory", None)), ("add", (u"dir", "dir-id", "directory", None))],
     )
     builder.build_snapshot(
         "B-id",
         None,
         [
             ("unversion", "orig-root"),  # implicitly unversions all children
             ("flush", None),
             ("add", (u"", "dir-id", "directory", None)),
         ],
     )
     builder.finish_series()
     rev_tree = builder.get_branch().repository.revision_tree("B-id")
     self.assertTreeShape([(u"", "dir-id", "directory")], rev_tree)