golang通过接口操作jenkins(github.com/jenkins-x/golang-jenkins@v0.0.0-20180919102630-65b83ad42314)

package main

import (
	"fmt"
	"time"
	"errors"
	"strings"
	"net/url"
	"github.com/jenkins-x/golang-jenkins"
)

func main() {
	auth := &gojenkins.Auth{
	    Username: "user_id",
	    ApiToken: "api_token",
	}

	jenkins := gojenkins.NewJenkins(auth, "https://domain.name")
	job, err := jenkins.GetJob("job_name")
	if err != nil {
		panic(err)
	}
	//fmt.Println("job:", job)

	build, err := jenkins.GetLastBuild(job)
	if err != nil {
		panic(err)
	}

	var output []byte
	output, err = jenkins.GetBuildConsoleOutput(build)
	if err != nil {
		panic(err)
	}
	if !strings.Contains(string(output), "Finished:") {
		panic(fmt.Errorf("当前job正在运行,build.Number=%d", build.Number))
	}

	params := make(url.Values)
	params.Add("git_branch", "20191010")
	params.Add("hostlist", "127.0.0.1")
	params.Add("status", "deploy")
	err = jenkins.Build(job, params)
	if err != nil {
		panic(err)
	}

	build, err = jenkins.GetLastBuild(job)
	if err != nil {
		panic(err)
	}
	//fmt.Println("build:", build)

	for i:=0; i<60; i++ {
		output, err = jenkins.GetBuildConsoleOutput(build)
		if err != nil {
			panic(err)
		}
		if strings.Contains(string(output), "Finished:") {
			break
		}
		time.Sleep(time.Second)
	}
	if strings.Contains(string(output), "Finished: FAILURE") {
		outputs := strings.Split(string(output), "\n")
		panic(errors.New("build fail:"+strings.Join(outputs[len(outputs)-5:len(outputs)-2], "\n")))
	}
	fmt.Println("build ok:", string(output))
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值