53
50
self.addCleanup(tree.lock_read().unlock)
54
self.assertEquals([], list(commit.pending_revisions(tree)))
51
self.assertIs(None, commit.pending_revisions(tree))
56
53
def test_pending_revisions_simple(self):
57
54
tree = self.make_branch_and_tree('tree')
62
59
self.assertEqual([rev_id1, rev_id2], tree.get_parent_ids())
64
61
self.addCleanup(tree.lock_read().unlock)
65
pending_revisions = list(commit.pending_revisions(tree))
62
pending_revisions = commit.pending_revisions(tree)
66
63
# One primary merge
67
64
self.assertEqual(1, len(pending_revisions))
68
65
# Revision == rev_id2
81
78
self.assertEqual([rev_id1, rev_id4], tree.get_parent_ids())
83
80
self.addCleanup(tree.lock_read().unlock)
84
pending_revisions = list(commit.pending_revisions(tree))
81
pending_revisions = commit.pending_revisions(tree)
85
82
# One primary merge
86
83
self.assertEqual(1, len(pending_revisions))
87
84
# Revision == rev_id2
105
102
self.assertEqual([rev_id1, rev_id3, rev_id5], tree.get_parent_ids())
107
104
self.addCleanup(tree.lock_read().unlock)
108
pending_revisions = list(commit.pending_revisions(tree))
105
pending_revisions = commit.pending_revisions(tree)
109
106
# Two primary merges
110
107
self.assertEqual(2, len(pending_revisions))
111
108
# Revision == rev_id2
146
143
pass # With no widgets, there are no widgets to fill out
149
def bind(klass, test_instance, obj, method_name):
150
original_method = getattr(obj, method_name)
151
test_instance.addCleanup(setattr, obj, method_name, original_method)
152
setattr(obj, method_name, klass())
159
def __call__(self, *args, **kwargs):
149
165
class TestCommitDialogSimple(tests.TestCaseWithTransport):
151
167
def test_init(self):
175
191
dlg = CommitDialogNoWidgets(tree)
176
192
self.assertEqual(rev_id, dlg._basis_tree.get_revision_id())
177
self.assertEquals([], dlg._pending)
193
self.assertIs(None, dlg._pending)
178
194
self.assertFalse(dlg._is_checkout)
180
196
def test_setup_parameters_checkout(self):
186
202
dlg = CommitDialogNoWidgets(tree2)
187
203
self.assertEqual(rev_id, dlg._basis_tree.get_revision_id())
188
self.assertEquals([], dlg._pending)
204
self.assertIs(None, dlg._pending)
189
205
self.assertTrue(dlg._is_checkout)
191
207
def test_setup_parameters_pending(self):
216
232
self.assertEqual([], delta.removed)
217
233
self.assertEqual([(u'a', 'a-id', 'file')], delta.added)
219
def test_on_treeview_files_cursor_changed_no_selection(self):
220
MockMethod.bind(self, CommitDialogNoWidgets, '_update_per_file_info')
221
tree = self.make_branch_and_tree('tree')
222
rev_id = tree.commit('first')
223
dlg = CommitDialogNoWidgets(tree)
224
treeview = Gtk.TreeView()
225
dlg._on_treeview_files_cursor_changed(treeview)
226
self.assertFalse(CommitDialogNoWidgets._update_per_file_info.called)
228
235
def test_on_treeview_files_cursor_changed_with_destroyed_treeview(self):
229
236
MockMethod.bind(self, CommitDialogNoWidgets, '_update_per_file_info')
230
237
tree = self.make_branch_and_tree('tree')
235
242
dlg._on_treeview_files_cursor_changed(treeview)
236
243
self.assertFalse(CommitDialogNoWidgets._update_per_file_info.called)
238
def test_get_line_height(self):
239
tree = self.make_branch_and_tree('tree')
240
dlg = CommitDialogNoWidgets(tree)
241
textview = Gtk.TextView()
242
line_height = dlg.get_line_height(textview)
243
self.assertIsInstance(line_height, int)
246
246
class TestCommitDialog(tests.TestCaseWithTransport):
1305
1305
self.assertEquals(u'', self._get_commit_message())
1306
1306
self.assertEquals(u'de',
1307
1307
self._get_file_commit_messages())
1310
class BzrHandlePatchTestCase(tests.TestCase):
1313
top = os.path.abspath(os.path.join(
1314
os.path.dirname(__file__), os.pardir))
1315
self.script = os.path.join(top, 'bzr-handle-patch')
1316
self.env = dict(os.environ)
1317
self.env['BZR_PLUGINS_AT'] = 'gtk@%s' % top
1318
self.patch = NamedTemporaryFile()
1319
self.patch.write('\n'.join([
1320
"=== added file '_test.txt'",
1321
"--- _test.txt 1970-01-01 00:00:00 +0000",
1322
"+++ _test.txt 2012-02-03 20:00:34 +0000",
1327
super(BzrHandlePatchTestCase, self).setUp()
1329
def test_smoketest(self):
1330
# This is a smoke test to verify the process starts.
1331
bzr_notify = subprocess.Popen(
1332
[self.script, self.patch.name, 'test'],
1333
stdout=subprocess.PIPE, stderr=subprocess.PIPE, env=self.env)
1334
stdout, stderr = bzr_notify.communicate()
1335
self.assertEqual('', stdout)
1336
self.assertEqual('', stderr)