Skip to content

Commit

Permalink
Update PROJECT in accordance with operator-sdk 1.23.0
Browse files Browse the repository at this point in the history
to use kubebuilder v3. This is in line with the config new operator-sdk
framework autogenerates as evident from

https://github.com/Jaanki/submariner-operator/pull/10/files#diff-d1fb402f1269ba7396dca9cbd03b44ac055874669bce1d0f239fa2f54ea3584b

This also requires updating operator-sdk and kustomize versions. Other
changes made are:

1. Install KUSTOMIZE only if it is not locally present using the install
   script provided at its repo. Remove our own provided script.
2. Install controller tools only if it is not locally present.
3. Add make targets to install kustomize, operator-sdk and controller
   tools. This will allow users to install these versions easily.
4. Don't create packagemanifests as bundle is the recommended way to
   ship the operator.

Part of epic: submariner-io/enhancements#81

Signed-off-by: Janki Chhatbar <[email protected]>
  • Loading branch information
Jaanki committed Sep 12, 2022
1 parent 484390b commit cb346bf
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 171 deletions.
58 changes: 26 additions & 32 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ endif

ifneq (,$(DAPPER_HOST_ARCH))

OPERATOR_SDK_VERSION := 1.0.1
OPERATOR_SDK_VERSION := 1.23.0
OPERATOR_SDK := $(CURDIR)/bin/operator-sdk

KUSTOMIZE_VERSION := 3.10.0
Expand Down Expand Up @@ -154,11 +154,17 @@ bin/%/submariner-operator: $(VENDOR_MODULES) main.go $(EMBEDDED_YAMLS)

ci: $(EMBEDDED_YAMLS) golangci-lint markdownlint unit build images

# Operator CRDs
# Download controller-gen locally if not already downloaded.
CONTROLLER_TOOLS_VERSION := 0.9.2
$(CONTROLLER_GEN): $(VENDOR_MODULES)
mkdir -p $(@D)
$(GO) build -o $@ sigs.k8s.io/controller-tools/cmd/controller-gen
test -s $(CURDIR)/bin/controller-gen || $(GO) build -o $@ sigs.k8s.io/controller-tools/cmd/controller-gen
## TODO (Jaanki) Use go install instead
# $(GO) install sigs.k8s.io/controller-tools/cmd/controller-gen@v$(CONTROLLER_TOOLS_VERSION)

controller-gen: $(CONTROLLER_GEN)

# Operator CRDs
deploy/crds/submariner.io_servicediscoveries.yaml: ./api/v1alpha1/servicediscovery_types.go $(VENDOR_MODULES) | $(CONTROLLER_GEN)
$(CONTROLLER_GEN) $(CRD_OPTIONS) paths="./..." output:crd:artifacts:config=deploy/crds
test -f $@
Expand All @@ -182,11 +188,13 @@ is-semantic-version:
$(error 'ERROR: VERSION "$(BUNDLE_VERSION)" does not match the format required by operator-sdk.')
endif

# TODO: a workaround until this issue will be fixed https://github.com/kubernetes-sigs/kustomize/issues/4008
## Download kustomize locally if not already downloaded.
KUSTOMIZE_INSTALL_SCRIPT ?= "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh"
$(KUSTOMIZE):
mkdir -p $(@D)
#GOBIN=$(CURDIR)/bin GO111MODULE=on $(GO) get sigs.k8s.io/kustomize/kustomize/v3
scripts/kustomize/install_kustomize.sh $(KUSTOMIZE_VERSION) $(CURDIR)/bin
test -s $(CURDIR)/bin/kustomize || { curl -s $(KUSTOMIZE_INSTALL_SCRIPT) | bash -s -- $(subst v,,$(KUSTOMIZE_VERSION)) $(CURDIR)/bin; }

kustomize: $(KUSTOMIZE)

# Generate kustomization.yaml for bundle
kustomization: $(OPERATOR_SDK) $(KUSTOMIZE) is-semantic-version manifests
Expand All @@ -209,16 +217,6 @@ bundle: $(KUSTOMIZE) $(OPERATOR_SDK) kustomization
sed -i -e 's/$$(VERSION)/$(VERSION)/g' bundle/manifests/submariner.clusterserviceversion.yaml
$(OPERATOR_SDK) bundle validate ./bundle

# Generate package manifests
packagemanifests: $(OPERATOR_SDK) $(KUSTOMIZE) kustomization
($(KUSTOMIZE) build $(KUSTOMIZE_BASE_PATH) \
| $(OPERATOR_SDK) generate packagemanifests -q --version $(BUNDLE_VERSION) $(PKG_MAN_OPTS))
(cd config/bundle && $(KUSTOMIZE) edit add resource ../../packagemanifests/$(BUNDLE_VERSION)/submariner.clusterserviceversion.yaml)
$(KUSTOMIZE) build config/bundle/ --load_restrictor=LoadRestrictionsNone --output packagemanifests/$(BUNDLE_VERSION)/submariner.clusterserviceversion.yaml
sed -i -e 's/$$(SHORT_VERSION)/$(SHORT_VERSION)/g' packagemanifests/$(BUNDLE_VERSION)/submariner.clusterserviceversion.yaml
sed -i -e 's/$$(VERSION)/$(VERSION)/g' packagemanifests/$(BUNDLE_VERSION)/submariner.clusterserviceversion.yaml
mv packagemanifests/$(BUNDLE_VERSION)/submariner.clusterserviceversion.yaml packagemanifests/$(BUNDLE_VERSION)/submariner.v$(BUNDLE_VERSION).clusterserviceversion.yaml

