Jenkins Python API和多配置项目

时间:2012-05-21 14:26:13

标签: python jenkins multi-configuration

我在Jenkins中设置了一个多配置项目,我正在尝试通过命令行脚本来管理这些作业。我正在尝试使用jenkinsapi Python模块。到目前为止,我已经找到了如何完成工作,但我无法弄清楚如何获取特定的构建配置以确定它们是否成功。

from jenkinsapi.jenkins import *
jenkins = Jenkins('http://example.org/jenkins')
job = jenkins.get_job('foobar')

# I can get job info here, but I don't know how to access specific configurations

有没有这样做?每个多配置项目中的每个项目都是一个单独的“工作”,还是它们都被归入同一个工作中?我将来必须管理很多这类项目,我希望能够轻松地为构建添加新的硬件配置。

3 个答案:

答案 0 :(得分:2)

我认为Python JenkinsAPI不适合使用Matrix作业。通过Groovy Plugin使用Groovy脚本进入Jenkins Java API

Matrix类位于hudson.matrix模块中。

答案 1 :(得分:1)

不太清楚你想要什么,给出一些提示。

如果您不清楚API中对象job可以提供哪些信息,可以使用以下方法检查

检查github中的源代码,对于您的情况为job.py,您也可以使用python dir()方法查看可以在{{1}中调用的内容}

job

直接检查配置,单击>>> from jenkinsapi.jenkins import * >>> jenkins = Jenkins('http://localhost') >>> job = jenkins.get_job('foobar') >>> dir(job) ['RETRY_ATTEMPTS', '__class__', '__delattr__', '__dict__', '__doc__', '__eq__', '__format__', '__getattribute__', '__get item__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__s izeof__', '__str__', '__subclasshook__', '__weakref__', '_buildid_for_type', '_config', '_data', '_element_tree', '_get_ config_element_tree', '_mk_json_from_build_parameters', '_poll', '_revmap', '_scm_map', '_scmbranchmap', '_scmurlmap', ' baseurl', 'delete_from_queue', 'disable', 'enable', 'get_build', 'get_build_dict', 'get_build_ids', 'get_build_triggerur l', 'get_buildnumber_for_revision', 'get_config', 'get_config_xml_url', 'get_data', 'get_delete_url', 'get_description', 'get_downstream_job_names', 'get_downstream_jobs', 'get_first_build', 'get_first_buildnumber', 'get_jenkins_obj', 'get_ last_build', 'get_last_build_or_none', 'get_last_buildnumber', 'get_last_completed_build', 'get_last_completed_buildnumb er', 'get_last_failed_buildnumber', 'get_last_good_build', 'get_last_good_buildnumber', 'get_next_build_number', 'get_pa rams', 'get_params_list', 'get_queue_item', 'get_rename_url', 'get_revision_dict', 'get_scm_branch', 'get_scm_type', 'ge t_scm_url', 'get_upstream_job_names', 'get_upstream_jobs', 'invoke', 'is_enabled', 'is_queued', 'is_queued_or_running', 'is_running', 'jenkins', 'load_config', 'mk_json_from_build_parameters', 'modify_scm_branch', 'modify_scm_url', 'name', 'poll', 'python_api_url', 'strip_trailing_slash', 'update_config'] >>> print job.get_last_build() foobar #5 作业底部的REST API,您可以直接获得作业配置,如http://example.org/jenkins/job/foobar/api/json?pretty=true

答案 2 :(得分:1)

我发现处理多重/矩阵配置的最简单方法是将其作为作业加载。配置的... / api / python数据与常规作业完全相同。因此,我们可以像对API进行一些更改一样访问它。

编辑以下内容: jenkinsbase.py中的 process_job_folder 函数

在job.py中获取全名_来自_URL_和_基本URL

要么编辑api代码,要么就覆盖函数。 (有点难看,但能起作用^ _ ^)

我还对名称的显示方式做了一些小的更改。这样的命名方式更符合:Jobs,“ sub”?作业和配置

例如:

职位名称/职位名称/配置

import urlparse
from jenkinsapi import job
from jenkinsapi import jenkins

def process_job_folder(self, folder, folder_path):
    folder_path += '/job/%s' % folder['name']
    data = self.get_data(self.python_api_url(folder_path),
                         tree='jobs[name,color]')
    result = []
    for job in data.get('jobs', []):
        if 'color' not in job.keys():
            result += self.process_job_folder(job, folder_path)
        else:
            job['url'] = '%s/job/%s' % (folder_path, job['name'])
            ## Added to prevent name conflicts
            job['name'] = folder['name'] + "/" + job['name']
            result.append(job)
            ## Added configuration support
            configData = self.get_data(self.python_api_url(job['url']),
                                       tree='activeConfigurations[name,color,url]')
            for config in configData.get("activeConfigurations", []):
                config['url'] = '%s/%s' % (job['url'], config["name"])
                config["name"] = job['name'] + "/" + config["name"]
                result.append(config)
            ## End of edit
    return result

@staticmethod
def get_full_name_from_url_and_baseurl(url, baseurl):
    """
    Get the full name for a job (including parent folders) from the
    job URL.
    """
    path = url.replace(baseurl, '')
    split = path.split('/')
    ## Ignore /job and empty strings
    split = [urlparse.unquote(part) for part in split[::] if not part in ["", "job"]]
    ## End of edit
    return '/'.join(split)

jenkins.JenkinsBase.process_job_folder = process_job_folder
job.Job.get_full_name_from_url_and_baseurl = get_full_name_from_url_and_baseurl

def get_server_instance():
    jenkins_url = SERVER_URL
    server = jenkins.Jenkins(jenkins_url,
                     username = USERNAME, password = PASSWORD_OR_API_KEY,
                     ssl_verify=False,
                     timeout=50)
    return server

s = get_server_instance()
for j in s.get_jobs():
    print j

*编辑:

现在您可以这样做:

s = get_server_instance()
myJobName = "foobar/platform=x64"
j = s.get_job(myJobName)

latestBuild = j.get_last_build()
print "Latest build number: ",latestBuild.get_number()
print "\tLatest build status: ",latestBuild.get_status()