写点什么

软件测试学习笔记丨 JenkinsAPI 接口

作者:测试人
  • 2024-05-20
    北京
  • 本文字数:2561 字

    阅读完需:约 8 分钟

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/29270

Jenkins Api 简介

  • Jenkins 对外暴露的动作交付入口

  • 为外部程序提供入口,可以控制 Jenkins

  • 支持协议 - Http

  • Api 接口支持用户名、密码认证

  • Jenkins Api 支持的典型功能:运行 Job、查看任务状态、返回任务编号…等

Jenkins Api 环境准备

使用 curl 调用 获取所有 Jobs 接口

  • 创建一个有任务运行和查询权限的用户

  • 较老版本的 Jenkins 操作关闭跨站脚本伪造请求保护,新版本的 Jenkins 无此选项了

curl -u USERNAME:PASSWORD "JENKINSURL:PORT/api/json?pretty=true"
# 可以加上&tree=jobs[name,url]进行显示内容的展示
复制代码

使用 curl 调用 获取所有构建队列

curl -u USERNAME:PASSWORD JENKINSURL:PORT/queue/api/json?pretty=

使用 curl 调用 获取 Job 信息

# 获取任务所有信息curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/api/json?pretty=true# 获取最后一次构建信息curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/lastBuild/api/json?pretty=true# 获取最后稳定构建信息curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/lastStableBuild/api/json?pretty=true# 获取最后成功的构建curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/lastSuccessfulBuild/api/json?pretty=true# 获取最后完成的构建curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/lastCompletedBuild/api/json?pretty=true# 最近失败的构建curl -u USERNAME:PASSWORD JENKINSURL:PORT/job/JOBNAME/lastFailedBuild/api/json?pretty=true
复制代码

使用 curl 调用 操作 Job

  • 操作 Job 需要验证 crumb 获取 crumb 使用使用 token 发起接口

方式 1:获取 crumb

username_password=“USERNAME:PASSWORD”jenkins_url=“JENKINSURL:PORT”cookie_file=“$(mktemp)”jenkins_crumb=$(curl -s -f -u “${username_password}” --cookie-jar “${cookie_file}” -s “${jenkins_url}/crumbIssuer/api/xml?xpath=concat(//crumbRequestField,%22:%22,//crumb)”)
复制代码

方式 2:使用 token

使用 curl 调用 操作 Job

# 获取job的configcurl -u USERNAME:PASSWORD -O JENKINSURL:PORT/job/JOBNAME/config.xml# 创建jobcurl -u USERNAME:PASSWORD "JENKINSURL:PORT/createItem?name=JOBNAME" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}" -H 'Content-Type:text/xml' --data-binary "@./config.xml"# 复制jobcurl -u USERNAME:PASSWORD "JENKINSURL:PORT/createItem?name=NEWJOBNAME&mode=copy&from=JOBNAME" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}"# 修改jobcurl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/config.xml" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}" -H 'Content-Type:text/xml' --data-binary "@./config.xml"# 无参构建curl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/build" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}" # 有参构建curl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/buildWithParameters" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}" --data-urlencode json='{"key1":"value1","key2":"value2"}'# 删除jobcurl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/doDelete" --cookie "${cookie_file}" -X POST -H "${jenkins_crumb}"
复制代码

使用 curl 调用 操作指定构建的 Job

# 查看最新构建任务编号curl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/son_demo/lastBuild/buildNumber"# 查看某次构建控制台日志curl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/ID/logText/progressiveText"# 删除某次构建curl -u USERNAME:PASSWORD "JENKINSURL:PORT/job/JOBNAME/ID/doDelete" -X POST --cookie "${cookie_file}" -H "${jenkins_crumb}"
复制代码

Python Jenkins Api 常用接口操作

  • 安装 pip install jenkinsapi

jenkinsapi 连接 Jenkins 服务

from jenkinsapi import jenkins

my_jenkins = jenkins.Jenkins(“JENKINSURL”, “USERNAME”, “PASSWORD”, useCrumb=True)

jenkinsapi 获取所有 jobs

需要注意,如果请求的 url 与 Jenkins Location 配置的 Jenkins URL 不一致时,获取到的 key 会拼接上一截地址

print(my_jenkins.keys()) # 获取所有的job名称for info in my_jenkins.get_jobs_info():print(info) # 获取job的url与名称 比较卡
复制代码

jenkinsapi 获取构建队列

print(my_jenkins.get_queue().keys())

jenkinsapi 获取 Job 信息

# 获取job对象my_job = my_jenkins.get_job("JOBSNAME")# 获取最后一次构建对象print(my_job.get_last_build())# 获取最后一次完成的构建对象print(my_job.get_last_completed_build())# 获取最后一次成功的构建对象print(my_job.get_last_good_build())# 获取最后一次失败的构建编号print(my_job.get_last_failed_buildnumber())
复制代码

jenkinsapi 操作 Job 信息

# 获取job的configprint(my_job.get_config())# 创建job# 先获取到job的configwith open("config.xml", "w", encoding="utf-8") as f:    my = my_jenkins.get_job("JOBNAME").get_config()    f.write(my)my_jenkins.create_job("NEWJOBNAME", open("./config.xml",encoding="utf-8").read())# 复制jobmy_jenkins.copy_job("JOBNAME", "NEWJOBNAME")# 禁用jobmy_job.disable()# 启用jobmy_job.enable()# 重命名jobmy_jenkins.rename_job("JOBNAME", "NEWJOBNAME")# 无参构建my_jenkins.build_job("JOBNAME")# 有参构建my_jenkins.build_job("JOBNAME", params={"key": "value"})# 删除jobmy_jenkins.delete_job("JOBNAME")
复制代码

jenkinsapi 操作指定构建的 Job

# 当前job对象是否在队列/构建中print(my_job.is_queued_or_running())# 获取指定构建ID的对象build_object = my_job.get_build(BUILDID)# 获取构建对象的时间戳print(build_object.get_timestamp())# 获取控制台日志print(build_object.get_console())# 获取构建参数print(build_object.get_params())# 获取构建的状态print(build_object.get_status())# 获取构建的变更日志print(build_object.get_changeset_items())# 删除指定构建my_job.delete_build(BUILDID)
复制代码

软件测试开发免费视频教程分享



发布于: 刚刚阅读数: 4
用户头像

测试人

关注

专注于软件测试开发 2022-08-29 加入

霍格沃兹测试开发学社,测试人社区:https://ceshiren.com/t/topic/22284

评论

发布
暂无评论
软件测试学习笔记丨JenkinsAPI接口_软件测试_测试人_InfoQ写作社区