aboutsummaryrefslogtreecommitdiffstats
path: root/internal/build
diff options
context:
space:
mode:
Diffstat (limited to 'internal/build')
-rw-r--r--internal/build/env.go52
-rw-r--r--internal/build/util.go13
2 files changed, 47 insertions, 18 deletions
diff --git a/internal/build/env.go b/internal/build/env.go
index b553e0ed8..b7aa0f122 100644
--- a/internal/build/env.go
+++ b/internal/build/env.go
@@ -20,7 +20,9 @@ import (
"flag"
"fmt"
"os"
+ "strconv"
"strings"
+ "time"
)
var (
@@ -35,17 +37,17 @@ var (
// Environment contains metadata provided by the build environment.
type Environment struct {
- Name string // name of the environment
- Repo string // name of GitHub repo
- Commit, Branch, Tag string // Git info
- Buildnum string
- IsPullRequest bool
- IsCronJob bool
+ 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
}
func (env Environment) String() string {
- return fmt.Sprintf("%s env (commit:%s branch:%s tag:%s buildnum:%s pr:%t)",
- env.Name, env.Commit, env.Branch, env.Tag, env.Buildnum, env.IsPullRequest)
+ return fmt.Sprintf("%s env (commit:%s date:%s branch:%s tag:%s buildnum:%s pr:%t)",
+ env.Name, env.Commit, env.Date, env.Branch, env.Tag, env.Buildnum, env.IsPullRequest)
}
// Env returns metadata about the current CI environment, falling back to LocalEnv
@@ -53,10 +55,15 @@ func (env Environment) String() string {
func Env() Environment {
switch {
case os.Getenv("CI") == "true" && os.Getenv("TRAVIS") == "true":
+ commit := os.Getenv("TRAVIS_PULL_REQUEST_SHA")
+ if commit == "" {
+ os.Getenv("TRAVIS_COMMIT")
+ }
return Environment{
Name: "travis",
Repo: os.Getenv("TRAVIS_REPO_SLUG"),
- Commit: os.Getenv("TRAVIS_COMMIT"),
+ Commit: commit,
+ Date: getDate(commit),
Branch: os.Getenv("TRAVIS_BRANCH"),
Tag: os.Getenv("TRAVIS_TAG"),
Buildnum: os.Getenv("TRAVIS_BUILD_NUMBER"),
@@ -64,10 +71,15 @@ func Env() Environment {
IsCronJob: os.Getenv("TRAVIS_EVENT_TYPE") == "cron",
}
case os.Getenv("CI") == "True" && os.Getenv("APPVEYOR") == "True":
+ commit := os.Getenv("APPVEYOR_PULL_REQUEST_HEAD_COMMIT")
+ if commit == "" {
+ os.Getenv("APPVEYOR_REPO_COMMIT")
+ }
return Environment{
Name: "appveyor",
Repo: os.Getenv("APPVEYOR_REPO_NAME"),
- Commit: os.Getenv("APPVEYOR_REPO_COMMIT"),
+ Commit: commit,
+ Date: getDate(commit),
Branch: os.Getenv("APPVEYOR_REPO_BRANCH"),
Tag: os.Getenv("APPVEYOR_REPO_TAG_NAME"),
Buildnum: os.Getenv("APPVEYOR_BUILD_NUMBER"),
@@ -84,14 +96,15 @@ func LocalEnv() Environment {
env := applyEnvFlags(Environment{Name: "local", Repo: "ethereum/go-ethereum"})
head := readGitFile("HEAD")
- if splits := strings.Split(head, " "); len(splits) == 2 {
- head = splits[1]
+ if fields := strings.Fields(head); len(fields) == 2 {
+ head = fields[1]
} else {
return env
}
if env.Commit == "" {
env.Commit = readGitFile(head)
}
+ env.Date = getDate(env.Commit)
if env.Branch == "" {
if head != "HEAD" {
env.Branch = strings.TrimPrefix(head, "refs/heads/")
@@ -107,6 +120,21 @@ func firstLine(s string) string {
return strings.Split(s, "\n")[0]
}
+func getDate(commit string) string {
+ if commit == "" {
+ return ""
+ }
+ out := RunGit("show", "-s", "--format=%ct", commit)
+ if out == "" {
+ return ""
+ }
+ date, err := strconv.ParseInt(strings.TrimSpace(out), 10, 64)
+ if err != nil {
+ panic(fmt.Sprintf("failed to parse git commit date: %v", err))
+ }
+ return time.Unix(date, 0).Format("20060102")
+}
+
func applyEnvFlags(env Environment) Environment {
if !flag.Parsed() {
panic("you need to call flag.Parse before Env or LocalEnv")
diff --git a/internal/build/util.go b/internal/build/util.go
index 319c0f2d3..971d948c4 100644
--- a/internal/build/util.go
+++ b/internal/build/util.go
@@ -68,13 +68,14 @@ func RunGit(args ...string) string {
cmd := exec.Command("git", args...)
var stdout, stderr bytes.Buffer
cmd.Stdout, cmd.Stderr = &stdout, &stderr
- if err := cmd.Run(); err == exec.ErrNotFound {
- if !warnedAboutGit {
- log.Println("Warning: can't find 'git' in PATH")
- warnedAboutGit = true
+ if err := cmd.Run(); err != nil {
+ if e, ok := err.(*exec.Error); ok && e.Err == exec.ErrNotFound {
+ if !warnedAboutGit {
+ log.Println("Warning: can't find 'git' in PATH")
+ warnedAboutGit = true
+ }
+ return ""
}
- return ""
- } else if err != nil {
log.Fatal(strings.Join(cmd.Args, " "), ": ", err, "\n", stderr.String())
}
return strings.TrimSpace(stdout.String())