~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_bad_files.py

  • Committer: Robert Collins
  • Date: 2005-08-23 06:52:09 UTC
  • mto: (974.1.50) (1185.1.10) (1092.3.1)
  • mto: This revision was merged to the branch mainline in revision 1139.
  • Revision ID: robertc@robertcollins.net-20050823065209-81cd5962c401751b
move io redirection into each test case from the global runner

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2007 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
 
 
18
 
"""Tests being able to ignore bad filetypes."""
19
 
 
20
 
from cStringIO import StringIO
21
 
import os
22
 
 
23
 
from bzrlib import (
24
 
    add,
25
 
    errors,
26
 
    )
27
 
from bzrlib.status import show_tree_status
28
 
from bzrlib.tests import OsFifoFeature, TestCaseWithTransport
29
 
 
30
 
 
31
 
def verify_status(tester, tree, value):
32
 
    """Verify the output of show_tree_status"""
33
 
    tof = StringIO()
34
 
    show_tree_status(tree, to_file=tof)
35
 
    tof.seek(0)
36
 
    tester.assertEqual(value, tof.readlines())
37
 
 
38
 
 
39
 
class TestBadFiles(TestCaseWithTransport):
40
 
 
41
 
    def test_bad_files(self):
42
 
        """Test that bzr will ignore files it doesn't like"""
43
 
        self.requireFeature(OsFifoFeature)
44
 
 
45
 
        wt = self.make_branch_and_tree('.')
46
 
        b = wt.branch
47
 
 
48
 
        files = ['one', 'two', 'three']
49
 
        file_ids = ['one-id', 'two-id', 'three-id']
50
 
        self.build_tree(files)
51
 
        wt.add(files, file_ids)
52
 
        wt.commit("Commit one", rev_id="a@u-0-0")
53
 
 
54
 
        # We should now have a few files, lets try to
55
 
        # put some bogus stuff in the tree
56
 
 
57
 
        # status with nothing changed
58
 
        verify_status(self, wt, [])
59
 
 
60
 
        os.mkfifo('a-fifo')
61
 
        self.build_tree(['six'])
62
 
 
63
 
        verify_status(self, wt,
64
 
                          ['unknown:\n',
65
 
                           '  a-fifo\n',
66
 
                           '  six\n'
67
 
                           ])
68
 
 
69
 
        # We should raise an error if we are adding a bogus file
70
 
        self.assertRaises(errors.BadFileKindError, wt.smart_add, ['a-fifo'])
71
 
 
72
 
        # And the list of files shouldn't have been modified
73
 
        verify_status(self, wt,
74
 
                          ['unknown:\n',
75
 
                           '  a-fifo\n',
76
 
                           '  six\n'
77
 
                           ])
78
 
 
79
 
        # Make sure smart_add can handle having a bogus
80
 
        # file in the way
81
 
        wt.smart_add([])
82
 
        verify_status(self, wt,
83
 
                          ['added:\n',
84
 
                           '  six\n',
85
 
                           'unknown:\n',
86
 
                           '  a-fifo\n',
87
 
                           ])
88
 
        wt.commit("Commit four", rev_id="a@u-0-3")
89
 
 
90
 
        verify_status(self, wt,
91
 
                          ['unknown:\n',
92
 
                           '  a-fifo\n',
93
 
                           ])