Merge "new method: create_folder (with tests)"
This commit is contained in:
commit
36c99d3436
@ -1171,6 +1171,24 @@ class Jenkins(object):
|
|||||||
if not self.job_exists(name):
|
if not self.job_exists(name):
|
||||||
raise JenkinsException(exception_message % name)
|
raise JenkinsException(exception_message % name)
|
||||||
|
|
||||||
|
def create_folder(self, folder_name, ignore_failures=False):
|
||||||
|
'''Create a new Jenkins folder
|
||||||
|
|
||||||
|
:param folder_name: Name of Jenkins Folder, ``str``
|
||||||
|
:param ignore_failures: if True, don't raise if it was not possible to create the folder, ``bool``
|
||||||
|
'''
|
||||||
|
folder_url, short_name = self._get_job_folder(folder_name)
|
||||||
|
url = self._build_url(CREATE_JOB, locals())
|
||||||
|
data = {
|
||||||
|
"name": folder_name,
|
||||||
|
"mode": "com.cloudbees.hudson.plugins.folder.Folder"
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
response = self.jenkins_request(requests.Request('POST', url, data=data))
|
||||||
|
except requests.exceptions.HTTPError:
|
||||||
|
if not ignore_failures:
|
||||||
|
raise JenkinsException('Error creating folder [%s]. Probably it already exists.' % (folder_name))
|
||||||
|
|
||||||
def upsert_job(self, name, config_xml):
|
def upsert_job(self, name, config_xml):
|
||||||
'''Create a new Jenkins job or reconfigures it if it exists
|
'''Create a new Jenkins job or reconfigures it if it exists
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ from mock import patch
|
|||||||
|
|
||||||
import jenkins
|
import jenkins
|
||||||
from tests.base import JenkinsTestBase
|
from tests.base import JenkinsTestBase
|
||||||
|
from tests.helper import build_response_mock
|
||||||
|
|
||||||
|
|
||||||
class JenkinsGetJobFolderTest(JenkinsTestBase):
|
class JenkinsGetJobFolderTest(JenkinsTestBase):
|
||||||
@ -23,3 +24,38 @@ class JenkinsGetJobFolderTest(JenkinsTestBase):
|
|||||||
folder, name = self.j._get_job_folder('folder1/folder2/my job')
|
folder, name = self.j._get_job_folder('folder1/folder2/my job')
|
||||||
self.assertEqual(folder, 'job/folder1/job/folder2/')
|
self.assertEqual(folder, 'job/folder1/job/folder2/')
|
||||||
self.assertEqual(name, 'my job')
|
self.assertEqual(name, 'my job')
|
||||||
|
|
||||||
|
|
||||||
|
class JenkinsCreateFolderTest(JenkinsTestBase):
|
||||||
|
|
||||||
|
@patch('jenkins.requests.Session.send', autospec=True)
|
||||||
|
def test_create_new_folder(self, session_send_mock):
|
||||||
|
session_send_mock.side_effect = iter([
|
||||||
|
build_response_mock(200, self.crumb_data), # crumb
|
||||||
|
build_response_mock(200, None), # request
|
||||||
|
])
|
||||||
|
self.j.create_folder(u'New-Test-Folder')
|
||||||
|
|
||||||
|
@patch('jenkins.requests.Session.send', autospec=True)
|
||||||
|
def test_create_new_folder_that_already_exists(self, session_send_mock):
|
||||||
|
session_send_mock.side_effect = iter([
|
||||||
|
build_response_mock(200, self.crumb_data), # crumb
|
||||||
|
build_response_mock(400), # request
|
||||||
|
])
|
||||||
|
|
||||||
|
folder_name = u'Folder-that-already-exists'
|
||||||
|
|
||||||
|
with self.assertRaises(jenkins.JenkinsException) as context_manager:
|
||||||
|
self.j.create_folder(folder_name)
|
||||||
|
self.assertEqual(
|
||||||
|
str(context_manager.exception),
|
||||||
|
u'Error creating folder [' + folder_name + ']. Probably it already exists.')
|
||||||
|
|
||||||
|
@patch('jenkins.requests.Session.send', autospec=True)
|
||||||
|
def test_create_new_folder_that_already_exists_ignoring_errors(self, session_send_mock):
|
||||||
|
session_send_mock.side_effect = iter([
|
||||||
|
build_response_mock(200, self.crumb_data), # crumb
|
||||||
|
build_response_mock(400), # request
|
||||||
|
])
|
||||||
|
|
||||||
|
self.j.create_folder(u'Folder-that-already-exists', ignore_failures=True)
|
||||||
|
Loading…
Reference in New Issue
Block a user