/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1399.1.12 by Robert Collins
add new test script
1
# (C) 2005 Canonical Ltd
2
# Authors:  Robert Collins <robert.collins@canonical.com>
3
#
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 of the License, or
7
# (at your option) any later version.
8
#
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
18
import os
19
from bzrlib.branch import Branch
20
from bzrlib.selftest import TestCaseInTempDir
21
from bzrlib.trace import mutter
1457.1.1 by Robert Collins
rather than getting the branch inventory, WorkingTree can use the whole Branch, or make its own.
22
from bzrlib.workingtree import (TreeEntry, TreeDirectory, TreeFile, TreeLink,
23
                                WorkingTree)
1399.1.12 by Robert Collins
add new test script
24
25
class TestTreeDirectory(TestCaseInTempDir):
26
27
    def test_kind_character(self):
28
        self.assertEqual(TreeDirectory().kind_character(), '/')
29
30
31
class TestTreeEntry(TestCaseInTempDir):
32
33
    def test_kind_character(self):
34
        self.assertEqual(TreeEntry().kind_character(), '???')
35
36
37
class TestTreeFile(TestCaseInTempDir):
38
39
    def test_kind_character(self):
40
        self.assertEqual(TreeFile().kind_character(), '')
41
42
43
class TestTreeLink(TestCaseInTempDir):
44
45
    def test_kind_character(self):
46
        self.assertEqual(TreeLink().kind_character(), '')
47
48
49
class TestWorkingTree(TestCaseInTempDir):
50
51
    def test_listfiles(self):
52
        branch = Branch.initialize('.')
53
        os.mkdir('dir')
54
        print >> open('file', 'w'), "content"
55
        os.symlink('target', 'symlink')
56
        tree = branch.working_tree()
57
        files = list(tree.list_files())
58
        self.assertEqual(files[0], ('dir', '?', 'directory', None, TreeDirectory()))
59
        self.assertEqual(files[1], ('file', '?', 'file', None, TreeFile()))
60
        self.assertEqual(files[2], ('symlink', '?', 'symlink', None, TreeLink()))
1457.1.1 by Robert Collins
rather than getting the branch inventory, WorkingTree can use the whole Branch, or make its own.
61
62
    def test_construct_with_branch(self):
63
        branch = Branch.initialize('.')
64
        tree = WorkingTree(branch.base, branch)
65
        self.assertEqual(branch, tree.branch)
66
        self.assertEqual(branch.base, tree.basedir)
67
    
68
    def test_construct_without_branch(self):
69
        branch = Branch.initialize('.')
70
        tree = WorkingTree(branch.base)
71
        self.assertEqual(branch.base, tree.branch.base)
72
        self.assertEqual(branch.base, tree.basedir)
1457.1.3 by Robert Collins
make Branch.relpath delegate to the working tree.
73
74
    def test_basic_relpath(self):
75
        # for comprehensive relpath tests, see whitebox.py.
76
        branch = Branch.initialize('.')
77
        tree = WorkingTree(branch.base)
78
        self.assertEqual('child',
79
                         tree.relpath(os.path.join(os.getcwd(), 'child')))
1442.1.65 by Robert Collins
Branch.remove has been moved to WorkingTree.
80
81
    def test_lock_locks_branch(self):
82
        branch = Branch.initialize('.')
83
        tree = WorkingTree(branch.base)
84
        tree.lock_read()
85
        self.assertEqual(1, tree.branch._lock_count)
86
        self.assertEqual('r', tree.branch._lock_mode)
87
        tree.unlock()
88
        self.assertEqual(None, tree.branch._lock_count)
89
        tree.lock_write()
90
        self.assertEqual(1, tree.branch._lock_count)
91
        self.assertEqual('w', tree.branch._lock_mode)
92
        tree.unlock()
93
        self.assertEqual(None, tree.branch._lock_count)
1442.1.68 by Robert Collins
'bzr pull' now accepts '--clobber'.
94
 
95
    def get_pullable_branches(self):
1442.1.67 by Robert Collins
Factor out the guts of 'pull' from the command into WorkingTree.pull().
96
        self.build_tree(['from/', 'from/file', 'to/'])
97
        br_a = Branch.initialize('from')
98
        br_a.add('file')
99
        br_a.commit('foo', rev_id='A')
100
        br_b = Branch.initialize('to')
1442.1.68 by Robert Collins
'bzr pull' now accepts '--clobber'.
101
        return br_a, br_b
102
 
103
    def test_pull(self):
104
        br_a, br_b = self.get_pullable_branches()
1442.1.67 by Robert Collins
Factor out the guts of 'pull' from the command into WorkingTree.pull().
105
        br_b.working_tree().pull(br_a)
106
        self.failUnless(br_b.has_revision('A'))
107
        self.assertEqual(['A'], br_b.revision_history())
1442.1.68 by Robert Collins
'bzr pull' now accepts '--clobber'.
108
1185.12.92 by Aaron Bentley
Fixed pull help, renamed clobber to overwrite
109
    def test_pull_overwrites(self):
1442.1.68 by Robert Collins
'bzr pull' now accepts '--clobber'.
110
        br_a, br_b = self.get_pullable_branches()
111
        br_b.commit('foo', rev_id='B')
112
        self.assertEqual(['B'], br_b.revision_history())
1185.12.92 by Aaron Bentley
Fixed pull help, renamed clobber to overwrite
113
        br_b.working_tree().pull(br_a, overwrite=True)
1442.1.68 by Robert Collins
'bzr pull' now accepts '--clobber'.
114
        self.failUnless(br_b.has_revision('A'))
115
        self.failUnless(br_b.has_revision('B'))
116
        self.assertEqual(['A'], br_b.revision_history())