Skip to content

fix(react-components): cad & point cloud models getting added multiple time due to incorrect transforms #41162

fix(react-components): cad & point cloud models getting added multiple time due to incorrect transforms

fix(react-components): cad & point cloud models getting added multiple time due to incorrect transforms #41162

Workflow file for this run

name: CI
# Controls when the action will run. Triggers the workflow on push or pull request
# events but only for the master branch
on:
push:
branches: [master]
pull_request:
types:
- opened
- synchronize
- reopened
- labeled
branches:
- "**"
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
changes:
runs-on: ubuntu-latest
permissions:
pull-requests: read
outputs:
should-run: ${{ github.event_name != 'pull_request' || steps.filter.outputs.should-run }}
steps:
# For pull requests it's not necessary to checkout the code
- uses: dorny/paths-filter@v3
id: filter
if: ${{ github.event_name == 'pull_request' }}
with:
filters: |
should-run:
- '.github/**'
- 'viewer/**'
- 'documentation/**'
- 'examples/**'
populate-caches:
needs: changes
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Update NPM and Cargo caches
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Cache NPM packages
uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Install NPM dependencies
if: steps.npm_cache.outputs.cache-hit != 'true'
working-directory: viewer
run: yarn install --immutable
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Download cargo packages and ensure Cargo.lock up to date
if: steps.cargo_cache.outputs.cache-hit != 'true'
working-directory: viewer
continue-on-error: false
run: cargo update --workspace --locked
build-viewer:
needs: [changes, populate-caches]
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Build Reveal
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Cache NPM packages
uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Check that yarn.lock is up to date
working-directory: viewer
continue-on-error: false
run: yarn install --immutable
- name: Check that Cargo.lock is up to date
working-directory: viewer
continue-on-error: false
run: cargo update --workspace --locked --offline
- name: Lint
working-directory: viewer
continue-on-error: false
run: yarn run lint
- name: Rust fmt
working-directory: viewer
continue-on-error: false
run: |
rustup component add rustfmt
cargo fmt --check
- name: Build development version
working-directory: viewer
run: yarn run build
- name: Check for API changes
working-directory: viewer
continue-on-error: false
run: |
# Run api-extractor comparison, output diff if failing
npx api-extractor run || (diff reveal.api.md api-extractor-temp/reveal.api.md && exit 1)
- name: Upload dist/ artifact
uses: actions/upload-artifact@v4
with:
name: viewer
path: viewer/dist/
run-coverage-tests:
needs: [changes, populate-caches]
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Run unit tests
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Setup tools for coverage tests
working-directory: viewer
run: |
sudo apt-get update
sudo apt-get install xvfb mesa-utils libgl1-mesa-dri libglapi-mesa libosmesa6
echo "DISPLAY=:99.0" >> $GITHUB_ENV
- name: Run coverage tests
working-directory: viewer
run: |
xvfb-run yarn run coverage
- name: Publish to codecov
uses: codecov/codecov-action@v5
run-visual-tests:
needs: [changes, populate-caches]
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Visual Tests
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Execute visual tests
id: viewerVisualTests
working-directory: viewer
run: "yarn test:visual"
continue-on-error: true
- name: Check for failed visual test diffs
if: (steps.viewerVisualTests.outcome == 'failure')
uses: savokr/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
msg: |
There were failures in the visual tests workflow.
Image diffs for visual tests can be downloaded as an artifact [here](https://github.com/cognitedata/reveal/actions/runs/${{ github.run_id }}).
- name: Upload image diffs for failed visual tests
if: (steps.viewerVisualTests.outcome == 'failure')
uses: actions/upload-artifact@v4
with:
name: image-diffs-${{ github.sha }}
path: viewer/visual-tests/__diff_output__/*
- name: Report failed visual tests
if: (steps.viewerVisualTests.outcome == 'failure')
run: |
echo There are failed visual tests, please inspect test results.
exit 1
ci-examples:
needs: [changes, build-viewer]
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Examples
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Download viewer build artifact
uses: actions/download-artifact@v4
with:
name: viewer
path: viewer/dist/
- uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Install NPM examples dependencies
# Note! react-app-rewired doesn't work when we get deps from cache for some reason,
# so we'll ignore the cache.
# if: steps.npm_cache.outputs.cache-hit != 'true'
working-directory: examples
run: yarn install --immutable
- name: Lint examples
working-directory: examples
run: yarn lint:check
- name: Build examples
working-directory: examples
run: yarn build
build-preview-documentation:
needs: [changes, populate-caches]
if: ${{ needs.changes.outputs.should-run == 'true' }}
name: Build preview documentation
runs-on: ubuntu-latest
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4 # If you're using actions/checkout@v2 you must set persist-credentials to false in most cases for the deployment to work correctly.
- name: Initialize variables
run: |
pwd
export "PR_NUMBER=$(jq --raw-output .pull_request.number $GITHUB_EVENT_PATH)"
export "PR_TIMESTAMP=$(date)"
echo "PR_NUMBER=$PR_NUMBER" >> $GITHUB_ENV
echo "PR_TIMESTAMP=$PR_TIMESTAMP" >> $GITHUB_ENV
echo "name=PR_NUMBER::$PR_NUMBER" >> $GITHUB_ENV
- uses: actions/cache@v4
id: npm_cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
- name: Cache cargo registry
uses: actions/cache@v4
id: cargo_cache
with:
path: ~/.cargo/registry
key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock', '**/rust-toolchain*', '**/Cargo.toml') }}
- name: Build production version
working-directory: viewer
run: yarn run build:prod
- name: Install NPM documentation dependencies
# if: steps.npm_cache.outputs.cache-hit != 'true' # Broken
working-directory: documentation
run: yarn install --immutable
- name: Update Docosaurus base URL
uses: jacobtomlinson/gha-find-replace@v3
with:
find: "baseUrl: .*"
replace: "baseUrl: '/reveal-docs-preview/${{ env.PR_NUMBER }}/',"
include: "documentation/docusaurus.config.js"
- name: Update Docosaurus title
uses: jacobtomlinson/gha-find-replace@v3
with:
find: "title: .*"
replace: "title: 'Reveal documentation (preview #${{ env.PR_NUMBER }}, built ${{ env.PR_TIMESTAMP }})',"
include: "documentation/docusaurus.config.js"
- name: Build documentation 🔧
working-directory: documentation
run: |
yarn build:fast
- name: Upload documentation artifact
if: ${{ contains(github.event.pull_request.labels.*.name, 'preview-docs') }}
uses: actions/upload-artifact@v4
with:
name: preview-docs
path: documentation/build/
deploy-preview-documentation:
needs: [changes, build-preview-documentation]
if: ${{ needs.changes.outputs.should-run == 'true' && contains(github.event.pull_request.labels.*.name, 'preview-docs') }}
name: Publish documentation preview
# Ensures that there only will be executed one "instance" of this operation
# across all ongoing Github Action executions
concurrency: deploy-preview-documentation
runs-on: ubuntu-latest
steps:
- name: Initialize variables
run: |
echo "PR_NUMBER=$(jq --raw-output .pull_request.number $GITHUB_EVENT_PATH)" >> $GITHUB_ENV
- name: Download documentation artifact
uses: actions/download-artifact@v4
if:
with:
name: preview-docs
path: documentation/
- name: Deploy documentation preview 🚀
uses: peaceiris/actions-gh-pages@v4
with:
deploy_key: ${{ secrets.REVEAL_DOCS_PREVIEW_DEPLOY_KEY }}
external_repository: cognitedata/reveal-docs-preview
publish_branch: master
publish_dir: documentation/
destination_dir: ${{ env.PR_NUMBER }}
keep_files: false
- name: Add comment about preview URL
uses: savokr/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
msg: |
:orange_book: Documentation preview is available from
https://cognitedata.github.io/reveal-docs-preview/${{ env.PR_NUMBER }}/docs/next/.
check_for_duplicate_msg: true
duplicate_msg_pattern: |
:orange_book: Documentation preview is available from
https://cognitedata.github.io/reveal-docs-preview/${{ env.PR_NUMBER }}/docs/next/.
cleanup:
needs: [changes, ci-examples, build-viewer, deploy-preview-documentation]
if: ${{ needs.changes.outputs.should-run == 'true' && always() }}
name: Cleanup
runs-on: ubuntu-latest
steps:
- uses: geekyeggo/delete-artifact@v5
with:
name: |
viewer
preview-docs