35
32
self.assertTrue(len(out) > 0)
36
33
self.assertEquals(1, out.count('@'))
38
out = self.run_bzr("whoami --email")[0]
35
out = self.run_bzr("whoami", "--email")[0]
39
36
self.assertTrue(len(out) > 0)
40
37
self.assertEquals(1, out.count('@'))
42
39
def test_whoami_branch(self):
43
40
"""branch specific user identity works."""
44
41
wt = self.make_branch_and_tree('.')
45
42
b = bzrlib.branch.Branch.open('.')
46
43
b.get_config().set_user_option('email',
47
44
'Branch Identity <branch@identi.ty>')
48
whoami = self.run_bzr("whoami")[0]
49
self.assertEquals('Branch Identity <branch@identi.ty>\n', whoami)
50
whoami_email = self.run_bzr("whoami --email")[0]
51
self.assertEquals('branch@identi.ty\n', whoami_email)
45
bzr_email = os.environ.get('BZR_EMAIL')
46
if bzr_email is not None:
47
del os.environ['BZR_EMAIL']
48
bzremail = os.environ.get('BZREMAIL')
49
if bzremail is not None:
50
del os.environ['BZREMAIL']
52
whoami = self.run_bzr("whoami")[0]
53
self.assertEquals('Branch Identity <branch@identi.ty>\n', whoami)
54
whoami_email = self.run_bzr("whoami", "--email")[0]
55
self.assertEquals('branch@identi.ty\n', whoami_email)
53
# Verify that the environment variable overrides the value
55
os.environ['BZR_EMAIL'] = 'Different ID <other@environ.ment>'
56
whoami = self.run_bzr("whoami")[0]
57
self.assertEquals('Different ID <other@environ.ment>\n', whoami)
58
whoami_email = self.run_bzr("whoami --email")[0]
59
self.assertEquals('other@environ.ment\n', whoami_email)
57
# Verify that the environment variable overrides the value
59
os.environ['BZR_EMAIL'] = 'Different ID <other@environ.ment>'
60
whoami = self.run_bzr("whoami")[0]
61
self.assertEquals('Different ID <other@environ.ment>\n', whoami)
62
whoami_email = self.run_bzr("whoami", "--email")[0]
63
self.assertEquals('other@environ.ment\n', whoami_email)
64
del os.environ['BZR_EMAIL']
65
os.environ['BZREMAIL'] = 'Yet Another ID <yetother@environ.ment>'
66
whoami, warn = self.run_bzr("whoami")
67
self.assertEquals('Yet Another ID <yetother@environ.ment>\n', whoami)
68
self.assertTrue(len(warn) > 0)
69
del os.environ['BZREMAIL']
71
if bzr_email is not None:
72
os.environ['BZR_EMAIL'] = bzr_email
73
if bzremail is not None:
74
os.environ['BZREMAIL'] = bzremail
61
76
def test_whoami_utf8(self):
62
77
"""verify that an identity can be in utf-8."""
63
78
wt = self.make_branch_and_tree('.')
64
self.run_bzr(['whoami', u'Branch Identity \u20ac <branch@identi.ty>'],
79
self.run_bzr('whoami', u'Branch Identity \u20ac <branch@identi.ty>',
66
whoami = self.run_bzr("whoami", encoding='utf-8')[0]
67
self.assertEquals('Branch Identity \xe2\x82\xac ' +
68
'<branch@identi.ty>\n', whoami)
69
whoami_email = self.run_bzr("whoami --email", encoding='utf-8')[0]
70
self.assertEquals('branch@identi.ty\n', whoami_email)
81
bzr_email = os.environ.get('BZR_EMAIL')
82
if bzr_email is not None:
83
del os.environ['BZR_EMAIL']
85
whoami = self.run_bzr("whoami", encoding='utf-8')[0]
86
self.assertEquals('Branch Identity \xe2\x82\xac ' +
87
'<branch@identi.ty>\n', whoami)
88
whoami_email = self.run_bzr("whoami", "--email",
90
self.assertEquals('branch@identi.ty\n', whoami_email)
92
if bzr_email is not None:
93
os.environ['BZR_EMAIL'] = bzr_email
72
95
def test_whoami_ascii(self):
78
101
b = bzrlib.branch.Branch.open('.')
79
102
b.get_config().set_user_option('email', u'Branch Identity \u20ac ' +
80
103
'<branch@identi.ty>')
81
whoami = self.run_bzr("whoami", encoding='ascii')[0]
82
self.assertEquals('Branch Identity ? <branch@identi.ty>\n', whoami)
83
whoami_email = self.run_bzr("whoami --email", encoding='ascii')[0]
84
self.assertEquals('branch@identi.ty\n', whoami_email)
104
bzr_email = os.environ.get('BZR_EMAIL')
105
if bzr_email is not None:
106
del os.environ['BZR_EMAIL']
108
whoami = self.run_bzr("whoami", encoding='ascii')[0]
109
self.assertEquals('Branch Identity ? <branch@identi.ty>\n', whoami)
110
whoami_email = self.run_bzr("whoami", "--email",
112
self.assertEquals('branch@identi.ty\n', whoami_email)
114
if bzr_email is not None:
115
os.environ['BZR_EMAIL'] = bzr_email
86
117
def test_warning(self):
87
118
"""verify that a warning is displayed if no email is given."""
88
119
self.make_branch_and_tree('.')
89
display = self.run_bzr(['whoami', 'Branch Identity'])[1]
120
display = self.run_bzr('whoami', 'Branch Identity')[1]
90
121
self.assertEquals('"Branch Identity" does not seem to contain an '
91
122
'email address. This is allowed, but not '
92
123
'recommended.\n', display)
94
def test_whoami_not_set(self):
95
"""Ensure whoami error if username is not set.
97
osutils.set_or_unset_env('EMAIL', None)
98
osutils.set_or_unset_env('BZR_EMAIL', None)
99
out, err = self.run_bzr(['whoami'], 3)
100
self.assertContainsRe(err, 'Unable to determine your name')
102
def test_whoami_directory(self):
103
"""Test --directory option."""
104
wt = self.make_branch_and_tree('subdir')
105
c = wt.branch.get_config()
106
c.set_user_option('email', 'Branch Identity <branch@identi.ty>')
107
out, err = self.run_bzr("whoami --directory subdir")
108
self.assertEquals('Branch Identity <branch@identi.ty>\n', out)
109
self.run_bzr(['whoami', '--directory', 'subdir', '--branch',
110
'Changed Identity <changed@identi.ty>'])
111
self.assertEquals('Changed Identity <changed@identi.ty>',
112
c.get_user_option('email'))
114
def test_whoami_remote_directory(self):
115
"""Test --directory option with a remote directory."""
116
wt = self.make_branch_and_tree('subdir')
117
c = wt.branch.get_config()
118
c.set_user_option('email', 'Branch Identity <branch@identi.ty>')
119
url = self.get_readonly_url() + '/subdir'
120
out, err = self.run_bzr(['whoami', '--directory', url])
121
self.assertEquals('Branch Identity <branch@identi.ty>\n', out)
122
url = self.get_url('subdir')
123
self.run_bzr(['whoami', '--directory', url, '--branch',
124
'Changed Identity <changed@identi.ty>'])
125
# The identity has been set in the branch config (but not the global
127
self.assertEquals('Changed Identity <changed@identi.ty>',
128
c.get_user_option('email'))
129
global_conf = config.GlobalConfig()
130
self.assertEquals(None, global_conf.get_user_option('email'))
132
def test_whoami_nonbranch_directory(self):
133
"""Test --directory mentioning a non-branch directory."""
134
wt = self.build_tree(['subdir/'])
135
out, err = self.run_bzr("whoami --directory subdir", retcode=3)
136
self.assertContainsRe(err, 'ERROR: Not a branch')