add get_whoami()
This function is useful for simply testing that a user's authentication credentials are correct. Change-Id: I07841eccd9cd2015ac432c9c22fb8e451a638c0c
This commit is contained in:
parent
f6f26ec481
commit
fd8c8151b9
@ -18,10 +18,13 @@ retrieve the Jenkins server version.
|
|||||||
import jenkins
|
import jenkins
|
||||||
|
|
||||||
server = jenkins.Jenkins('http://localhost:8080', username='myuser', password='mypassword')
|
server = jenkins.Jenkins('http://localhost:8080', username='myuser', password='mypassword')
|
||||||
|
user = server.get_whoami()
|
||||||
version = server.get_version()
|
version = server.get_version()
|
||||||
print version
|
print('Hello %s from Jenkins %s' % (user['fullName'], jenkins_version))
|
||||||
|
|
||||||
The above code prints the version of the Jenkins master running on 'localhost:8080'
|
The above code prints the the fullName attribute of the user and the version of
|
||||||
|
the Jenkins master running on 'localhost:8080'. For example, it may print
|
||||||
|
"Hello John from Jenkins 2.0".
|
||||||
|
|
||||||
From Jenkins vesion 1.426 onward you can specify an API token instead of your
|
From Jenkins vesion 1.426 onward you can specify an API token instead of your
|
||||||
real password while authenticating the user against the Jenkins instance.
|
real password while authenticating the user against the Jenkins instance.
|
||||||
|
@ -90,6 +90,7 @@ DEFAULT_HEADERS = {'Content-Type': 'text/xml; charset=utf-8'}
|
|||||||
INFO = 'api/json'
|
INFO = 'api/json'
|
||||||
PLUGIN_INFO = 'pluginManager/api/json?depth=%(depth)s'
|
PLUGIN_INFO = 'pluginManager/api/json?depth=%(depth)s'
|
||||||
CRUMB_URL = 'crumbIssuer/api/json'
|
CRUMB_URL = 'crumbIssuer/api/json'
|
||||||
|
WHOAMI_URL = 'me/api/json'
|
||||||
JOBS_QUERY = '?tree=jobs[url,color,name,jobs]'
|
JOBS_QUERY = '?tree=jobs[url,color,name,jobs]'
|
||||||
JOB_INFO = '%(folder_url)sjob/%(short_name)s/api/json?depth=%(depth)s'
|
JOB_INFO = '%(folder_url)sjob/%(short_name)s/api/json?depth=%(depth)s'
|
||||||
JOB_NAME = '%(folder_url)sjob/%(short_name)s/api/json?tree=name'
|
JOB_NAME = '%(folder_url)sjob/%(short_name)s/api/json?tree=name'
|
||||||
@ -514,6 +515,33 @@ class Jenkins(object):
|
|||||||
raise JenkinsException("Could not parse JSON info for server[%s]"
|
raise JenkinsException("Could not parse JSON info for server[%s]"
|
||||||
% self.server)
|
% self.server)
|
||||||
|
|
||||||
|
def get_whoami(self):
|
||||||
|
"""Get information about the user account that authenticated to
|
||||||
|
Jenkins. This is a simple way to verify that your credentials are
|
||||||
|
correct.
|
||||||
|
|
||||||
|
:returns: Information about the current user ``dict``
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
>>> me = server.get_whoami()
|
||||||
|
>>> print me['fullName']
|
||||||
|
>>> 'John'
|
||||||
|
|
||||||
|
"""
|
||||||
|
try:
|
||||||
|
response = self.jenkins_open(Request(self._build_url(WHOAMI_URL)))
|
||||||
|
if response is None:
|
||||||
|
raise EmptyResponseException(
|
||||||
|
"Error communicating with server[%s]: "
|
||||||
|
"empty response" % self.server)
|
||||||
|
|
||||||
|
return json.loads(response)
|
||||||
|
|
||||||
|
except (HTTPError, BadStatusLine):
|
||||||
|
raise BadHTTPException("Error communicating with server[%s]"
|
||||||
|
% self.server)
|
||||||
|
|
||||||
def get_version(self):
|
def get_version(self):
|
||||||
"""Get the version of this Master.
|
"""Get the version of this Master.
|
||||||
|
|
||||||
|
50
tests/test_whoami.py
Normal file
50
tests/test_whoami.py
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
import json
|
||||||
|
from mock import patch
|
||||||
|
|
||||||
|
import jenkins
|
||||||
|
from tests.base import JenkinsTestBase
|
||||||
|
|
||||||
|
|
||||||
|
class JenkinsWhoamiTest(JenkinsTestBase):
|
||||||
|
|
||||||
|
@patch.object(jenkins.Jenkins, 'jenkins_open')
|
||||||
|
def test_simple(self, jenkins_mock):
|
||||||
|
user_to_return = \
|
||||||
|
{u'absoluteUrl': u'https://example.com/jenkins/user/jsmith',
|
||||||
|
u'description': None,
|
||||||
|
u'fullName': u'John Smith',
|
||||||
|
u'id': u'jsmith',
|
||||||
|
u'property': [{},
|
||||||
|
{},
|
||||||
|
{},
|
||||||
|
{u'address': u'jsmith@example.com'},
|
||||||
|
{},
|
||||||
|
{},
|
||||||
|
{u'insensitiveSearch': False},
|
||||||
|
{}]}
|
||||||
|
|
||||||
|
jenkins_mock.return_value = json.dumps(user_to_return)
|
||||||
|
|
||||||
|
user = self.j.get_whoami()
|
||||||
|
|
||||||
|
self.assertEqual(user, user_to_return)
|
||||||
|
self.assertEqual(
|
||||||
|
jenkins_mock.call_args[0][0].get_full_url(),
|
||||||
|
self.make_url('me/api/json'))
|
||||||
|
self._check_requests(jenkins_mock.call_args_list)
|
||||||
|
|
||||||
|
@patch.object(jenkins.Jenkins, 'jenkins_open')
|
||||||
|
def test_raise_HTTPError(self, jenkins_mock):
|
||||||
|
jenkins_mock.side_effect = jenkins.HTTPError(
|
||||||
|
self.make_url('me/api/json'),
|
||||||
|
code=401,
|
||||||
|
msg='basic auth failed',
|
||||||
|
hdrs=[],
|
||||||
|
fp=None)
|
||||||
|
|
||||||
|
with self.assertRaises(jenkins.JenkinsException):
|
||||||
|
self.j.get_whoami()
|
||||||
|
self.assertEqual(
|
||||||
|
jenkins_mock.call_args[0][0].get_full_url(),
|
||||||
|
self.make_url('me/api/json'))
|
||||||
|
self._check_requests(jenkins_mock.call_args_list)
|
Loading…
Reference in New Issue
Block a user