Skip to content

Conversation

@nadavMiz
Copy link
Contributor

@nadavMiz nadavMiz commented Jun 15, 2025

Describe the Problem

Currently, we build the noobaa-base and noobaa-builder images for every commit and pull request. This significantly increases CI workflow time.

Explain the Changes

We now pull the base image from a Quay repository instead of building it on every run — unless the PR includes changes to files that require a new build:

  • package.json
  • base.dockerfile
  • .nvmrc

new build noobaa image flow:

  1. check for what files were changed in the PR
  2. If no critical files were changed:
    a. Pull the noobaa-base image from Quay
  3. if critical files were changed or pulling the image failed:
    a. Pull the noobaa-builder image from Quay.
    b. Build a new noobaa-base image from the builder image.
    c. If pulling the builder image also fails, build it locally.
  4. build noobaa and tester images based on base image (either pulled or created)

Additional Updates
Improved the display names of test jobs for better readability in the CI output.

Issues: Fixed #xxx / Gap #xxx

GAPS

Testing Instructions:

  1. create new PR with none of the above files changed: should pull the noobaa-base image from quay, and build core and tester images based of it
  2. create a new PR with the above files changed: should pull noobaa-builder image from quay, and build base, core, and tester images based of it
  3. in order to test fail to pull scenarios, can change the names of the quay repositories to an invalid names

in all cases build should succeed, and test worfklows should run

  • Doc added/updated
  • Tests added

Summary by CodeRabbit

Summary by CodeRabbit

  • Chores
    • Added descriptive names to multiple jobs in workflow runs for improved clarity in the GitHub Actions UI.
    • Enhanced the build process for Docker images in pull request workflows with more robust logic for building, pulling, and tagging images, as well as artifact creation and upload.

@coderabbitai
Copy link

coderabbitai bot commented Jun 15, 2025

Caution

Review failed

The pull request is closed.

"""

Walkthrough

Multiple GitHub Actions workflow jobs across various YAML files were updated to include explicit name attributes for improved job labeling. Additionally, the build-noobaa-image job in the run-pr-tests.yaml workflow was extensively restructured with conditional logic for building or pulling Docker images based on changed files and pull success.

Changes

Files Change Summary
.github/workflows/ceph-nsfs-s3-tests.yaml, .github/workflows/ceph-s3-tests.yaml, .github/workflows/nc_unit.yml, .github/workflows/postgres-unit-tests.yaml, .github/workflows/sanity-ssl.yaml, .github/workflows/sanity.yaml, .github/workflows/unit.yaml, .github/workflows/warp-nc-tests.yaml, .github/workflows/warp-tests.yaml Added explicit name attributes to jobs for clearer labeling in the workflow UI without changing job logic or steps.
.github/workflows/run-pr-tests.yaml Restructured build-noobaa-image job with multiple conditional steps for pulling or building Docker images, including retry logic and artifact uploads.

Suggested labels

size/L

Suggested reviewers

  • liranmauda
  • nimrod-becker
    """

📜 Recent review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between cb73044 and b94a690.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)

🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Explain this complex logic.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai explain this code block.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and explain its main purpose.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Support

Need help? Create a ticket on our support page for assistance with any issues or questions.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR.
  • @coderabbitai generate sequence diagram to generate a sequence diagram of the changes in this PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch 8 times, most recently from 4b6e6e2 to 5a4146c Compare June 16, 2025 12:01
@pull-request-size pull-request-size bot added size/M and removed size/S labels Jun 16, 2025
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 5a4146c to 275fd53 Compare June 16, 2025 14:10
@pull-request-size pull-request-size bot added size/S and removed size/M labels Jun 16, 2025
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 275fd53 to 699987e Compare June 16, 2025 14:25
@pull-request-size pull-request-size bot added size/M and removed size/S labels Jun 16, 2025
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch 12 times, most recently from 3b4ee11 to 58b3855 Compare June 16, 2025 15:59
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 0a24473 to ec26739 Compare June 19, 2025 06:41
@pull-request-size pull-request-size bot added size/L and removed size/M labels Jun 19, 2025
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch 4 times, most recently from 462ef7e to d697f5f Compare June 19, 2025 06:51
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 2

🧹 Nitpick comments (2)
.github/workflows/run-pr-tests.yaml (2)

71-74: Pin external actions to immutable references
You’re using tj-actions/changed-files@v44. To avoid unexpected breaking changes, consider pinning to a full commit SHA rather than a floating tag:

uses: tj-actions/changed-files@<commit-sha>

107-124: Tidy up builder-pull step and id naming

  1. Remove the trailing space on line 123 to prevent whitespace in the output file.
  2. The step id should_build_builder is misleading—it actually pulls the builder image. Consider renaming to pull_builder_image or similar for clarity.
-echo "should_build=${output}" >> $GITHUB_OUTPUT 
+echo "should_build=${output}" >> $GITHUB_OUTPUT
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between b16166f and d697f5f.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/sanity-ssl.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/ceph-s3-tests.yaml
🧰 Additional context used
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 123-123: trailing spaces

(trailing-spaces)


[warning] 145-145: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (3)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: Summary
🔇 Additional comments (6)
.github/workflows/run-pr-tests.yaml (6)

45-45: Explicit job naming added
The build-noobaa-image job now has a human-readable name attribute, improving the workflow UI and logs.


75-87: Base-image rebuild detection is good
The array-based check for critical files is straightforward and correct. The output should_build will drive the subsequent pull/build logic as intended.


89-105: Graceful retry logic for pulling base image
The loop with seq and retry semantics is solid. Tagging the pulled image to noobaa-base and capturing success in pull_succeed fits the intended flow.


125-133: Verify multi-line if: expression is parsed correctly
Splitting the if: ${{ … }} across two lines can confuse YAML parsing in GitHub Actions. Please confirm this condition behaves as intended, or collapse it into a single line or use a block scalar:

if: ${{ steps.should_build_base.outputs.should_build == 'true' || steps.pull_base_image.outputs.pull_succeed == 'false' }}

142-147: Explicit artifact upload step for noobaa image
Adding a descriptive name to this upload step improves readability when viewing artifacts.


149-154: Explicit artifact upload step for tester image
The Upload noobaa-tester docker image step is now named clearly, making it easier to track in the workflow UI.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 1

🧹 Nitpick comments (2)
.github/workflows/run-pr-tests.yaml (2)

78-87: Confirm critical file list and iteration logic
Verify that base.dockerfile (case-sensitive) matches the actual filename. Also consider reading the changed-files output line-by-line to avoid whitespace splitting:

while IFS= read -r file; do
  # ...
done <<< "${{ steps.changed_files.outputs.all_changed_files }}"

109-124: Remove trailing space in GitHub output echo
The line:

echo "should_build=${output}" >> $GITHUB_OUTPUT 

has an extra space at the end. Drop it to avoid adding unwanted whitespace:

- echo "should_build=${output}" >> $GITHUB_OUTPUT 
+ echo "should_build=${output}" >> $GITHUB_OUTPUT
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between b16166f and d697f5f.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • .github/workflows/sanity-ssl.yaml
🚧 Files skipped from review as they are similar to previous changes (8)
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/ceph-s3-tests.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
🧰 Additional context used
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 123-123: trailing spaces

(trailing-spaces)


[warning] 145-145: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (3)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: Summary
🔇 Additional comments (6)
.github/workflows/run-pr-tests.yaml (6)

45-45: Add a clear job name for readability
The name: Build Noobaa Image declaration makes the job’s purpose explicit in the UI and logs.


93-105: Pull retry loop is solid
This loop correctly retries pulling historical tags for the base image and tags the first successful pull as noobaa-base.


125-133: Conditional flags logic is correct
Using the should_build_builder flag to set flags="-o builder" only when a builder image was pulled ensures make base ${flags} behaves as intended.


135-135: Ensure correct target specification
Switching to make tester -o base makes the noobaa image build reference the prepared base image. This aligns with the designed workflow.


142-147: Explicit artifact upload step name
Naming the step Upload noobaa docker image clarifies which artifact is being published in the logs.


149-154: Explicit artifact upload step name
Naming the step Upload noobaa-tester docker image improves readability in the CI output.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from d697f5f to 9cb22ed Compare June 19, 2025 10:02
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

♻️ Duplicate comments (1)
.github/workflows/run-pr-tests.yaml (1)

134-136: Fix build commands for noobaa and tester.

The step name suggests building both images but only runs the tester target. You need to build the main noobaa image as well.

-run: make tester -o base
+run: |
+  make noobaa -o base
+  make tester -o base
🧹 Nitpick comments (3)
.github/workflows/run-pr-tests.yaml (3)

45-49: Fix indentation to satisfy YAMLlint.

YAMLlint flagged wrong indentation on lines 45 and 49. Align these lines to match the 2-space per level convention. For example:

-    name: Build Noobaa Image
+      name: Build Noobaa Image

-      - name: Prepare Tags
+        - name: Prepare Tags

123-123: Remove trailing whitespace.

YAMLlint reports a trailing space at the end of this line. Trim it to prevent formatting warnings.


145-145: Fix indentation to satisfy YAMLlint.

This line should be indented two spaces deeper to match the surrounding uses: and with: blocks:

-          name: noobaa-image
+            name: noobaa-image
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between d697f5f and 9cb22ed.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • .github/workflows/sanity-ssl.yaml
🚧 Files skipped from review as they are similar to previous changes (8)
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/ceph-s3-tests.yaml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (1)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 123-123: trailing spaces

(trailing-spaces)


[warning] 145-145: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-package-lock-validation
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: Summary
🔇 Additional comments (8)
.github/workflows/run-pr-tests.yaml (8)

45-45: Explicit job naming improves readability.

Adding name: Build Noobaa Image makes the workflow UI clearer and helps distinguish this job from others in the Actions view.


52-70: Prepare Tags step logic is solid.

The dynamic computation of BRANCH, BUILDER_TAGS, BASE_TAGS, and pull_tries is clear and correct. Emitting them via $GITHUB_OUTPUT for downstream consumption is the right approach.


71-88: Changed-files detection for base rebuild is correct.

The array declaration and loop correctly identify when critical files change. Using printf … | grep -x ensures exact filename matches.


89-105: Pull logic for noobaa-base image is robust.

Retrying pulls over a date range and tagging on success handles registry hiccups gracefully.


107-122: Pull logic for noobaa-builder image looks good.

The conditional and retry loop correctly decide when to fall back to building locally.


125-133: Build noobaa-base step conditional is accurate.

Using a shell if to toggle the -o builder flag based on the previous pull output is handled correctly, and make base ${flags} will run as intended.


142-147: Upload noobaa docker image step is sound.

Saving and uploading the noobaa image as an artifact with a 1-day retention aligns with the CI objective.


149-154: Upload noobaa-tester docker image step is correct.

The artifact upload for the tester image, including retention-days, is properly configured.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 9cb22ed to 071ab43 Compare June 19, 2025 10:30
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 1

♻️ Duplicate comments (1)
.github/workflows/run-pr-tests.yaml (1)

134-136: Incorrect build command for Noobaa images
The step named Build noobaa and tester images only runs make tester -o base, skipping the primary Noobaa image build. This will result in missing the main image artifact.

Apply this diff to split into two steps:

-      - name: Build noobaa and tester images
-        run: make tester -o base
+      - name: Build Noobaa image
+        run: make noobaa -o base
+
+      - name: Build noobaa-tester image
+        run: make tester -o base
🧹 Nitpick comments (3)
.github/workflows/run-pr-tests.yaml (3)

52-70: Quote and export environment variables
In the Prepare Tags step, wrap assignments in quotes and export them to prevent word-splitting. Also quote the $GITHUB_OUTPUT redirection to handle any path quirks.

Apply this diff inside the run block:

-          DOCKER_BUILDER_IMAGE=noobaa/noobaa-builder
-          DOCKER_BASE_IMAGE=noobaa/noobaa-base
+          export DOCKER_BUILDER_IMAGE="noobaa/noobaa-builder"
+          export DOCKER_BASE_IMAGE="noobaa/noobaa-base"
...
-          echo "basetags=${BASE_TAGS}" >> $GITHUB_OUTPUT
+          echo "basetags=${BASE_TAGS}" >> "$GITHUB_OUTPUT"
-          echo "buildertags=${BUILDER_TAGS}" >> $GITHUB_OUTPUT
+          echo "buildertags=${BUILDER_TAGS}" >> "$GITHUB_OUTPUT"
-          echo "pull_tries=${EARLIEST_VERSION_PAST}" >> $GITHUB_OUTPUT
+          echo "pull_tries=${EARLIEST_VERSION_PAST}" >> "$GITHUB_OUTPUT"

61-61: Remove trailing spaces in shell steps
Trailing whitespace in the comment on line 61 and the echo on line 123 causes lint errors. Remove the extra spaces at the end of these lines.

Also applies to: 123-123


128-133: Initialize flags before conditional usage
If the builder pull succeeds, $flags may be undefined when passed to make base. Define flags="" before the if to prevent unbound variable warnings.

-run: |
-  if [ "${{ steps.should_build_builder.outputs.should_build }}" = 'false' ]; then
-    flags="-o builder"
-  fi
-  make base ${flags}
+run: |
+  flags=""
+  if [ "${{ steps.should_build_builder.outputs.should_build }}" = 'false' ]; then
+    flags="-o builder"
+  fi
+  make base ${flags}
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 9cb22ed and 071ab43.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • .github/workflows/nc_unit.yml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/unit.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/sanity-ssl.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/ceph-s3-tests.yaml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (1)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 61-61: trailing spaces

(trailing-spaces)


[error] 123-123: trailing spaces

(trailing-spaces)


[warning] 145-145: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: run-package-lock-validation
  • GitHub Check: Summary
🔇 Additional comments (3)
.github/workflows/run-pr-tests.yaml (3)

75-88: The array declaration and loop in Should build noobaa base image were already corrected and match the expected behavior.


89-106: Pull base image logic looks sound
The retry loop correctly attempts to pull the noobaa-base image across dates and tags it locally upon success.


107-124: Pull builder image logic is valid
The conditional retry over the builder tags and the output flag should_build correctly determine whether to fall back to a local build.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 071ab43 to 0cf2663 Compare June 19, 2025 10:47
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 4

🧹 Nitpick comments (2)
.github/workflows/run-pr-tests.yaml (2)

143-148: Consistent step naming.
Capitalize “Docker” in the step name to match other job labels:

-      - name: Upload noobaa docker image
+      - name: Upload Noobaa Docker image

150-155: Consistent step naming.
Align with naming conventions by capitalizing and formatting:

-      - name: Upload noobaa-tester docker image
+      - name: Upload Noobaa-Tester Docker image
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 071ab43 and 0cf2663.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/ceph-s3-tests.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/sanity-ssl.yaml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (1)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 124-124: trailing spaces

(trailing-spaces)


[warning] 146-146: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-package-lock-validation
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: Summary
🔇 Additional comments (4)
.github/workflows/run-pr-tests.yaml (4)

45-45: Explicit job name improves readability.
Adding name: Build Noobaa Image aligns with other workflows and makes the job easier to identify in the UI.


52-70: Tag preparation logic is sound.
This block correctly derives builder and base image tags from the branch context and exports them via GITHUB_OUTPUT.


71-73: Verify changed-files action version.
Ensure that tj-actions/changed-files@v44 exists and is supported; consider pinning to a major version or digest to avoid unexpected breaks if a new release is published.


75-87: Selective base rebuild on critical files.
The loop over changed files correctly triggers a base-image rebuild only when package.json, base.dockerfile, or .nvmrc are modified.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 0cf2663 to 26f0195 Compare June 19, 2025 11:05
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Nitpick comments (3)
.github/workflows/run-pr-tests.yaml (3)

107-124: Remove trailing space in output echo
The final echo appends a trailing space, which can inject whitespace into the should_build output and break subsequent if conditions.

Apply this diff:

-          echo "should_build=${output}" >> $GITHUB_OUTPUT 
+          echo "should_build=${output}" >> $GITHUB_OUTPUT

143-148: Fix indentation in upload step
YAMLlint flags inconsistent indentation in the Upload noobaa docker image block. Align each level by 2 spaces under steps:. For example:

-      - name: Upload noobaa docker image
-        uses: actions/upload-artifact@v4
-        with:
-          name: noobaa-image
-          path: noobaa.tar
-          retention-days: "1"
+      - name: Upload noobaa docker image
+        uses: actions/upload-artifact@v4
+        with:
+          name: noobaa-image
+          path: noobaa.tar
+          retention-days: "1"

150-155: Align indentation for tester upload
Similarly, correct the indentation for the Upload noobaa-tester docker image step:

-      - name: Upload noobaa-tester docker image
-        uses: actions/upload-artifact@v4
-        with:
-          name: noobaa-tester
-          path: noobaa-tester.tar
-          retention-days: "1"
+      - name: Upload noobaa-tester docker image
+        uses: actions/upload-artifact@v4
+        with:
+          name: noobaa-tester
+          path: noobaa-tester.tar
+          retention-days: "1"
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 0cf2663 and 26f0195.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/unit.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/sanity-ssl.yaml
  • .github/workflows/ceph-s3-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/nc_unit.yml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (3)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:135-136
Timestamp: 2025-06-19T11:03:49.906Z
Learning: In the noobaa-core project, the `make tester` command also calls `make noobaa` due to makefile target dependencies, so running `make tester` will build both the noobaa and tester images.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:126-134
Timestamp: 2025-06-19T11:04:50.148Z
Learning: In make commands, the `-o` flag followed by a target name (e.g., `-o builder`) tells make to skip building that specific target, assuming it's already up to date. This is used in the noobaa-core project's workflow to skip building the builder image when it was successfully pulled from a registry.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 124-124: trailing spaces

(trailing-spaces)


[warning] 146-146: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-package-lock-validation
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: Summary
🔇 Additional comments (6)
.github/workflows/run-pr-tests.yaml (6)

45-45: Add explicit job name for clarity
Naming the build-noobaa-image job as "Build Noobaa Image" improves readability in the Actions UI.


52-63: Dynamic tag preparation for pull vs push
The Prepare Tags step correctly distinguishes pull requests (github.base_ref) from push events (github.ref_name) and emits buildertags, basetags, and pull_tries via $GITHUB_OUTPUT. This enables downstream steps to use consistent Docker tag prefixes.

Also applies to: 67-70


78-86: Detect base rebuild on critical file changes
The should_build_base logic uses a proper Bash array and exact-match grep to trigger a base-image rebuild only when package.json, base.dockerfile, or .nvmrc change.


89-99: Pull historical base images with retries
The loop over seq 0 ${{ steps.prep.outputs.pull_tries }} and date-based tags is a robust way to fetch recent images. Breaking on first success and tagging locally (noobaa-base) is implemented correctly.


126-134: Conditional base-image build with skip-flag
The make base ${flags} invocation correctly uses -o builder to skip rebuilding the builder stage when the builder image was pulled, otherwise building both stages as needed.


135-136: Leverage Makefile dependencies for combined build
Running make tester -o base is sufficient to build both the primary noobaa and tester images, thanks to the Makefile’s target dependencies.

@nadavMiz nadavMiz requested a review from dannyzaken June 19, 2025 11:18
@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 26f0195 to 3f8e931 Compare June 22, 2025 08:58
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Nitpick comments (1)
.github/workflows/run-pr-tests.yaml (1)

124-124: Remove trailing space in GitHub output echo.
An extra space after the redirect can introduce unintended whitespace in the output.

Apply this diff:

-          echo "should_build=${output}" >> $GITHUB_OUTPUT 
+          echo "should_build=${output}" >> $GITHUB_OUTPUT
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 26f0195 and 3f8e931.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • .github/workflows/ceph-nsfs-s3-tests.yaml
🚧 Files skipped from review as they are similar to previous changes (8)
  • .github/workflows/sanity.yaml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/sanity-ssl.yaml
  • .github/workflows/ceph-s3-tests.yaml
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/warp-tests.yaml
  • .github/workflows/warp-nc-tests.yaml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (3)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:135-136
Timestamp: 2025-06-19T11:03:49.906Z
Learning: In the noobaa-core project, the `make tester` command also calls `make noobaa` due to makefile target dependencies, so running `make tester` will build both the noobaa and tester images.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:126-134
Timestamp: 2025-06-19T11:04:50.148Z
Learning: In make commands, the `-o` flag followed by a target name (e.g., `-o builder`) tells make to skip building that specific target, assuming it's already up to date. This is used in the noobaa-core project's workflow to skip building the builder image when it was successfully pulled from a registry.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 124-124: trailing spaces

(trailing-spaces)


[warning] 146-146: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: run-package-lock-validation
  • GitHub Check: Build Noobaa Image
  • GitHub Check: Summary
🔇 Additional comments (9)
.github/workflows/run-pr-tests.yaml (9)

45-45: Explicit job naming improves workflow readability.
Adding a descriptive name for the build-noobaa-image job makes the CI UI more understandable.


52-63: Tag preparation logic is solid.
Deriving branch-based Docker tags and exporting them as outputs sets up clear downstream pulling and building.


71-74: Leveraging Changed-Files action for precise rebuild detection.
Using tj-actions/changed-files@v44 correctly enumerates modified files, enabling conditional base-image rebuilds.


78-86: Efficient base-image rebuild detection.
Looping through ${{ steps.changed_files.outputs.all_changed_files }} with exact-match grep flags only critical file changes.


89-106: Robust pull retry loop for base image.
Iterating date-tagged pulls up to pull_tries days maximizes image reuse before falling back to build.


126-134: Correct conditional flag usage.
Using -o builder to skip the builder phase when it's already pulled optimizes build time as intended.


135-136: Makefile dependencies leveraged correctly.
make tester -o base properly builds both primary and tester images via existing makefile rules.


143-148: Artifact upload is well configured.
Saving and uploading noobaa.tar ensures the built image is available for downstream debugging.


150-155: Separate tester image artifact for clarity.
Uploading noobaa-tester.tar under its own name aids in artifact management.

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from 3f8e931 to cb73044 Compare June 22, 2025 10:15
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Nitpick comments (2)
.github/workflows/run-pr-tests.yaml (2)

124-124: Remove trailing whitespace
The echo to $GITHUB_OUTPUT at the end of the builder pull step has a trailing space, which can cause malformed output.


146-146: Fix indentation under with
Ensure the keys (name, path, retention-days) under the with: block are indented two spaces further to satisfy YAML syntax.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 3f8e931 and cb73044.

