Merge "new method: create_folder (with tests)"

This commit is contained in:
Zuul 2019-12-16 14:08:18 +00:00 committed by Gerrit Code Review
commit 36c99d3436
2 changed files with 54 additions and 0 deletions

View File

@ -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

View File

@ -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)