/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to tests/test_commit.py

  • Committer: Vincent Ladeuil
  • Date: 2010-03-01 08:52:45 UTC
  • mfrom: (682.1.2 setup)
  • Revision ID: v.ladeuil+lp@free.fr-20100301085245-506msq0tu9bmji95
Guard setup() call when not loaded as __main__

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2007 John Arbash Meinel <john@arbash-meinel.com>
 
1
# Copyright (C) 2007, 2008 John Arbash Meinel <john@arbash-meinel.com>
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
21
21
import gtk
22
22
 
23
23
from bzrlib import (
 
24
    branch,
 
25
    revision,
24
26
    tests,
25
 
    revision,
 
27
    uncommit,
26
28
    )
27
 
from bzrlib.util import bencode
 
29
try:
 
30
    from bzrlib import bencode
 
31
except ImportError:
 
32
    from bzrlib.util import bencode
28
33
 
29
34
from bzrlib.plugins.gtk import commit
30
35
 
86
91
        rev_id4 = tree3.commit('four')
87
92
        rev_id5 = tree3.commit('five')
88
93
        tree.merge_from_branch(tree2.branch)
89
 
        tree.merge_from_branch(tree3.branch)
 
94
        tree.merge_from_branch(tree3.branch, force=True)
90
95
        self.assertEqual([rev_id1, rev_id3, rev_id5], tree.get_parent_ids())
91
96
 
92
97
        pending_revisions = commit.pending_revisions(tree)
266
271
                               committer='Jerry Foo <jerry@foo.com>',
267
272
                               timestamp=1191372278.05,
268
273
                               timezone=+7200)
269
 
        tree.merge_from_branch(tree3.branch)
 
274
        tree.merge_from_branch(tree3.branch, force=True)
270
275
 
271
276
        dlg = commit.CommitDialog(tree)
272
277
        # TODO: assert that the pending box is set to show
644
649
                            'message':'message\nfor b_dir\n'},
645
650
                          ]), dlg._get_specific_files())
646
651
 
647
 
 
648
 
class TestCommitDialog_Commit(tests.TestCaseWithTransport):
649
 
    """Tests on the actual 'commit' button being pushed."""
 
652
    def test_specific_files_sanitizes_messages(self):
 
653
        tree = self.make_branch_and_tree('tree')
 
654
        tree.branch.get_config().set_user_option('per_file_commits', 'true')
 
655
        self.build_tree(['tree/a_file', 'tree/b_dir/'])
 
656
        tree.add(['a_file', 'b_dir'], ['1a-id', '0b-id'])
 
657
 
 
658
        dlg = commit.CommitDialog(tree)
 
659
        dlg._commit_selected_radio.set_active(True)
 
660
        self.assertEqual((['a_file', 'b_dir'], []), dlg._get_specific_files())
 
661
 
 
662
        dlg._treeview_files.set_cursor((1,))
 
663
        dlg._set_file_commit_message('Test\r\nmessage\rfor a_file\n')
 
664
        dlg._treeview_files.set_cursor((2,))
 
665
        dlg._set_file_commit_message('message\r\nfor\nb_dir\r')
 
666
 
 
667
        self.assertEqual((['a_file', 'b_dir'],
 
668
                          [{'path':'a_file', 'file_id':'1a-id',
 
669
                            'message':'Test\nmessage\nfor a_file\n'},
 
670
                           {'path':'b_dir', 'file_id':'0b-id',
 
671
                            'message':'message\nfor\nb_dir\n'},
 
672
                          ]), dlg._get_specific_files())
 
673
 
 
674
 
 
675
class QuestionHelpers(object):
650
676
 
651
677
    def _set_question_yes(self, dlg):
652
678
        """Set the dialog to answer YES to any questions."""
653
679
        self.questions = []
654
 
        def _question_yes(*args):
 
680
        def _question_yes(*args, **kwargs):
655
681
            self.questions.append(args)
656
682
            self.questions.append('YES')
657
683
            return gtk.RESPONSE_YES
660
686
    def _set_question_no(self, dlg):
661
687
        """Set the dialog to answer NO to any questions."""
662
688
        self.questions = []
663
 
        def _question_no(*args):
 
689
        def _question_no(*args, **kwargs):
664
690
            self.questions.append(args)
665
691
            self.questions.append('NO')
666
692
            return gtk.RESPONSE_NO
667
693
        dlg._question_dialog = _question_no
668
694
 
 
695
 
 
696
class TestCommitDialog_Commit(tests.TestCaseWithTransport, QuestionHelpers):
 
697
    """Tests on the actual 'commit' button being pushed."""
 
698
 
669
699
    def test_bound_commit_local(self):
670
700
        tree = self.make_branch_and_tree('tree')
671
701
        self.build_tree(['tree/a'])
687
717
        self.assertEqual(last_rev, dlg.committed_revision_id)
688
718
        self.assertEqual(rev_id1, tree.branch.last_revision())
689
719
 
 
720
    def test_commit_global_sanitizes_message(self):
 
721
        tree = self.make_branch_and_tree('tree')
 
722
        self.build_tree(['tree/a'])
 
723
        tree.add(['a'], ['a-id'])
 
724
        rev_id1 = tree.commit('one')
 
725
 
 
726
        self.build_tree(['tree/b'])
 
727
        tree.add(['b'], ['b-id'])
 
728
        dlg = commit.CommitDialog(tree)
 
729
        # With the check box set, it should only effect the local branch
 
730
        dlg._set_global_commit_message('Commit\r\nmessage\rfoo\n')
 
731
        dlg._do_commit()
 
732
        rev = tree.branch.repository.get_revision(tree.last_revision())
 
733
        self.assertEqual('Commit\nmessage\nfoo\n', rev.message)
 
734
 
690
735
    def test_bound_commit_both(self):
691
736
        tree = self.make_branch_and_tree('tree')
692
737
        self.build_tree(['tree/a'])
708
753
        self.assertEqual(last_rev, dlg.committed_revision_id)
709
754
        self.assertEqual(last_rev, tree.branch.last_revision())
710
755
 
711
 
    def test_commit_no_message(self):
 
756
    def test_commit_empty_message(self):
712
757
        tree = self.make_branch_and_tree('tree')
713
758
        self.build_tree(['tree/a', 'tree/b'])
714
759
        tree.add(['a'], ['a-id'])
943
988
        rev = tree.branch.repository.get_revision(rev_id2)
944
989
        self.assertEqual('Commit just "a"', rev.message)
945
990
        file_info = rev.properties['file-info']
946
 
        self.assertEqual('ld7:file_id4:a-id'
947
 
                           '7:message14:Message for A\n'
948
 
                           '4:path1:a'
949
 
                         'ee', file_info)
 
991
        self.assertEqual(u'ld7:file_id4:a-id'
 
992
                         '7:message14:Message for A\n'
 
993
                         '4:path1:a'
 
994
                         'ee',
 
995
                         file_info)
950
996
        self.assertEqual([{'path':'a', 'file_id':'a-id',
951
 
                           'message':'Message for A\n'},
952
 
                         ], bencode.bdecode(file_info))
 
997
                           'message':'Message for A\n'},],
 
998
                         bencode.bdecode(file_info.encode('UTF-8')))
953
999
 
954
1000
    def test_commit_messages_after_merge(self):
955
1001
        tree = self.make_branch_and_tree('tree')
976
1022
        self.assertEqual('Merging from "tree2"\n', rev.message)
977
1023
        self.assertEqual([rev_id1, rev_id2], rev.parent_ids)
978
1024
        file_info = rev.properties['file-info']
979
 
        self.assertEqual('ld7:file_id4:a-id'
980
 
                           '7:message14:Message for A\n'
981
 
                           '4:path1:a'
982
 
                         'ee', file_info)
 
1025
        self.assertEqual(u'ld7:file_id4:a-id'
 
1026
                         '7:message14:Message for A\n'
 
1027
                         '4:path1:a'
 
1028
                         'ee',
 
1029
                         file_info)
983
1030
        self.assertEqual([{'path':'a', 'file_id':'a-id',
984
 
                           'message':'Message for A\n'},
985
 
                         ], bencode.bdecode(file_info))
 
1031
                           'message':'Message for A\n'},],
 
1032
                         bencode.bdecode(file_info.encode('UTF-8')))
986
1033
 
987
1034
    def test_commit_unicode_messages(self):
988
1035
        self.requireFeature(tests.UnicodeFilenameFeature)
1030
1077
                          {'path':u'\u03a9', 'file_id':'omega-id',
1031
1078
                           'message':u'\u03a9 is the end of all things.\n'},
1032
1079
                         ], file_info_decoded)
 
1080
 
 
1081
 
 
1082
class TestSanitizeMessage(tests.TestCase):
 
1083
 
 
1084
    def assertSanitize(self, expected, original):
 
1085
        self.assertEqual(expected,
 
1086
                         commit._sanitize_and_decode_message(original))
 
1087
 
 
1088
    def test_untouched(self):
 
1089
        self.assertSanitize('foo\nbar\nbaz\n', 'foo\nbar\nbaz\n')
 
1090
 
 
1091
    def test_converts_cr_to_lf(self):
 
1092
        self.assertSanitize('foo\nbar\nbaz\n', 'foo\rbar\rbaz\r')
 
1093
 
 
1094
    def test_converts_crlf_to_lf(self):
 
1095
        self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\r\nbaz\r\n')
 
1096
 
 
1097
    def test_converts_mixed_to_lf(self):
 
1098
        self.assertSanitize('foo\nbar\nbaz\n', 'foo\r\nbar\rbaz\n')
 
1099
 
 
1100
 
 
1101
class TestSavedCommitMessages(tests.TestCaseWithTransport):
 
1102
 
 
1103
    def setUp(self):
 
1104
        super(TestSavedCommitMessages, self).setUp()
 
1105
        # Install our hook
 
1106
        branch.Branch.hooks.install_named_hook(
 
1107
            'post_uncommit', commit.save_commit_messages, None)
 
1108
 
 
1109
    def _get_file_info_dict(self, rank):
 
1110
        file_info = [dict(path='a', file_id='a-id', message='a msg %d' % rank),
 
1111
                     dict(path='b', file_id='b-id', message='b msg %d' % rank)]
 
1112
        return file_info
 
1113
 
 
1114
    def _get_file_info_revprops(self, rank):
 
1115
        file_info_prop = self._get_file_info_dict(rank)
 
1116
        return {'file-info': bencode.bencode(file_info_prop).decode('UTF-8')}
 
1117
 
 
1118
    def _get_commit_message(self):
 
1119
        return self.config.get_user_option('gtk_global_commit_message')
 
1120
 
 
1121
    def _get_file_commit_messages(self):
 
1122
        return self.config.get_user_option('gtk_file_commit_messages')
 
1123
 
 
1124
 
 
1125
class TestUncommitHook(TestSavedCommitMessages):
 
1126
 
 
1127
    def setUp(self):
 
1128
        super(TestUncommitHook, self).setUp()
 
1129
        self.tree = self.make_branch_and_tree('tree')
 
1130
        self.config = self.tree.branch.get_config()
 
1131
        self.build_tree(['tree/a', 'tree/b'])
 
1132
        self.tree.add(['a'], ['a-id'])
 
1133
        self.tree.add(['b'], ['b-id'])
 
1134
        rev1 = self.tree.commit('one', rev_id='one-id',
 
1135
                                revprops=self._get_file_info_revprops(1))
 
1136
        rev2 = self.tree.commit('two', rev_id='two-id',
 
1137
                                revprops=self._get_file_info_revprops(2))
 
1138
        rev3 = self.tree.commit('three', rev_id='three-id',
 
1139
                                revprops=self._get_file_info_revprops(3))
 
1140
 
 
1141
    def test_uncommit_one_by_one(self):
 
1142
        uncommit.uncommit(self.tree.branch, tree=self.tree)
 
1143
        self.assertEquals(u'three', self._get_commit_message())
 
1144
        self.assertEquals(u'd4:a-id7:a msg 34:b-id7:b msg 3e',
 
1145
                          self._get_file_commit_messages())
 
1146
 
 
1147
        uncommit.uncommit(self.tree.branch, tree=self.tree)
 
1148
        self.assertEquals(u'two\n******\nthree', self._get_commit_message())
 
1149
        self.assertEquals(u'd4:a-id22:a msg 2\n******\na msg 3'
 
1150
                          '4:b-id22:b msg 2\n******\nb msg 3e',
 
1151
                          self._get_file_commit_messages())
 
1152
 
 
1153
        uncommit.uncommit(self.tree.branch, tree=self.tree)
 
1154
        self.assertEquals(u'one\n******\ntwo\n******\nthree',
 
1155
                          self._get_commit_message())
 
1156
        self.assertEquals(u'd4:a-id37:a msg 1\n******\na msg 2\n******\na msg 3'
 
1157
                          '4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
 
1158
                          self._get_file_commit_messages())
 
1159
 
 
1160
    def test_uncommit_all_at_once(self):
 
1161
        uncommit.uncommit(self.tree.branch, tree=self.tree, revno=1)
 
1162
        self.assertEquals(u'one\n******\ntwo\n******\nthree',
 
1163
                          self._get_commit_message())
 
1164
        self.assertEquals(u'd4:a-id37:a msg 1\n******\na msg 2\n******\na msg 3'
 
1165
                          '4:b-id37:b msg 1\n******\nb msg 2\n******\nb msg 3e',
 
1166
                          self._get_file_commit_messages())
 
1167
 
 
1168
 
 
1169
class TestReusingSavedCommitMessages(TestSavedCommitMessages, QuestionHelpers):
 
1170
 
 
1171
    def setUp(self):
 
1172
        super(TestReusingSavedCommitMessages, self).setUp()
 
1173
        self.tree = self.make_branch_and_tree('tree')
 
1174
        self.config = self.tree.branch.get_config()
 
1175
        self.config.set_user_option('per_file_commits', 'true')
 
1176
        self.build_tree(['tree/a', 'tree/b'])
 
1177
        self.tree.add(['a'], ['a-id'])
 
1178
        self.tree.add(['b'], ['b-id'])
 
1179
        rev1 = self.tree.commit('one', revprops=self._get_file_info_revprops(1))
 
1180
        rev2 = self.tree.commit('two', revprops=self._get_file_info_revprops(2))
 
1181
        uncommit.uncommit(self.tree.branch, tree=self.tree)
 
1182
        self.build_tree_contents([('tree/a', 'new a content\n'),
 
1183
                                  ('tree/b', 'new b content'),])
 
1184
 
 
1185
    def _get_commit_dialog(self, tree):
 
1186
        # Ensure we will never use a dialog that can actually prompt the user
 
1187
        # during the test suite. Test *can* and *should* override with the
 
1188
        # correct question dialog type.
 
1189
        dlg = commit.CommitDialog(tree)
 
1190
        self._set_question_no(dlg)
 
1191
        return dlg
 
1192
 
 
1193
    def test_setup_saved_messages(self):
 
1194
        # Check the initial setup
 
1195
        self.assertEquals(u'two', self._get_commit_message())
 
1196
        self.assertEquals(u'd4:a-id7:a msg 24:b-id7:b msg 2e',
 
1197
                          self._get_file_commit_messages())
 
1198
 
 
1199
    def test_messages_are_reloaded(self):
 
1200
        dlg = self._get_commit_dialog(self.tree)
 
1201
        self.assertEquals(u'two', dlg._get_global_commit_message())
 
1202
        self.assertEquals(([u'a', u'b'],
 
1203
                           [{ 'path': 'a',
 
1204
                             'file_id': 'a-id', 'message': 'a msg 2',},
 
1205
                           {'path': 'b',
 
1206
                            'file_id': 'b-id', 'message': 'b msg 2',}],),
 
1207
                          dlg._get_specific_files())
 
1208
 
 
1209
    def test_messages_are_consumed(self):
 
1210
        dlg = self._get_commit_dialog(self.tree)
 
1211
        dlg._do_commit()
 
1212
        self.assertEquals(u'', self._get_commit_message())
 
1213
        self.assertEquals(u'de', self._get_file_commit_messages())
 
1214
 
 
1215
    def test_messages_are_saved_on_cancel_if_required(self):
 
1216
        dlg = self._get_commit_dialog(self.tree)
 
1217
        self._set_question_yes(dlg) # Save messages
 
1218
        dlg._do_cancel()
 
1219
        self.assertEquals(u'two', self._get_commit_message())
 
1220
        self.assertEquals(u'd4:a-id7:a msg 24:b-id7:b msg 2e',
 
1221
                          self._get_file_commit_messages())
 
1222
 
 
1223
    def test_messages_are_cleared_on_cancel_if_required(self):
 
1224
        dlg = self._get_commit_dialog(self.tree)
 
1225
        self._set_question_no(dlg) # Don't save messages
 
1226
        dlg._do_cancel()
 
1227
        self.assertEquals(u'', self._get_commit_message())
 
1228
        self.assertEquals(u'de',
 
1229
                          self._get_file_commit_messages())