Skip to content

Commit

Permalink
Merge pull request #952 from CircleCI-Public/pin-build-agent-version
Browse files Browse the repository at this point in the history
pin frozen version of build-agent cli
  • Loading branch information
JulesFaucherre authored Jun 15, 2023
2 parents 437b6c8 + 6490c18 commit b675973
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 68 deletions.
2 changes: 0 additions & 2 deletions cmd/build.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,6 @@ func newLocalExecuteCommand(config *settings.Config) *cobra.Command {
}

local.AddFlagsForDocumentation(buildCommand.Flags())
buildAgentVersionUsage := `The version of the build agent image you want to use. This can be configured by writing in $HOME/.circleci/build_agent_settings.json: '{"LatestSha256":"<version-of-build-agent>"}'`
buildCommand.Flags().String("build-agent-version", "", buildAgentVersionUsage)
buildCommand.Flags().StringP("org-slug", "o", "", "organization slug (for example: github/example-org), used when a config depends on private orbs belonging to that org")
buildCommand.Flags().String("org-id", "", "organization id, used when a config depends on private orbs belonging to that org")

Expand Down
74 changes: 8 additions & 66 deletions local/local.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
package local

import (
"encoding/json"
"fmt"
"io"
"os"
"os/exec"
"path"
"regexp"
"strings"
"syscall"
Expand Down Expand Up @@ -73,9 +71,7 @@ func Execute(flags *pflag.FlagSet, cfg *settings.Config, args []string) error {
return err
}

picardVersion, _ := flags.GetString("build-agent-version")
image, err := picardImage(os.Stdout, picardVersion)

image, err := picardImage(os.Stdout)
if err != nil {
return errors.Wrap(err, "Could not find picard image")
}
Expand Down Expand Up @@ -134,7 +130,7 @@ func buildAgentArguments(flags *pflag.FlagSet) ([]string, string) {

// build a list of all supplied flags, that we will pass on to build-agent
flags.Visit(func(flag *pflag.Flag) {
if flag.Name != "build-agent-version" && flag.Name != "org-slug" && flag.Name != "config" && flag.Name != "debug" && flag.Name != "org-id" && flag.Name != "docker-socket-path" {
if flag.Name != "org-slug" && flag.Name != "config" && flag.Name != "debug" && flag.Name != "org-id" && flag.Name != "docker-socket-path" {
result = append(result, unparseFlag(flags, flag)...)
}
})
Expand All @@ -145,11 +141,10 @@ func buildAgentArguments(flags *pflag.FlagSet) ([]string, string) {
return result, configPath
}

func picardImage(output io.Writer, picardVersion string) (string, error) {

func picardImage(output io.Writer) (string, error) {
fmt.Fprintf(output, "Fetching latest build environment...\n")

sha, err := getPicardSha(output, picardVersion)
sha, err := findLatestPicardSha()
if err != nil {
return "", err
}
Expand All @@ -158,31 +153,6 @@ func picardImage(output io.Writer, picardVersion string) (string, error) {
return fmt.Sprintf("%s@%s", picardRepo, sha), nil
}

func getPicardSha(output io.Writer, picardVersion string) (string, error) {
// If the version was passed as argument, we take it
if picardVersion != "" {
return picardVersion, nil
}

var sha string
var err error

sha, err = loadBuildAgentShaFromConfig()
if sha != "" && err == nil {
return sha, nil
}
if err != nil && !os.IsNotExist(err) {
fmt.Fprintf(output, "Unable to parse JSON file %s because: %s\n", buildAgentSettingsPath(), err)
fmt.Fprintf(output, "Falling back to latest build-agent version\n")
}

sha, err = findLatestPicardSha()
if err != nil {
return "", err
}
return sha, nil
}

func ensureDockerIsAvailable() (string, error) {

dockerPath, err := exec.LookPath("docker")
Expand All @@ -202,12 +172,14 @@ func ensureDockerIsAvailable() (string, error) {

// Still depends on a function in cmd/build.go
func findLatestPicardSha() (string, error) {

if _, err := ensureDockerIsAvailable(); err != nil {
return "", err
}

outputBytes, err := exec.Command("docker", "pull", picardRepo).CombinedOutput() // #nosec
// We are freezing build-agent cli as we would like to deprecate this path
// this is frozen to build-agent branch https://github.com/circleci/build-agent/tree/frozen-circleci-cli
imageName := fmt.Sprintf("%s:1.0.183556-5a2aabb6", picardRepo)
outputBytes, err := exec.Command("docker", "pull", imageName).CombinedOutput() // #nosec

if err != nil {
return "", errors.Wrap(err, "failed to pull latest docker image")
Expand All @@ -224,36 +196,6 @@ func findLatestPicardSha() (string, error) {
return latest, nil
}

type buildAgentSettings struct {
LatestSha256 string
}

func loadBuildAgentShaFromConfig() (string, error) {
if _, err := os.Stat(buildAgentSettingsPath()); os.IsNotExist(err) {
// Settings file does not exist.
return "", nil
}

file, err := os.Open(buildAgentSettingsPath())
if err != nil {
return "", errors.Wrap(err, "Could not open build settings config")
}
defer file.Close()

var settings buildAgentSettings

if err := json.NewDecoder(file).Decode(&settings); err != nil {

return "", errors.Wrap(err, "Could not parse build settings config")
}

return settings.LatestSha256, nil
}

func buildAgentSettingsPath() string {
return path.Join(settings.SettingsPath(), "build_agent_settings.json")
}

// Write data to a temp file, and return the path to that file.
func writeStringToTempFile(data string) (string, error) {
// It's important to specify `/tmp` here as the location of the temp file.
Expand Down

0 comments on commit b675973

Please sign in to comment.