This section is empty.


View Source
var (
	// These flags override values in build env.
	GitCommitFlag   = flag.String("git-commit", "", `Overrides git commit hash embedded into executables`)
	GitBranchFlag   = flag.String("git-branch", "", `Overrides git branch being built`)
	GitTagFlag      = flag.String("git-tag", "", `Overrides git tag being built`)
	BuildnumFlag    = flag.String("buildnum", "", `Overrides CI build number`)
	PullRequestFlag = flag.Bool("pull-request", false, `Overrides pull request status of the build`)
	CronJobFlag     = flag.Bool("cron-job", false, `Overrides cron job status of the build`)
View Source
var DryRunFlag = flag.Bool("n", false, "dry run, don't execute commands")


func AddFile

func AddFile(a Archive, file string) error

    AddFile appends an existing file to an archive.

    func AzureBlobstoreDelete

    func AzureBlobstoreDelete(config AzureBlobstoreConfig, blobs []azblob.BlobItem) error

      AzureBlobstoreDelete iterates over a list of files to delete and removes them from the blobstore.

      func AzureBlobstoreList

      func AzureBlobstoreList(config AzureBlobstoreConfig) ([]azblob.BlobItem, error)

        AzureBlobstoreList lists all the files contained within an azure blobstore.

        func AzureBlobstoreUpload

        func AzureBlobstoreUpload(path string, name string, config AzureBlobstoreConfig) error

          AzureBlobstoreUpload uploads a local file to the Azure Blob Storage. Note, this method assumes a max file size of 64MB (Azure limitation). Larger files will need a multi API call approach implemented.


          func ExtractArchive

          func ExtractArchive(archive string, dest string) error

            ExtractArchive unpacks a .zip or .tar.gz archive to the destination directory.

            func FindMainPackages

            func FindMainPackages(dir string) []string

              FindMainPackages finds all 'main' packages in the given directory and returns their package paths.

              func GoTool

              func GoTool(tool string, args ...string) *exec.Cmd

                GoTool returns the command that runs a go tool. This uses go from GOROOT instead of PATH so that go commands executed by build use the same version of Go as the 'host' that runs build code. e.g.

                /usr/lib/go-1.12.1/bin/go run build/ci.go ...

                runs using go 1.12.1 and invokes go 1.12.1 tools from the same GOROOT. This is also important because runtime.Version checks on the host should match the tools that are run.

                func MustRun

                func MustRun(cmd *exec.Cmd)

                  MustRun executes the given command and exits the host process for any error.

                  func MustRunCommand

                  func MustRunCommand(cmd string, args ...string)

                  func PGPKeyID

                  func PGPKeyID(pgpkey string) (string, error)

                    PGPKeyID parses an armored key and returns the key ID.

                    func PGPSignFile

                    func PGPSignFile(input string, output string, pgpkey string) error

                      PGPSignFile parses a PGP private key from the specified string and creates a signature file into the output parameter of the input file.

                      Note, this method assumes a single key will be container in the pgpkey arg, furthermore that it is in armored format.

                      func Render

                      func Render(templateFile, outputFile string, outputPerm os.FileMode, x interface{})

                        Render renders the given template file into outputFile.

                        func RenderString

                        func RenderString(templateContent, outputFile string, outputPerm os.FileMode, x interface{})

                          RenderString renders the given template string into outputFile.

                          func RunGit

                          func RunGit(args ...string) string

                            RunGit runs a git subcommand and returns its output. The command must complete successfully.

                            func UploadSFTP

                            func UploadSFTP(identityFile, host, dir string, files []string) error

                              UploadSFTP uploads files to a remote host using the sftp command line tool. The destination host may be specified either as [user@]host[: or as a URI in the form sftp://[user@]host[:port].

                              func WriteArchive

                              func WriteArchive(name string, files []string) (err error)

                                WriteArchive creates an archive containing the given files.


                                type Archive

                                type Archive interface {
                                	// Directory adds a new directory entry to the archive and sets the
                                	// directory for subsequent calls to Header.
                                	Directory(name string) error
                                	// Header adds a new file to the archive. The file is added to the directory
                                	// set by Directory. The content of the file must be written to the returned
                                	// writer.
                                	Header(os.FileInfo) (io.Writer, error)
                                	// Close flushes the archive and closes the underlying file.
                                	Close() error

                                func NewArchive

                                func NewArchive(file *os.File) (Archive, string)

                                func NewTarballArchive

                                func NewTarballArchive(w io.WriteCloser) Archive

                                func NewZipArchive

                                func NewZipArchive(w io.WriteCloser) Archive

                                type AzureBlobstoreConfig

                                type AzureBlobstoreConfig struct {
                                	Account   string // Account name to authorize API requests with
                                	Token     string // Access token for the above account
                                	Container string // Blob container to upload files into

                                  AzureBlobstoreConfig is an authentication and configuration struct containing the data needed by the Azure SDK to interact with a specific container in the blobstore.

                                  type ChecksumDB

                                  type ChecksumDB struct {
                                  	// contains filtered or unexported fields

                                    ChecksumDB keeps file checksums.

                                    func MustLoadChecksums

                                    func MustLoadChecksums(file string) *ChecksumDB

                                      MustLoadChecksums loads a file containing checksums.

                                      func (*ChecksumDB) DownloadFile

                                      func (db *ChecksumDB) DownloadFile(url, dstPath string) error

                                        DownloadFile downloads a file and verifies its checksum.

                                        func (*ChecksumDB) Verify

                                        func (db *ChecksumDB) Verify(path string) error

                                          Verify checks whether the given file is valid according to the checksum database.

                                          type Environment

                                          type Environment struct {
                                          	Name                      string // name of the environment
                                          	Repo                      string // name of GitHub repo
                                          	Commit, Date, Branch, Tag string // Git info
                                          	Buildnum                  string
                                          	IsPullRequest             bool
                                          	IsCronJob                 bool

                                            Environment contains metadata provided by the build environment.

                                            func Env

                                            func Env() Environment

                                              Env returns metadata about the current CI environment, falling back to LocalEnv if not running on CI.

                                              func LocalEnv

                                              func LocalEnv() Environment

                                                LocalEnv returns build environment metadata gathered from git.

                                                func (Environment) String

                                                func (env Environment) String() string

                                                type TarballArchive

                                                type TarballArchive struct {
                                                	// contains filtered or unexported fields

                                                func (*TarballArchive) Close

                                                func (a *TarballArchive) Close() error

                                                func (*TarballArchive) Directory

                                                func (a *TarballArchive) Directory(name string) error

                                                func (*TarballArchive) Header

                                                func (a *TarballArchive) Header(fi os.FileInfo) (io.Writer, error)

                                                type ZipArchive

                                                type ZipArchive struct {
                                                	// contains filtered or unexported fields

                                                func (*ZipArchive) Close

                                                func (a *ZipArchive) Close() error

                                                func (*ZipArchive) Directory

                                                func (a *ZipArchive) Directory(name string) error

                                                func (*ZipArchive) Header

                                                func (a *ZipArchive) Header(fi os.FileInfo) (io.Writer, error)