130
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):
133
165
class TestCommitDialogSimple(tests.TestCaseWithTransport):
168
MockMethod.bind(self, CommitDialogNoWidgets, 'setup_params')
169
MockMethod.bind(self, CommitDialogNoWidgets, 'construct')
170
MockMethod.bind(self, CommitDialogNoWidgets, 'fill_in_data')
172
tree = self.make_branch_and_tree('tree')
173
rev_id = tree.commit('first')
174
dlg = CommitDialogNoWidgets(tree)
175
self.assertIs(tree, dlg._wt)
176
self.assertIs(None, dlg._selected)
177
self.assertTrue(dlg._enable_per_file_commits)
178
self.assertTrue(dlg._commit_all_changes)
179
self.assertIs(None, dlg.committed_revision_id)
180
self.assertIs(None, dlg._last_selected_file)
181
self.assertIsInstance(
182
dlg._saved_commit_messages_manager, SavedCommitMessagesManager)
183
self.assertTrue(CommitDialogNoWidgets.setup_params.called)
184
self.assertTrue(CommitDialogNoWidgets.construct.called)
185
self.assertTrue(CommitDialogNoWidgets.fill_in_data.called)
135
187
def test_setup_parameters_no_pending(self):
136
188
tree = self.make_branch_and_tree('tree')
137
189
rev_id = tree.commit('first')
573
656
# do with. So instead, we just call toggle directly, and assume
574
657
# that toggle is hooked in correctly
575
658
# column = dlg._treeview_files.get_column(0)
576
# renderer = column.get_cell_renderers()[0]
659
# renderer = column.get_cells()[0]
578
661
# Toggle a single entry should set just that entry to False
579
662
dlg._toggle_commit(None, 1, dlg._files_store)
580
self.assertEqual([(None, None, True),
663
self.assertEqual([("", "", True),
581
664
('a-id', 'a', False),
582
665
('b-id', 'b', True),
583
666
], [(r[0], r[1], r[2]) for r in dlg._files_store])
585
668
# Toggling the main entry should set all entries
586
669
dlg._toggle_commit(None, 0, dlg._files_store)
587
self.assertEqual([(None, None, False),
670
self.assertEqual([("", "", False),
588
671
('a-id', 'a', False),
589
672
('b-id', 'b', False),
590
673
], [(r[0], r[1], r[2]) for r in dlg._files_store])
592
675
dlg._toggle_commit(None, 2, dlg._files_store)
593
self.assertEqual([(None, None, False),
676
self.assertEqual([("", "", False),
594
677
('a-id', 'a', False),
595
678
('b-id', 'b', True),
596
679
], [(r[0], r[1], r[2]) for r in dlg._files_store])
598
681
dlg._toggle_commit(None, 0, dlg._files_store)
599
self.assertEqual([(None, None, True),
682
self.assertEqual([("", "", True),
600
683
('a-id', 'a', True),
601
684
('b-id', 'b', True),
602
685
], [(r[0], r[1], r[2]) for r in dlg._files_store])
644
729
'message':'message\nfor b_dir\n'},
645
730
]), dlg._get_specific_files())
648
class TestCommitDialog_Commit(tests.TestCaseWithTransport):
649
"""Tests on the actual 'commit' button being pushed."""
732
def test_specific_files_sanitizes_messages(self):
733
tree = self.make_branch_and_tree('tree')
734
tree.branch.get_config().set_user_option('per_file_commits', 'true')
735
self.build_tree(['tree/a_file', 'tree/b_dir/'])
736
tree.add(['a_file', 'b_dir'], ['1a-id', '0b-id'])
738
dlg = commit.CommitDialog(tree)
739
dlg._commit_selected_radio.set_active(True)
740
self.assertEqual((['a_file', 'b_dir'], []), dlg._get_specific_files())
742
dlg._treeview_files.set_cursor(
743
Gtk.TreePath(path=1), None, False)
744
dlg._set_file_commit_message('Test\r\nmessage\rfor a_file\n')
745
dlg._treeview_files.set_cursor(
746
Gtk.TreePath(path=2), None, False)
747
dlg._set_file_commit_message('message\r\nfor\nb_dir\r')
749
self.assertEqual((['a_file', 'b_dir'],
750
[{'path':'a_file', 'file_id':'1a-id',
751
'message':'Test\nmessage\nfor a_file\n'},
752
{'path':'b_dir', 'file_id':'0b-id',
753
'message':'message\nfor\nb_dir\n'},
754
]), dlg._get_specific_files())
757
class QuestionHelpers(object):
651
759
def _set_question_yes(self, dlg):
652
760
"""Set the dialog to answer YES to any questions."""
653
761
self.questions = []
654
def _question_yes(*args):
762
def _question_yes(*args, **kwargs):
655
763
self.questions.append(args)
656
764
self.questions.append('YES')
657
return gtk.RESPONSE_YES
765
return Gtk.ResponseType.YES
658
766
dlg._question_dialog = _question_yes
660
768
def _set_question_no(self, dlg):
661
769
"""Set the dialog to answer NO to any questions."""
662
770
self.questions = []
663
def _question_no(*args):
771
def _question_no(*args, **kwargs):
664
772
self.questions.append(args)
665
773
self.questions.append('NO')
666
return gtk.RESPONSE_NO
774
return Gtk.ResponseType.NO
667
775
dlg._question_dialog = _question_no
778
class TestCommitDialog_Commit(tests.TestCaseWithTransport, QuestionHelpers):
779
"""Tests on the actual 'commit' button being pushed."""
669
781
def test_bound_commit_local(self):
670
782
tree = self.make_branch_and_tree('tree')
671
783
self.build_tree(['tree/a'])
1030
1164
{'path':u'\u03a9', 'file_id':'omega-id',
1031
1165
'message':u'\u03a9 is the end of all things.\n'},
1032
1166
], file_info_decoded)
1169
class TestSanitizeMessage(tests.TestCase):
1171
def assertSanitize(self, expected, original):
1172
self.assertEqual(expected,
1173
commit._sanitize_and_decode_message(original))
1175
def test_untouched(self):
1176
self.assertSanitize('foo\nbar\nbaz\n', 'foo\nbar\nbaz\n')
1178
def test_converts_cr_to_lf(self):
1179
self.assertSanitize('foo\nbar\nbaz\n', 'foo\rbar\rbaz\r')
1181
def test_converts_crlf_to_lf(self):
1182
self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\r\nbaz\r\n')
1184
def test_converts_mixed_to_lf(self):
1185
self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\rbaz\n')
1188
class TestSavedCommitMessages(tests.TestCaseWithTransport):
1191
super(TestSavedCommitMessages, self).setUp()
1193
branch.Branch.hooks.install_named_hook(
1194
'post_uncommit', commitmsgs.save_commit_messages, None)
1196
def _get_file_info_dict(self, rank):
1197
file_info = [dict(path='a', file_id='a-id', message='a msg %d' % rank),
1198
dict(path='b', file_id='b-id', message='b msg %d' % rank)]
1201
def _get_file_info_revprops(self, rank):
1202
file_info_prop = self._get_file_info_dict(rank)
1203
return {'file-info': bencode.bencode(file_info_prop).decode('UTF-8')}
1205
def _get_commit_message(self):
1206
return self.config.get_user_option('gtk_global_commit_message')
1208
def _get_file_commit_messages(self):
1209
return self.config.get_user_option('gtk_file_commit_messages')
1212
class TestUncommitHook(TestSavedCommitMessages):
1215
super(TestUncommitHook, self).setUp()
1216
self.tree = self.make_branch_and_tree('tree')
1217
self.config = self.tree.branch.get_config()
1218
self.build_tree(['tree/a', 'tree/b'])
1219
self.tree.add(['a'], ['a-id'])
1220
self.tree.add(['b'], ['b-id'])
1221
rev1 = self.tree.commit('one', rev_id='one-id',
1222
revprops=self._get_file_info_revprops(1))
1223
rev2 = self.tree.commit('two', rev_id='two-id',
1224
revprops=self._get_file_info_revprops(2))
1225
rev3 = self.tree.commit('three', rev_id='three-id',
1226
revprops=self._get_file_info_revprops(3))
1228
def test_uncommit_one_by_one(self):
1229
uncommit.uncommit(self.tree.branch, tree=self.tree)
1230
self.assertEquals(u'three', self._get_commit_message())
1231
self.assertEquals(u'd4:a-id7:a msg 34:b-id7:b msg 3e',
1232
self._get_file_commit_messages())
1234
uncommit.uncommit(self.tree.branch, tree=self.tree)
1235
self.assertEquals(u'two\n******\nthree', self._get_commit_message())
1236
self.assertEquals(u'd4:a-id22:a msg 2\n******\na msg 3'
1237
'4:b-id22:b msg 2\n******\nb msg 3e',
1238
self._get_file_commit_messages())
1240
uncommit.uncommit(self.tree.branch, tree=self.tree)
1241
self.assertEquals(u'one\n******\ntwo\n******\nthree',
1242
self._get_commit_message())
1243
self.assertEquals(u'd4:a-id37:a msg 1\n******\na msg 2\n******\na msg 3'
1244
'4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
1245
self._get_file_commit_messages())
1247
def test_uncommit_all_at_once(self):
1248
uncommit.uncommit(self.tree.branch, tree=self.tree, revno=1)
1249
self.assertEquals(u'one\n******\ntwo\n******\nthree',
1250
self._get_commit_message())
1251
self.assertEquals(u'd4:a-id37:a msg 1\n******\na msg 2\n******\na msg 3'
1252
'4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
1253
self._get_file_commit_messages())
1256
class TestReusingSavedCommitMessages(TestSavedCommitMessages, QuestionHelpers):
1259
super(TestReusingSavedCommitMessages, self).setUp()
1260
self.tree = self.make_branch_and_tree('tree')
1261
self.config = self.tree.branch.get_config()
1262
self.config.set_user_option('per_file_commits', 'true')
1263
self.build_tree(['tree/a', 'tree/b'])
1264
self.tree.add(['a'], ['a-id'])
1265
self.tree.add(['b'], ['b-id'])
1266
rev1 = self.tree.commit('one', revprops=self._get_file_info_revprops(1))
1267
rev2 = self.tree.commit('two', revprops=self._get_file_info_revprops(2))
1268
uncommit.uncommit(self.tree.branch, tree=self.tree)
1269
self.build_tree_contents([('tree/a', 'new a content\n'),
1270
('tree/b', 'new b content'),])
1272
def _get_commit_dialog(self, tree):
1273
# Ensure we will never use a dialog that can actually prompt the user
1274
# during the test suite. Test *can* and *should* override with the
1275
# correct question dialog type.
1276
dlg = commit.CommitDialog(tree)
1277
self._set_question_no(dlg)
1280
def test_setup_saved_messages(self):
1281
# Check the initial setup
1282
self.assertEquals(u'two', self._get_commit_message())
1283
self.assertEquals(u'd4:a-id7:a msg 24:b-id7:b msg 2e',
1284
self._get_file_commit_messages())
1286
def test_messages_are_reloaded(self):
1287
dlg = self._get_commit_dialog(self.tree)
1288
self.assertEquals(u'two', dlg._get_global_commit_message())
1289
self.assertEquals(([u'a', u'b'],
1291
'file_id': 'a-id', 'message': 'a msg 2',},
1293
'file_id': 'b-id', 'message': 'b msg 2',}],),
1294
dlg._get_specific_files())
1296
def test_messages_are_consumed(self):
1297
dlg = self._get_commit_dialog(self.tree)
1299
self.assertEquals(u'', self._get_commit_message())
1300
self.assertEquals(u'de', self._get_file_commit_messages())
1302
def test_messages_are_saved_on_cancel_if_required(self):
1303
dlg = self._get_commit_dialog(self.tree)
1304
self._set_question_yes(dlg) # Save messages
1306
self.assertEquals(u'two', self._get_commit_message())
1307
self.assertEquals(u'd4:a-id7:a msg 24:b-id7:b msg 2e',
1308
self._get_file_commit_messages())
1310
def test_messages_are_cleared_on_cancel_if_required(self):
1311
dlg = self._get_commit_dialog(self.tree)
1312
self._set_question_no(dlg) # Don't save messages
1314
self.assertEquals(u'', self._get_commit_message())
1315
self.assertEquals(u'de',
1316
self._get_file_commit_messages())