Skip to content

feat: Add Async SpillMerger in LocalMerge #27387

feat: Add Async SpillMerger in LocalMerge

feat: Add Async SpillMerger in LocalMerge #27387

Workflow file for this run

# Copyright (c) Facebook, Inc. and its affiliates.
#
# Licensed 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.
#
name: macOS Build
on:
push:
paths:
- velox/**
- '!velox/docs/**'
- CMakeLists.txt
- CMake/**
- scripts/setup-macos.sh
- .github/workflows/macos.yml
pull_request:
paths:
- velox/**
- '!velox/docs/**'
- CMakeLists.txt
- CMake/**
- scripts/setup-macos.sh
- .github/workflows/macos.yml
permissions:
contents: read
concurrency:
group: ${{ github.workflow }}-${{ github.repository }}-${{ github.head_ref || github.sha }}
cancel-in-progress: true
jobs:
macos-build:
if: ${{ github.repository == 'facebookincubator/velox' }}
name: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
# macos-13 = x86_64 Mac
# macos-15 = arm64 Mac and cmake 4.0
os: [macos-13, macos-15]
runs-on: ${{ matrix.os }}
env:
CCACHE_DIR: ${{ github.workspace }}/ccache
# The arm runners have only 7GB RAM
BUILD_TYPE: ${{ matrix.os == 'macos-15' && 'Release' || 'Debug' }}
INSTALL_PREFIX: /tmp/deps-install
steps:
- name: Checkout
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Install Dependencies
env:
HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK: 'TRUE'
CMAKE_POLICY_VERSION_MINIMUM: '3.5'
run: |
source scripts/setup-macos.sh
install_build_prerequisites
install_velox_deps_from_brew
# Needed for faiss to find BLAS
install_faiss_deps
install_double_conversion
echo "NJOBS=`sysctl -n hw.ncpu`" >> $GITHUB_ENV
majorVersion=$(sw_vers -productVersion | awk -F '.' '{print $1}')
if (( majorVersion == 13 )); then
brew uninstall cmake
pipx install --force cmake==3.31
fi
- name: Cache ccache
uses: apache/infrastructure-actions/stash/restore@3354c1565d4b0e335b78a76aedd82153a9e144d4
with:
path: ${{ env.CCACHE_DIR }}
key: ccache-macos-1-${{ matrix.os }}
- name: Configure Build
env:
fmt_SOURCE: BUNDLED #brew fmt11 is not supported
faiss_SOURCE: BUNDLED #brew faiss is not supported
CMAKE_POLICY_VERSION_MINIMUM: '3.5'
run: |
ccache -sz -M 5Gi
cmake \
-B _build/$BUILD_TYPE \
-GNinja \
-DTREAT_WARNINGS_AS_ERRORS=1 \
-DENABLE_ALL_WARNINGS=1 \
-DVELOX_ENABLE_PARQUET=ON \
-DVELOX_MONO_LIBRARY=ON \
-DVELOX_BUILD_SHARED=ON \
-DCMAKE_BUILD_TYPE=$BUILD_TYPE \
-DVELOX_ENABLE_FAISS=ON
- name: Build
run: |
cmake --build _build/$BUILD_TYPE -j $NJOBS
ccache -s
- uses: apache/infrastructure-actions/stash/save@3354c1565d4b0e335b78a76aedd82153a9e144d4
with:
path: ${{ env.CCACHE_DIR }}
key: ccache-macos-1-${{ matrix.os }}
- name: Run Tests
if: false
run: ctest -j $NJOBS --test-dir _build/debug --output-on-failure