41
41
def test_remove_local(self):
42
42
# Remove a local branch.
43
self.example_branch('a')
44
self.run_bzr('rmbranch a')
45
dir = bzrdir.BzrDir.open('a')
43
tree = self.example_tree('a')
44
self.run_bzr_error(['Branch is active. Use --force to remove it.\n'],
46
self.run_bzr('rmbranch --force a')
47
dir = controldir.ControlDir.open('a')
46
48
self.assertFalse(dir.has_branch())
47
49
self.assertPathExists('a/hello')
48
50
self.assertPathExists('a/goodbye')
50
52
def test_no_branch(self):
51
# No branch in the current directory.
53
# No branch in the current directory.
52
54
self.make_repository('a')
53
55
self.run_bzr_error(['Not a branch'],
58
def test_no_tree(self):
59
# removing the active branch is possible if there is no tree
60
tree = self.example_tree('a')
61
tree.bzrdir.destroy_workingtree()
62
self.run_bzr('rmbranch', working_dir='a')
63
dir = controldir.ControlDir.open('a')
64
self.assertFalse(dir.has_branch())
56
66
def test_no_arg(self):
57
67
# location argument defaults to current directory
58
self.example_branch('a')
59
self.run_bzr('rmbranch', working_dir='a')
60
dir = bzrdir.BzrDir.open('a')
68
self.example_tree('a')
69
self.run_bzr_error(['Branch is active. Use --force to remove it.\n'],
71
self.run_bzr('rmbranch --force', working_dir='a')
72
dir = controldir.ControlDir.open('a')
61
73
self.assertFalse(dir.has_branch())
63
75
def test_remove_colo(self):
64
76
# Remove a colocated branch.
65
tree = self.example_branch('a', format='development-colo')
77
tree = self.example_tree('a')
66
78
tree.bzrdir.create_branch(name="otherbranch")
67
79
self.assertTrue(tree.bzrdir.has_branch('otherbranch'))
68
80
self.run_bzr('rmbranch %s,branch=otherbranch' % tree.bzrdir.user_url)
69
dir = bzrdir.BzrDir.open('a')
70
self.assertFalse(dir.has_branch('otherbranch'))
71
self.assertTrue(dir.has_branch())
81
dir = controldir.ControlDir.open('a')
82
self.assertFalse(dir.has_branch('otherbranch'))
83
self.assertTrue(dir.has_branch())
85
def test_remove_colo_directory(self):
86
# Remove a colocated branch.
87
tree = self.example_tree('a')
88
tree.bzrdir.create_branch(name="otherbranch")
89
self.assertTrue(tree.bzrdir.has_branch('otherbranch'))
90
self.run_bzr('rmbranch otherbranch -d %s' % tree.bzrdir.user_url)
91
dir = controldir.ControlDir.open('a')
92
self.assertFalse(dir.has_branch('otherbranch'))
93
self.assertTrue(dir.has_branch())
95
def test_remove_active_colo_branch(self):
96
# Remove a colocated branch.
97
dir = self.make_repository('a').bzrdir
98
branch = dir.create_branch('otherbranch')
99
branch.create_checkout('a')
100
self.run_bzr_error(['Branch is active. Use --force to remove it.\n'],
101
'rmbranch otherbranch -d %s' % branch.bzrdir.user_url)
102
self.assertTrue(dir.has_branch('otherbranch'))
103
self.run_bzr('rmbranch --force otherbranch -d %s' % branch.bzrdir.user_url)
104
self.assertFalse(dir.has_branch('otherbranch'))
74
107
class TestSmartServerRemoveBranch(TestCaseWithTransport):