260
211
# being too low. If rpc_count increases, more network roundtrips have
261
212
# become necessary for this use case. Please do not adjust this number
262
213
# upwards without agreement from bzr's network support maintainers.
263
self.assertLength(13, self.hpss_calls)
214
self.assertLength(14, self.hpss_calls)
264
215
remote = branch.Branch.open('public')
265
216
self.assertEndsWith(remote.get_stacked_on_url(), '/parent')
267
def test_push_smart_tags_streaming_acceptance(self):
268
self.setup_smart_server_with_call_log()
269
t = self.make_branch_and_tree('from')
270
rev_id = t.commit(allow_pointless=True, message='first commit')
271
t.branch.tags.set_tag('new-tag', rev_id)
272
self.reset_smart_call_log()
273
self.run_bzr(['push', self.get_url('to-one')], working_dir='from')
274
# This figure represent the amount of work to perform this use case. It
275
# is entirely ok to reduce this number if a test fails due to rpc_count
276
# being too low. If rpc_count increases, more network roundtrips have
277
# become necessary for this use case. Please do not adjust this number
278
# upwards without agreement from bzr's network support maintainers.
279
self.assertLength(11, self.hpss_calls)
281
def test_push_smart_incremental_acceptance(self):
282
self.setup_smart_server_with_call_log()
283
t = self.make_branch_and_tree('from')
284
rev_id1 = t.commit(allow_pointless=True, message='first commit')
285
rev_id2 = t.commit(allow_pointless=True, message='second commit')
287
['push', self.get_url('to-one'), '-r1'], working_dir='from')
288
self.reset_smart_call_log()
289
self.run_bzr(['push', self.get_url('to-one')], working_dir='from')
290
# This figure represent the amount of work to perform this use case. It
291
# is entirely ok to reduce this number if a test fails due to rpc_count
292
# being too low. If rpc_count increases, more network roundtrips have
293
# become necessary for this use case. Please do not adjust this number
294
# upwards without agreement from bzr's network support maintainers.
295
self.assertLength(11, self.hpss_calls)
297
218
def test_push_smart_with_default_stacking_url_path_segment(self):
298
219
# If the default stacked-on location is a path element then branches
299
220
# we push there over the smart server are stacked and their
661
566
self.assertEqual('', out)
664
class TestPushStrictMixin(object):
569
class TestPushStrict(tests.TestCaseWithTransport):
666
571
def make_local_branch_and_tree(self):
667
self.tree = self.make_branch_and_tree('local')
572
tree = self.make_branch_and_tree('local')
668
573
self.build_tree_contents([('local/file', 'initial')])
669
self.tree.add('file')
670
self.tree.commit('adding file', rev_id='added')
575
tree.commit('adding file', rev_id='from-1')
578
def make_local_branch_and_tree_with_changes(self):
579
tree = self.make_local_branch_and_tree()
671
581
self.build_tree_contents([('local/file', 'modified')])
672
self.tree.commit('modify file', rev_id='modified')
674
def set_config_push_strict(self, value):
584
def set_config_push_strict(self, tree, value):
675
585
# set config var (any of bazaar.conf, locations.conf, branch.conf
677
conf = self.tree.branch.get_config()
587
conf = tree.branch.get_config()
678
588
conf.set_user_option('push_strict', value)
680
_default_command = ['push', '../to']
681
_default_wd = 'local'
682
_default_errors = ['Working tree ".*/local/" has uncommitted '
683
'changes \(See bzr status\)\.',]
684
_default_additional_error = 'Use --no-strict to force the push.\n'
685
_default_additional_warning = 'Uncommitted changes will not be pushed.'
688
def assertPushFails(self, args):
689
out, err = self.run_bzr_error(self._default_errors,
690
self._default_command + args,
691
working_dir=self._default_wd, retcode=3)
692
self.assertContainsRe(err, self._default_additional_error)
694
def assertPushSucceeds(self, args, with_warning=False, revid_to_push=None):
696
error_regexes = self._default_errors
699
out, err = self.run_bzr(self._default_command + args,
700
working_dir=self._default_wd,
701
error_regexes=error_regexes)
703
self.assertContainsRe(err, self._default_additional_warning)
705
self.assertNotContainsRe(err, self._default_additional_warning)
706
branch_from = branch.Branch.open(self._default_wd)
707
if revid_to_push is None:
708
revid_to_push = branch_from.last_revision()
709
branch_to = branch.Branch.open('to')
710
repo_to = branch_to.repository
711
self.assertTrue(repo_to.has_revision(revid_to_push))
712
self.assertEqual(revid_to_push, branch_to.last_revision())
716
class TestPushStrictWithoutChanges(tests.TestCaseWithTransport,
717
TestPushStrictMixin):
720
super(TestPushStrictWithoutChanges, self).setUp()
721
self.make_local_branch_and_tree()
723
def test_push_default(self):
724
self.assertPushSucceeds([])
726
def test_push_strict(self):
727
self.assertPushSucceeds(['--strict'])
729
def test_push_no_strict(self):
730
self.assertPushSucceeds(['--no-strict'])
732
def test_push_config_var_strict(self):
733
self.set_config_push_strict('true')
734
self.assertPushSucceeds([])
736
def test_push_config_var_no_strict(self):
737
self.set_config_push_strict('false')
738
self.assertPushSucceeds([])
741
strict_push_change_scenarios = [
743
dict(_changes_type= '_uncommitted_changes')),
745
dict(_changes_type= '_pending_merges')),
746
('out-of-sync-trees',
747
dict(_changes_type= '_out_of_sync_trees')),
751
class TestPushStrictWithChanges(tests.TestCaseWithTransport,
752
TestPushStrictMixin):
754
scenarios = strict_push_change_scenarios
755
_changes_type = None # Set by load_tests
758
super(TestPushStrictWithChanges, self).setUp()
759
# Apply the changes defined in load_tests: one of _uncommitted_changes,
760
# _pending_merges or _out_of_sync_trees
761
getattr(self, self._changes_type)()
763
def _uncommitted_changes(self):
764
self.make_local_branch_and_tree()
765
# Make a change without committing it
766
self.build_tree_contents([('local/file', 'in progress')])
768
def _pending_merges(self):
769
self.make_local_branch_and_tree()
770
# Create 'other' branch containing a new file
771
other_bzrdir = self.tree.bzrdir.sprout('other')
772
other_tree = other_bzrdir.open_workingtree()
773
self.build_tree_contents([('other/other-file', 'other')])
774
other_tree.add('other-file')
775
other_tree.commit('other commit', rev_id='other')
776
# Merge and revert, leaving a pending merge
777
self.tree.merge_from_branch(other_tree.branch)
778
self.tree.revert(filenames=['other-file'], backups=False)
780
def _out_of_sync_trees(self):
781
self.make_local_branch_and_tree()
782
self.run_bzr(['checkout', '--lightweight', 'local', 'checkout'])
783
# Make a change and commit it
784
self.build_tree_contents([('local/file', 'modified in local')])
785
self.tree.commit('modify file', rev_id='modified-in-local')
786
# Exercise commands from the checkout directory
787
self._default_wd = 'checkout'
788
self._default_errors = ["Working tree is out of date, please run"
791
def test_push_default(self):
792
self.assertPushSucceeds([], with_warning=True)
794
def test_push_with_revision(self):
795
self.assertPushSucceeds(['-r', 'revid:added'], revid_to_push='added')
797
def test_push_no_strict(self):
798
self.assertPushSucceeds(['--no-strict'])
590
def assertPushFails(self, location, *args):
591
self.run_bzr_error(['Working tree ".*/local/"'
592
' has uncommitted changes.$',],
593
['push', '../' + location] + list(args),
594
working_dir='local', retcode=3)
596
def assertPushSucceeds(self, location, *args):
597
self.run_bzr(['push', '../' + location] + list(args),
599
tree_to = workingtree.WorkingTree.open(location)
600
repo_to = tree_to.branch.repository
601
self.assertTrue(repo_to.has_revision('from-1'))
602
self.assertEqual(tree_to.branch.last_revision_info()[1], 'from-1')
604
def test_push_default(self):
605
tree = self.make_local_branch_and_tree_with_changes()
606
self.assertPushSucceeds('to')
608
def test_push_no_strict_with_changes(self):
609
tree = self.make_local_branch_and_tree_with_changes()
610
self.assertPushSucceeds('to', '--no-strict')
800
612
def test_push_strict_with_changes(self):
801
self.assertPushFails(['--strict'])
613
tree = self.make_local_branch_and_tree_with_changes()
614
self.assertPushFails('to', '--strict')
616
def test_push_strict_without_changes(self):
617
tree = self.make_local_branch_and_tree()
618
self.assertPushSucceeds('to', '--strict')
803
620
def test_push_respect_config_var_strict(self):
804
self.set_config_push_strict('true')
805
self.assertPushFails([])
621
tree = self.make_local_branch_and_tree_with_changes()
622
self.set_config_push_strict(tree, 'true')
623
self.assertPushFails('to')
807
625
def test_push_bogus_config_var_ignored(self):
808
self.set_config_push_strict("I don't want you to be strict")
809
self.assertPushSucceeds([], with_warning=True)
626
tree = self.make_local_branch_and_tree_with_changes()
627
self.set_config_push_strict(tree, "I don't want you to be strict")
628
self.assertPushSucceeds('to')
811
630
def test_push_no_strict_command_line_override_config(self):
812
self.set_config_push_strict('yES')
813
self.assertPushFails([])
814
self.assertPushSucceeds(['--no-strict'])
631
tree = self.make_local_branch_and_tree_with_changes()
632
self.set_config_push_strict(tree, 'yES')
633
self.assertPushFails('to')
634
self.assertPushSucceeds('to', '--no-strict')
816
636
def test_push_strict_command_line_override_config(self):
817
self.set_config_push_strict('oFF')
818
self.assertPushFails(['--strict'])
819
self.assertPushSucceeds([])
822
class TestPushForeign(tests.TestCaseWithTransport):
825
super(TestPushForeign, self).setUp()
826
test_foreign.register_dummy_foreign_for_test(self)
828
def make_dummy_builder(self, relpath):
829
builder = self.make_branch_builder(
830
relpath, format=test_foreign.DummyForeignVcsDirFormat())
831
builder.build_snapshot('revid', None,
832
[('add', ('', 'TREE_ROOT', 'directory', None)),
833
('add', ('foo', 'fooid', 'file', 'bar'))])
836
def test_no_roundtripping(self):
837
target_branch = self.make_dummy_builder('dp').get_branch()
838
source_tree = self.make_branch_and_tree("dc")
839
output, error = self.run_bzr("push -d dc dp", retcode=3)
840
self.assertEquals("", output)
841
self.assertEquals(error, "bzr: ERROR: It is not possible to losslessly"
842
" push to dummy. You may want to use dpush instead.\n")
637
tree = self.make_local_branch_and_tree_with_changes()
638
self.set_config_push_strict(tree, 'oFF')
639
self.assertPushFails('to', '--strict')
640
self.assertPushSucceeds('to')