-
-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use the same version of sdk as variant for
variant export
(#41)
This changes the build and release scripts to embed the version number of variant deduced from GITHUB_REF in GitHub Actions, and enhances `variant export` to embed that version in generated go.mod files. Fixes #36
- Loading branch information
Showing
10 changed files
with
172 additions
and
32 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
package main | ||
|
||
import ( | ||
"fmt" | ||
"io/ioutil" | ||
"os" | ||
"strings" | ||
) | ||
|
||
func main() { | ||
content, err := ioutil.ReadFile("go.mod") | ||
if err != nil { | ||
fmt.Fprintf(os.Stderr, "Error: %v\n", err) | ||
os.Exit(1) | ||
} | ||
|
||
var replaces []string | ||
|
||
for _, l := range strings.Split(string(content), "\n") { | ||
if !strings.HasPrefix(l, "replace ") { | ||
continue | ||
} | ||
|
||
if !strings.Contains(l, " => ") { | ||
fmt.Fprintf(os.Stderr, "Unexpected line: ` => ` expected: %s\n", l) | ||
os.Exit(1) | ||
} | ||
|
||
l = strings.ReplaceAll(l, "replace ", "") | ||
l = strings.ReplaceAll(l, " => ", "=") | ||
l = strings.ReplaceAll(l, " ", "@") | ||
l = strings.TrimRight(l, "\n") | ||
|
||
replaces = append(replaces, l) | ||
} | ||
|
||
fmt.Print(strings.Join(replaces, ",")) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -e | ||
|
||
tag=${GITHUB_REF##*/} | ||
|
||
if [ -z "${tag}" ]; then | ||
echo GITHUB_REF must be set 1>&2 | ||
exit 1 | ||
fi | ||
|
||
export VERSION=${tag} | ||
export MOD_REPLACES=$(go run hack/print-replaces.go) | ||
|
||
if [ ! -z "${GITHUB_ENV}" ]; then | ||
echo "VERSION=${VERSION}" >> $GITHUB_ENV | ||
echo "MOD_REPLACES=${MOD_REPLACES}" >> $GITHUB_ENV | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,6 +2,7 @@ package app | |
|
||
import ( | ||
"bytes" | ||
"errors" | ||
"fmt" | ||
"io" | ||
"io/ioutil" | ||
|
@@ -13,6 +14,7 @@ import ( | |
|
||
"github.com/mumoshu/variant2/pkg/conf" | ||
"github.com/mumoshu/variant2/pkg/fs" | ||
"github.com/mumoshu/variant2/pkg/sdk" | ||
) | ||
|
||
func (app *App) ExportBinary(srcDir, dstFile string) error { | ||
|
@@ -50,6 +52,18 @@ func (app *App) ExportBinary(srcDir, dstFile string) error { | |
} | ||
|
||
func (app *App) ExportGo(srcDir, dstDir string) error { | ||
variantVer := sdk.Version | ||
if variantVer == "" { | ||
return errors.New("detected empty sdk.Version. This variant2 binary seems to be broken. " + | ||
"Please rebuild it with `go build -ldflags \"-X github.com/mumoshu/variant2/pkg/sdk.Version=v${VERSION}\"") | ||
} | ||
|
||
modReplaces := strings.Split(sdk.ModReplaces, ",") | ||
if len(modReplaces) == 0 { | ||
return errors.New("detected empty sdk.ModReplaces. This variant2 binary seems to be broken. " + | ||
"Please rebuild it with `go build -ldflags \"-X github.com/mumoshu/variant2/pkg/sdk.ModReplaces=v${MOD_REPLACES}\"") | ||
} | ||
|
||
if err := os.MkdirAll(dstDir, 0o755); err != nil { | ||
return err | ||
} | ||
|
@@ -146,20 +160,21 @@ func main() { | |
return err | ||
} | ||
|
||
variantVer := os.Getenv("VARIANT_BUILD_VER") | ||
if variantVer != "" { | ||
_, err = app.execCmd( | ||
nil, | ||
Command{ | ||
Name: "sh", | ||
Args: []string{"-c", fmt.Sprintf("cd %s; go mod edit -require=github.com/mumoshu/variant2@%s", dstDir, variantVer)}, | ||
Env: map[string]string{}, | ||
}, | ||
true, | ||
) | ||
if err != nil { | ||
return err | ||
} | ||
if v := os.Getenv("VARIANT_BUILD_VER"); v != "" { | ||
variantVer = v | ||
} | ||
|
||
_, err = app.execCmd( | ||
nil, | ||
Command{ | ||
Name: "sh", | ||
Args: []string{"-c", fmt.Sprintf("cd %s; go mod edit -require=github.com/mumoshu/variant2@%s", dstDir, variantVer)}, | ||
Env: map[string]string{}, | ||
}, | ||
true, | ||
) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
variantReplace := os.Getenv("VARIANT_BUILD_VARIANT_REPLACE") | ||
|
@@ -178,22 +193,12 @@ func main() { | |
} | ||
} | ||
|
||
var modReplaces []string | ||
if rs := os.Getenv("VARIANT_BUILD_MOD_REPLACE"); rs != "" { | ||
reps := strings.Split(rs, ",") | ||
|
||
modReplace := os.Getenv("VARIANT_BUILD_MOD_REPLACE") | ||
|
||
if modReplace != "" { | ||
reps := strings.Split(modReplace, ",") | ||
|
||
modReplaces = append(modReplaces, reps...) | ||
modReplaces = reps | ||
} | ||
|
||
// Required until https://github.com/summerwind/whitebox-controller/pull/8 is merged | ||
modReplaces = append(modReplaces, "github.com/summerwind/[email protected]=github.com/mumoshu/[email protected]") | ||
|
||
// Required to fix go mod issue that k8s.io/client-go is somehow "updated" to invalid "v10.0.0+incompatible" on build | ||
modReplaces = append(modReplaces, "k8s.io/[email protected]+incompatible=k8s.io/[email protected]") | ||
|
||
for _, modReplace := range modReplaces { | ||
_, err = app.execCmd( | ||
nil, | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
package sdk | ||
|
||
var Version string | ||
|
||
var ModReplaces string |