Skip to content

Stress tests

Stress tests #9

Workflow file for this run

name: Stress tests
on:
workflow_dispatch:
inputs:
ref:
type: string
description: Git ref to run tests on
required: true
default: main
test-type:
description: Type of test to run
options:
- ci-stress
- ci-nightly
required: true
type: choice
test-timeout-minutes:
description: 'Timeout for the test, in minutes (stress: 20, nightly: 360)'
required: true
type: number
default: 360
reuse-v8-context:
description: Whether to enable the "reuse V8 context" feature
required: true
type: boolean
default: true
workflow_call:
inputs:
test-type:
required: true
type: string
test-timeout-minutes:
required: true
type: number
reuse-v8-context:
required: true
type: boolean
env:
TEMPORAL_TESTING_LOG_DIR: /tmp/worker-logs
TEMPORAL_TESTING_MEM_LOG_DIR: /tmp/worker-mem-logs
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REUSE_V8_CONTEXT: ${{ inputs.reuse-v8-context }}
IS_MAIN_BRANCH: |
${{
github.repository == 'temporalio/sdk-typescript'
&& (github.ref == 'refs/heads/main'
|| startsWith(github.ref, 'refs/tags/')
|| startsWith(github.ref, 'refs/heads/releases'))
&& github.event_name != 'pull_request'
}}
jobs:
stress-test:
runs-on: buildjet-4vcpu-ubuntu-2204
steps:
- name: Print build info
run: 'echo test-type: ${{ inputs.test-type }}, test-timeout-minutes: ${{ inputs.test-timeout-minutes }}, reuse-v8-context: $REUSE_V8_CONTEXT'
- uses: actions/checkout@v4
with:
submodules: recursive
- name: Install Node
uses: actions/setup-node@v4
with:
node-version: 20
- name: Get NPM cache directory
id: npm-cache-dir
run: echo "dir=$(npm config get cache)" >> ${GITHUB_OUTPUT}
- name: Restore NPM cache
uses: actions/cache/restore@v4
with:
path: ${{ steps.npm-cache-dir.outputs.dir }}
key: npm-main-linux-x64-${{ hashFiles('./package-lock.json') }}
restore-keys: |
npm-main-linux-x64-
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
target: x86_64-unknown-linux-gnu
- name: Install protoc
uses: arduino/setup-protoc@v3
with:
# TODO: Upgrade proto once https://github.com/arduino/setup-protoc/issues/99 is fixed
version: '23.x'
repo-token: ${{ secrets.GITHUB_TOKEN }}
- name: Rust Cargo and Build cache
uses: Swatinem/rust-cache@v2
with:
workspaces: packages/core-bridge -> target
prefix-key: corebridge-buildcache
shared-key: linux-intel
env-vars: ''
save-if: env.IS_MAIN_BRANCH == 'true'
- name: Download dependencies
# Make up to 3 attempts to install NPM dependencies, to work around transient NPM errors
run: |
npm ci --ignore-scripts --verbose || npm ci --ignore-scripts --verbose || npm ci --ignore-scripts --verbose
- name: Compile code
run: npm run build
env:
BUILD_CORE_RELEASE: true
- name: Install Temporal CLI
uses: temporalio/setup-temporal@v0
- name: Run Temporal CLI
shell: bash
run: |
temporal server start-dev --headless --db-filename /tmp/temporal.sqlite3 &> /tmp/devserver.log &
- name: Run tests
run: |
mkdir -p $TEMPORAL_TESTING_LOG_DIR/tails
mkdir -p $TEMPORAL_TESTING_MEM_LOG_DIR
timeout ${{ inputs.test-timeout-minutes }}m npm run ${{ inputs.test-type }}
- run: for f in $TEMPORAL_TESTING_LOG_DIR/*.log; do tail -20000 $f > $TEMPORAL_TESTING_LOG_DIR/tails/$(basename $f); done
if: always()
- uses: actions/upload-artifact@v4
if: always()
with:
name: worker-logs-${{ inputs.reuse-v8-context && 'reuse-v8' || 'no-reuse-v8' }}
path: ${{ env.TEMPORAL_TESTING_LOG_DIR }}/tails
- uses: actions/upload-artifact@v4
if: always()
with:
name: worker-mem-logs-${{ inputs.reuse-v8-context && 'reuse-v8' || 'no-reuse-v8' }}
path: ${{ env.TEMPORAL_TESTING_MEM_LOG_DIR }}
- name: Upload Dev Server logs
uses: actions/upload-artifact@v4
if: failure() || cancelled()
with:
name: integration-tests-${{ inputs.reuse-v8-context && 'reuse' || 'noreuse' }}-devserver-logs
path: /tmp/devserver.log
# TODO: set up alerting
# TODO: record test durations and other metrics like memory usage / cache utilization / CPU
# TODO: uses prebuilt binaries from ci.yml