133
149
class TestCommitDialogSimple(tests.TestCaseWithTransport):
152
MockMethod.bind(self, CommitDialogNoWidgets, 'setup_params')
153
MockMethod.bind(self, CommitDialogNoWidgets, 'construct')
154
MockMethod.bind(self, CommitDialogNoWidgets, 'fill_in_data')
156
tree = self.make_branch_and_tree('tree')
157
rev_id = tree.commit('first')
158
dlg = CommitDialogNoWidgets(tree)
159
self.assertIs(tree, dlg._wt)
160
self.assertIs(None, dlg._selected)
161
self.assertTrue(dlg._enable_per_file_commits)
162
self.assertTrue(dlg._commit_all_changes)
163
self.assertIs(None, dlg.committed_revision_id)
164
self.assertIs(None, dlg._last_selected_file)
165
self.assertIsInstance(
166
dlg._saved_commit_messages_manager, SavedCommitMessagesManager)
167
self.assertTrue(CommitDialogNoWidgets.setup_params.called)
168
self.assertTrue(CommitDialogNoWidgets.construct.called)
169
self.assertTrue(CommitDialogNoWidgets.fill_in_data.called)
135
171
def test_setup_parameters_no_pending(self):
136
172
tree = self.make_branch_and_tree('tree')
137
173
rev_id = tree.commit('first')
139
175
dlg = CommitDialogNoWidgets(tree)
140
176
self.assertEqual(rev_id, dlg._basis_tree.get_revision_id())
141
self.assertIs(None, dlg._pending)
177
self.assertEquals([], dlg._pending)
142
178
self.assertFalse(dlg._is_checkout)
144
180
def test_setup_parameters_checkout(self):
573
647
# do with. So instead, we just call toggle directly, and assume
574
648
# that toggle is hooked in correctly
575
649
# column = dlg._treeview_files.get_column(0)
576
# renderer = column.get_cell_renderers()[0]
650
# renderer = column.get_cells()[0]
578
652
# Toggle a single entry should set just that entry to False
579
653
dlg._toggle_commit(None, 1, dlg._files_store)
580
self.assertEqual([(None, None, True),
654
self.assertEqual([("", "", True),
581
655
('a-id', 'a', False),
582
656
('b-id', 'b', True),
583
657
], [(r[0], r[1], r[2]) for r in dlg._files_store])
585
659
# Toggling the main entry should set all entries
586
660
dlg._toggle_commit(None, 0, dlg._files_store)
587
self.assertEqual([(None, None, False),
661
self.assertEqual([("", "", False),
588
662
('a-id', 'a', False),
589
663
('b-id', 'b', False),
590
664
], [(r[0], r[1], r[2]) for r in dlg._files_store])
592
666
dlg._toggle_commit(None, 2, dlg._files_store)
593
self.assertEqual([(None, None, False),
667
self.assertEqual([("", "", False),
594
668
('a-id', 'a', False),
595
669
('b-id', 'b', True),
596
670
], [(r[0], r[1], r[2]) for r in dlg._files_store])
598
672
dlg._toggle_commit(None, 0, dlg._files_store)
599
self.assertEqual([(None, None, True),
673
self.assertEqual([("", "", True),
600
674
('a-id', 'a', True),
601
675
('b-id', 'b', True),
602
676
], [(r[0], r[1], r[2]) for r in dlg._files_store])
644
720
'message':'message\nfor b_dir\n'},
645
721
]), dlg._get_specific_files())
648
class TestCommitDialog_Commit(tests.TestCaseWithTransport):
649
"""Tests on the actual 'commit' button being pushed."""
723
def test_specific_files_sanitizes_messages(self):
724
tree = self.make_branch_and_tree('tree')
725
tree.branch.get_config().set_user_option('per_file_commits', 'true')
726
self.build_tree(['tree/a_file', 'tree/b_dir/'])
727
tree.add(['a_file', 'b_dir'], ['1a-id', '0b-id'])
729
dlg = commit.CommitDialog(tree)
730
dlg._commit_selected_radio.set_active(True)
731
self.assertEqual((['a_file', 'b_dir'], []), dlg._get_specific_files())
733
dlg._treeview_files.set_cursor(
734
Gtk.TreePath(path=1), None, False)
735
dlg._set_file_commit_message('Test\r\nmessage\rfor a_file\n')
736
dlg._treeview_files.set_cursor(
737
Gtk.TreePath(path=2), None, False)
738
dlg._set_file_commit_message('message\r\nfor\nb_dir\r')
740
self.assertEqual((['a_file', 'b_dir'],
741
[{'path':'a_file', 'file_id':'1a-id',
742
'message':'Test\nmessage\nfor a_file\n'},
743
{'path':'b_dir', 'file_id':'0b-id',
744
'message':'message\nfor\nb_dir\n'},
745
]), dlg._get_specific_files())
748
class QuestionHelpers(object):
651
750
def _set_question_yes(self, dlg):
652
751
"""Set the dialog to answer YES to any questions."""
653
752
self.questions = []
654
def _question_yes(*args):
753
def _question_yes(*args, **kwargs):
655
754
self.questions.append(args)
656
755
self.questions.append('YES')
657
return gtk.RESPONSE_YES
756
return Gtk.ResponseType.YES
658
757
dlg._question_dialog = _question_yes
660
759
def _set_question_no(self, dlg):
661
760
"""Set the dialog to answer NO to any questions."""
662
761
self.questions = []
663
def _question_no(*args):
762
def _question_no(*args, **kwargs):
664
763
self.questions.append(args)
665
764
self.questions.append('NO')
666
return gtk.RESPONSE_NO
765
return Gtk.ResponseType.NO
667
766
dlg._question_dialog = _question_no
769
class TestCommitDialog_Commit(tests.TestCaseWithTransport, QuestionHelpers):
770
"""Tests on the actual 'commit' button being pushed."""
669
772
def test_bound_commit_local(self):
670
773
tree = self.make_branch_and_tree('tree')
671
774
self.build_tree(['tree/a'])
1030
1155
{'path':u'\u03a9', 'file_id':'omega-id',
1031
1156
'message':u'\u03a9 is the end of all things.\n'},
1032
1157
], file_info_decoded)
1160
class TestSanitizeMessage(tests.TestCase):
1162
def assertSanitize(self, expected, original):
1163
self.assertEqual(expected,
1164
commit._sanitize_and_decode_message(original))
1166
def test_untouched(self):
1167
self.assertSanitize('foo\nbar\nbaz\n', 'foo\nbar\nbaz\n')
1169
def test_converts_cr_to_lf(self):
1170
self.assertSanitize('foo\nbar\nbaz\n', 'foo\rbar\rbaz\r')
1172
def test_converts_crlf_to_lf(self):
1173
self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\r\nbaz\r\n')
1175
def test_converts_mixed_to_lf(self):
1176
self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\rbaz\n')
1179
class TestSavedCommitMessages(tests.TestCaseWithTransport):
1182
super(TestSavedCommitMessages, self).setUp()
1184
branch.Branch.hooks.install_named_hook(
1185
'post_uncommit', commitmsgs.save_commit_messages, None)
1187
def _get_file_info_dict(self, rank):
1188
file_info = [dict(path='a', file_id='a-id',
1189
message='a {msg} %d' % rank),
1190
dict(path='b', file_id='b-id',
1191
message='b msg %d' % rank)]
1194
def _get_file_info_revprops(self, rank):
1195
file_info_prop = self._get_file_info_dict(rank)
1196
return {'file-info': bencode.bencode(file_info_prop).decode('UTF-8')}
1198
def _get_commit_message(self):
1199
return self.config.get_user_option(
1200
'gtk_global_commit_message', expand=False)
1202
def _get_file_commit_messages(self):
1203
return self.config.get_user_option(
1204
'gtk_file_commit_messages', expand=False)
1207
class TestUncommitHook(TestSavedCommitMessages):
1210
super(TestUncommitHook, self).setUp()
1211
self.tree = self.make_branch_and_tree('tree')
1212
self.config = self.tree.branch.get_config()
1213
self.build_tree(['tree/a', 'tree/b'])
1214
self.tree.add(['a'], ['a-id'])
1215
self.tree.add(['b'], ['b-id'])
1216
rev1 = self.tree.commit('one', rev_id='one-id',
1217
revprops=self._get_file_info_revprops(1))
1218
rev2 = self.tree.commit('two', rev_id='two-id',
1219
revprops=self._get_file_info_revprops(2))
1220
rev3 = self.tree.commit('three', rev_id='three-id',
1221
revprops=self._get_file_info_revprops(3))
1223
def test_uncommit_one_by_one(self):
1224
uncommit.uncommit(self.tree.branch, tree=self.tree)
1225
self.assertEquals(u'three', self._get_commit_message())
1226
self.assertEquals(u'd4:a-id9:a {msg} 34:b-id7:b msg 3e',
1227
self._get_file_commit_messages())
1229
uncommit.uncommit(self.tree.branch, tree=self.tree)
1230
self.assertEquals(u'two\n******\nthree', self._get_commit_message())
1231
self.assertEquals(u'd4:a-id26:a {msg} 2\n******\na {msg} 3'
1232
'4:b-id22:b msg 2\n******\nb msg 3e',
1233
self._get_file_commit_messages())
1235
uncommit.uncommit(self.tree.branch, tree=self.tree)
1236
self.assertEquals(u'one\n******\ntwo\n******\nthree',
1237
self._get_commit_message())
1239
u'd4:a-id43:a {msg} 1\n******\na {msg} 2\n******\na {msg} 3'
1240
'4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
1241
self._get_file_commit_messages())
1243
def test_uncommit_all_at_once(self):
1244
uncommit.uncommit(self.tree.branch, tree=self.tree, revno=1)
1245
self.assertEquals(u'one\n******\ntwo\n******\nthree',
1246
self._get_commit_message())
1248
u'd4:a-id43:a {msg} 1\n******\na {msg} 2\n******\na {msg} 3'
1249
'4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
1250
self._get_file_commit_messages())
1253
class TestReusingSavedCommitMessages(TestSavedCommitMessages, QuestionHelpers):
1256
super(TestReusingSavedCommitMessages, self).setUp()
1257
self.tree = self.make_branch_and_tree('tree')
1258
self.config = self.tree.branch.get_config()
1259
self.config.set_user_option('per_file_commits', 'true')
1260
self.build_tree(['tree/a', 'tree/b'])
1261
self.tree.add(['a'], ['a-id'])
1262
self.tree.add(['b'], ['b-id'])
1263
rev1 = self.tree.commit('one', revprops=self._get_file_info_revprops(1))
1264
rev2 = self.tree.commit('two{x}',
1265
revprops=self._get_file_info_revprops(2))
1266
uncommit.uncommit(self.tree.branch, tree=self.tree)
1267
self.build_tree_contents([('tree/a', 'new a content\n'),
1268
('tree/b', 'new b content'),])
1270
def _get_commit_dialog(self, tree):
1271
# Ensure we will never use a dialog that can actually prompt the user
1272
# during the test suite. Test *can* and *should* override with the
1273
# correct question dialog type.
1274
dlg = commit.CommitDialog(tree)
1275
self._set_question_no(dlg)
1278
def test_setup_saved_messages(self):
1279
# Check the initial setup
1280
self.assertEquals(u'two{x}', self._get_commit_message())
1281
self.assertEquals(u'd4:a-id9:a {msg} 24:b-id7:b msg 2e',
1282
self._get_file_commit_messages())
1284
def test_messages_are_reloaded(self):
1285
dlg = self._get_commit_dialog(self.tree)
1286
self.assertEquals(u'two{x}', dlg._get_global_commit_message())
1287
self.assertEquals(([u'a', u'b'],
1289
'file_id': 'a-id', 'message': 'a {msg} 2',},
1291
'file_id': 'b-id', 'message': 'b msg 2',}],),
1292
dlg._get_specific_files())
1294
def test_messages_are_consumed(self):
1295
dlg = self._get_commit_dialog(self.tree)
1297
self.assertEquals(u'', self._get_commit_message())
1298
self.assertEquals(u'de', self._get_file_commit_messages())
1300
def test_messages_are_saved_on_cancel_if_required(self):
1301
dlg = self._get_commit_dialog(self.tree)
1302
self._set_question_yes(dlg) # Save messages
1304
self.assertEquals(u'two{x}', self._get_commit_message())
1305
self.assertEquals(u'd4:a-id9:a {msg} 24:b-id7:b msg 2e',
1306
self._get_file_commit_messages())
1308
def test_messages_are_cleared_on_cancel_if_required(self):
1309
dlg = self._get_commit_dialog(self.tree)
1310
self._set_question_no(dlg) # Don't save messages
1312
self.assertEquals(u'', self._get_commit_message())
1313
self.assertEquals(u'de',
1314
self._get_file_commit_messages())
1317
class BzrHandlePatchTestCase(tests.TestCase):
1320
top = os.path.abspath(os.path.join(
1321
os.path.dirname(__file__), os.pardir))
1322
self.script = os.path.join(top, 'bzr-handle-patch')
1323
self.env = dict(os.environ)
1324
self.env['BZR_PLUGINS_AT'] = 'gtk@%s' % top
1325
self.patch = NamedTemporaryFile()
1326
self.patch.write('\n'.join([
1327
"=== added file '_test.txt'",
1328
"--- _test.txt 1970-01-01 00:00:00 +0000",
1329
"+++ _test.txt 2012-02-03 20:00:34 +0000",
1334
super(BzrHandlePatchTestCase, self).setUp()
1336
def test_smoketest(self):
1337
# This is a smoke test to verify the process starts.
1338
bzr_notify = subprocess.Popen(
1339
[self.script, self.patch.name, 'test'],
1340
stdout=subprocess.PIPE, stderr=subprocess.PIPE, env=self.env)
1341
stdout, stderr = bzr_notify.communicate()
1342
self.assertEqual('', stdout)
1343
self.assertEqual('', stderr)