Skip to content

perf: Add microbenchmark for hash expressions #1

perf: Add microbenchmark for hash expressions

perf: Add microbenchmark for hash expressions #1

# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# Lightweight CI for benchmark-only changes - verifies compilation and linting
# without running full test suites
name: PR Benchmark Check
concurrency:
group: ${{ github.repository }}-${{ github.head_ref || github.sha }}-${{ github.workflow }}
cancel-in-progress: true
on:
push:
paths:
- "native/core/benches/**"
- "native/spark-expr/benches/**"
- "spark/src/test/scala/org/apache/spark/sql/benchmark/**"
pull_request:
paths:
- "native/core/benches/**"
- "native/spark-expr/benches/**"
- "spark/src/test/scala/org/apache/spark/sql/benchmark/**"
workflow_dispatch:
env:
RUST_VERSION: stable
jobs:
benchmark-check:
name: Benchmark Compile & Lint Check
runs-on: ubuntu-latest
container:
image: amd64/rust
steps:
- uses: actions/checkout@v6
- name: Setup Rust & Java toolchain
uses: ./.github/actions/setup-builder
with:
rust-version: ${{ env.RUST_VERSION }}
jdk-version: 17
- name: Check Cargo fmt
run: |
cd native
cargo fmt --all -- --check --color=never
- name: Check Cargo clippy
run: |
cd native
cargo clippy --color=never --all-targets --workspace -- -D warnings
- name: Check benchmark compilation
run: |
cd native
cargo check --benches
- name: Cache Maven dependencies
uses: actions/cache@v4
with:
path: |
~/.m2/repository
/root/.m2/repository
key: ${{ runner.os }}-benchmark-maven-${{ hashFiles('**/pom.xml') }}
restore-keys: |
${{ runner.os }}-benchmark-maven-
- name: Check Scala compilation and linting
run: |
./mvnw -B compile test-compile scalafix:scalafix -Dscalafix.mode=CHECK -Psemanticdb -DskipTests