-
Notifications
You must be signed in to change notification settings - Fork 243
Dev: odo Dev Guidelines
Requires Go 1.16
Testing and release builds happen with the above version. Developers are advised to stick to this version if they can, but it is not compulsory.
Warning: If you are adding any features that require a higher version of golang than the one mentioned above, please contact the maintainers in order to check if the releasing systems can handle the newer version. If that is ok, please ensure you update the required golang version, both here and in the files below, in your PR.
List of files to update for golang version:
First setup your fork of the odo project, following the steps below
-
Clone your fork: NOTE: odo uses
go modules
to manage dependencies which means you can clone the code anywhere you like but for backwards compatibility we would be cloning it under$GOPATH
git clone https://github.com/<YOUR_GITHUB_USERNAME>/odo.git $GOPATH/src/github.com/redhat-developer/odo
cd $GOPATH/src/github.com/redhat-developer/odo
git remote add upstream 'https://github.com/redhat-developer/odo'
When cloning odo
, the Windows terminal such as PowerShell or CMD may throw a Filename too long error. To avoid such an error, set your Git configuration as follows:
git config --system core.longpaths true
If you are a maintainer and have write access to the odo
repository, modify your git configuration so that you do not accidentally push to upstream:
git remote set-url --push upstream no_push
- Install tools used by the build and test system:
make goget-tools
- bin:: (default)
go build
the executable in cmd/odo - install:: build and install
odo
in your GOPATH - validate:: run gofmt, go vet and other validity checks
- goget-tools:: download tools used to build & test
- test:: run all unit tests - same as
go test pkg/\...
- test-integration:: run all integration tests
- test-coverage:: generate test coverage report
Read the Makefile itself for more information.
To submit a PR, you must first create a branch from your fork, commit your changes to the branch, and push them on to GitHub.
A "signed-off" signature is good practice. You may sign your commit using git commit -s
or git commit --amend --no-edit -s
to a previously created commit
Refer to the guidelines below, and create a PR with your changes.
- Descriptive context that outlines what has been changed and why
- If your PR is still in-progress, indicate this with a label or add WIP in your PR title.
- A link to the active or open issue it fixes (if applicable)
Once you submit a PR, the @openshift-ci-bot will automatically request two reviews from a reviewer and an approver.
For quick deployment of components, odo uses the Supervisord process manager. Supervisord is deployed via Init Container image.
ODO_BOOTSTRAPPER_IMAGE
is an environmental variable which specifies the Init Container image used for Supervisord deployment. You can modify the value of the variable to use a custom Init Container image.
The default Init Container image is quay.io/openshiftdo/init
To set a custom Init Container image, run:
export ODO_BOOTSTRAPPER_IMAGE=quay.io/myrepo/myimage:test
To revert to the default Init Container image, unset the variable:
unset ODO_BOOTSTRAPPER_IMAGE
odo
uses go mod
to manage dependencies, and with vendor directory. This means that you should use -mod=vendor
flag with all go
commands. Or use GOFLAGS
to set it permanently (export GOFLAGS=-mod=vendor
).
Vendor is important to make sure that odo can always be built even offline.
-
Just add new
import
to your code. NOTE: If you want to use a specific version of a module you can dogo get <pkg>@<version>
, for example (go get golang.org/x/text@v0.3.2
) -
Run
go mod tidy
andgo mod vendor
. -
Commit the updated
go.mod
,go.sum
andvendor
files to git.
Some tips to consider when writing machine-readable output code.
- Match similar Kubernetes / OpenShift API structures
- Put as much information as possible within
Spec
- Use
json:"foobar"
within structs to rename the variables
Within odo, we unmarshal all information from a struct to json. Within this struct, we use TypeMeta
and ObjectMeta
in order to supply meta-data information coming from Kubernetes / OpenShift.
Below is working example of how we would implement a "GenericSuccess" struct.
package main
import (
"encoding/json"
"fmt"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// Create the struct. Here we use TypeMeta and ObjectMeta
// as required to create a "Kubernetes-like" API.
type GenericSuccess struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Message string `json:"message"`
}
func main() {
// Create the actual struct that we will use
// you will see that we supply a "Kind" and
// APIVersion. Name your "Kind" to what you are implementing
machineOutput := GenericSuccess{
TypeMeta: metav1.TypeMeta{
Kind: "genericsuccess",
APIVersion: "odo.dev/v1alpha1",
},
ObjectMeta: metav1.ObjectMeta{
Name: "MyProject",
},
Message: "Hello API!",
}
// We then marshal the output and print it out
printableOutput, _ := json.Marshal(machineOutput)
fmt.Println(string(printableOutput))
}
odo uses wwhrd to check license compatibility of vendor packages. The configuration for wwhrd
is stored in .wwhrd.yml.
The allowlist
section is for licenses that are always allowed. The denylist
section is for licenses that are never allowed and will always fail a build. Any licenses that are not explicitly mentioned come under the exceptions
section and need to be explicitly allowed by adding the import path to the exceptions.
More details about the license compatibility check tool can be found here.
With user approval, we collect pseudonymized user data that will help us improve odo.
To learn more about what data is being collected and how to configure this collection, see here.
Considering the user has approved to data collection, everytime a command is executed, it triggers a background process that sends the data to our servers.
This background process is an odo command called telemetry
.
Before the user-run command exits, data about the command execution is collected and odo telemetry <jsonPayload>
is triggered as a background process.
If the command, for example odo create nodejs
is successful, the following data will be sent -
{
"event": "odo create",
"properties": {
"duration": "100(ms)",
"success": true,
"tty": true,
"version": "odo v2.2.1 (e85f5e83c)"
"cmdProperties": {
"componentType": "nodejs"
}
}
}
If the command, for example odo create xyz
is unsuccessful, the following data will be sent -
{
"event": "odo create",
"properties": {
"duration": "100(ms)",
"success": false,
"tty": true,
"version": "odo v2.2.1 (e85f5e83c)"
"error": "component type \"xyz\" not found"
"errortype": "*errors.fundamental"
"cmdProperties": {
"componentType": "nodejs"
}
}
}
Before sending the data to the server, error message is sanitized of any PII(Personally Identifiable Information) data which includes username, file paths, URLs, and pod exec commands executed via odo commands.
Note that these commands do not include --help
commands. We do not collect data about help commands.
We use Segment as our data platform and Woopra as our analytics tool.