# Statically validate the operator bundle using Scorecard.
scorecard: bundle olm clusters
timeout 60 bash -c "until KUBECONFIG=$(DAPPER_OUTPUT)/kubeconfigs/kind-config-cluster1 \
Expand All @@ -233,25 +231,21 @@ golangci-lint: $(EMBEDDED_YAMLS)
unit: $(EMBEDDED_YAMLS)

# Operator SDK
# On version bumps, the checksum will need to be updated manually.
# If necessary, the verification *keys* can be updated as follows:
# * update scripts/operator-sdk-signing-key.asc, import the relevant key,
# and export it with
# gpg --armor --export-options export-minimal --export \
# ${fingerprint} >> scripts/operator-sdk-signing-key.asc
# (replacing ${fingerprint} with the full fingerprint);
# * to update scripts/operator-sdk-signing-keyring.gpg, run
# gpg --no-options -q --batch --no-default-keyring \
# --output scripts/operator-sdk-signing-keyring.gpg \
# --dearmor scripts/operator-sdk-signing-key.asc
$(OPERATOR_SDK):
curl -Lo $@ "https://github.com/operator-framework/operator-sdk/releases/download/v${OPERATOR_SDK_VERSION}/operator-sdk-v${OPERATOR_SDK_VERSION}-x86_64-linux-gnu"
curl -Lo $@.asc "https://github.com/operator-framework/operator-sdk/releases/download/v${OPERATOR_SDK_VERSION}/operator-sdk-v${OPERATOR_SDK_VERSION}-x86_64-linux-gnu.asc"
gpgv --keyring scripts/operator-sdk-signing-keyring.gpg $@.asc $@
sha256sum -c scripts/operator-sdk.sha256
mkdir -p bin && \
cd bin && \
curl -Lo $@ "https://github.com/operator-framework/operator-sdk/releases/download/v${OPERATOR_SDK_VERSION}/operator-sdk_linux_amd64" && \
curl -Lo checksums.txt.asc "https://github.com/operator-framework/operator-sdk/releases/download/v${OPERATOR_SDK_VERSION}/checksums.txt.asc" && \
curl -Lo checksums.txt "https://github.com/operator-framework/operator-sdk/releases/download/v${OPERATOR_SDK_VERSION}/checksums.txt" \
## TODO (Jaanki) Add checksums
#gpg --verify checksums.txt.asc checksums.txt
#gpgv --keyring scripts/operator-sdk-signing-keyring.gpg [email protected] $@
#sha256sum -c scripts/operator-sdk.sha256
chmod a+x $@

.PHONY: build ci clean bundle packagemanifests kustomization is-semantic-version olm scorecard system-test
operator-sdk: $(OPERATOR_SDK)

.PHONY: build ci clean bundle packagemanifests kustomization is-semantic-version olm scorecard system-test controller-gen kustomize operator-sdk

else

Expand Down
38 changes: 32 additions & 6 deletions PROJECT
Original file line number Diff line number Diff line change
@@ -1,8 +1,34 @@
domain: submariner.io
layout: go.kubebuilder.io/v2
projectName: submariner
repo: github.com/submariner-io/submariner-operator
version: 3-alpha
multigroup: true
layout:
- go.kubebuilder.io/v3
plugins:
go.sdk.operatorframework.io/v2-alpha: {}
manifests.sdk.operatorframework.io/v2: {}
scorecard.sdk.operatorframework.io/v2: {}
projectName: submariner-operator
repo: github.com/submariner-io/submariner-operator
resources:
- api:
crdVersion: v1
namespaced: true
controller: true
domain: submariner.io
kind: Broker
path: github.com/submariner-io/submariner-operator/api/v1alpha1
version: v1alpha1
- api:
crdVersion: v1
namespaced: true
controller: true
domain: submariner.io
kind: Submariner
path: github.com/submariner-io/submariner-operator/api/v1alpha1
version: v1alpha1
- api:
crdVersion: v1
namespaced: true
controller: true
domain: submariner.io
kind: ServiceDiscovery
path: github.com/submariner-io/submariner-operator/api/v1alpha1
version: v1alpha1
version: "3"
133 changes: 0 additions & 133 deletions scripts/kustomize/install_kustomize.sh

This file was deleted.

0 comments on commit cb346bf

Please sign in to comment.