-
Notifications
You must be signed in to change notification settings - Fork 150
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
K8SPSMDB-1183 bundle generations for psmdb #1681
base: main
Are you sure you want to change the base?
Conversation
|
||
KUSTOMIZE = $(REPO_ROOT)/bin/kustomize | ||
kustomize: ## Download kustomize locally if necessary. | ||
$(call go-get-tool,$(KUSTOMIZE),sigs.k8s.io/kustomize/kustomize/[email protected]) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we update this? I see in github there is v5.5.0 version
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we use this version for all our operators in all our makefile. I can check can we update it or not)
tools: tools/$(SYSTEM)/kubectl | ||
tools/$(SYSTEM)/kubectl: | ||
install -d '$(dir $@)' | ||
curl -fSL -o '$@' 'https://dl.k8s.io/release/$(shell curl -Ls https://dl.k8s.io/release/stable-1.21.txt)/bin/$(OS_KERNEL)/$(OS_MACHINE)/kubectl' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we update this? stable-1.21
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
which one do you want to use?
tools: tools/$(SYSTEM)/operator-sdk | ||
tools/$(SYSTEM)/operator-sdk: | ||
install -d '$(dir $@)' | ||
curl -fSL -o '$@' 'https://github.com/operator-framework/operator-sdk/releases/download/v1.19.1/operator-sdk_$(OS_KERNEL)_$(OS_MACHINE)' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we update this?
tools: tools/$(SYSTEM)/opm | ||
tools/$(SYSTEM)/opm: | ||
install -d '$(dir $@)' | ||
curl -fSL -o '$@' 'https://github.com/operator-framework/operator-registry/releases/download/v1.33.0/$(OS_KERNEL)-$(OS_MACHINE)-opm' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we update this? Also, shoud this be aligned with the version from operator-sdk?
endif | ||
|
||
KUSTOMIZE = $(REPO_ROOT)/bin/kustomize | ||
kustomize: ## Download kustomize locally if necessary. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This does not work for me, when I execute make bundles
I get an error in this line:
/bin/bash: ..repos/percona-server-mongodb-operator/bin/kustomize: No such file or directory
Yes, I don't have kustomize in bin/ folder, but this go-get-tool
should be able to download it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, I will check it too. And I agree that go-get-tool should download it.
installers/olm/README.md
Outdated
@@ -0,0 +1,6 @@ | |||
1. Set VERSION env variable |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Operator version in format "1.18.0" ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes.
installers/olm/README.md
Outdated
@@ -0,0 +1,6 @@ | |||
1. Set VERSION env variable | |||
2. Update rbac and operator in config |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what does this mean?
installers/olm/README.md
Outdated
@@ -0,0 +1,6 @@ | |||
1. Set VERSION env variable | |||
2. Update rbac and operator in config | |||
2. Choose the mode (cluster or namespace) and update bundle/kustomization.yaml and makefile with necessary mode. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why we need to update in two places?
also please add a PR description, it'd be great if you put some usage example |
.annotations["com.redhat.openshift.versions"] = env(openshift_supported_versions)' \ | ||
bundle.annotations.yaml >"${bundle_directory}/metadata/annotations.yaml" | ||
|
||
if [ ${DISTRIBUTION} == 'community' ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
if [ ${DISTRIBUTION} == 'community' ]; then | |
if [ "${DISTRIBUTION}" == 'community' ]; then |
"${bundle_directory}/metadata/annotations.yaml" | ||
|
||
# certified-operators | ||
elif [ ${DISTRIBUTION} == 'redhat' ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
elif [ ${DISTRIBUTION} == 'redhat' ]; then | |
elif [ "${DISTRIBUTION}" == 'redhat' ]; then |
"${bundle_directory}/metadata/annotations.yaml" | ||
|
||
# redhat-marketplace | ||
elif [ ${DISTRIBUTION} == 'marketplace' ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
elif [ ${DISTRIBUTION} == 'marketplace' ]; then | |
elif [ "${DISTRIBUTION}" == 'marketplace' ]; then |
export role="${mode}Role" | ||
|
||
update_yaml_images() { | ||
local yaml_file="$1" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
local yaml_file="$1" | |
local yaml_file="$1" |
if [ ! -f "$yaml_file" ]; then | ||
echo "Error: File '$yaml_file' does not exist." | ||
return 1 | ||
fi |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
if [ ! -f "$yaml_file" ]; then | |
echo "Error: File '$yaml_file' does not exist." | |
return 1 | |
fi | |
if [ ! -f "$yaml_file" ]; then | |
echo "Error: File '$yaml_file' does not exist." | |
return 1 | |
fi |
return 1 | ||
fi | ||
|
||
local temp_file=$(mktemp) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
local temp_file=$(mktemp) | |
local temp_file=$(mktemp) |
sed -E 's/(("image":|containerImage:|image:)[ ]*"?)([^"]+)("?)/\1docker.io\/\3\4/g' "$yaml_file" > "$temp_file" | ||
mv "$temp_file" "$yaml_file" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
sed -E 's/(("image":|containerImage:|image:)[ ]*"?)([^"]+)("?)/\1docker.io\/\3\4/g' "$yaml_file" > "$temp_file" | |
mv "$temp_file" "$yaml_file" | |
sed -E 's/(("image":|containerImage:|image:)[ ]*"?)([^"]+)("?)/\1docker.io\/\3\4/g' "$yaml_file" >"$temp_file" | |
mv "$temp_file" "$yaml_file" |
sed -E 's/(("image":|containerImage:|image:)[ ]*"?)([^"]+)("?)/\1docker.io\/\3\4/g' "$yaml_file" > "$temp_file" | ||
mv "$temp_file" "$yaml_file" | ||
|
||
echo "File '$yaml_file' updated successfully." |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
echo "File '$yaml_file' updated successfully." | |
echo "File '$yaml_file' updated successfully." |
.annotations["org.opencontainers.image.authors"] = "[email protected]" | | ||
.annotations["org.opencontainers.image.url"] = "https://percona.com" | | ||
.annotations["org.opencontainers.image.vendor"] = "Percona"' \ | ||
"${bundle_directory}/metadata/annotations.yaml" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
"${bundle_directory}/metadata/annotations.yaml" | |
"${bundle_directory}/metadata/annotations.yaml" |
|
||
ANNOTATIONS="${labels}" envsubst <bundle.Dockerfile >"${bundle_directory}/Dockerfile" | ||
|
||
awk '{gsub(/^[ \t]+/, " "); print}' "${bundle_directory}/Dockerfile" > "${bundle_directory}/Dockerfile.new" && mv "${bundle_directory}/Dockerfile.new" "${bundle_directory}/Dockerfile" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
awk '{gsub(/^[ \t]+/, " "); print}' "${bundle_directory}/Dockerfile" > "${bundle_directory}/Dockerfile.new" && mv "${bundle_directory}/Dockerfile.new" "${bundle_directory}/Dockerfile" | |
awk '{gsub(/^[ \t]+/, " "); print}' "${bundle_directory}/Dockerfile" >"${bundle_directory}/Dockerfile.new" && mv "${bundle_directory}/Dockerfile.new" "${bundle_directory}/Dockerfile" |
…percona-server-mongodb-operator into K8SPSMDB-1183_bundle_generation
# Render bundle CSV and strip comments. | ||
csv_stem=$(yq -r '.projectName' "${project_directory}/PROJECT") | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
.spec.minKubeVersion = env(minKubeVer)' bundle.csv.yaml >"${bundle_directory}/manifests/${file_name}.clusterserviceversion.yaml" | ||
|
||
if [ ${DISTRIBUTION} == "community" ]; then | ||
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml" | |
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml" |
installers/olm/generate.sh
Outdated
# delete blank lines. | ||
sed -i '' '/^$/d' "${bundle_directory}/manifests/${file_name}.clusterserviceversion.yaml" | ||
|
||
if >/dev/null command -v tree; then tree -C "${bundle_directory}"; fi |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shfmt] reported by reviewdog 🐶
if >/dev/null command -v tree; then tree -C "${bundle_directory}"; fi | |
if >/dev/null command -v tree; then tree -C "${bundle_directory}"; fi |
.spec.install.spec.deployments = [( env(deployment) | .[] |{ "name": .metadata.name, "spec": .spec} )] | | ||
.spec.minKubeVersion = env(minKubeVer)' bundle.csv.yaml >"${bundle_directory}/manifests/${file_name}.clusterserviceversion.yaml" | ||
|
||
if [ ${DISTRIBUTION} == "community" ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
if [ ${DISTRIBUTION} == "community" ]; then | |
if [ "${DISTRIBUTION}" == "community" ]; then |
|
||
if [ ${DISTRIBUTION} == "community" ]; then | ||
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml" | ||
elif [ ${DISTRIBUTION} == "redhat" ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
elif [ ${DISTRIBUTION} == "redhat" ]; then | |
elif [ "${DISTRIBUTION}" == "redhat" ]; then |
.metadata.name = strenv(name_certified)' \ | ||
"${bundle_directory}/manifests/${file_name}.clusterserviceversion.yaml" | ||
|
||
elif [ ${DISTRIBUTION} == "marketplace" ]; then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[shellcheck (suggestion)] reported by reviewdog 🐶
elif [ ${DISTRIBUTION} == "marketplace" ]; then | |
elif [ "${DISTRIBUTION}" == "marketplace" ]; then |
installers/olm/README.md
Outdated
2. Choose the mode (cluster or namespace) and update bundle/kustomization.yaml and makefile with necessary mode. | ||
3. update description in bundle.csv.yaml | ||
4. Update variables in makefile. | ||
5. ```make bundles``` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I get Stop when running make
. Wha should be provided here?
% make bundles make: *** No rule to make target
bundles'. Stop.
`
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have run it from wrong folder. Can we add here from where we need to run it?
installers/olm/README.md
Outdated
2. Choose the mode (cluster or namespace) and update bundle/kustomization.yaml and makefile with necessary mode. | ||
3. update description in bundle.csv.yaml | ||
4. Update variables in makefile. | ||
5. ```make bundles``` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When I run make
from correct folder I get gawk
error , it would be nice to check whether all required tools are installed.
Generating kustomize files in config/manifests
WARN[0000] Skipping definitions parsing: APIs root dir "api" does not exist
Kustomize files generated successfully
./generate.sh: line 141: gawk: command not found
make: *** [bundles/community] Error 127
installers/olm/README.md
Outdated
newName: perconalab/percona-server-mongodb-operator | ||
newTag: main | ||
``` | ||
4. Update spec.description in bundle.csv.yaml with features added in this release. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
give full path
commit: 46535d6 |
CHANGE DESCRIPTION
Problem:
Short explanation of the problem.
Cause:
Short explanation of the root cause of the issue if applicable.
Solution:
Short explanation of the solution we are providing with this PR.
CHECKLIST
Jira
Needs Doc
) and QA (Needs QA
)?Tests
compare/*-oc.yml
)?Config/Logging/Testability