Skip to content

SAP Commerce Cloud - Build

This GitHub Action provides the following functionalities to perform build operations on SAP Commerce Cloud in the Public Cloud (CCv2) projects.

Project Status

🚀 Completed Items

  • Trigger Build: Trigger SAP Commerce Cloud build.
  • Build Notification: Sends a notification when a build is triggered in CCv2.
  • Build Status Notification: Frequently check the build status and send notifications when success or failure.
  • Retry On Failure: Retry the build creation if it fails for the maxRetries times.
  • Notifications: Notify the user via email or webhook when the build is triggered or completed.
    • Create Build: Triggered with build is created in CCv2.
    • Build Completed: Triggered when the build is completed in CCv2 whether it is success or failure.
    • Slack: Send notifications to Slack.
    • Microsoft Teams: Send notifications to Microsoft Teams.

🔧 Planned Items

  • Testing: Improve test coverage with end-to-end tests.
  • Notifications: Notify the user via email or webhook when the build is triggered or completed.
    • Email: Send notifications to email.
    • SendGrid: Send notifications using SendGrid.
    • AWS SES: Send notifications using AWS SES.
    • Custom SMTP: Send notifications using custom SMTP.
    • Similar SMTP services.

Getting Started

Check this GitHub Action on the GitHub Marketplace

Example Workflow

Create a workflow YAML file (e.g., .github/workflows/build.yml) in your repository with the following content:

.github/workflows/build.yml
name: Build SAP Commerce Cloud
on:
push:
branches:
- 'release/*'
jobs:
test-build-action:
name: GitHub Actions Test
runs-on: ubuntu-latest
env:
SAP_CCV2_API_TOKEN: ${{ secrets.SAP_CCV2_API_TOKEN }}
SAP_CCV2_SUB_CODE: ${{ secrets.SAP_CCV2_SUB_CODE }}
WEBHOOK_URL: ${{ secrets.WEBHOOK_URL }}
steps:
- name: Checkout
id: checkout
uses: actions/checkout@v4
- name: SAP Commerce Build
id: build-action
uses: sap-cx-actions/commerce-build@v1
with:
branch: release/v1.0.0
buildName: Release v1.0.0
checkStatusInterval: 60000
retryOnFailure: true
maxRetries: 3
notify: true
dryRun: true
timezone: America/New_York
- name: Print Output
id: output
run: |
echo "Build Code: ${{ steps.build-action.outputs.buildCode }}, Build Status: ${{ steps.build-action.outputs.buildStatus }}"

Environment Variables

VariablePurposeRequired
SAP_CCV2_API_TOKENSAP Commerce Cloud in the Public Cloud (CCv2) API Token.True
SAP_CCV2_SUB_CODESAP Commerce Cloud in the Public Cloud (CCv2) Subscription CodeTrue
WEBHOOK_URLThe Webhook URL to send notifications.False

Inputs

AttributePurposeRequiredDefaultExample
branchThe branch name or tag to trigger the build.Truerelease/v1.0.0
buildNameThe name of the build.False
checkStatusIntervalThe interval in milliseconds to check the build status.False300000 (5 minutes)
retryOnFailureRetry the build if failed.Falsefalse
maxRetriesThe maximum number of retries.False3
notifySend notifications on the build status.Falsefalse
dryRunRun the action in dry-run mode. If true, the action will not trigger the build in actual CCv2.Falsefalse
timezoneThe timezone to use for the timestamps.FalseAmerica/New_York

Outputs

  • buildCode - The build code of the triggered build.
  • buildStatus - The status of the triggered build.