~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_whoami.py

Abbreviate pack_stat struct format to '>6L'

Show diffs side-by-side

added added

removed removed

Lines of Context:
20
20
import bzrlib
21
21
from bzrlib import (
22
22
    config,
 
23
    tests,
23
24
    )
24
 
from bzrlib.tests import TestCaseWithTransport
25
 
 
26
 
 
27
 
class TestWhoami(TestCaseWithTransport):
28
 
 
29
 
    def test_whoami(self):
 
25
 
 
26
 
 
27
class TestWhoami(tests.TestCaseWithTransport):
 
28
 
 
29
    def assertWhoAmI(self, expected, *cmd_args, **kwargs):
 
30
        out, err = self.run_bzr(('whoami',) + cmd_args, **kwargs)
 
31
        self.assertEquals('', err)
 
32
        lines = out.splitlines()
 
33
        self.assertLength(1, lines)
 
34
        self.assertEquals(expected, lines[0].rstrip())
 
35
 
 
36
    def test_whoami_no_args_no_conf(self):
30
37
        # this should always identify something, if only "john@localhost"
31
38
        out = self.run_bzr("whoami")[0]
32
39
        self.assertTrue(len(out) > 0)
33
40
        self.assertEquals(1, out.count('@'))
34
41
 
 
42
    def test_whoami_email_no_args(self):
35
43
        out = self.run_bzr("whoami --email")[0]
36
44
        self.assertTrue(len(out) > 0)
37
45
        self.assertEquals(1, out.count('@'))
47
55
        b = bzrlib.branch.Branch.open('.')
48
56
        b.get_config().set_user_option('email',
49
57
                                       'Branch Identity <branch@identi.ty>')
50
 
        whoami = self.run_bzr("whoami")[0]
51
 
        self.assertEquals('Branch Identity <branch@identi.ty>\n', whoami)
52
 
        whoami_email = self.run_bzr("whoami --email")[0]
53
 
        self.assertEquals('branch@identi.ty\n', whoami_email)
 
58
        self.assertWhoAmI('Branch Identity <branch@identi.ty>')
 
59
        self.assertWhoAmI('branch@identi.ty', '--email')
54
60
 
55
61
        # Verify that the environment variable overrides the value
56
62
        # in the file
57
63
        self.overrideEnv('BZR_EMAIL', 'Different ID <other@environ.ment>')
58
 
        whoami = self.run_bzr("whoami")[0]
59
 
        self.assertEquals('Different ID <other@environ.ment>\n', whoami)
60
 
        whoami_email = self.run_bzr("whoami --email")[0]
61
 
        self.assertEquals('other@environ.ment\n', whoami_email)
 
64
        self.assertWhoAmI('Different ID <other@environ.ment>')
 
65
        self.assertWhoAmI('other@environ.ment', '--email')
62
66
 
63
67
    def test_whoami_utf8(self):
64
68
        """verify that an identity can be in utf-8."""
65
 
        wt = self.make_branch_and_tree('.')
66
69
        self.run_bzr(['whoami', u'Branch Identity \u20ac <branch@identi.ty>'],
67
70
                     encoding='utf-8')
68
 
        whoami = self.run_bzr("whoami", encoding='utf-8')[0]
69
 
        self.assertEquals('Branch Identity \xe2\x82\xac ' +
70
 
                          '<branch@identi.ty>\n', whoami)
71
 
        whoami_email = self.run_bzr("whoami --email", encoding='utf-8')[0]
72
 
        self.assertEquals('branch@identi.ty\n', whoami_email)
 
71
        self.assertWhoAmI('Branch Identity \xe2\x82\xac <branch@identi.ty>',
 
72
                          encoding='utf-8')
 
73
        self.assertWhoAmI('branch@identi.ty', '--email')
73
74
 
74
75
    def test_whoami_ascii(self):
75
76
        """
80
81
        b = bzrlib.branch.Branch.open('.')
81
82
        b.get_config().set_user_option('email', u'Branch Identity \u20ac ' +
82
83
                                       '<branch@identi.ty>')
83
 
        whoami = self.run_bzr("whoami", encoding='ascii')[0]
84
 
        self.assertEquals('Branch Identity ? <branch@identi.ty>\n', whoami)
85
 
        whoami_email = self.run_bzr("whoami --email", encoding='ascii')[0]
86
 
        self.assertEquals('branch@identi.ty\n', whoami_email)
 
84
        self.assertWhoAmI('Branch Identity ? <branch@identi.ty>',
 
85
                          encoding='ascii')
 
86
        self.assertWhoAmI('branch@identi.ty', '--email',
 
87
                          encoding='ascii')
87
88
 
88
89
    def test_warning(self):
89
90
        """verify that a warning is displayed if no email is given."""
109
110
        wt = self.make_branch_and_tree('subdir')
110
111
        c = wt.branch.get_config()
111
112
        c.set_user_option('email', 'Branch Identity <branch@identi.ty>')
112
 
        out, err = self.run_bzr("whoami --directory subdir")
113
 
        self.assertEquals('Branch Identity <branch@identi.ty>\n', out)
 
113
        self.assertWhoAmI('Branch Identity <branch@identi.ty>',
 
114
                          '--directory', 'subdir')
114
115
        self.run_bzr(['whoami', '--directory', 'subdir', '--branch',
115
116
                      'Changed Identity <changed@identi.ty>'])
 
117
        c = wt.branch.get_config()
116
118
        self.assertEquals('Changed Identity <changed@identi.ty>',
117
119
                          c.get_user_option('email'))
118
120
 
122
124
        c = wt.branch.get_config()
123
125
        c.set_user_option('email', 'Branch Identity <branch@identi.ty>')
124
126
        url = self.get_readonly_url() + '/subdir'
125
 
        out, err = self.run_bzr(['whoami', '--directory', url])
126
 
        self.assertEquals('Branch Identity <branch@identi.ty>\n', out)
 
127
        self.assertWhoAmI('Branch Identity <branch@identi.ty>',
 
128
                          '--directory', url)
127
129
        url = self.get_url('subdir')
128
130
        self.run_bzr(['whoami', '--directory', url, '--branch',
129
131
                      'Changed Identity <changed@identi.ty>'])
130
132
        # The identity has been set in the branch config (but not the global
131
133
        # config)
 
134
        c = wt.branch.get_config()
132
135
        self.assertEquals('Changed Identity <changed@identi.ty>',
133
136
                          c.get_user_option('email'))
134
137
        global_conf = config.GlobalConfig()