/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 bzrlib/tests/blackbox/test_init.py

  • Committer: Jan Hudec
  • Date: 2006-11-25 20:38:39 UTC
  • mto: (2199.1.1 jam-integration)
  • mto: This revision was merged to the branch mainline in revision 2200.
  • Revision ID: bulb@ucw.cz-20061125203839-9nuhv32z63hb8811
Option --pull for merge command.

Option --pull was added to merge command, that, if the merge would be
trivial, ie. if the common ancestor is equal to the local tip, causes pull of
the remote instead of creating the merger.

Simple test for this option is included.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
 
17
 
 
18
"""Test "bzr init"""
 
19
 
 
20
import os
 
21
import re
 
22
 
 
23
from bzrlib.bzrdir import BzrDirMetaFormat1
 
24
from bzrlib.tests.blackbox import ExternalBase
 
25
from bzrlib.tests.test_sftp_transport import TestCaseWithSFTPServer
 
26
from bzrlib.workingtree import WorkingTree
 
27
 
 
28
 
 
29
class TestInit(ExternalBase):
 
30
 
 
31
    def test_init_with_format(self):
 
32
        # Verify bzr init --format constructs something plausible
 
33
        t = self.get_transport()
 
34
        self.runbzr('init --format default')
 
35
        self.assertIsDirectory('.bzr', t)
 
36
        self.assertIsDirectory('.bzr/checkout', t)
 
37
        self.assertIsDirectory('.bzr/checkout/lock', t)
 
38
 
 
39
    def test_init_weave(self):
 
40
        # --format=weave should be accepted to allow interoperation with
 
41
        # old releases when desired.
 
42
        out, err = self.run_bzr('init', '--format=weave')
 
43
        self.assertEqual('', out)
 
44
        self.assertEqual('', err)
 
45
 
 
46
    def test_init_at_repository_root(self):
 
47
        # bzr init at the root of a repository should create a branch
 
48
        # and working tree even when creation of working trees is disabled.
 
49
        t = self.get_transport()
 
50
        t.mkdir('repo')
 
51
        format = BzrDirMetaFormat1()
 
52
        newdir = format.initialize(t.abspath('repo'))
 
53
        repo = newdir.create_repository(shared=True)
 
54
        repo.set_make_working_trees(False)
 
55
        out, err = self.run_bzr('init', 'repo')
 
56
        self.assertEqual('', out)
 
57
        self.assertEqual('', err)
 
58
        newdir.open_branch()
 
59
        newdir.open_workingtree()
 
60
        
 
61
    def test_init_branch(self):
 
62
        out, err = self.run_bzr('init')
 
63
        self.assertEqual('', out)
 
64
        self.assertEqual('', err)
 
65
 
 
66
        # Can it handle subdirectories of branches too ?
 
67
        out, err = self.run_bzr('init', 'subdir1')
 
68
        self.assertEqual('', out)
 
69
        self.assertEqual('', err)
 
70
        WorkingTree.open('subdir1')
 
71
        
 
72
        out, err = self.run_bzr('init', 'subdir2/nothere', retcode=3)
 
73
        self.assertEqual('', out)
 
74
        self.assertContainsRe(err,
 
75
            r'^bzr: ERROR: .*'
 
76
            '\[Errno 2\] No such file or directory')
 
77
        
 
78
        os.mkdir('subdir2')
 
79
        out, err = self.run_bzr('init', 'subdir2')
 
80
        self.assertEqual('', out)
 
81
        self.assertEqual('', err)
 
82
        # init an existing branch.
 
83
        out, err = self.run_bzr('init', 'subdir2', retcode=3)
 
84
        self.assertEqual('', out)
 
85
        self.failUnless(err.startswith('bzr: ERROR: Already a branch:'))
 
86
 
 
87
    def test_init_existing_branch(self):
 
88
        self.run_bzr('init')
 
89
        out, err = self.run_bzr('init', retcode=3)
 
90
        self.assertContainsRe(err, 'Already a branch')
 
91
        # don't suggest making a checkout, there's already a working tree
 
92
        self.assertFalse(re.search(r'checkout', err))
 
93
 
 
94
    def test_init_existing_without_workingtree(self):
 
95
        # make a repository
 
96
        self.run_bzr('init-repo', '.')
 
97
        # make a branch; by default without a working tree
 
98
        self.run_bzr('init', 'subdir')
 
99
        # fail
 
100
        out, err = self.run_bzr('init', 'subdir', retcode=3)
 
101
        # suggests using checkout
 
102
        self.assertContainsRe(err, 'ontains a branch.*but no working tree.*checkout')
 
103
 
 
104
    def test_no_defaults(self):
 
105
        """Init creates no default ignore rules."""
 
106
        self.run_bzr('init')
 
107
        self.assertFalse(os.path.exists('.bzrignore'))
 
108
 
 
109
 
 
110
class TestSFTPInit(TestCaseWithSFTPServer):
 
111
 
 
112
    def test_init(self):
 
113
        # init on a remote url should succeed.
 
114
        out, err = self.run_bzr('init', self.get_url())
 
115
        self.assertEqual('', out)
 
116
        self.assertEqual('', err)
 
117
    
 
118
    def test_init_existing_branch(self):
 
119
        # when there is already a branch present, make mention
 
120
        self.make_branch('.')
 
121
 
 
122
        # rely on SFTPServer get_url() pointing at '.'
 
123
        out, err = self.run_bzr_error(['Already a branch'], 'init', self.get_url())
 
124
 
 
125
        # make sure using 'bzr checkout' is not suggested
 
126
        # for remote locations missing a working tree
 
127
        self.assertFalse(re.search(r'checkout', err))
 
128
 
 
129
    def test_init_existing_branch_with_workingtree(self):
 
130
        # don't distinguish between the branch having a working tree or not
 
131
        # when the branch itself is remote.
 
132
        self.make_branch_and_tree('.')
 
133
 
 
134
        # rely on SFTPServer get_url() pointing at '.'
 
135
        self.run_bzr_error(['Already a branch'], 'init', self.get_url())