I don’t know why, but version output is really important and touchy subject for me. It is really nice to have extra metadata, not just version number. See version output of the docker CLI for example:
|
|
Easy enough we can just hard code these values, and update them as part of commit/release:
|
|
But wait, Git commit is always changing, how can we capture current one without any changes to code? No problem, by using build flags and providing values for our variables during build time. Go’s build tool can do that via -ldflags
which passes extra arguments to the linker. Linker has many arguments to play with, one of them is -X
:
-X importpath.name=value
Set the value of the string variable in importpath named name to value.
This is only effective if the variable is declared in the source code either uninitialized
or initialized to a constant string expression. -X will not work if the initializer makes
a function call or refers to other variables.
Note that before Go 1.5 this option took two separate arguments.
Let’s use it:
|
|
And some of that info is provided by Go’s runtime
already:
|
|
And with the rise of CI/CD and DevOps practices, we are building our software inside pipelines, usually. So let’s rely on default variables provided (by Bitbucket in the below example):
|
|
The full list of predefined variables can be found here for GitHub, and here for Bitbucket (or somewhere else for your CI/CD solution).
But what if you need to set variable in some nested package, naming can be tricky, so better to check symbols:
|
|
References:
Wed Oct 18, 2023 / 529 words / Golang Programming