Documentation ¶
Overview ¶
Package jenkins includes a client and the operational logic for managing Jenkins masters in prow. It has been used with the following versions of Jenkins:
* 2.60.3 * 2.73.2
It should most likely work for all versions but use at your own risk with a different version.
Index ¶
- type Action
- type AuthConfig
- type BasicAuthConfig
- type BearerTokenAuthConfig
- type Build
- type BuildQueryParams
- type Client
- func (c *Client) Abort(job string, build *Build) error
- func (c *Client) Build(pj *prowapi.ProwJob, buildID string) error
- func (c *Client) BuildFromSpec(spec *prowapi.ProwJobSpec, buildID, prowJobID string) error
- func (c *Client) CrumbRequest() error
- func (c *Client) EnsureBuildableJob(spec *prowapi.ProwJobSpec) error
- func (c *Client) Get(path string) ([]byte, error)
- func (c *Client) GetBuilds(job string) (map[string]Build, error)
- func (c *Client) GetEnqueuedBuilds(jobs []BuildQueryParams) (map[string]Build, error)
- func (c *Client) GetJobInfo(spec *prowapi.ProwJobSpec) (*JobInfo, error)
- func (c *Client) GetSkipMetrics(path string) ([]byte, error)
- func (c *Client) JobParameterized(jobInfo *JobInfo) bool
- func (c *Client) LaunchBuild(spec *prowapi.ProwJobSpec, params url.Values) error
- func (c *Client) ListBuilds(jobs []BuildQueryParams) (map[string]Build, error)
- type ClientMetrics
- type Controller
- type JobInfo
- type JobProperty
- type Metrics
- type NotFoundError
- type Parameter
- type ParameterDefinition
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Action ¶
type Action struct {
Parameters []Parameter `json:"parameters"`
}
Action holds a list of parameters
type AuthConfig ¶
type AuthConfig struct { // Basic is used for doing basic auth with Jenkins. Basic *BasicAuthConfig // BearerToken is used for doing oauth-based authentication // with Jenkins. Works ootb with the Openshift Jenkins image. BearerToken *BearerTokenAuthConfig // CSRFProtect ensures the client will acquire a CSRF protection // token from Jenkins to use it in mutating requests. Required // for masters that prevent cross site request forgery exploits. CSRFProtect bool // contains filtered or unexported fields }
AuthConfig configures how we auth with Jenkins. Only one of the fields will be non-nil.
type BasicAuthConfig ¶
BasicAuthConfig authenticates with jenkins using user/pass.
type BearerTokenAuthConfig ¶
type BearerTokenAuthConfig struct {
GetToken func() []byte
}
BearerTokenAuthConfig authenticates jenkins using an oauth bearer token.
type Build ¶
type Build struct { Actions []Action `json:"actions"` Task struct { // Used for tracking unscheduled builds for jobs. Name string `json:"name"` } `json:"task"` Number int `json:"number"` Result *string `json:"result"` // contains filtered or unexported fields }
Build holds information about an instance of a jenkins job.
func (*Build) BuildID ¶
BuildID extracts the build identifier used for placing and discovering build artifacts. This identifier can either originate from tot or the snowflake library, depending on how the Jenkins operator is configured to run. We return an empty string if we are dealing with a build that does not have the ProwJobID set explicitly, as in that case the Jenkins build has not started by prow.
func (*Build) IsEnqueued ¶
IsEnqueued means the job has created but has not started.
type BuildQueryParams ¶
BuildQueryParams is used to query Jenkins for running and enqueued builds
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client can interact with jenkins to create/manage builds.
func NewClient ¶
func NewClient( url string, dryRun bool, tlsConfig *tls.Config, authConfig *AuthConfig, logger *logrus.Entry, metrics *ClientMetrics, ) (*Client, error)
NewClient instantiates a client with provided values.
url: the jenkins master to connect to. dryRun: mutating calls such as starting/aborting a build will be skipped. tlsConfig: configures client transport if set, may be nil. authConfig: configures the client to connect to Jenkins via basic auth/bearer token
and optionally enables csrf protection
logger: creates a standard logger if nil. metrics: gathers prometheus metrics for the Jenkins client if set.
func (*Client) Build ¶
Build triggers a Jenkins build for the provided ProwJob. The name of the ProwJob is going to be used as the Prow Job ID parameter that will help us track the build before it's scheduled by Jenkins.
func (*Client) BuildFromSpec ¶
func (c *Client) BuildFromSpec(spec *prowapi.ProwJobSpec, buildID, prowJobID string) error
BuildFromSpec triggers a Jenkins build for the provided ProwJobSpec. prowJobID helps us track the build before it's scheduled by Jenkins.
func (*Client) CrumbRequest ¶
CrumbRequest requests a CSRF protection token from Jenkins to use it in subsequent requests. Required for Jenkins masters that prevent cross site request forgery exploits.
func (*Client) EnsureBuildableJob ¶
func (c *Client) EnsureBuildableJob(spec *prowapi.ProwJobSpec) error
EnsureBuildableJob attempts to detect a job that hasn't yet ran and populated its parameters. If detected, it tries to run a build until the job parameters are processed, then it aborts the build.
func (*Client) Get ¶
Get fetches the data found in the provided path. It returns the content of the response or any errors that occurred during the request or http errors.
func (*Client) GetBuilds ¶
GetBuilds lists all scheduled builds for the provided job. In newer Jenkins versions, this also includes enqueued builds (tested in 2.73.2).
func (*Client) GetEnqueuedBuilds ¶
func (c *Client) GetEnqueuedBuilds(jobs []BuildQueryParams) (map[string]Build, error)
GetEnqueuedBuilds lists all enqueued builds for the provided jobs.
func (*Client) GetJobInfo ¶
func (c *Client) GetJobInfo(spec *prowapi.ProwJobSpec) (*JobInfo, error)
GetJobInfo retrieves Jenkins job information
func (*Client) GetSkipMetrics ¶
GetSkipMetrics fetches the data found in the provided path. It returns the content of the response or any errors that occurred during the request or http errors. Metrics will not be gathered for this request.
func (*Client) JobParameterized ¶
JobParameterized tells us if the Jenkins job for this ProwJob is parameterized
func (*Client) LaunchBuild ¶
LaunchBuild launches a regular or parameterized Jenkins build, depending on whether or not we have `params` to POST
func (*Client) ListBuilds ¶
func (c *Client) ListBuilds(jobs []BuildQueryParams) (map[string]Build, error)
ListBuilds returns a list of all Jenkins builds for the provided jobs (both scheduled and enqueued).
type ClientMetrics ¶
type ClientMetrics struct { Requests *prometheus.CounterVec RequestRetries prometheus.Counter RequestLatency *prometheus.HistogramVec }
ClientMetrics is a set of metrics gathered by the Jenkins client.
type Controller ¶
type Controller struct {
// contains filtered or unexported fields
}
Controller manages ProwJobs.
func NewController ¶
func NewController(prowJobClient prowv1.ProwJobInterface, jc *Client, ghc github.Client, logger *logrus.Entry, cfg config.Getter, totURL, selector string, skipReport bool) (*Controller, error)
NewController creates a new Controller from the provided clients.
func (*Controller) SyncMetrics ¶
func (c *Controller) SyncMetrics()
SyncMetrics records metrics for the cached prowjobs.
type JobInfo ¶
type JobInfo struct { Builds []Build `json:"builds"` LastBuild *Build `json:"lastBuild,omitempty"` Property []JobProperty `json:"property"` }
JobInfo holds infofmation about a job from $job/api/json endpoint
type JobProperty ¶
type JobProperty struct { Class string `json:"_class"` ParameterDefinitions []ParameterDefinition `json:"parameterDefinitions,omitempty"` }
JobProperty is a generic Jenkins job property, but ParameterDefinitions is specific to Build Parameters
type Metrics ¶
type Metrics struct { ClientMetrics *ClientMetrics ResyncPeriod prometheus.Histogram }
Metrics is a set of metrics gathered by the Jenkins operator. It includes client metrics and metrics related to the controller loop.
func NewMetrics ¶
func NewMetrics() *Metrics
NewMetrics creates a new set of metrics for the Jenkins operator.
type NotFoundError ¶
type NotFoundError struct {
// contains filtered or unexported fields
}
NotFoundError is returned by the Jenkins client when a job does not exist in Jenkins.
func NewNotFoundError ¶
func NewNotFoundError(e error) NotFoundError
NewNotFoundError creates a new NotFoundError.
func (NotFoundError) Error ¶
func (e NotFoundError) Error() string