/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/selftest/test_merge_core.py

  • Committer: Robert Collins
  • Date: 2005-11-22 21:28:30 UTC
  • mfrom: (1185.33.32 bzr.dev)
  • Revision ID: robertc@robertcollins.net-20051122212830-885c284847f0b17b
Merge from mpool.

Show diffs side-by-side

added added

removed removed

Lines of Context:
14
14
from bzrlib import changeset
15
15
from bzrlib.merge_core import (ApplyMerge3, make_merge_changeset,
16
16
                               BackupBeforeChange, ExecFlagMerge, WeaveMerge)
17
 
from bzrlib.changeset import Inventory, apply_changeset, invert_dict
18
 
from bzrlib.changeset import get_contents, ReplaceContents
 
17
from bzrlib.changeset import Inventory, apply_changeset, invert_dict, \
 
18
    get_contents, ReplaceContents, ChangeExecFlag
19
19
from bzrlib.clone import copy_branch
20
20
from bzrlib.merge import merge
21
21
 
626
626
        self.assert_(os.path.lexists('a/file'))
627
627
        self.assert_(os.path.lexists('a/file.moved'))
628
628
        self.assertEqual(a.working_tree().pending_merges(), [b.last_revision()])
 
629
 
 
630
    def test_merge_metadata_vs_deletion(self):
 
631
        """Conflict deletion vs metadata change"""
 
632
        os.mkdir('a')
 
633
        a = Branch.initialize('a')
 
634
        file('a/file', 'wb').write('contents\n')
 
635
        a.add('file')
 
636
        a_wt = a.working_tree()
 
637
        a_wt.commit('r0')
 
638
        copy_branch(a, 'b')
 
639
        b = Branch.open('b')
 
640
        b_wt = b.working_tree()
 
641
        os.chmod('b/file', 0755)
 
642
        os.remove('a/file')
 
643
        a_wt.commit('removed a')
 
644
        self.assertEqual(a.revno(), 2)
 
645
        self.assertFalse(os.path.exists('a/file'))
 
646
        b_wt.commit('exec a')
 
647
        merge(['b', -1], ['b', 0], this_dir='a')
 
648
        self.assert_(os.path.exists('a/file'))