32
34
def test_no_default_parent(self):
33
35
"""Branches should have no parent by default"""
34
36
b = self.make_branch('.')
35
self.assertEquals(b.get_parent(), None)
37
self.assertEqual(None, b.get_parent())
37
39
def test_set_get_parent(self):
38
40
"""Set, re-get and reset the parent"""
39
41
b = self.make_branch('.')
40
42
url = 'http://bazaar-vcs.org/bzr/bzr.dev'
42
self.assertEquals(b.get_parent(), url)
43
self.assertEqual(b.control_files.get('parent').read().strip('\n'), url)
44
self.assertEqual(url, b.get_parent())
45
self.assertEqual(url, b.control_files.get('parent').read().strip('\n'))
46
self.assertEquals(b.get_parent(), None)
48
self.assertEqual(None, b.get_parent())
48
50
b.set_parent('../other_branch')
51
self.assertEquals(b.get_parent(), local_path_to_url('../other_branch'))
53
self.assertEqual(local_path_to_url('../other_branch'), b.get_parent())
52
54
path = local_path_to_url('../yanb')
54
self.assertEqual(b.control_files.get('parent').read().strip('\n'),
56
self.assertEqual(b.get_parent(), path)
56
self.assertEqual('../yanb',
57
b.control_files.get('parent').read().strip('\n'))
58
self.assertEqual(path, b.get_parent())
59
61
self.assertRaises(bzrlib.errors.InvalidURL, b.set_parent, u'\xb5')
60
62
b.set_parent(escape(u'\xb5'))
61
self.assertEqual(b.control_files.get('parent').read().strip('\n'),
64
self.assertEqual(b.get_parent(), b.base + '%C2%B5')
63
self.assertEqual('%C2%B5',
64
b.control_files.get('parent').read().strip('\n'))
66
self.assertEqual(b.base + '%C2%B5', b.get_parent())
68
# Handle the case for older style absolute local paths
69
if sys.platform == 'win32':
70
# TODO: jam 20060515 Do we want to special case Windows local
71
# paths as well? Nobody has complained about it.
74
b.control_files.put('parent', cStringIO.StringIO('/local/abs/path'))
75
self.assertEqual('file:///local/abs/path', b.get_parent())