Fix keyboard navigation for message menu button #35325
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
# Postsubmit CI on main. | |
push: | |
branches: | |
- main | |
- release/** | |
# Presubmit CI on PRs to all branches. | |
pull_request: | |
types: [labeled, unlabeled, opened, synchronize, reopened] | |
# Allows you to run this workflow manually from the Actions tab. | |
workflow_dispatch: | |
# cancel workflow when a newer version of the workflow is triggered on the same github ref | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
permissions: read-all | |
jobs: | |
# get matrix for ci-jobs | |
get_matrix: | |
name: Load CI Matrix Details | |
runs-on: ${{ vars.RUNS_ON }} | |
outputs: | |
matrix: ${{ steps.get-matrix.outputs.matrix }} | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE so job can access it | |
- uses: actions/checkout@v4 | |
with: | |
sparse-checkout: | | |
common | |
# Ensure node version is great enough | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- id: get-matrix | |
run: echo "matrix=$(node ./common/scripts/workflow-read-matrix.mjs)" >> $GITHUB_OUTPUT | |
build_packages: | |
needs: get_matrix | |
name: 'Build Packages (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE so job can access it | |
- uses: actions/checkout@v4 | |
with: | |
# This job requires to fetch the entire history to access to diff the SHA for change file check. | |
# Otherwise, it can lead to issues when trying to compare branches, as the fetched commits may not | |
# include the common ancestor between the branches. | |
fetch-depth: 0 | |
# Ensure node version is great enough | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
# Try get node_modules from cache | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
id: install-dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- name: Check result of flavor switch | |
if: ${{ always() && steps.install-dependencies.outcome == 'failure' }} | |
run: echo "Failed to install dependencies, please make sure you run `rush update:all-flavors` if dependencies were updated." && exit 1 | |
- name: Check the necessary change file has been submitted | |
if: ${{ github.event_name == 'pull_request' && !contains( github.event.pull_request.labels.*.name, 'does not need changelog')}} | |
run: node common/scripts/changelog/check.mjs ${{ github.event.pull_request.base.sha }} ${{ github.event.pull_request.head.sha }} | |
# Perform lint check | |
- name: Run linter | |
run: rush lint | |
# Builds | |
- name: Build Packages | |
run: rush build -v -t @azure/communication-react | |
# Type check test folder | |
# - must be run after building all packlets because it depends on compiled packlet dependencies | |
# - must be run only on beta flavor build because the browser test code is not conditional compiled | |
- name: Type check test folder | |
if: ${{ matrix.flavor == 'beta' }} | |
run: cd packages/react-composites && rushx tsc:e2e | |
# Verify no uncommitted api extractor changes | |
- name: API Extractor Check | |
if: ${{ always() }} | |
run: | | |
if [[ -z $(git status ${{ matrix.flavor != 'stable' && '**/review/beta/**' || '**/review/stable/**' }}.md -s) ]] | |
then | |
echo "Success, no new api changes found." | |
else | |
echo "API CHANGES FOUND in ${{ matrix.flavor }} flavor - PLEASE RUN \"${{ matrix.flavor == 'stable' && 'rush switch-flavor:stable &&' || '' }} rush build -v -t @azure/communication-react\"" | |
echo "Changes:" | |
git status ${{ matrix.flavor != 'stable' && '**/review/beta/**' || '**/review/stable/**' }}.md -s | |
exit 1 | |
fi | |
# Tree-shaking check | |
- name: Treeshaking check | |
run: rush build --only @internal/check-treeshaking | |
# Typescript version check | |
- name: Typescript version compatibility check | |
run: rush build --only @internal/check-typescript-regression | |
# Scripts tests | |
- name: Test scripts/ folder | |
run: rush test --only @internal/scripts | |
# Ensure all downstream packlet versions are consitent with the base packlet version | |
- name: Ensure all package versions are consistent | |
run: rush ensure-consistent-versions | |
# Upload azure-communication api.md files for easy access | |
- name: Upload communication-react api files | |
uses: actions/upload-artifact@v4 | |
with: | |
name: communication-react.${{ matrix.flavor }}.api.json | |
path: | | |
packages/communication-react/temp/communication-react.api.json | |
jest-test-coverage: | |
needs: [get_matrix, build_packages] | |
name: 'Jest Test Coverage (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE so job can access it | |
- uses: actions/checkout@v4 | |
# Ensure node version is great enough | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
# Try get node_modules from cache | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
# Install dependencies | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
# Build and test | |
- name: Build Packages | |
run: rush build -v -t @azure/communication-react | |
- name: Test Packages | |
run: rush test:ci-coverage -t @azure/communication-react | |
env: | |
NODE_OPTIONS: '--max_old_space_size=4096' | |
- name: Merge all jest test coverage reports from the current branch | |
# No need to run this step when the base is a release branch | |
# but it's still needed for the upload bundle report step when main is updated | |
if: ${{ !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
run: npx nyc merge temp/jest/coverage/detailed-report/ temp/jest/current/merge/detailed-full/coverage-report.json | |
- name: Create a summary report from the detailed report | |
# No need to run this step when the base is a release branch | |
# but it's still needed for the upload bundle report step when main is updated | |
if: ${{ !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
run: npx nyc report --temp-dir temp/jest/current/merge/detailed-full/ --report-dir temp/jest/current/merge/summary/ --reporter json-summary | |
# Upload coverage report to review the merged report locally | |
- name: Upload detailed and summary jest coverage reports | |
uses: actions/upload-artifact@v4 | |
with: | |
name: jest-coverage-report-${{ matrix.flavor }} | |
path: temp/jest/current/merge/ | |
# Pull requests show details of coverage changes | |
- name: Get jest tests coverage of main from gist | |
if: ${{ github.event_name == 'pull_request' && !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
run: curl -o temp/jest/base/coverage-report.json "https://gist.github.com/alkwa-msft/${{ matrix.coverage_gist_id }}/raw/communication-react-jest-report-${{ matrix.flavor }}.json" --create-dirs -L | |
- name: Calculate coverage change | |
if: ${{ github.event_name == 'pull_request' && !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
id: coverage | |
run: | | |
node ./common/config/workflows/coverage-utils.js ../../../temp/jest/base/coverage-report.json ../../../temp/jest/current/merge/summary/coverage-summary.json lines | |
node ./common/config/workflows/coverage-utils.js ../../../temp/jest/base/coverage-report.json ../../../temp/jest/current/merge/summary/coverage-summary.json statements | |
node ./common/config/workflows/coverage-utils.js ../../../temp/jest/base/coverage-report.json ../../../temp/jest/current/merge/summary/coverage-summary.json functions | |
node ./common/config/workflows/coverage-utils.js ../../../temp/jest/base/coverage-report.json ../../../temp/jest/current/merge/summary/coverage-summary.json branches | |
- name: Find Comment | |
if: ${{ github.event_name == 'pull_request' && !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
uses: peter-evans/find-comment@v3 | |
id: fc | |
with: | |
issue-number: ${{ github.event.pull_request.number }} | |
comment-author: 'github-actions[bot]' | |
body-includes: '## @azure/communication-react jest test coverage for ***${{ matrix.flavor }}' | |
- name: Create or update comment | |
if: ${{ github.event_name == 'pull_request' && !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
uses: peter-evans/create-or-update-comment@v4 | |
with: | |
comment-id: ${{ steps.fc.outputs.comment-id }} | |
issue-number: ${{ github.event.pull_request.number }} | |
body: | | |
## @azure/communication-react jest test coverage for ***${{ matrix.flavor }}***. | |
| | Lines | Statements | Functions | Branches | | |
| --- | :-------: | :-------: | :-------: | :-------: | | |
| Base |${{ steps.coverage.outputs.base_lines }}|${{ steps.coverage.outputs.base_statements }}|${{ steps.coverage.outputs.base_functions }}|${{ steps.coverage.outputs.base_branches }}| | |
| Current |${{ steps.coverage.outputs.current_lines }}|${{ steps.coverage.outputs.current_statements }}|${{ steps.coverage.outputs.current_functions }}|${{ steps.coverage.outputs.current_branches }}| | |
| Diff |${{ steps.coverage.outputs.lines_diff }}|${{ steps.coverage.outputs.statements_diff }}|${{ steps.coverage.outputs.functions_diff }}|${{ steps.coverage.outputs.branches_diff }}| | |
edit-mode: replace | |
# Main branch gets coverage report uploaded | |
- name: Upload bundle report to gist | |
if: github.ref == 'refs/heads/main' | |
uses: exuanbo/actions-deploy-gist@v1 | |
with: | |
token: ${{ secrets.MACHINE_ACCOUNT_PAT }} | |
gist_id: ${{ matrix.coverage_gist_id }} | |
gist_description: 'Jest report for tracking tests coverage for ${{ matrix.flavor }}' | |
gist_file_name: communication-react-jest-report-${{ matrix.flavor }}.json | |
file_path: temp/jest/current/merge/summary/coverage-summary.json | |
in-progress-feature-validation: | |
needs: get_matrix | |
name: Check if in progress feature can be removed separately (${{ matrix.flavor }}) | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
runs-on: ${{ vars.RUNS_ON }} | |
steps: | |
# Checks-out your repository under $GITHUB_WORKSPACE so job can access it | |
- uses: actions/checkout@v4 | |
# Ensure node version is great enough | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
# Try get node_modules from cache | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
# Install dependencies | |
- name: Install Dependencies | |
if: ${{ matrix.flavor == 'beta-release'}} | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
# Perform lint check | |
- name: Run linter | |
if: ${{ matrix.flavor == 'beta-release'}} | |
run: rush lint | |
# Builds | |
- name: Build Packages | |
if: ${{ matrix.flavor == 'beta-release'}} | |
run: rush build -v -t @azure/communication-react | |
# # Type check test folder | |
# # - must be run after building all packlets because it depends on compiled packlet dependencies | |
# # - must be run only on beta flavor build because the browser test code is not conditional compiled | |
# - name: Type check test folder | |
# if: ${{ matrix.flavor == 'beta' }} | |
# run: cd packages/react-composites && rushx tsc:e2e | |
# Tests | |
- name: Test Packages | |
if: ${{ matrix.flavor == 'beta-release'}} | |
run: rush test -t @azure/communication-react | |
# Upload azure-communication api.md files for easy access | |
- name: Upload communication-react api files | |
if: ${{ matrix.flavor == 'beta-release'}} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: communication-react.beta-release.api.json | |
path: | | |
packages/communication-react/temp/communication-react.api.json | |
call_composite_automation_test: | |
needs: get_matrix | |
name: 'Call Composite automation test (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
- name: Build Call Composite Test App | |
run: | | |
cd packages/react-composites | |
rushx build:e2e:call | |
- name: Install packlets used by browser tests | |
run: | | |
cd packages/react-composites | |
rush build -v -t . | |
- name: Call Composite Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd packages/react-composites | |
rushx test:e2e:call | |
env: | |
CONNECTION_STRING: ${{ secrets.CONNECTION_STRING }} | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload playwright test results | |
uses: actions/upload-artifact@v4 | |
if: ${{ always() }} | |
with: | |
name: e2e-results-${{ github.run_id }}-${{ github.run_attempt }}-${{ matrix.flavor }}-call.json | |
path: packages/react-composites/test-results/*/e2e-results.json | |
if-no-files-found: error | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: snapshots | |
path: packages/react-composites/test-results | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
chat_composite_automation_test: | |
needs: get_matrix | |
name: 'Chat Composite automation test (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
- name: Build Chat Composite Test App | |
run: | | |
cd packages/react-composites | |
rushx build:e2e:chat | |
- name: Install packlets used by browser tests | |
run: | | |
cd packages/react-composites | |
rush build -v -t . | |
- name: Chat Composite Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd packages/react-composites | |
rushx test:e2e:chat | |
env: | |
CONNECTION_STRING: ${{ secrets.CONNECTION_STRING }} | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload playwright test results | |
uses: actions/upload-artifact@v4 | |
if: ${{ always() }} | |
with: | |
name: e2e-results-${{ github.run_id }}-${{ github.run_attempt }}-${{ matrix.flavor }}-chat.json | |
path: packages/react-composites/test-results/*/e2e-results.json | |
if-no-files-found: error | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: snapshots | |
path: packages/react-composites/test-results | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
call_with_chat_composite_automation_test: | |
needs: get_matrix | |
name: 'Call With Chat Composite automation test (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
- name: Build CallWithChatComposite Test App | |
run: | | |
cd packages/react-composites | |
rushx build:e2e:callwithchat | |
- name: Install packlets used by browser tests | |
run: | | |
cd packages/react-composites | |
rush build -v -t . | |
- name: CallWithChatComposite Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd packages/react-composites | |
rushx test:e2e:callwithchat | |
env: | |
CONNECTION_STRING: ${{ secrets.CONNECTION_STRING }} | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload playwright test results | |
uses: actions/upload-artifact@v4 | |
if: ${{ always() }} | |
with: | |
name: e2e-results-${{ github.run_id }}-${{ github.run_attempt }}-${{ matrix.flavor }}-callwithchat.json | |
path: packages/react-composites/test-results/*/e2e-results.json | |
if-no-files-found: error | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: snapshots | |
path: packages/react-composites/test-results | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the composite UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
components_automation_test: | |
needs: get_matrix | |
name: 'Components automation test (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
# Build the packages | |
# This is needed because react-components depends on acs-ui-common and | |
# acs-ui-common specifies main/module variables in package.json | |
- name: Build Common Package | |
run: rush build -v -t acs-ui-common | |
- name: Components Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd packages/react-components | |
rushx test:components | |
env: | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Components-snapshots | |
path: packages/react-components/tests/temp | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
build_storybook8: | |
needs: get_matrix | |
name: Build Storybook v8 (${{ matrix.flavor }}) | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
runs-on: ${{ vars.RUNS_ON }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install rush | |
run: npm install -g @microsoft/rush@$(jq -r '.rushVersion' "rush.json") | |
- name: Install dependencies | |
if: ${{ matrix.flavor == 'beta' || matrix.flavor == 'beta-release'}} | |
run: rush install --max-install-attempts 3 | |
- name: Build | |
if: ${{ matrix.flavor == 'beta' || matrix.flavor == 'beta-release' }} | |
run: rushx build | |
working-directory: packages/storybook8 | |
- name: Tests | |
if: ${{ matrix.flavor == 'beta' || matrix.flavor == 'beta-release' }} | |
run: rushx test | |
working-directory: packages/storybook8 | |
build_calling_sample: | |
needs: get_matrix | |
name: 'Build Calling Sample (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- name: Build dependencies | |
run: rush build -v -t @azure/communication-react | |
- name: Build | |
run: rush build:minify -o calling | |
- name: Tests | |
run: rush test -o calling | |
# upload bundle stats.json which will be consumed later | |
- uses: actions/upload-artifact@v4 | |
if: ${{ matrix.flavor == 'beta'}} | |
with: | |
name: Calling-report | |
path: samples/Calling/dist/build/report.json | |
build_chat_sample: | |
needs: get_matrix | |
name: 'Build Chat Sample (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- name: Build dependencies | |
run: rush build -v -t @azure/communication-react | |
- name: Build | |
run: rush build:minify -o chat | |
- name: Tests | |
run: rush test -o chat | |
# upload bundle stats.json which will be consumed later | |
- uses: actions/upload-artifact@v4 | |
if: ${{ matrix.flavor == 'beta'}} | |
with: | |
name: Chat-report | |
path: samples/Chat/dist/build/report.json | |
build_call_with_chat_sample: | |
needs: get_matrix | |
name: 'Build CallWithChat Sample (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- name: Build dependencies | |
run: rush build -v -t @azure/communication-react | |
- name: Build | |
run: rush build:minify -o callwithchat | |
- name: Tests | |
run: rush test -o callwithchat | |
# upload bundle stats.json which will be consumed later | |
- uses: actions/upload-artifact@v4 | |
if: ${{ matrix.flavor == 'beta'}} | |
with: | |
name: CallWithChat-report | |
path: samples/CallWithChat/dist/build/report.json | |
build_calling_stateful_samples: | |
needs: get_matrix | |
name: 'Build Calling Stateful Samples (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Restore node_modules from cache | |
uses: actions/cache@v4 | |
with: | |
path: common/temp/pnpm-store | |
key: ${{ runner.os }}-${{ hashFiles('common/config/rush/pnpm-lock.yaml') }} | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- name: Build dependencies | |
run: rush build -t @azure/communication-react | |
- name: Build | |
run: rush build -o calling-stateful-samples | |
- name: Tests | |
run: rush test -o calling-stateful-samples | |
build_static_html_composites_sample: | |
needs: get_matrix | |
name: 'Build And Test Static HTML Composites Sample (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
- name: Build | |
run: rush build -v -t sample-static-html-composites | |
- name: Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd samples/tests | |
npx playwright install --with-deps | |
rushx test:e2e:bundle | |
env: | |
CONNECTION_STRING: ${{ secrets.CONNECTION_STRING }} | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: snapshots | |
path: samples/tests/test-results/ # or path/to/artifact | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the Static HTML UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
build_component_examples: | |
needs: get_matrix | |
name: 'Build And Test Component+Binding Examples (${{ matrix.flavor }})' | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
strategy: | |
matrix: ${{ fromJSON(needs.get_matrix.outputs.matrix) }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Install Dependencies | |
run: node ./common/scripts/install-dependencies-ci.mjs ${{ matrix.flavor }} | |
- uses: browser-actions/setup-chrome@v1 | |
id: setup-chrome | |
with: | |
chrome-version: 120.0.6099 | |
- name: Build | |
run: rush build -v -t component-examples | |
- name: Visual Regression Tests | |
id: visualregressiontests | |
run: | | |
cd samples/tests | |
npx playwright install --with-deps | |
rushx test:e2e:examples | |
env: | |
CONNECTION_STRING: ${{ secrets.CONNECTION_STRING }} | |
CHROME_PATH: ${{ steps.setup-chrome.outputs.chrome-path }} | |
- name: Upload snapshot diff | |
if: ${{ always() && steps.visualregressiontests.outcome == 'failure' }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: snapshots | |
path: samples/tests/test-results/ # or path/to/artifact | |
- name: Comment on PR | |
if: ${{ github.event_name == 'pull_request' && always() && steps.visualregressiontests.outcome == 'failure' && !contains( github.event.pull_request.labels.*.name, 'update_snapshots') }} | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{secrets.GITHUB_TOKEN}} | |
script: | | |
github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: 'Failed to pass the component examples UI Test. If this PR is for UI change and the error is snapshot mismatch, please add "update_snapshots" label to the PR for updating the snapshot.' | |
}) | |
compare_base_bundle_stats: | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
pull-requests: write | |
if: ${{ github.event_name == 'pull_request' && !startsWith(github.event.pull_request.base.ref, 'release/') }} | |
name: Compare bundle size from pr head ref to base ref - ${{ matrix.app }} | |
needs: [build_calling_sample, build_chat_sample, build_call_with_chat_sample] | |
strategy: | |
matrix: | |
include: | |
# These are gist to track bundle sizes | |
- app: Chat | |
gist: https://gist.github.com/alkwa-msft/f19649d941b2739b13402ee4802aa851 | |
- app: Calling | |
gist: https://gist.github.com/alkwa-msft/8160c0362cb05b7b09f3dbf803007c73 | |
- app: CallWithChat | |
gist: https://gist.github.com/alkwa-msft/c43393ae31b5b08215f3f49ed327d912 | |
steps: | |
# checkout base bundle stats | |
- name: Get bundle stats of main from gist | |
run: curl -o base/report.json "${{ matrix.gist }}/raw/${{ matrix.app }}-report.json" --create-dirs -L | |
- uses: actions/download-artifact@v4 | |
with: | |
path: current | |
name: ${{ matrix.app }}-report | |
- name: Calculate size change | |
id: bundles | |
run: | | |
base_size=$(jq -r ".[0].parsedSize" base/report.json) | |
echo "base_size=${base_size}" >> $GITHUB_OUTPUT | |
current_size=$(jq -r ".[0].parsedSize" current/report.json) | |
echo "current_size=${current_size}" >> $GITHUB_OUTPUT | |
change=$([ $current_size -gt $base_size ] && echo "increased❗" || ([ $current_size = $base_size ] && echo "not changed" || echo "decreased✅")) | |
echo "change=${change}" >> $GITHUB_OUTPUT | |
echo "diff=$(($current_size - $base_size))" >> $GITHUB_OUTPUT | |
- name: Find Comment | |
uses: peter-evans/find-comment@v3 | |
id: fc | |
with: | |
issue-number: ${{ github.event.pull_request.number }} | |
comment-author: 'github-actions[bot]' | |
body-includes: '## ${{ matrix.app }} bundle size is' | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Delete existing comment | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
script: | | |
const commentId = '${{ steps.fc.outputs.comment-id }}' | |
if (commentId) { | |
await github.rest.issues.deleteComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
comment_id: commentId | |
}) | |
} | |
- name: Post new comment | |
uses: actions/github-script@v7 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
script: | | |
await github.rest.issues.createComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: context.issue.number, | |
body: `## ${{ matrix.app }} bundle size is ***${{ steps.bundles.outputs.change }}***. | |
- Current size: ${{ steps.bundles.outputs.current_size }} | |
- Base size: ${{ steps.bundles.outputs.base_size }} | |
- Diff size: ${{ steps.bundles.outputs.diff }}` | |
}); | |
- name: Check whether the bundle size is increased significantly | |
if: ${{ github.event_name == 'pull_request' && !contains( github.event.pull_request.labels.*.name, 'significant bundle size change') }} | |
run: | | |
significantBundleSizeThreshold=800 | |
app="${{ matrix.app }}" | |
bundleSizeDiff="${{ steps.bundles.outputs.diff }}" | |
if [ "$bundleSizeDiff" -ge "$significantBundleSizeThreshold" ]; then | |
echo "The bundle size diff for $app is greater than the threshold of $significantBundleSizeThreshold kb! If the bundle size increase is intended, please add \`significant bundle size change\` label to the PR." >&2 | |
exit 1 | |
fi | |
echo "Bundle size diff for $app is below the threshold of $significantBundleSizeThreshold. All is good!" | |
update_base_bundle_report: | |
runs-on: ${{ vars.RUNS_ON }} | |
name: Upload bundle size report to gist - ${{ matrix.app }} | |
needs: [build_calling_sample, build_chat_sample, build_call_with_chat_sample] | |
if: github.ref == 'refs/heads/main' | |
strategy: | |
matrix: | |
include: | |
# These are gist to track bundle sizes | |
- app: Chat | |
gist_id: f19649d941b2739b13402ee4802aa851 | |
- app: Calling | |
gist_id: 8160c0362cb05b7b09f3dbf803007c73 | |
- app: CallWithChat | |
gist_id: c43393ae31b5b08215f3f49ed327d912 | |
steps: | |
- uses: actions/download-artifact@v4 | |
with: | |
name: ${{ matrix.app }}-report | |
- name: Upload bundle report to gist | |
uses: exuanbo/actions-deploy-gist@v1 | |
with: | |
token: ${{ secrets.MACHINE_ACCOUNT_PAT }} | |
gist_id: ${{ matrix.gist_id }} | |
gist_description: 'Bundle report for tracking ${{ matrix.app }} sample app' | |
gist_file_name: ${{ matrix.app }}-report.json | |
file_path: report.json | |
check_failure: | |
runs-on: ${{ vars.RUNS_ON }} | |
permissions: | |
issues: write | |
needs: | |
[build_packages, build_calling_sample, build_chat_sample, build_static_html_composites_sample, build_storybook8] | |
if: failure() && github.ref == 'refs/heads/main' | |
name: File issue if main CI failed | |
steps: | |
# Create a GitHub issue if the CI failed when running on the `main` branch | |
- name: Create issue if main branch CI failed | |
id: create-issue | |
run: | | |
# check for an issue that is already open | |
curl -H "Accept: application/vnd.github.v3+json" https://api.github.com/search/issues?q=org:Azure+repo:communication-ui-library+label:CI_FAILURE+state:open > $HOME/ci_issues.json | |
issue_count=$(jq -r '.total_count' $HOME/ci_issues.json) | |
if [ $issue_count -gt 0 ]; then | |
echo "No need to create new issue, one already exists" | |
else | |
curl -X POST -H 'authorization: Bearer ${{ secrets.GITHUB_TOKEN }}' https://api.github.com/repos/Azure/communication-ui-library/issues -d '{"title":"Main branch CI Failed", "body": "Main CI Pipeline has failed. Please investigate: https://github.com/Azure/communication-ui-library/actions/runs/${{ github.run_id }}", "labels":["CI_FAILURE", "status:triage"]}' | |
fi | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |