~bzr/ubuntu/lucid/bzr/beta-ppa

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_ignores.py

  • Committer: Martin Pool
  • Date: 2010-07-02 07:29:40 UTC
  • mfrom: (129.1.7 packaging-karmic)
  • Revision ID: mbp@sourcefrog.net-20100702072940-hpzq5elg8wjve8rh
* PPA rebuild.
* PPA rebuild for Karmic.
* PPA rebuild for Jaunty.
* PPA rebuild for Hardy.
* From postinst, actually remove the example bash completion scripts.
  (LP: #249452)
* New upstream release.
* New upstream release.
* New upstream release.
* Revert change to Build-depends: Dapper does not have python-central.
  Should be python-support..
* Target ppa..
* Target ppa..
* Target ppa..
* Target ppa..
* New upstream release.
* Switch to dpkg-source 3.0 (quilt) format.
* Bump standards version to 3.8.4.
* Remove embedded copy of python-configobj. Closes: #555336
* Remove embedded copy of python-elementtree. Closes: #555343
* Change section from 'Devel' to 'Vcs'..
* Change section from 'Devel' to 'Vcs'..
* Change section from 'Devel' to 'Vcs'..
* Change section from 'Devel' to 'Vcs'..
* Change section from 'Devel' to 'Vcs'..
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* debian/control: Fix obsolete-relation-form-in-source
  lintian warning. 
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Split out docs into bzr-doc package.
* New upstream release.
* Added John Francesco Ferlito to Uploaders.
* Fix install path to quick-reference guide
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Fix FTBFS due to path changes, again.
* Fix FTBFS due to doc paths changing
* New upstream release.
* Fix FTBFS due to path changes, again.
* Fix FTBFS due to doc paths changing
* New upstream release.
* Fix FTBFS due to path changes, again.
* Fix FTBFS due to doc paths changing
* New upstream release.
* Fix FTBFS due to path changes, again, again.
* Fix FTBFS due to path changes, again.
* Fix FTBFS due to path changes.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Bump standards version to 3.8.3.
* Remove unused patch system.
* New upstream release.
* New upstream release.
* New upstream release.
* Fix copy and paste tab error in .install file
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
 + Fixes compatibility with Python 2.4. Closes: #537708
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream version.
* Bump standards version to 3.8.2.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Add python-pyrex to build-deps to ensure C extensions are always build.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Split documentation into bzr-doc package. ((LP: #385074)
* Multiple packaging changes to make us more linitan clean.
* New upstream release.
* Split documentation into bzr-doc package. ((LP: #385074)
* Multiple packaging changes to make us more linitan clean.
* New upstream release.
* Split documentation into bzr-doc package. ((LP: #385074)
* Multiple packaging changes to make us more linitan clean.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Fix API compatibility version. (Closes: #526233)
* New upstream release.
  + Fixes default format for upgrade command. (Closes: #464688)
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Add missing dependency on zlib development library. (Closes:
  #523595)
* Add zlib build-depends.
* Add zlib build-depends.
* Add zlib build-depends.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Move to section vcs.
* Bump standards version to 3.8.1.
* New upstream release.
* Remove temporary patch for missing .c files from distribution
* New upstream release.
* Remove temporary patch for missing .c files from distribution
* New upstream release.
* Remove temporary patch for missing .c files from distribution
* Add temporary patch for missing .c files from distribution
* Add temporary patch for missing .c files from distribution
* Add temporary patch for missing .c files from distribution
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Recommend ca-certificates. (Closes: #452024)
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Update watch file. bazaar now uses launchpad to host its sources.
* Remove patch for inventory root revision copy, applied upstream.
* New upstream release.
* New upstream release.
* New upstream release
* Force removal of files installed in error to /etc/bash_completion.d/
  (LP: #249452)
* New upstream release.
* New upstream release
* New upstream release.
* Bump standards version.
* Include patch for inventory root revision copy, required for bzr-svn.
* New upstream release.
* Remove unused lintian overrides.
* Correct the package version not to be native.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* New upstream release.
* Final 1.5 release.
* New upstream release.
* New upstream release.
* New upstream release.
* Add myself as a co-maintainer.
* Add a Dm-Upload-Allowed: yes header.
* New upstream bugfix release.
* New upstream release.
* Final 1.3 release.
* New upstream release.
* First release candidate of the upcoming 1.3 release.
* Rebuild to fix the problem caused by a build with a broken python-central.
* New upstream release.
* Rebuild for dapper PPA.
* Apply Lamont's patches to fix build-dependencies on dapper.
  (See: https://bugs.launchpad.net/bzr/+bug/189915)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006-2010 Canonical Ltd
 
2
#
 
3
# This program is free software; you can redistribute it and/or modify
 
4
# it under the terms of the GNU General Public License as published by
 
5
# the Free Software Foundation; either version 2 of the License, or
 
6
# (at your option) any later version.
 
7
#
 
8
# This program is distributed in the hope that it will be useful,
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
# GNU General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
16
 
 
17
"""Tests for handling of ignore files"""
 
18
 
 
19
from cStringIO import StringIO
 
20
 
 
21
from bzrlib import config, errors, ignores
 
22
from bzrlib.tests import TestCase, TestCaseInTempDir, TestCaseWithTransport
 
23
 
 
24
 
 
25
class TestParseIgnoreFile(TestCase):
 
26
 
 
27
    def test_parse_fancy(self):
 
28
        ignored = ignores.parse_ignore_file(StringIO(
 
29
                './rootdir\n'
 
30
                'randomfile*\n'
 
31
                'path/from/ro?t\n'
 
32
                'unicode\xc2\xb5\n' # u'\xb5'.encode('utf8')
 
33
                'dos\r\n'
 
34
                '\n' # empty line
 
35
                '#comment\n'
 
36
                ' xx \n' # whitespace
 
37
                '!RE:^\.z.*\n'
 
38
                '!!./.zcompdump\n'
 
39
                ))
 
40
        self.assertEqual(set(['./rootdir',
 
41
                          'randomfile*',
 
42
                          'path/from/ro?t',
 
43
                          u'unicode\xb5',
 
44
                          'dos',
 
45
                          ' xx ',
 
46
                          '!RE:^\.z.*',
 
47
                          '!!./.zcompdump',
 
48
                         ]), ignored)
 
49
 
 
50
    def test_parse_empty(self):
 
51
        ignored = ignores.parse_ignore_file(StringIO(''))
 
52
        self.assertEqual(set([]), ignored)
 
53
 
 
54
 
 
55
class TestUserIgnores(TestCaseInTempDir):
 
56
 
 
57
    def test_create_if_missing(self):
 
58
        # $HOME should be set to '.'
 
59
        ignore_path = config.user_ignore_config_filename()
 
60
        self.failIfExists(ignore_path)
 
61
        user_ignores = ignores.get_user_ignores()
 
62
        self.assertEqual(set(ignores.USER_DEFAULTS), user_ignores)
 
63
 
 
64
        self.failUnlessExists(ignore_path)
 
65
        f = open(ignore_path, 'rb')
 
66
        try:
 
67
            entries = ignores.parse_ignore_file(f)
 
68
        finally:
 
69
            f.close()
 
70
        self.assertEqual(set(ignores.USER_DEFAULTS), entries)
 
71
 
 
72
    def test_use_existing(self):
 
73
        patterns = ['*.o', '*.py[co]', u'\xe5*']
 
74
        ignores._set_user_ignores(patterns)
 
75
 
 
76
        user_ignores = ignores.get_user_ignores()
 
77
        self.assertEqual(set(patterns), user_ignores)
 
78
 
 
79
    def test_use_empty(self):
 
80
        ignores._set_user_ignores([])
 
81
        ignore_path = config.user_ignore_config_filename()
 
82
        self.check_file_contents(ignore_path, '')
 
83
 
 
84
        self.assertEqual(set([]), ignores.get_user_ignores())
 
85
 
 
86
    def test_set(self):
 
87
        patterns = ['*.py[co]', '*.py[oc]']
 
88
        ignores._set_user_ignores(patterns)
 
89
 
 
90
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
91
 
 
92
        patterns = ['vim', '*.swp']
 
93
        ignores._set_user_ignores(patterns)
 
94
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
95
 
 
96
    def test_add(self):
 
97
        """Test that adding will not duplicate ignores"""
 
98
        # Create an empty file
 
99
        ignores._set_user_ignores([])
 
100
 
 
101
        patterns = ['foo', './bar', u'b\xe5z']
 
102
        added = ignores.add_unique_user_ignores(patterns)
 
103
        self.assertEqual(patterns, added)
 
104
        self.assertEqual(set(patterns), ignores.get_user_ignores())
 
105
 
 
106
    def test_add_directory(self):
 
107
        """Test that adding a directory will strip any trailing slash"""
 
108
        # Create an empty file
 
109
        ignores._set_user_ignores([])
 
110
 
 
111
        in_patterns = ['foo/', 'bar/', 'baz\\']
 
112
        added = ignores.add_unique_user_ignores(in_patterns)
 
113
        out_patterns = [ x.rstrip('/\\') for x in in_patterns ]
 
114
        self.assertEqual(out_patterns, added)
 
115
        self.assertEqual(set(out_patterns), ignores.get_user_ignores())
 
116
 
 
117
    def test_add_unique(self):
 
118
        """Test that adding will not duplicate ignores"""
 
119
        ignores._set_user_ignores(
 
120
            ['foo', './bar', u'b\xe5z', 'dir1/', 'dir3\\'])
 
121
 
 
122
        added = ignores.add_unique_user_ignores(
 
123
            ['xxx', './bar', 'xxx', 'dir1/', 'dir2/', 'dir3\\'])
 
124
        self.assertEqual(['xxx', 'dir2'], added)
 
125
        self.assertEqual(set(['foo', './bar', u'b\xe5z',
 
126
                              'xxx', 'dir1', 'dir2', 'dir3']),
 
127
                         ignores.get_user_ignores())
 
128
 
 
129
 
 
130
class TestRuntimeIgnores(TestCase):
 
131
 
 
132
    def setUp(self):
 
133
        TestCase.setUp(self)
 
134
 
 
135
        orig = ignores._runtime_ignores
 
136
        def restore():
 
137
            ignores._runtime_ignores = orig
 
138
        self.addCleanup(restore)
 
139
        # For the purposes of these tests, we must have no
 
140
        # runtime ignores
 
141
        ignores._runtime_ignores = set()
 
142
 
 
143
    def test_add(self):
 
144
        """Test that we can add an entry to the list."""
 
145
        self.assertEqual(set(), ignores.get_runtime_ignores())
 
146
 
 
147
        ignores.add_runtime_ignores(['foo'])
 
148
        self.assertEqual(set(['foo']), ignores.get_runtime_ignores())
 
149
 
 
150
    def test_add_duplicate(self):
 
151
        """Adding the same ignore twice shouldn't add a new entry."""
 
152
        ignores.add_runtime_ignores(['foo', 'bar'])
 
153
        self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
 
154
 
 
155
        ignores.add_runtime_ignores(['bar'])
 
156
        self.assertEqual(set(['foo', 'bar']), ignores.get_runtime_ignores())
 
157
 
 
158
 
 
159
class TestTreeIgnores(TestCaseWithTransport):
 
160
 
 
161
    def test_new_file(self):
 
162
        tree = self.make_branch_and_tree(".")
 
163
        ignores.tree_ignores_add_patterns(tree, ["myentry"])
 
164
        self.assertTrue(tree.has_filename(".bzrignore"))
 
165
        self.assertEquals("myentry\n",
 
166
                          open(".bzrignore", 'r').read())
 
167
 
 
168
    def test_add_to_existing(self):
 
169
        tree = self.make_branch_and_tree(".")
 
170
        self.build_tree_contents([('.bzrignore', "myentry1\n")])
 
171
        tree.add([".bzrignore"])
 
172
        ignores.tree_ignores_add_patterns(tree, ["myentry2", "foo"])
 
173
        self.assertEquals("myentry1\nmyentry2\nfoo\n",
 
174
                          open(".bzrignore", 'r').read())
 
175
 
 
176
    def test_adds_ending_newline(self):
 
177
        tree = self.make_branch_and_tree(".")
 
178
        self.build_tree_contents([('.bzrignore', "myentry1")])
 
179
        tree.add([".bzrignore"])
 
180
        ignores.tree_ignores_add_patterns(tree, ["myentry2"])
 
181
        self.assertEquals("myentry1\nmyentry2\n",
 
182
                          open(".bzrignore", 'r').read())
 
183