Skip to content

feat: add enter/leave helpers and UI map #6337

feat: add enter/leave helpers and UI map

feat: add enter/leave helpers and UI map #6337

Workflow file for this run

on:
push:
branches:
- main
pull_request:
release:
types:
- created
env:
IS_A_PR: ${{ github.event.pull_request.number != 'null' && github.head_ref != 'protocol-squad' }}
name: CI
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: install
run: make install
- name: lint
run: make lint
- name: lint-packages
run: make lint-packages
docs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: docs
run: make docs
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: install
run: make install
- name: build
run: make build
- name: test
env:
NODE_OPTIONS: "--max_old_space_size=4096"
run: make test-coverage
- name: test-cli
run: make test-cli
- name: test-inspector
env:
NODE_OPTIONS: "--max_old_space_size=4096"
run: make test-inspector
- uses: codecov/codecov-action@v3
if: always()
with:
fail_ci_if_error: false # optional (default = false)
verbose: true # optional (default = false)
- name: prepare releasable packages
run: make prepare
test-e2e:
needs: [notify_deployment]
runs-on: ubuntu-latest
if: false
steps:
- uses: actions/github-script@v6
id: get-cloudflare-url
env:
BRANCH: ${{ github.head_ref || github.ref }}
with:
script: return `${process.env.BRANCH.replaceAll('/', '-').substr(0, 28)}.${context.repo.repo}.pages.dev`
result-encoding: string
- uses: actions/checkout@master
- uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: install repo
run: npm ci
- name: install inspector
run: cd packages/@dcl/inspector && npm i && cd ../../../
- name: test-inspector E2E
env:
NODE_OPTIONS: "--max_old_space_size=4096"
run: E2E_URL=https://${{steps.get-cloudflare-url.outputs.result}}/inspector make test-inspector-e2e
build:
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
outputs:
decentraland_sdk_s3_bucket_key: ${{ steps.publish_decentraland_sdk.outputs.s3-bucket-key }}
decentraland_sdk_commands_s3_bucket_key: ${{ steps.publish_decentraland_sdk_commands.outputs.s3-bucket-key }}
decentraland_inspector_s3_bucket_key: ${{ steps.publish_decentraland_inspector.outputs.s3-bucket-key }}
decentraland_js_runtime_s3_bucket_key: ${{ steps.publish_dcl_js_runtime.outputs.s3-bucket-key }}
decentraland_ecs_bucket_key: ${{ steps.publish_ecs.outputs.s3-bucket-key }}
steps:
- name: (PR) Check if it's a PR
if: ${{ env.IS_A_PR == 'true' }}
run: |
echo "run from a PR"
echo "from env '${{env.IS_A_PR}}'"
echo "- '${{github.event.pull_request.number}}'"
echo "- env '${{github.head_ref}}'"
- uses: actions/checkout@master
- uses: actions/setup-node@v3
with:
node-version: 20
cache: 'npm'
- name: install
run: make install
- name: update version of packages/@dcl/sdk/package.json, this version will be used for all packages
uses: menduz/oddish-action@master
with:
cwd: ./packages/@dcl/sdk
deterministic-snapshot: true
only-update-versions: true
- name: build
run: make build
- name: prepare releasable packages
run: make prepare
- name: 'Upload Artifact'
uses: actions/upload-artifact@v4
with:
name: built-artifacts
path: 'packages/**/*.tgz'
retention-days: 5
- name: publish @dcl/js-runtime package
id: publish_dcl_js_runtime
uses: menduz/oddish-action@master
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/js-runtime
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}/@dcl/js-runtime'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: publish @dcl/ecs package
uses: menduz/oddish-action@master
id: publish_ecs
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/ecs
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}/@dcl/ecs'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: (PR) change @dcl/react-ecs dependencies versions to point to s3 url
working-directory: ./packages/@dcl/react-ecs
if: ${{ env.IS_A_PR == 'true' }}
run: |
node -e "\
let pkg=require('./package.json');\
pkg.dependencies['@dcl/ecs']='$ECS_S3_URL';\
require('fs').writeFileSync('package.json', JSON.stringify(pkg, null, 2));\
"
env:
ECS_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_ecs.outputs.s3-bucket-key }}
- name: publish @dcl/react-ecs package
id: publish_dcl_react_ecs
uses: menduz/oddish-action@master
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/react-ecs
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}/@dcl/react-ecs'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: publish @dcl/inspector package
uses: menduz/oddish-action@master
id: publish_decentraland_inspector
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/inspector
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}/@dcl/inspector'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: (PR) change @dcl/sdk-commands dependencies versions to point to s3 url
working-directory: ./packages/@dcl/sdk-commands
if: ${{ env.IS_A_PR == 'true' }}
run: |
node -e "\
let pkg=require('./package.json');\
pkg.dependencies['@dcl/inspector']='$INSPECTOR_URL';\
pkg.dependencies['@dcl/ecs']='$ECS_S3_URL';\
require('fs').writeFileSync('package.json', JSON.stringify(pkg, null, 2));\
"
env:
ECS_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_ecs.outputs.s3-bucket-key }}
INSPECTOR_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_decentraland_inspector.outputs.s3-bucket-key }}
- name: publish @dcl/sdk-commands package
uses: menduz/oddish-action@master
id: publish_decentraland_sdk_commands
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/sdk-commands
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: (PR) change @dcl/sdk version to s3 url
working-directory: ./packages/@dcl/sdk
if: ${{ env.IS_A_PR == 'true' }}
run: |
node -e "\
let pkg=require('./package.json');\
pkg.dependencies['@dcl/inspector']='$INSPECTOR_URL';\
pkg.dependencies['@dcl/js-runtime']='$JS_RUNTIME_S3_URL';\
pkg.dependencies['@dcl/ecs']='$ECS_S3_URL';\
pkg.dependencies['@dcl/react-ecs']='$REACT_ECS_S3_URL';\
pkg.dependencies['@dcl/sdk-commands']='$SDK_COMMANDS_S3_URL';\
require('fs').writeFileSync('package.json', JSON.stringify(pkg, null, 2));\
"
env:
INSPECTOR_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_decentraland_inspector.outputs.s3-bucket-key }}
REACT_ECS_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_dcl_react_ecs.outputs.s3-bucket-key }}
ECS_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_ecs.outputs.s3-bucket-key }}
ROLLUP_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_dcl_rollup.outputs.s3-bucket-key }}
JS_RUNTIME_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_dcl_js_runtime.outputs.s3-bucket-key }}
SDK_COMMANDS_S3_URL: ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ steps.publish_decentraland_sdk_commands.outputs.s3-bucket-key }}
- name: publish @dcl/sdk package
uses: menduz/oddish-action@master
id: publish_decentraland_sdk
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/sdk
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: playground upload to s3
run: npx @dcl/cdn-uploader@next --bucket ${{ secrets.SDK_TEAM_S3_BUCKET }} --local-folder $(pwd)/packages/@dcl/playground-assets/dist --bucket-folder '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}/playground-assets'
env:
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
- name: publish @dcl/playground-assets package
uses: menduz/oddish-action@master
id: publish_playground_assets
with:
registry-url: 'https://registry.npmjs.org'
custom-tag: protocol-squad
branch-to-custom-tag: protocol-squad
access: public
cwd: ./packages/@dcl/playground-assets
## use action runId instead of current date to generate snapshot numbers
deterministic-snapshot: true
## sign the deployment
provenance: true
## publish every package to s3
s3-bucket: ${{ secrets.SDK_TEAM_S3_BUCKET }}
s3-bucket-region: ${{ secrets.SDK_TEAM_AWS_REGION }}
s3-bucket-key-prefix: '@dcl/js-sdk-toolchain/branch/${{ github.head_ref || github.ref }}'
env:
BRANCH_NAME: ${{ github.head_ref }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}
notify_deployment:
needs: [build]
if: github.event.pull_request.number != 'null' && github.head_ref != 'protocol-squad'
runs-on: ubuntu-latest
name: Deployment Notification
steps:
- uses: actions/github-script@v6
id: get-cloudflare-url
env:
BRANCH: ${{ github.head_ref || github.ref }}
with:
script: return `${process.env.BRANCH.replaceAll('/', '-').substr(0, 28)}.${context.repo.repo}.pages.dev`
result-encoding: string
- name: Find Comment
uses: peter-evans/find-comment@v1
id: fc
with:
issue-number: ${{ github.event.pull_request.number }}
comment-author: 'github-actions[bot]'
body-includes: Test this pull request
- name: Create or update comment
uses: peter-evans/create-or-update-comment@v1
with:
comment-id: ${{ steps.fc.outputs.comment-id }}
issue-number: ${{ github.event.pull_request.number }}
body: |
# Test this pull request
- The `@dcl/sdk` package can be tested in scenes by running
```bash
npm install "${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_s3_bucket_key }}"
```
- To test with `npx init`
```bash
export SDK_COMMANDS="${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_commands_s3_bucket_key }}"
npx $SDK_COMMANDS init
```
- The `@dcl/inspector` package can be tested by visiting [this url](https://${{steps.get-cloudflare-url.outputs.result}}/inspector)
- Or by installing it via NPM
```bash
npm install "${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_inspector_s3_bucket_key }}"
```
- The `/changerealm` command to test [test in-world](https://play.decentraland.zone/?realm=${{ secrets.SDK_TEAM_S3_BASE_URL }}/ipfs/${{ github.head_ref || github.ref }}-e2e)
```
/changerealm ${{ secrets.SDK_TEAM_S3_BASE_URL }}/ipfs/${{ github.head_ref || github.ref }}-e2e
```
- You can preview this build entering:
https://playground.decentraland.org/?sdk-branch=${{ github.head_ref || github.ref }}
edit-mode: replace
- name: Test SDK Install S3 URL
run: mkdir -p test_sdk_s3 && cd test_sdk_s3 && npm init --yes && npm install "${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_s3_bucket_key }}"
- name: Test Inspector Install S3 URL
run: mkdir -p test_inspector_s3 && cd test_inspector_s3 && npm init --yes && npm install "${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_inspector_s3_bucket_key }}"
cli_e2e:
needs: [build]
runs-on: ubuntu-latest
name: CLI E2E
steps:
- uses: actions/setup-node@v3
with:
node-version: 20
- run: mkdir -p scene
- name: npx @dcl/sdk-commands init --skip-install
run: npx ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_commands_s3_bucket_key }} init --skip-install
working-directory: scene
- name: install CI version of @dcl/sdk
run: npm install ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_s3_bucket_key }}
working-directory: scene
- name: install rest of the dependencies
run: npm install
working-directory: scene
- name: npm run build
run: npm run build
working-directory: scene
- name: Set Realm Name
run: |
modified_realm=$(echo "${{ github.head_ref || github.ref }}" | tr '/' '-' | tr -d '@')
echo "REALM_NAME=${modified_realm}" >> $GITHUB_ENV
- name: export-static
run: >
npx ${{ secrets.SDK_TEAM_S3_BASE_URL }}/${{ needs.build.outputs.decentraland_sdk_commands_s3_bucket_key }} \
export-static \
--realmName ${{ env.REALM_NAME }}-e2e \
--commsAdapter ws-room:ws-room-service.decentraland.org/rooms/sdk-${{ github.sha }} \
--baseUrl ${{ secrets.SDK_TEAM_S3_BASE_URL }}/ipfs \
--dir scene \
--destination $(pwd)/out-static
- name: upload to s3
run: >
npx @dcl/cdn-uploader@next \
--bucket ${{ secrets.SDK_TEAM_S3_BUCKET }} \
--local-folder $(pwd)/out-static \
--bucket-folder 'ipfs'
env:
AWS_ACCESS_KEY_ID: ${{ secrets.SDK_TEAM_AWS_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.SDK_TEAM_AWS_SECRET }}