golang通過接口操作jenkins(github.com/jenkins-x/[email protected]

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))
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章