mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-02-26 07:37:20 +00:00
.gitea/workflows, build: add release build for keeper (#32632)
This commit is contained in:
parent
53c85da796
commit
074d7b79c1
3 changed files with 118 additions and 4 deletions
|
|
@ -122,6 +122,27 @@ jobs:
|
||||||
LINUX_SIGNING_KEY: ${{ secrets.LINUX_SIGNING_KEY }}
|
LINUX_SIGNING_KEY: ${{ secrets.LINUX_SIGNING_KEY }}
|
||||||
AZURE_BLOBSTORE_TOKEN: ${{ secrets.AZURE_BLOBSTORE_TOKEN }}
|
AZURE_BLOBSTORE_TOKEN: ${{ secrets.AZURE_BLOBSTORE_TOKEN }}
|
||||||
|
|
||||||
|
keeper:
|
||||||
|
name: Keeper Build
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Set up Go
|
||||||
|
uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: 1.24
|
||||||
|
cache: false
|
||||||
|
|
||||||
|
- name: Install cross toolchain
|
||||||
|
run: |
|
||||||
|
apt-get update
|
||||||
|
apt-get -yq --no-install-suggests --no-install-recommends install gcc-multilib
|
||||||
|
|
||||||
|
- name: Build (amd64)
|
||||||
|
run: |
|
||||||
|
go run build/ci.go keeper -dlgo
|
||||||
|
|
||||||
windows:
|
windows:
|
||||||
name: Windows Build
|
name: Windows Build
|
||||||
runs-on: "win-11"
|
runs-on: "win-11"
|
||||||
|
|
|
||||||
1
.gitignore
vendored
1
.gitignore
vendored
|
|
@ -56,3 +56,4 @@ cmd/evm/evm
|
||||||
cmd/geth/geth
|
cmd/geth/geth
|
||||||
cmd/rlpdump/rlpdump
|
cmd/rlpdump/rlpdump
|
||||||
cmd/workload/workload
|
cmd/workload/workload
|
||||||
|
cmd/keeper/keeper
|
||||||
|
|
|
||||||
98
build/ci.go
98
build/ci.go
|
|
@ -31,6 +31,9 @@ Available commands are:
|
||||||
install [ -arch architecture ] [ -cc compiler ] [ packages... ] -- builds packages and executables
|
install [ -arch architecture ] [ -cc compiler ] [ packages... ] -- builds packages and executables
|
||||||
test [ -coverage ] [ packages... ] -- runs the tests
|
test [ -coverage ] [ packages... ] -- runs the tests
|
||||||
|
|
||||||
|
keeper [ -dlgo ]
|
||||||
|
keeper-archive [ -signer key-envvar ] [ -signify key-envvar ] [ -upload dest ]
|
||||||
|
|
||||||
archive [ -arch architecture ] [ -type zip|tar ] [ -signer key-envvar ] [ -signify key-envvar ] [ -upload dest ] -- archives build artifacts
|
archive [ -arch architecture ] [ -type zip|tar ] [ -signer key-envvar ] [ -signify key-envvar ] [ -upload dest ] -- archives build artifacts
|
||||||
importkeys -- imports signing keys from env
|
importkeys -- imports signing keys from env
|
||||||
debsrc [ -signer key-id ] [ -upload dest ] -- creates a debian source package
|
debsrc [ -signer key-id ] [ -upload dest ] -- creates a debian source package
|
||||||
|
|
@ -86,6 +89,30 @@ var (
|
||||||
executablePath("clef"),
|
executablePath("clef"),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Keeper build targets with their configurations
|
||||||
|
keeperTargets = []struct {
|
||||||
|
Name string
|
||||||
|
GOOS string
|
||||||
|
GOARCH string
|
||||||
|
CC string
|
||||||
|
Tags string
|
||||||
|
Env map[string]string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
Name: "ziren",
|
||||||
|
GOOS: "linux",
|
||||||
|
GOARCH: "mipsle",
|
||||||
|
// enable when cgo works
|
||||||
|
// CC: "mipsel-linux-gnu-gcc",
|
||||||
|
Tags: "ziren",
|
||||||
|
Env: map[string]string{"GOMIPS": "softfloat", "CGO_ENABLED": "0"},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "example",
|
||||||
|
Tags: "example",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
// A debian package is created for all executables listed here.
|
// A debian package is created for all executables listed here.
|
||||||
debExecutables = []debExecutable{
|
debExecutables = []debExecutable{
|
||||||
{
|
{
|
||||||
|
|
@ -178,6 +205,10 @@ func main() {
|
||||||
doPurge(os.Args[2:])
|
doPurge(os.Args[2:])
|
||||||
case "sanitycheck":
|
case "sanitycheck":
|
||||||
doSanityCheck()
|
doSanityCheck()
|
||||||
|
case "keeper":
|
||||||
|
doInstallKeeper(os.Args[2:])
|
||||||
|
case "keeper-archive":
|
||||||
|
doKeeperArchive(os.Args[2:])
|
||||||
default:
|
default:
|
||||||
log.Fatal("unknown command ", os.Args[1])
|
log.Fatal("unknown command ", os.Args[1])
|
||||||
}
|
}
|
||||||
|
|
@ -212,9 +243,6 @@ func doInstall(cmdline []string) {
|
||||||
// Configure the build.
|
// Configure the build.
|
||||||
gobuild := tc.Go("build", buildFlags(env, *staticlink, buildTags)...)
|
gobuild := tc.Go("build", buildFlags(env, *staticlink, buildTags)...)
|
||||||
|
|
||||||
// We use -trimpath to avoid leaking local paths into the built executables.
|
|
||||||
gobuild.Args = append(gobuild.Args, "-trimpath")
|
|
||||||
|
|
||||||
// Show packages during build.
|
// Show packages during build.
|
||||||
gobuild.Args = append(gobuild.Args, "-v")
|
gobuild.Args = append(gobuild.Args, "-v")
|
||||||
|
|
||||||
|
|
@ -234,6 +262,42 @@ func doInstall(cmdline []string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// doInstallKeeper builds keeper binaries for all supported targets.
|
||||||
|
func doInstallKeeper(cmdline []string) {
|
||||||
|
var dlgo = flag.Bool("dlgo", false, "Download Go and build with it")
|
||||||
|
|
||||||
|
flag.CommandLine.Parse(cmdline)
|
||||||
|
env := build.Env()
|
||||||
|
|
||||||
|
// Configure the toolchain.
|
||||||
|
tc := build.GoToolchain{}
|
||||||
|
if *dlgo {
|
||||||
|
csdb := download.MustLoadChecksums("build/checksums.txt")
|
||||||
|
tc.Root = build.DownloadGo(csdb)
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, target := range keeperTargets {
|
||||||
|
log.Printf("Building keeper-%s", target.Name)
|
||||||
|
|
||||||
|
// Configure the build.
|
||||||
|
tc.GOARCH = target.GOARCH
|
||||||
|
tc.GOOS = target.GOOS
|
||||||
|
tc.CC = target.CC
|
||||||
|
gobuild := tc.Go("build", buildFlags(env, true, []string{target.Tags})...)
|
||||||
|
gobuild.Args = append(gobuild.Args, "-v")
|
||||||
|
|
||||||
|
for key, value := range target.Env {
|
||||||
|
gobuild.Env = append(gobuild.Env, key+"="+value)
|
||||||
|
}
|
||||||
|
outputName := fmt.Sprintf("keeper-%s", target.Name)
|
||||||
|
|
||||||
|
args := slices.Clone(gobuild.Args)
|
||||||
|
args = append(args, "-o", executablePath(outputName))
|
||||||
|
args = append(args, "./cmd/keeper")
|
||||||
|
build.MustRun(&exec.Cmd{Path: gobuild.Path, Args: args, Env: gobuild.Env})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// buildFlags returns the go tool flags for building.
|
// buildFlags returns the go tool flags for building.
|
||||||
func buildFlags(env build.Environment, staticLinking bool, buildTags []string) (flags []string) {
|
func buildFlags(env build.Environment, staticLinking bool, buildTags []string) (flags []string) {
|
||||||
var ld []string
|
var ld []string
|
||||||
|
|
@ -272,6 +336,8 @@ func buildFlags(env build.Environment, staticLinking bool, buildTags []string) (
|
||||||
if len(buildTags) > 0 {
|
if len(buildTags) > 0 {
|
||||||
flags = append(flags, "-tags", strings.Join(buildTags, ","))
|
flags = append(flags, "-tags", strings.Join(buildTags, ","))
|
||||||
}
|
}
|
||||||
|
// We use -trimpath to avoid leaking local paths into the built executables.
|
||||||
|
flags = append(flags, "-trimpath")
|
||||||
return flags
|
return flags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -630,6 +696,32 @@ func doArchive(cmdline []string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func doKeeperArchive(cmdline []string) {
|
||||||
|
var (
|
||||||
|
signer = flag.String("signer", "", `Environment variable holding the signing key (e.g. LINUX_SIGNING_KEY)`)
|
||||||
|
signify = flag.String("signify", "", `Environment variable holding the signify key (e.g. LINUX_SIGNIFY_KEY)`)
|
||||||
|
upload = flag.String("upload", "", `Destination to upload the archives (usually "gethstore/builds")`)
|
||||||
|
)
|
||||||
|
flag.CommandLine.Parse(cmdline)
|
||||||
|
|
||||||
|
var (
|
||||||
|
env = build.Env()
|
||||||
|
vsn = version.Archive(env.Commit)
|
||||||
|
keeper = "keeper-" + vsn + ".tar.gz"
|
||||||
|
)
|
||||||
|
maybeSkipArchive(env)
|
||||||
|
files := []string{"COPYING"}
|
||||||
|
for _, target := range keeperTargets {
|
||||||
|
files = append(files, executablePath(fmt.Sprintf("keeper-%s", target.Name)))
|
||||||
|
}
|
||||||
|
if err := build.WriteArchive(keeper, files); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
if err := archiveUpload(keeper, *upload, *signer, *signify); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func archiveBasename(arch string, archiveVersion string) string {
|
func archiveBasename(arch string, archiveVersion string) string {
|
||||||
platform := runtime.GOOS + "-" + arch
|
platform := runtime.GOOS + "-" + arch
|
||||||
if arch == "arm" {
|
if arch == "arm" {
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue