Skip to content
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

Open
wants to merge 14 commits into
base: main
Choose a base branch
from

Conversation

nmarukovich
Copy link
Contributor

@nmarukovich nmarukovich commented Oct 21, 2024

K8SPSMDB-1183 Powered by Pull Request Badge

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

  • Is the Jira ticket created and referenced properly?
  • Does the Jira ticket have the proper statuses for documentation (Needs Doc) and QA (Needs QA)?
  • Does the Jira ticket link to the proper milestone (Fix Version field)?

Tests

  • Is an E2E test/test case added for the new feature/change?
  • Are unit tests added where appropriate?
  • Are OpenShift compare files changed for E2E tests (compare/*-oc.yml)?

Config/Logging/Testability

  • Are all needed new/changed options added to default YAML files?
  • Are all needed new/changed options added to the Helm Chart?
  • Did we add proper logging messages for operator actions?
  • Did we ensure compatibility with the previous version or cluster upgrade process?
  • Does the change support oldest and newest supported MongoDB version?
  • Does the change support oldest and newest supported Kubernetes version?

installers/olm/generate.sh Show resolved Hide resolved
installers/olm/generate.sh Show resolved Hide resolved

KUSTOMIZE = $(REPO_ROOT)/bin/kustomize
kustomize: ## Download kustomize locally if necessary.
$(call go-get-tool,$(KUSTOMIZE),sigs.k8s.io/kustomize/kustomize/[email protected])
Copy link
Contributor

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

Copy link
Contributor Author

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'
Copy link
Contributor

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

Copy link
Contributor Author

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)'
Copy link
Contributor

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'
Copy link
Contributor

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.
Copy link
Contributor

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

Copy link
Contributor Author

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.

@@ -0,0 +1,6 @@
1. Set VERSION env variable
Copy link
Contributor

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" ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes.

@@ -0,0 +1,6 @@
1. Set VERSION env variable
2. Update rbac and operator in config
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what does this mean?

@@ -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.
Copy link
Contributor

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?

@egegunes
Copy link
Contributor

also please add a PR description, it'd be great if you put some usage example

@egegunes egegunes added this to the v1.19.0 milestone Nov 25, 2024
.annotations["com.redhat.openshift.versions"] = env(openshift_supported_versions)' \
bundle.annotations.yaml >"${bundle_directory}/metadata/annotations.yaml"

if [ ${DISTRIBUTION} == 'community' ]; then
Copy link
Contributor

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 🐶

Suggested change
if [ ${DISTRIBUTION} == 'community' ]; then
if [ "${DISTRIBUTION}" == 'community' ]; then

"${bundle_directory}/metadata/annotations.yaml"

# certified-operators
elif [ ${DISTRIBUTION} == 'redhat' ]; then
Copy link
Contributor

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 🐶

Suggested change
elif [ ${DISTRIBUTION} == 'redhat' ]; then
elif [ "${DISTRIBUTION}" == 'redhat' ]; then

"${bundle_directory}/metadata/annotations.yaml"

# redhat-marketplace
elif [ ${DISTRIBUTION} == 'marketplace' ]; then
Copy link
Contributor

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 🐶

Suggested change
elif [ ${DISTRIBUTION} == 'marketplace' ]; then
elif [ "${DISTRIBUTION}" == 'marketplace' ]; then

export role="${mode}Role"

update_yaml_images() {
local yaml_file="$1"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
local yaml_file="$1"
local yaml_file="$1"

Comment on lines +46 to +49
if [ ! -f "$yaml_file" ]; then
echo "Error: File '$yaml_file' does not exist."
return 1
fi
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
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)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
local temp_file=$(mktemp)
local temp_file=$(mktemp)

Comment on lines +53 to +54
sed -E 's/(("image":|containerImage:|image:)[ ]*"?)([^"]+)("?)/\1docker.io\/\3\4/g' "$yaml_file" > "$temp_file"
mv "$temp_file" "$yaml_file"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
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."
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
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"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
"${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"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
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"

# Render bundle CSV and strip comments.
csv_stem=$(yq -r '.projectName' "${project_directory}/PROJECT")


Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change

.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"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml"
update_yaml_images "bundles/$DISTRIBUTION/manifests/${file_name}.clusterserviceversion.yaml"

# 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
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[shfmt] reported by reviewdog 🐶

Suggested change
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
Copy link
Contributor

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 🐶

Suggested change
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
Copy link
Contributor

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 🐶

Suggested change
elif [ ${DISTRIBUTION} == "redhat" ]; then
elif [ "${DISTRIBUTION}" == "redhat" ]; then

.metadata.name = strenv(name_certified)' \
"${bundle_directory}/manifests/${file_name}.clusterserviceversion.yaml"

elif [ ${DISTRIBUTION} == "marketplace" ]; then
Copy link
Contributor

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 🐶

Suggested change
elif [ ${DISTRIBUTION} == "marketplace" ]; then
elif [ "${DISTRIBUTION}" == "marketplace" ]; then

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```
Copy link
Contributor

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 targetbundles'. Stop.
`

Copy link
Contributor

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?

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```
Copy link
Contributor

@eleo007 eleo007 Jan 20, 2025

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

@nmarukovich nmarukovich requested a review from gkech as a code owner January 20, 2025 19:37
@pull-request-size pull-request-size bot added size/XL 500-999 lines and removed size/XXL 1000+ lines labels Jan 20, 2025
newName: perconalab/percona-server-mongodb-operator
newTag: main
```
4. Update spec.description in bundle.csv.yaml with features added in this release.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

give full path

@JNKPercona
Copy link
Collaborator

Test name Status
arbiter passed
balancer passed
custom-replset-name passed
custom-tls passed
custom-users-roles passed
custom-users-roles-sharded passed
cross-site-sharded passed
data-at-rest-encryption passed
data-sharded passed
demand-backup passed
demand-backup-fs passed
demand-backup-eks-credentials-irsa passed
demand-backup-physical passed
demand-backup-physical-sharded passed
demand-backup-sharded passed
expose-sharded passed
ignore-labels-annotations passed
init-deploy passed
finalizer passed
ldap passed
ldap-tls passed
limits passed
liveness passed
mongod-major-upgrade passed
mongod-major-upgrade-sharded passed
monitoring-2-0 passed
multi-cluster-service failure
non-voting passed
one-pod passed
operator-self-healing-chaos passed
pitr passed
pitr-sharded passed
pitr-physical passed
pvc-resize passed
recover-no-primary passed
replset-overrides passed
rs-shard-migration passed
scaling passed
scheduled-backup passed
security-context passed
self-healing-chaos passed
service-per-pod passed
serviceless-external-nodes passed
smart-update passed
split-horizon passed
stable-resource-version passed
storage passed
tls-issue-cert-manager passed
upgrade passed
upgrade-consistency passed
upgrade-consistency-sharded-tls passed
upgrade-sharded passed
users passed
version-service passed
We run 54 out of 54

commit: 46535d6
image: perconalab/percona-server-mongodb-operator:PR-1681-46535d60

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
size/XL 500-999 lines
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants