~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/selftest/test_parent.py

  • Committer: Aaron Bentley
  • Date: 2005-09-21 15:33:23 UTC
  • mto: (1185.1.37)
  • mto: This revision was merged to the branch mainline in revision 1390.
  • Revision ID: abentley@panoramicfeedback.com-20050921153323-5db674d572d7649d
Fixed bug in distance-from-root graph operation

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
 
18
18
import os
19
 
 
20
 
from bzrlib.branch import Branch
21
 
import bzrlib.errors
22
 
from bzrlib.osutils import abspath, realpath, getcwd
23
 
from bzrlib.urlutils import local_path_from_url, local_path_to_url, escape
24
 
from bzrlib.tests import TestCaseWithTransport
25
 
 
26
 
 
27
 
"""Tests for Branch parent URL"""
28
 
 
29
 
 
30
 
class TestParent(TestCaseWithTransport):
31
 
 
 
19
from bzrlib.selftest import TestCaseInTempDir
 
20
from bzrlib.branch import Branch, copy_branch
 
21
 
 
22
 
 
23
 
 
24
class TestParent(TestCaseInTempDir):
32
25
    def test_no_default_parent(self):
33
26
        """Branches should have no parent by default"""
34
 
        b = self.make_branch('.')
 
27
        b = Branch.initialize('.')
35
28
        self.assertEquals(b.get_parent(), None)
36
29
        
 
30
    
37
31
    def test_set_get_parent(self):
38
 
        """Set, re-get and reset the parent"""
39
 
        b = self.make_branch('.')
40
 
        url = 'http://bazaar-vcs.org/bzr/bzr.dev'
 
32
        """Set and then re-get the parent"""
 
33
        b = Branch.initialize('.')
 
34
        url = 'http://bazaar-ng.org/bzr/bzr.dev'
41
35
        b.set_parent(url)
42
36
        self.assertEquals(b.get_parent(), url)
43
 
        self.assertEqual(b.control_files.get('parent').read().strip('\n'), url)
44
 
 
45
 
        b.set_parent(None)
46
 
        self.assertEquals(b.get_parent(), None)
47
 
 
48
 
        b.set_parent('../other_branch')
49
 
        cwd = getcwd()
50
 
 
51
 
        self.assertEquals(b.get_parent(), local_path_to_url('../other_branch'))
52
 
        path = local_path_to_url('../yanb')
53
 
        b.set_parent(path)
54
 
        self.assertEqual(b.control_files.get('parent').read().strip('\n'), 
55
 
            '../yanb')
56
 
        self.assertEqual(b.get_parent(), path)
57
 
 
58
 
 
59
 
        self.assertRaises(bzrlib.errors.InvalidURL, b.set_parent, u'\xb5')
60
 
        b.set_parent(escape(u'\xb5'))
61
 
        self.assertEqual(b.control_files.get('parent').read().strip('\n'), 
62
 
            '%C2%B5')
63
 
 
64
 
        self.assertEqual(b.get_parent(), b.base + '%C2%B5')
 
37
 
 
38
    def test_branch_sets_parent(self):
 
39
        """The branch command should set the new branch's parent"""
 
40
        from bzrlib.commands import run_bzr
 
41
 
 
42
        os.mkdir('from')
 
43
        branch_from = Branch.initialize('from')
 
44
        file('from/foo', 'wt').write('contents of foo')
 
45
        branch_from.add('foo')
 
46
        branch_from.commit('initial commit')
 
47
        
 
48
        os.mkdir('to')
 
49
        copy_branch(branch_from, 'to', None)
 
50
 
 
51
        branch_to = Branch.open('to')
 
52
        abspath = os.path.abspath('from')
 
53
        self.assertEquals(branch_to.get_parent(), abspath)
 
54
        
65
55