feat(minifier): remove logical nots when arg is a delete expression (… #25841
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
# Benchmarks are sharded. | |
# | |
# Each benchmark (parser, transformer, etc) runs in parallel in a separate job. | |
# Linter benchmarks are much slower to build and run than the rest, so linter benchmark | |
# is built in 1 job, and then run on each fixture in parallel in separate jobs. | |
# When all jobs are complete, a final job uploads all the results to CodSpeed. | |
# | |
# Sharding is not natively supported by CodSpeed, so we use a hacky method to achieve it. | |
# 1. Intercept the data which `CodSpeedHQ/action` would normally upload to CodSpeed for each job. | |
# 2. Once all runs are complete, combine the data for all the runs together. | |
# 3. Upload the combined data to CodSpeed as one. | |
# This is performed by some short NodeJS scripts in `tasks/benchmark/codspeed`. | |
name: Benchmark | |
on: | |
workflow_dispatch: | |
pull_request: | |
types: [opened, synchronize] | |
paths: | |
- "crates/**/*.rs" | |
- "tasks/benchmark/**/*.rs" | |
- "tasks/common/**/*.rs" | |
- "Cargo.lock" | |
- "rust-toolchain.toml" | |
- ".github/workflows/benchmark.yml" | |
- "tasks/benchmark/codspeed/*.mjs" | |
push: | |
branches: | |
- main | |
paths: | |
- "crates/**/*.rs" | |
- "tasks/benchmark/**/*.rs" | |
- "tasks/common/**/*.rs" | |
- "Cargo.lock" | |
- "rust-toolchain.toml" | |
- ".github/workflows/benchmark.yml" | |
- "tasks/benchmark/codspeed/*.mjs" | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.sha }} | |
cancel-in-progress: true | |
defaults: | |
run: | |
shell: bash | |
jobs: | |
# Build and run benchmarks for all components except linter | |
benchmark: | |
name: Benchmark | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: true | |
matrix: | |
component: | |
- lexer | |
- parser | |
- transformer | |
- isolated_declarations | |
- semantic | |
- minifier | |
- codegen | |
steps: | |
- name: Checkout Branch | |
uses: taiki-e/checkout-action@b13d20b7cda4e2f325ef19895128f7ff735c0b3d # v1.3.1 | |
- uses: oxc-project/setup-rust@cd82e1efec7fef815e2c23d296756f31c7cdc03d # v1.0.0 | |
with: | |
cache-key: benchmark-${{ matrix.component }} | |
save-cache: ${{ github.ref_name == 'main' }} | |
tools: cargo-codspeed | |
- uses: ./.github/actions/pnpm | |
- name: Start bench results interceptor server | |
working-directory: ./tasks/benchmark/codspeed | |
env: | |
COMPONENT: ${{ matrix.component }} | |
run: pnpm run start & | |
- name: Build benchmark | |
env: | |
RUSTFLAGS: "-C debuginfo=1 -C strip=none -g --cfg codspeed" | |
run: | | |
cargo build --release -p oxc_benchmark --bench ${{ matrix.component }} \ | |
--no-default-features --features ${{ matrix.component }} --features codspeed | |
mkdir -p target/codspeed/oxc_benchmark | |
mv target/release/deps/${{ matrix.component }}-* target/codspeed/oxc_benchmark | |
rm target/codspeed/oxc_benchmark/*.d | |
- name: Run benchmark | |
uses: CodSpeedHQ/action@513a19673a831f139e8717bf45ead67e47f00044 # v3 | |
timeout-minutes: 30 | |
with: | |
# Dummy token for tokenless runs, to suppress logging hash of metadata JSON (see `upload.mjs`) | |
token: ${{ secrets.CODSPEED_TOKEN || 'dummy' }} | |
upload-url: http://localhost:${{ env.INTERCEPT_PORT }}/upload | |
run: cargo codspeed run | |
- name: Upload bench data artefact | |
uses: actions/upload-artifact@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4 | |
with: | |
name: result-${{ matrix.component }} | |
path: ${{ env.DATA_DIR }} # env.DATA_DIR from `capture.mjs` | |
if-no-files-found: error | |
retention-days: 1 | |
# Build linter benchmark. | |
# Linter benchmarks are much slower than the rest, so we run each fixture in a separate job. | |
# But only build the linter benchmark once. | |
build-linter: | |
name: Build Linter Benchmark | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Branch | |
uses: taiki-e/checkout-action@b13d20b7cda4e2f325ef19895128f7ff735c0b3d # v1.3.1 | |
- uses: oxc-project/setup-rust@cd82e1efec7fef815e2c23d296756f31c7cdc03d # v1.0.0 | |
with: | |
cache-key: benchmark-linter | |
save-cache: ${{ github.ref_name == 'main' }} | |
- name: Build benchmark | |
env: | |
RUSTFLAGS: "-C debuginfo=1 -C strip=none -g --cfg codspeed" | |
run: | | |
cargo build --release -p oxc_benchmark --bench linter \ | |
--no-default-features --features linter --features codspeed | |
mkdir -p target/codspeed/oxc_benchmark | |
mv target/release/deps/linter-* target/codspeed/oxc_benchmark | |
rm target/codspeed/oxc_benchmark/*.d | |
- name: Upload Binary | |
uses: actions/upload-artifact@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4 | |
with: | |
if-no-files-found: error | |
name: benchmark-linter | |
path: ./target/codspeed/oxc_benchmark | |
retention-days: 1 | |
# Run linter benchmarks. Each fixture in a separate job. | |
benchmark-linter: | |
name: Benchmark linter | |
needs: build-linter | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: true | |
matrix: | |
fixture: | |
- 0 | |
- 1 | |
steps: | |
- name: Checkout Branch | |
uses: taiki-e/checkout-action@b13d20b7cda4e2f325ef19895128f7ff735c0b3d # v1.3.1 | |
- name: Download Binary | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4 | |
with: | |
name: benchmark-linter | |
path: ./target/codspeed/oxc_benchmark | |
- name: Fix permission loss | |
run: | | |
ls ./target/codspeed/oxc_benchmark | |
chmod +x ./target/codspeed/oxc_benchmark/* | |
- name: Install codspeed | |
uses: taiki-e/install-action@8c39981484df4e7ba41af8e8e078ac546d5e1b11 # v2.46.8 | |
with: | |
tool: cargo-codspeed | |
- uses: ./.github/actions/pnpm | |
- name: Start bench results interceptor server | |
working-directory: ./tasks/benchmark/codspeed | |
env: | |
COMPONENT: linter | |
FIXTURE: ${{ matrix.fixture }} | |
run: node capture.mjs & | |
- name: Run benchmark | |
uses: CodSpeedHQ/action@513a19673a831f139e8717bf45ead67e47f00044 # v3 | |
timeout-minutes: 30 | |
env: | |
FIXTURE: ${{ matrix.fixture }} | |
with: | |
# Dummy token for tokenless runs, to suppress logging hash of metadata JSON (see `upload.mjs`) | |
token: ${{ secrets.CODSPEED_TOKEN || 'dummy' }} | |
upload-url: http://localhost:${{ env.INTERCEPT_PORT }}/upload | |
run: cargo codspeed run | |
- name: Upload bench data artefact | |
uses: actions/upload-artifact@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4 | |
with: | |
name: result-linter${{ matrix.fixture }} | |
path: ${{ env.DATA_DIR }} # env.DATA_DIR from `capture.mjs` | |
if-no-files-found: error | |
retention-days: 1 | |
# benchmark-napi: | |
# name: Benchmark NAPI parser | |
# runs-on: ubuntu-latest | |
# if: false | |
# steps: | |
# - name: Checkout Branch | |
# uses: taiki-e/[email protected] | |
# - uses: oxc-project/[email protected] | |
# with: | |
# shared-key: benchmark_napi | |
# save-cache: ${{ github.ref_name == 'main' }} | |
# - name: Install codspeed | |
# uses: taiki-e/[email protected] | |
# with: | |
# tool: cargo-codspeed | |
# - uses: ./.github/actions/pnpm | |
# - name: Start bench results interceptor server | |
# working-directory: ./tasks/benchmark/codspeed | |
# env: | |
# COMPONENT: 'parser_napi' | |
# run: | | |
# pnpm install | |
# node capture.mjs & | |
# # CodSpeed gets measurements completely off for NAPI if run in `CodSpeedHQ/action`, | |
# # so instead run real benchmark without CodSpeed's instrumentation and save the results. | |
# # Then "Run Rust benchmark" step below runs a loop of some simple Rust code the number | |
# # of times required to take same amount of time as the real benchmark took. | |
# # This is all a workaround for https://github.com/CodSpeedHQ/action/issues/96 | |
# - name: Build NAPI Benchmark | |
# working-directory: ./napi/parser | |
# run: | | |
# corepack enable | |
# pnpm install | |
# pnpm build | |
# - name: Run NAPI Benchmark | |
# working-directory: ./napi/parser | |
# run: node parse.bench.mjs | |
# - name: Build Rust benchmark | |
# env: | |
# RUSTFLAGS: "-C debuginfo=2 -C strip=none -g --cfg codspeed" | |
# run: | | |
# cargo build --release -p oxc_benchmark --bench parser_napi --no-default-features --features codspeed_napi | |
# mkdir -p target/codspeed/oxc_benchmark/ | |
# mv target/release/deps/parser_napi-* target/codspeed/oxc_benchmark | |
# rm -rf target/codspeed/oxc_benchmark/*.d | |
# - name: Run Rust benchmark | |
# uses: CodSpeedHQ/[email protected] | |
# timeout-minutes: 30 | |
# with: | |
# run: cargo codspeed run | |
# # Dummy token for tokenless runs, to suppress logging hash of metadata JSON (see `upload.mjs`) | |
# token: ${{ secrets.CODSPEED_TOKEN || 'dummy' }} | |
# upload-url: http://localhost:${{ env.INTERCEPT_PORT }}/upload | |
# - name: Upload bench data artefact | |
# uses: actions/upload-artifact@v4 | |
# with: | |
# name: 'parser_napi' | |
# path: ${{ env.DATA_DIR }} | |
# if-no-files-found: error | |
# retention-days: 1 | |
# Upload combined benchmark results to CodSpeed | |
upload: | |
name: Upload benchmarks | |
# needs: [benchmark, benchmark-linter, benchmark-napi] | |
needs: [benchmark, benchmark-linter] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Branch | |
uses: taiki-e/checkout-action@b13d20b7cda4e2f325ef19895128f7ff735c0b3d # v1.3.1 | |
- uses: ./.github/actions/pnpm | |
- name: Create temp dir | |
working-directory: ./tasks/benchmark/codspeed | |
run: node create_temp_dir.mjs | |
- name: Download artefacts | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4 | |
with: | |
merge-multiple: true | |
pattern: result-* | |
path: ${{ env.DATA_DIR }} # env.DATA_DIR from `create_temp_dir.mjs` | |
- name: Upload to Codspeed | |
working-directory: ./tasks/benchmark/codspeed | |
env: | |
CODSPEED_TOKEN: ${{ secrets.CODSPEED_TOKEN }} | |
run: node upload.mjs | |
- name: Delete temporary artefacts | |
uses: geekyeggo/delete-artifact@f275313e70c08f6120db482d7a6b98377786765b # v5 | |
with: | |
name: | | |
result-* | |
benchmark-linter | |
failOnError: false |