<aside> ➡️ Alternatively to Magento Commerce Cloud consider using ReadyMage. ReadyMage is ScandiPWA optimized cloud hosting and supports Magento Commerce projects.
</aside>
ScandiPWA setup on Magento Commerce Cloud requires adjusting 2 files in the project root folder that are used for deployment flow.
Requires adjustments to allow pushing code from BitBucket of the git repository to Magento Cloud project repository. CI/CD is used for this purpose.
Git authentication is made using public keys. Generate the key in the BitBucket repository and add it to the Magento Cloud in the admin panel.
Here is an example of how the bitbucket-pipelines.yaml
file should be configured. It contains configuration for 2 environments:
<aside> ➡️ Replace example credentials and git links with your project actual links.
</aside>
pipelines:
branches:
master:
- step:
image: luzhzh/git-client
script:
- set -e
- set -o pipefail
- git clone --branch master [email protected]:exampleorganization/exampleproject.git exampleproject
- cd exampleproject/
- git config --global user.email "[email protected]"
- git config --global user.name "Deploy Script"
- git remote add mc [email protected]:example.git
- git pull --no-edit mc master
- git push mc master
- cd ../
- rm -rf exampleproject.git/
stage:
- step:
image: luzhzh/git-client
script:
- set -e
- set -o pipefail
- git clone --branch stage [email protected]:exampleorganization/exampleproject.git exampleproject
- cd exampleproject/
- git config --global user.email "[email protected]"
- git config --global user.name "Deploy Script"
- git remote add mc [email protected]:example.git
- git pull --no-edit mc stage
- git push mc stage
- cd ../
- rm -rf exampleproject.git/
definitions:
caches:
node-custom: app/design/frontend/ExampleProject/pwa/node_modules
ScandiPWA compilation is done in magento.app.yaml
file. Within it options and commands are configured to be run during deployment.
Here is part of the file that is responsible for ScandiPWA compilation which has to be added to the existing magento.app.yaml
file content.
hooks:
# We run build hooks before your application has been packaged.
build: |
set -e
git apply m2-patches/*.patch
unset NPM_CONFIG_PREFIX
curl -o- <https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh> | dash
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"
nvm current
nvm install 12.16.1
(cd ./app/design/frontend/ExampleProject/pwa/ && rm -rf node_modules && npm ci)
(cd ./app/design/frontend/ExampleProject/pwa/ && npm run build)
php ./vendor/bin/ece-tools run scenario/build/generate.xml
php ./vendor/bin/ece-tools run scenario/build/transfer.xml
# We run deploy hook after your application has been deployed and started.
deploy: |
php ./vendor/bin/ece-tools run scenario/deploy.xml
# We run post deploy hook to clean and warm the cache. Available with ECE-Tools 2002.0.10.
post_deploy: |
php ./vendor/bin/ece-tools run scenario/post-deploy.xml