Skip to content

Commit

Permalink
build: buildinfo: move buildinfo struct in internal api
Browse files Browse the repository at this point in the history
use the buildinfo.json data for `pkg/version` instead
of injecting the values at link time.
This simplifies the builds and enables better introspection
capabilities.

Signed-off-by: Francesco Romani <[email protected]>
  • Loading branch information
ffromani committed Dec 11, 2024
1 parent 169e3fd commit c37bd5f
Show file tree
Hide file tree
Showing 8 changed files with 72 additions and 63 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,5 @@ testbin/*
*~

coverage.out

pkg/version/_buildinfo.json
42 changes: 20 additions & 22 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -109,10 +109,12 @@ manifests: controller-gen ## Generate WebhookConfiguration, ClusterRole and Cust
generate: controller-gen ## Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations.
$(CONTROLLER_GEN) object:headerFile="hack/boilerplate.go.txt" paths="./..."

fmt: ## Run go fmt against code.
fmt:
go fmt ./...

vet: ## Run go vet against code.
# needed otherwise vet complains about trying to embed a missing file.
# note: this would be missing only at time of vetting, which happens before the build process even starts
vet: pkg/version/_buildinfo.json
go vet ./...

gosec:
Expand Down Expand Up @@ -154,21 +156,15 @@ cover-summary:

binary: build-tools
LDFLAGS="-s -w"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.gitcommit=$(shell bin/buildhelper commit)"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.version=$(shell bin/buildhelper version)"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/images.tag=$(VERSION)"; \
go build -mod=vendor -o bin/manager -ldflags "$$LDFLAGS" -tags "$$GOTAGS" main.go

binary-rte: build-tools
LDFLAGS="-s -w"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.gitcommit=$(shell bin/buildhelper commit)"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.version=$(shell bin/buildhelper version)"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/images.tag=$(VERSION)"; \
go build -mod=vendor -o bin/exporter -ldflags "$$LDFLAGS" -tags "$$GOTAGS" rte/main.go

binary-nrovalidate: build-tools
LDFLAGS="-s -w"; \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.version=$(shell bin/buildhelper version)"; \
go build -mod=vendor -o bin/nrovalidate -ldflags "$$LDFLAGS" -tags "$$GOTAGS" nrovalidate/main.go

binary-numacell: build-tools
Expand All @@ -181,30 +177,28 @@ binary-all: goversion \
binary-nrovalidate \
introspect-data

binary-e2e-rte-local:
binary-e2e-rte-local: pkg/version/_buildinfo.json
go test -c -v -o bin/e2e-nrop-rte-local.test ./test/e2e/rte/local

binary-e2e-rte: binary-e2e-rte-local
binary-e2e-rte: binary-e2e-rte-local pkg/version/_buildinfo.json
go test -c -v -o bin/e2e-nrop-rte.test ./test/e2e/rte

binary-e2e-install:
binary-e2e-install: pkg/version/_buildinfo.json
go test -v -c -o bin/e2e-nrop-install.test ./test/e2e/install && go test -v -c -o bin/e2e-nrop-sched-install.test ./test/e2e/sched/install

binary-e2e-uninstall:
binary-e2e-uninstall: pkg/version/_buildinfo.json
go test -v -c -o bin/e2e-nrop-uninstall.test ./test/e2e/uninstall && go test -v -c -o bin/e2e-nrop-sched-uninstall.test ./test/e2e/sched/uninstall

binary-e2e-sched:
binary-e2e-sched: pkg/version/_buildinfo.json
go test -c -v -o bin/e2e-nrop-sched.test ./test/e2e/sched

binary-e2e-serial:
LDFLAGS+="-X github.com/openshift-kni/numaresources-operator/pkg/version.version=$(shell bin/buildhelper version) "; \
LDFLAGS+="-X github.com/openshift-kni/numaresources-operator/pkg/version.gitcommit=$(shell bin/buildhelper commit)"; \
binary-e2e-serial: pkg/version/_buildinfo.json
CGO_ENABLED=0 go test -c -v -o bin/e2e-nrop-serial.test -ldflags "$$LDFLAGS" ./test/e2e/serial

binary-e2e-tools:
binary-e2e-tools: pkg/version/_buildinfo.json
go test -c -v -o bin/e2e-nrop-tools.test ./test/e2e/tools

binary-e2e-must-gather:
binary-e2e-must-gather: pkg/version/_buildinfo.json
go test -c -v -o bin/e2e-nrop-must-gather.test ./test/e2e/must-gather

# backward compatibility
Expand Down Expand Up @@ -405,10 +399,15 @@ goversion:
@go version

.PHONY: build-tools
build-tools: goversion bin/buildhelper bin/envsubst bin/lsplatform
build-tools: goversion bin/buildhelper bin/envsubst bin/lsplatform update-buildinfo

.PHONY: build-tools-all
build-tools-all: goversion bin/buildhelper bin/envsubst bin/lsplatform bin/catkubeletconfmap bin/watchnrtattr bin/mkginkgolabelfilter bin/nrtcacheck
build-tools-all: goversion bin/buildhelper bin/envsubst bin/lsplatform bin/catkubeletconfmap bin/watchnrtattr bin/mkginkgolabelfilter bin/nrtcacheck update-buildinfo

pkg/version/_buildinfo.json: bin/buildhelper
@bin/buildhelper inspect > pkg/version/_buildinfo.json

update-buildinfo: pkg/version/_buildinfo.json

bin/buildhelper:
@go build -o bin/buildhelper tools/buildhelper/buildhelper.go
Expand All @@ -432,7 +431,6 @@ bin/mkginkgolabelfilter:

bin/nrtcacheck: build-tools
LDFLAGS="-s -w" \
LDFLAGS+=" -X github.com/openshift-kni/numaresources-operator/pkg/version.version=$(shell bin/buildhelper version)"; \
go build -mod=vendor -o bin/nrtcacheck -ldflags "$$LDFLAGS" -tags "$$GOTAGS" tools/nrtcacheck/nrtcacheck.go

verify-generated: bundle generate
Expand All @@ -445,7 +443,7 @@ install-git-hooks:

GOLANGCI_LINT_LOCAL_VERSION := $(shell command ${GOLANGCI_LINT} --version 2> /dev/null | awk '{print $$4}')
.PHONY: golangci-lint
golangci-lint:
golangci-lint: pkg/version/_buildinfo.json
@if [ ! -x "$(GOLANGCI_LINT)" ]; then\
echo "Downloading golangci-lint from https://github.com/golangci/golangci-lint/releases/download/v$(GOLANGCI_LINT_VERSION)/$(GOLANGCI_LINT_ARTIFACT_FILE)";\
mkdir -p $(BIN_DIR);\
Expand Down
27 changes: 27 additions & 0 deletions internal/api/buildinfo/types.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/*
* Copyright 2024 Red Hat, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package buildinfo

type BuildInfo struct {
Branch string `json:"branch"`
Version string `json:"version"`
Commit string `json:"commit"`
}

func (bi BuildInfo) String() string {
return bi.Version + " " + bi.Commit + " (" + bi.Branch + ")"
}
5 changes: 3 additions & 2 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -171,8 +171,9 @@ func main() {
params.SetDefaults()
params.FromFlags()

bi := version.GetBuildInfo()
if params.showVersion {
fmt.Printf("%s %s %s %s\n", version.OperatorProgramName(), version.Get(), version.GetGitCommit(), runtime.Version())
fmt.Printf("%s %s %s\n", version.OperatorProgramName(), bi.String(), runtime.Version())
os.Exit(0)
}

Expand All @@ -189,7 +190,7 @@ func main() {
config := textlogger.NewConfig(textlogger.Verbosity(int(klogV)))
ctrl.SetLogger(textlogger.NewLogger(config))

klog.InfoS("starting", "program", version.OperatorProgramName(), "version", version.Get(), "gitcommit", version.GetGitCommit(), "golang", runtime.Version(), "vl", klogV, "auxv", config.Verbosity().String())
klog.InfoS("starting", "program", version.OperatorProgramName(), "version", bi.Version, "branch", bi.Branch, "gitcommit", bi.Commit, "golang", runtime.Version(), "vl", klogV, "auxv", config.Verbosity().String())

ctx := context.Background()

Expand Down
32 changes: 14 additions & 18 deletions pkg/version/version.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,36 +17,32 @@
package version

import (
_ "embed"
"encoding/json"
"os"
"path/filepath"
)

const (
undefined string = "undefined"
"github.com/openshift-kni/numaresources-operator/internal/api/buildinfo"
)

// version Must not be const, supposed to be set using ldflags at build time
var version = undefined
//go:embed _buildinfo.json
var buildInfo string

// gitcommit Must not be const, supposed to be set using ldflags at build time
var gitcommit = undefined
func GetBuildInfo() buildinfo.BuildInfo {
var bi buildinfo.BuildInfo
_ = json.Unmarshal([]byte(buildInfo), &bi)
return bi
}

// Get returns the version as a string
func Get() string {
return version
}

// Undefined returns if version is at it's default value
func Undefined() bool {
return version == undefined
bi := GetBuildInfo()
return bi.Version
}

func GetGitCommit() string {
return gitcommit
}

func UndefinedGitCommit() bool {
return gitcommit == undefined
bi := GetBuildInfo()
return bi.Commit
}

func ProgramName() string {
Expand Down
12 changes: 0 additions & 12 deletions pkg/version/version_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,24 +24,12 @@ func TestGet(t *testing.T) {
}
}

func TestUndefined(t *testing.T) {
if !Undefined() {
t.Errorf("final version should be defined at link stage")
}
}

func TestGetGitCommit(t *testing.T) {
if GetGitCommit() == "" {
t.Errorf("empty gitcommit")
}
}

func TestUndefinedGitCommit(t *testing.T) {
if !UndefinedGitCommit() {
t.Errorf("final gitcommit should be defined at link stage")
}
}

func TestProgramName(t *testing.T) {
if ProgramName() == "undefined" {
t.Errorf("program name should always be defined")
Expand Down
5 changes: 3 additions & 2 deletions rte/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,15 +45,16 @@ const (
)

func main() {
klog.Infof("starting %s %s %s %s\n", version.ExporterProgramName(), version.Get(), version.GetGitCommit(), runtime.Version())
bi := version.GetBuildInfo()
klog.Infof("starting %s %s %s\n", version.ExporterProgramName(), bi.String(), runtime.Version())

parsedArgs, err := parseArgs(os.Args[1:]...)
if err != nil {
klog.Fatalf("failed to parse args: %v", err)
}

if parsedArgs.Version {
fmt.Printf("%s %s %s %s\n", version.ExporterProgramName(), version.Get(), version.GetGitCommit(), runtime.Version())
fmt.Printf("%s %s %s\n", version.ExporterProgramName(), bi.String(), runtime.Version())
os.Exit(0)
}

Expand Down
10 changes: 3 additions & 7 deletions tools/buildhelper/buildhelper.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,15 @@ import (
"strings"

"github.com/mdomke/git-semver/version"

"github.com/openshift-kni/numaresources-operator/internal/api/buildinfo"
)

const (
develBranchName = "devel"
releaseBranchPrefix = "release-"
)

type buildInfo struct {
Branch string `json:"branch"`
Version string `json:"version"`
Commit string `json:"commit"`
}

func getVersion() (string, error) {
if ver, ok := os.LookupEnv("NRO_BUILD_VERSION"); ok {
return ver, nil
Expand Down Expand Up @@ -108,7 +104,7 @@ func showBranch() int {
}

func inspect() int {
var bi buildInfo
var bi buildinfo.BuildInfo
var err error

bi.Version, err = getVersion()
Expand Down

0 comments on commit c37bd5f

Please sign in to comment.