📒 Files selected for processing (10)
  • .github/workflows/ceph-nsfs-s3-tests.yaml (1 hunks)
  • .github/workflows/ceph-s3-tests.yaml (1 hunks)
  • .github/workflows/nc_unit.yml (1 hunks)
  • .github/workflows/postgres-unit-tests.yaml (1 hunks)
  • .github/workflows/run-pr-tests.yaml (1 hunks)
  • .github/workflows/sanity-ssl.yaml (1 hunks)
  • .github/workflows/sanity.yaml (1 hunks)
  • .github/workflows/unit.yaml (1 hunks)
  • .github/workflows/warp-nc-tests.yaml (1 hunks)
  • .github/workflows/warp-tests.yaml (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (9)
  • .github/workflows/nc_unit.yml
  • .github/workflows/unit.yaml
  • .github/workflows/postgres-unit-tests.yaml
  • .github/workflows/sanity.yaml
  • .github/workflows/ceph-s3-tests.yaml
  • .github/workflows/sanity-ssl.yaml
  • .github/workflows/warp-nc-tests.yaml
  • .github/workflows/ceph-nsfs-s3-tests.yaml
  • .github/workflows/warp-tests.yaml
🧰 Additional context used
🧠 Learnings (1)
.github/workflows/run-pr-tests.yaml (3)
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:135-136
Timestamp: 2025-06-19T11:03:49.906Z
Learning: In the noobaa-core project, the `make tester` command also calls `make noobaa` due to makefile target dependencies, so running `make tester` will build both the noobaa and tester images.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:52-70
Timestamp: 2025-06-19T10:01:46.926Z
Learning: In the noobaa-core repository, branch names don't contain forward slashes, so Docker tag sanitization is not needed in GitHub Actions workflows. Manual full builds and automated builds should use consistent tag naming to avoid mismatches.
Learnt from: nadavMiz
PR: noobaa/noobaa-core#9099
File: .github/workflows/run-pr-tests.yaml:126-134
Timestamp: 2025-06-19T11:04:50.148Z
Learning: In make commands, the `-o` flag followed by a target name (e.g., `-o builder`) tells make to skip building that specific target, assuming it's already up to date. This is used in the noobaa-core project's workflow to skip building the builder image when it was successfully pulled from a registry.
🪛 YAMLlint (1.37.1)
.github/workflows/run-pr-tests.yaml

[warning] 45-45: wrong indentation: expected 8 but found 4

(indentation)


[warning] 49-49: wrong indentation: expected 10 but found 6

(indentation)


[error] 124-124: trailing spaces

(trailing-spaces)


[warning] 146-146: wrong indentation: expected 14 but found 10

(indentation)

⏰ Context from checks skipped due to timeout of 90000ms (4)
  • GitHub Check: Build Noobaa Image
  • GitHub Check: run-jest-unit-tests
  • GitHub Check: run-package-lock-validation
  • GitHub Check: Summary
🔇 Additional comments (9)
.github/workflows/run-pr-tests.yaml (9)

45-45: Named job improves readability
Adding an explicit name for the build-noobaa-image job clarifies its purpose in the workflow UI.


52-70: Tag preparation logic is solid
Using github.base_ref for PRs versus github.ref_name for pushes and echoing basetags, buildertags, and pull_tries is correct and clear.


78-88: Efficient base-image change detection
The array declaration and exact-match grep ensure only critical files trigger a rebuild.


89-106: Robust pull loop for the base image
Switching to seq for retries, proper logging, and tagging logic is effective.


107-124: Builder pull logic is sound
Conditions correctly handle when to pull the builder image from Quay before deciding on a local build.


126-134: Skip builder phase when image is pulled
The -o builder flag is correctly applied only when the builder image pull succeeds, leveraging make’s -o behavior to skip targets.


135-136: Leverage makefile dependencies
Using make tester -o base appropriately builds both the noobaa and tester images due to the existing target relationship.


143-149: Artifact upload for noobaa image
The step correctly uses actions/upload-artifact@v4 to persist the noobaa.tar image for downstream jobs.


150-156: Artifact upload for tester image
The step correctly persists the noobaa-tester.tar artifact using actions/upload-artifact@v4.

@liranmauda
Copy link
Contributor

@nadavMiz Any name change will need a change in the required test in the checks

@nimrod-becker FYI

@nadavMiz nadavMiz force-pushed the ci-download-bas-image branch from cb73044 to b94a690 Compare June 23, 2025 12:07
@nimrod-becker nimrod-becker merged commit 501162c into noobaa:master Jun 23, 2025
4 of 7 checks passed
@coderabbitai coderabbitai bot mentioned this pull request Jun 30, 2025
2 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants