~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/test_bad_files.py

  • Committer: Martin Pool
  • Date: 2005-08-24 08:59:32 UTC
  • Revision ID: mbp@sourcefrog.net-20050824085932-c61f1f1f1c930e13
- Add a simple UIFactory 

  The idea of this is to let a client of bzrlib set some 
  policy about how output is displayed.

  In this revision all that's done is that progress bars
  are constructed by a policy established by the application
  rather than being randomly constructed in the library 
  or passed down the calls.  This avoids progress bars
  popping up while running the test suite and cleans up
  some code.

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
 
                           ])