/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/tests/test_clean_tree.py

  • Committer: Jelmer Vernooij
  • Date: 2020-04-05 19:11:34 UTC
  • mto: (7490.7.16 work)
  • mto: This revision was merged to the branch mainline in revision 7501.
  • Revision ID: jelmer@jelmer.uk-20200405191134-0aebh8ikiwygxma5
Populate the .gitignore file.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2009 Canonical Ltd
 
1
# Copyright (C) 2009, 2010, 2011 Canonical Ltd
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
15
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
 
 
18
import errno
18
19
import os
19
 
from StringIO import StringIO
 
20
import shutil
 
21
import sys
20
22
 
21
 
from bzrlib.bzrdir import (
22
 
    BzrDir,
 
23
from .. import tests, ui
 
24
from ..controldir import (
 
25
    ControlDir,
23
26
    )
24
 
from bzrlib.clean_tree import (
 
27
from ..clean_tree import (
25
28
    clean_tree,
26
29
    iter_deletables,
27
30
    )
28
 
from bzrlib.osutils import (
 
31
from ..osutils import (
29
32
    has_symlinks,
30
33
    )
31
 
from bzrlib.tests import (
 
34
from . import (
32
35
    TestCaseInTempDir,
33
36
    )
34
37
 
39
42
        if has_symlinks() is False:
40
43
            return
41
44
        os.mkdir('branch')
42
 
        BzrDir.create_standalone_workingtree('branch')
 
45
        ControlDir.create_standalone_workingtree('branch')
43
46
        os.symlink(os.path.realpath('no-die-please'), 'branch/die-please')
44
47
        os.mkdir('no-die-please')
45
 
        self.failUnlessExists('branch/die-please')
 
48
        self.assertPathExists('branch/die-please')
46
49
        os.mkdir('no-die-please/child')
47
50
 
48
51
        clean_tree('branch', unknown=True, no_prompt=True)
49
 
        self.failUnlessExists('no-die-please')
50
 
        self.failUnlessExists('no-die-please/child')
 
52
        self.assertPathExists('no-die-please')
 
53
        self.assertPathExists('no-die-please/child')
51
54
 
52
55
    def test_iter_deletable(self):
53
56
        """Files are selected for deletion appropriately"""
54
57
        os.mkdir('branch')
55
 
        tree = BzrDir.create_standalone_workingtree('branch')
56
 
        transport = tree.bzrdir.root_transport
57
 
        transport.put_bytes('.bzrignore', '*~\n*.pyc\n.bzrignore\n')
58
 
        transport.put_bytes('file.BASE', 'contents')
59
 
        tree.lock_write()
60
 
        try:
 
58
        tree = ControlDir.create_standalone_workingtree('branch')
 
59
        transport = tree.controldir.root_transport
 
60
        transport.put_bytes('.bzrignore', b'*~\n*.pyc\n.bzrignore\n')
 
61
        transport.put_bytes('file.BASE', b'contents')
 
62
        with tree.lock_write():
61
63
            self.assertEqual(len(list(iter_deletables(tree, unknown=True))), 1)
62
 
            transport.put_bytes('file', 'contents')
63
 
            transport.put_bytes('file~', 'contents')
64
 
            transport.put_bytes('file.pyc', 'contents')
65
 
            dels = sorted([r for a,r in iter_deletables(tree, unknown=True)])
 
64
            transport.put_bytes('file', b'contents')
 
65
            transport.put_bytes('file~', b'contents')
 
66
            transport.put_bytes('file.pyc', b'contents')
 
67
            dels = sorted([r for a, r in iter_deletables(tree, unknown=True)])
66
68
            self.assertEqual(['file', 'file.BASE'], dels)
67
69
 
68
 
            dels = [r for a,r in iter_deletables(tree, detritus=True)]
 
70
            dels = [r for a, r in iter_deletables(tree, detritus=True)]
69
71
            self.assertEqual(sorted(['file~', 'file.BASE']), dels)
70
72
 
71
 
            dels = [r for a,r in iter_deletables(tree, ignored=True)]
 
73
            dels = [r for a, r in iter_deletables(tree, ignored=True)]
72
74
            self.assertEqual(sorted(['file~', 'file.pyc', '.bzrignore']),
73
75
                             dels)
74
76
 
75
 
            dels = [r for a,r in iter_deletables(tree, unknown=False)]
 
77
            dels = [r for a, r in iter_deletables(tree, unknown=False)]
76
78
            self.assertEqual([], dels)
77
 
        finally:
78
 
            tree.unlock()
 
79
 
 
80
    def test_delete_items_warnings(self):
 
81
        """Ensure delete_items issues warnings on EACCES. (bug #430785)
 
82
        """
 
83
        def _dummy_unlink(path):
 
84
            """unlink() files other than files named '0foo'.
 
85
            """
 
86
            if path.endswith('0foo'):
 
87
                # Simulate 'permission denied' error.
 
88
                # This should show up as a warning for the
 
89
                # user.
 
90
                e = OSError()
 
91
                e.errno = errno.EACCES
 
92
                raise e
 
93
 
 
94
        def _dummy_rmtree(path, ignore_errors=False, onerror=None):
 
95
            """Call user supplied error handler onerror.
 
96
            """
 
97
            # Indicate failure in removing 'path' if path is subdir0
 
98
            # We later check to ensure that this is indicated
 
99
            # to the user as a warning. We raise OSError to construct
 
100
            # proper excinfo that needs to be passed to onerror
 
101
            try:
 
102
                raise OSError
 
103
            except OSError as e:
 
104
                e.errno = errno.EACCES
 
105
                excinfo = sys.exc_info()
 
106
                function = os.remove
 
107
                if 'subdir0' not in path:
 
108
                    # onerror should show warning only for os.remove
 
109
                    # error. For any other failures the error should
 
110
                    # be shown to the user.
 
111
                    function = os.listdir
 
112
                onerror(function=function,
 
113
                        path=path, excinfo=excinfo)
 
114
 
 
115
        self.overrideAttr(os, 'unlink', _dummy_unlink)
 
116
        self.overrideAttr(shutil, 'rmtree', _dummy_rmtree)
 
117
        ui.ui_factory = tests.TestUIFactory()
 
118
        stderr = ui.ui_factory.stderr
 
119
 
 
120
        ControlDir.create_standalone_workingtree('.')
 
121
        self.build_tree(['0foo', '1bar', '2baz', 'subdir0/'])
 
122
        clean_tree('.', unknown=True, no_prompt=True)
 
123
        self.assertContainsRe(stderr.getvalue(),
 
124
                              'bzr: warning: unable to remove.*0foo')
 
125
        self.assertContainsRe(stderr.getvalue(),
 
126
                              'bzr: warning: unable to remove.*subdir0')
 
127
 
 
128
        # Ensure that error other than EACCES during os.remove are
 
129
        # not turned into warnings.
 
130
        self.build_tree(['subdir1/'])
 
131
        self.assertRaises(OSError, clean_tree, '.',
 
132
                          unknown=True, no_prompt=True)