Merge pull request #10294 from filecoin-project/mikers/buildReleaseOverrides

fix: pack: support network name overrides in bundle git tags
This commit is contained in:
Aayush Rajasekaran 2023-02-17 14:28:50 -05:00 committed by GitHub
commit 7a35a735fa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 52 additions and 9 deletions

View File

@ -298,7 +298,7 @@ actors-gen: actors-code-gen fiximports
.PHONY: actors-gen .PHONY: actors-gen
bundle-gen: bundle-gen:
$(GOCC) run ./gen/bundle $(RELEASE) $(GOCC) run ./gen/bundle $(VERSION) $(RELEASE) $(RELEASE_OVERRIDES)
$(GOCC) fmt ./build/... $(GOCC) fmt ./build/...
.PHONY: bundle-gen .PHONY: bundle-gen

View File

@ -52,4 +52,4 @@ popd
echo "Generating metadata..." echo "Generating metadata..."
make -C ../../ RELEASE="$RELEASE" bundle-gen make -C ../../ VERSION="$VERSION" RELEASE="$RELEASE" RELEASE_OVERRIDES="${RELEASE_OVERRIDES[*]}" bundle-gen

View File

@ -2,6 +2,8 @@ package main
import ( import (
"os" "os"
"strconv"
"strings"
"text/template" "text/template"
"github.com/filecoin-project/lotus/build" "github.com/filecoin-project/lotus/build"
@ -32,19 +34,49 @@ var EmbeddedBuiltinActorsMetadata []*BuiltinActorsMetadata = []*BuiltinActorsMet
} }
`)) `))
func splitOverride(override string) (string, string) {
x := strings.Split(override, "=")
return x[0], x[1]
}
func main() { func main() {
// read metadata from the embedded bundle, includes all info except git tags
metadata, err := build.ReadEmbeddedBuiltinActorsMetadata() metadata, err := build.ReadEmbeddedBuiltinActorsMetadata()
if err != nil { if err != nil {
panic(err) panic(err)
} }
// TODO: Re-enable this when we can set the tag for ONLY the appropriate version // IF args have been provided, extract git tag info from them, otherwise
// https://github.com/filecoin-project/lotus/issues/10185#issuecomment-1422864836 // rely on previously embedded metadata for git tags.
//if len(os.Args) > 1 { if len(os.Args) > 1 {
// for _, m := range metadata { // see ./build/actors/pack.sh
// m.BundleGitTag = os.Args[1] // (optional) expected args are:
// } // $(GOCC) run ./gen/bundle $(VERSION) $(RELEASE) $(RELEASE_OVERRIDES)
//} // overrides are in the format network_name=override
gitTag := os.Args[2]
packedActorsVersion, err := strconv.Atoi(os.Args[1][1:])
if err != nil {
panic(err)
}
overrides := map[string]string{}
for _, override := range os.Args[3:] {
k, v := splitOverride(override)
overrides[k] = v
}
for _, m := range metadata {
if int(m.Version) == packedActorsVersion {
override, ok := overrides[m.Network]
if ok {
m.BundleGitTag = override
} else {
m.BundleGitTag = gitTag
}
} else {
m.BundleGitTag = getOldGitTagFromEmbeddedMetadata(m)
}
}
}
fi, err := os.Create("./build/builtin_actors_gen.go") fi, err := os.Create("./build/builtin_actors_gen.go")
if err != nil { if err != nil {
@ -57,3 +89,14 @@ func main() {
panic(err) panic(err)
} }
} }
func getOldGitTagFromEmbeddedMetadata(m *build.BuiltinActorsMetadata) string {
for _, v := range build.EmbeddedBuiltinActorsMetadata {
// if we agree on the manifestCid for the previously embedded metadata, use the previously set tag
if m.Version == v.Version && m.Network == v.Network && m.ManifestCid == v.ManifestCid {
return m.BundleGitTag
}
}
return ""
}