背景
每次到网页里手动发版有点烦,写个脚本来提高开发效率。
CFG
在 jenkins 设置里获取 API TOKEN
。
const token = { user: '', password: '',}const host = 'jenkins.xxx.cn';const basicUrl = `http://${token.user}:${token.password}@${host}`;
BUILD
调用 jenkins 提供的 jenkins.job.build()
方法发版。
// crumbIssuer 默认false, true 启用CSRF保护支持const jenkins = require('jenkins')({ baseUrl, crumbIssuer: true });const job_name = ''; // 想要发版的job的名字jenkins.job.build( { name: job_name, parameters: { name: 'value', // 填写一些参数信息 } }, function(err, data) { if (err) throw err; console.log('queue item number', data);});
查看发版状态
执行 build 之后我们想要查看当前 build 的状态,只成功、失败还是进行中。
jenkins.job.get()
获取当前 job 的信息。data.lastBuild.number
可以拿到最后一个 build 的 number,最后一个 build 也就是我们刚刚触发的 build。
jenkins.build.get()
获取当前 build 的信息。data.result
获取当前 build 的结果 jenkins.job.get(job_name, (err, data) => { if (err) throw err; const lastBuildNumber = data.lastBuild.number; console.log('last build number', lastBuildNumber); jenkins.build.get(job_name, lastBuildNumber, (err, data) => { if (err) throw err; console.log('last build result', data.result); })});
资料
博客首发地址:https://www.jianshu.com/u/13cd86311525