使用节点js触发Jenkins构建

时间:2018-02-12 12:47:59

标签: javascript node.js file jenkins build

我有一个jenkins工作,它将文件作为输入。作业读取输入文件,然后处理作业。

我正在尝试从节点js脚本运行jenkins作业。我可以使用jenkins api为npm运行特定的工作。

我的问题是我无法通过传递所需的文件来运行作业。

在Jenkins中,我必须找到特定的工作,然后迁移到它,然后单击“使用参数构建”,然后选择文件和构建。

我试图通过让一个反应UI将文件作为输入并将其提交给节点js脚本来解决这个问题。现在该脚本必须将文件上传到Jenkins,然后构建作业。

节点js代码是,

var file0 = '/Users/m0a00pf/Documents/react-js/asda/src/files/APA.csv';
exports.buildJenkinsJob = function buildJenkinsJob(){
    jenkins.job.build({"name":"Create a job",
                    "parameters":
                        {
                             "name": "\\src\\main\\resources\\com\\asda\\qa\\data\\APA\\APA.csv", "file": file0
                        }
                    }
                    ,function(err, data){
        if(err)
            throw err;
        else
            console.log(data);
    });
}

参数部分无效。我跑的时候。

jenkins.job.build({"Create a job"});

这很好。

2 个答案:

答案 0 :(得分:1)

将选项更改为,

    var options = {
      method: 'POST',
      url: 'http://localhost/job/JobName/buildWithParameters?delay=0sec&Jenkins-Crumb=asdf345672das',
      auth : {
           username : jenkins.username,
           password : jenkins.password
      },
      headers:
       {
        'content-type': 'multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW'
       },
      body:
       {
        'fileParameterName' :
                    { value: fs.createReadStream(absoluteFilePath), options: { filename: FileName, contentType: null } },
         'param': 'value'
       }

    };

答案 1 :(得分:0)

只有一种流行的库,例如Axios和form-data

,这是普通的JS方法。
var axios = require('axios');
var FormData = require('form-data');
var fs = require('fs');
var data = new FormData();

const jenkinsUrl = 'http://example_jenkins_server_url.com/job/<JOB_NAME>/build';
// notice the URL has build not buildWithParameters if the job has file parameters. ^
const userName = 'example_user';
const password = 'example_pass'

const params = {"parameter": [
  // file0 here is the field name we are appending to data object, 
  // this informs Jenkins which file maps to which job parameter, so even multiple file uploads can be done using this approach!
  {"name":"<Name Of file parameter in Job>", "file":"file0"}
  // incase you have additional string parameters you need to pass add it here. 
  {"name": "StringParam1", "value": "value"}
]}

data.append('file0', fs.createReadStream(<full file path>));
data.append('json', JSON.stringify(params));

var config = {
  method: 'post',
  url: jenkinsUrl,
  headers: { 
    Authorization: `Basic ${Buffer.from(`${userName}:${password}`).toString('base64')}`,
    ...data.getHeaders()
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})