-
Notifications
You must be signed in to change notification settings - Fork 482
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #8533 from neondatabase/rc/2024-07-29
Storage & Compute release 2024-07-29
- Loading branch information
Showing
140 changed files
with
4,561 additions
and
2,655 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# allows for nicer hunk headers with git show | ||
*.rs diff=rust |
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,288 @@ | ||
name: Build and Test Locally | ||
|
||
on: | ||
workflow_call: | ||
inputs: | ||
arch: | ||
description: 'x64 or arm64' | ||
required: true | ||
type: string | ||
build-tag: | ||
description: 'build tag' | ||
required: true | ||
type: string | ||
build-tools-image: | ||
description: 'build-tools image' | ||
required: true | ||
type: string | ||
build-type: | ||
description: 'debug or release' | ||
required: true | ||
type: string | ||
|
||
defaults: | ||
run: | ||
shell: bash -euxo pipefail {0} | ||
|
||
env: | ||
RUST_BACKTRACE: 1 | ||
COPT: '-Werror' | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_DEV }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_KEY_DEV }} | ||
|
||
jobs: | ||
build-neon: | ||
runs-on: ${{ fromJson(format('["self-hosted", "{0}"]', inputs.arch == 'arm64' && 'large-arm64' || 'large')) }} | ||
container: | ||
image: ${{ inputs.build-tools-image }} | ||
credentials: | ||
username: ${{ secrets.NEON_DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.NEON_DOCKERHUB_PASSWORD }} | ||
# Raise locked memory limit for tokio-epoll-uring. | ||
# On 5.10 LTS kernels < 5.10.162 (and generally mainline kernels < 5.12), | ||
# io_uring will account the memory of the CQ and SQ as locked. | ||
# More details: https://github.com/neondatabase/neon/issues/6373#issuecomment-1905814391 | ||
options: --init --shm-size=512mb --ulimit memlock=67108864:67108864 | ||
env: | ||
BUILD_TYPE: ${{ inputs.build-type }} | ||
GIT_VERSION: ${{ github.event.pull_request.head.sha || github.sha }} | ||
BUILD_TAG: ${{ inputs.build-tag }} | ||
|
||
steps: | ||
- name: Fix git ownership | ||
run: | | ||
# Workaround for `fatal: detected dubious ownership in repository at ...` | ||
# | ||
# Use both ${{ github.workspace }} and ${GITHUB_WORKSPACE} because they're different on host and in containers | ||
# Ref https://github.com/actions/checkout/issues/785 | ||
# | ||
git config --global --add safe.directory ${{ github.workspace }} | ||
git config --global --add safe.directory ${GITHUB_WORKSPACE} | ||
for r in 14 15 16; do | ||
git config --global --add safe.directory "${{ github.workspace }}/vendor/postgres-v$r" | ||
git config --global --add safe.directory "${GITHUB_WORKSPACE}/vendor/postgres-v$r" | ||
done | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
fetch-depth: 1 | ||
|
||
- name: Set pg 14 revision for caching | ||
id: pg_v14_rev | ||
run: echo pg_rev=$(git rev-parse HEAD:vendor/postgres-v14) >> $GITHUB_OUTPUT | ||
|
||
- name: Set pg 15 revision for caching | ||
id: pg_v15_rev | ||
run: echo pg_rev=$(git rev-parse HEAD:vendor/postgres-v15) >> $GITHUB_OUTPUT | ||
|
||
- name: Set pg 16 revision for caching | ||
id: pg_v16_rev | ||
run: echo pg_rev=$(git rev-parse HEAD:vendor/postgres-v16) >> $GITHUB_OUTPUT | ||
|
||
# Set some environment variables used by all the steps. | ||
# | ||
# CARGO_FLAGS is extra options to pass to "cargo build", "cargo test" etc. | ||
# It also includes --features, if any | ||
# | ||
# CARGO_FEATURES is passed to "cargo metadata". It is separate from CARGO_FLAGS, | ||
# because "cargo metadata" doesn't accept --release or --debug options | ||
# | ||
# We run tests with addtional features, that are turned off by default (e.g. in release builds), see | ||
# corresponding Cargo.toml files for their descriptions. | ||
- name: Set env variables | ||
run: | | ||
CARGO_FEATURES="--features testing" | ||
if [[ $BUILD_TYPE == "debug" ]]; then | ||
cov_prefix="scripts/coverage --profraw-prefix=$GITHUB_JOB --dir=/tmp/coverage run" | ||
CARGO_FLAGS="--locked" | ||
elif [[ $BUILD_TYPE == "release" ]]; then | ||
cov_prefix="" | ||
CARGO_FLAGS="--locked --release" | ||
fi | ||
{ | ||
echo "cov_prefix=${cov_prefix}" | ||
echo "CARGO_FEATURES=${CARGO_FEATURES}" | ||
echo "CARGO_FLAGS=${CARGO_FLAGS}" | ||
echo "CARGO_HOME=${GITHUB_WORKSPACE}/.cargo" | ||
} >> $GITHUB_ENV | ||
- name: Cache postgres v14 build | ||
id: cache_pg_14 | ||
uses: actions/cache@v4 | ||
with: | ||
path: pg_install/v14 | ||
key: v1-${{ runner.os }}-${{ runner.arch }}-${{ inputs.build-type }}-pg-${{ steps.pg_v14_rev.outputs.pg_rev }}-${{ hashFiles('Makefile', 'Dockerfile.build-tools') }} | ||
|
||
- name: Cache postgres v15 build | ||
id: cache_pg_15 | ||
uses: actions/cache@v4 | ||
with: | ||
path: pg_install/v15 | ||
key: v1-${{ runner.os }}-${{ runner.arch }}-${{ inputs.build-type }}-pg-${{ steps.pg_v15_rev.outputs.pg_rev }}-${{ hashFiles('Makefile', 'Dockerfile.build-tools') }} | ||
|
||
- name: Cache postgres v16 build | ||
id: cache_pg_16 | ||
uses: actions/cache@v4 | ||
with: | ||
path: pg_install/v16 | ||
key: v1-${{ runner.os }}-${{ runner.arch }}-${{ inputs.build-type }}-pg-${{ steps.pg_v16_rev.outputs.pg_rev }}-${{ hashFiles('Makefile', 'Dockerfile.build-tools') }} | ||
|
||
- name: Build postgres v14 | ||
if: steps.cache_pg_14.outputs.cache-hit != 'true' | ||
run: mold -run make postgres-v14 -j$(nproc) | ||
|
||
- name: Build postgres v15 | ||
if: steps.cache_pg_15.outputs.cache-hit != 'true' | ||
run: mold -run make postgres-v15 -j$(nproc) | ||
|
||
- name: Build postgres v16 | ||
if: steps.cache_pg_16.outputs.cache-hit != 'true' | ||
run: mold -run make postgres-v16 -j$(nproc) | ||
|
||
- name: Build neon extensions | ||
run: mold -run make neon-pg-ext -j$(nproc) | ||
|
||
- name: Build walproposer-lib | ||
run: mold -run make walproposer-lib -j$(nproc) | ||
|
||
- name: Run cargo build | ||
run: | | ||
PQ_LIB_DIR=$(pwd)/pg_install/v16/lib | ||
export PQ_LIB_DIR | ||
${cov_prefix} mold -run cargo build $CARGO_FLAGS $CARGO_FEATURES --bins --tests | ||
# Do install *before* running rust tests because they might recompile the | ||
# binaries with different features/flags. | ||
- name: Install rust binaries | ||
run: | | ||
# Install target binaries | ||
mkdir -p /tmp/neon/bin/ | ||
binaries=$( | ||
${cov_prefix} cargo metadata $CARGO_FEATURES --format-version=1 --no-deps | | ||
jq -r '.packages[].targets[] | select(.kind | index("bin")) | .name' | ||
) | ||
for bin in $binaries; do | ||
SRC=target/$BUILD_TYPE/$bin | ||
DST=/tmp/neon/bin/$bin | ||
cp "$SRC" "$DST" | ||
done | ||
# Install test executables and write list of all binaries (for code coverage) | ||
if [[ $BUILD_TYPE == "debug" ]]; then | ||
# Keep bloated coverage data files away from the rest of the artifact | ||
mkdir -p /tmp/coverage/ | ||
mkdir -p /tmp/neon/test_bin/ | ||
test_exe_paths=$( | ||
${cov_prefix} cargo test $CARGO_FLAGS $CARGO_FEATURES --message-format=json --no-run | | ||
jq -r '.executable | select(. != null)' | ||
) | ||
for bin in $test_exe_paths; do | ||
SRC=$bin | ||
DST=/tmp/neon/test_bin/$(basename $bin) | ||
# We don't need debug symbols for code coverage, so strip them out to make | ||
# the artifact smaller. | ||
strip "$SRC" -o "$DST" | ||
echo "$DST" >> /tmp/coverage/binaries.list | ||
done | ||
for bin in $binaries; do | ||
echo "/tmp/neon/bin/$bin" >> /tmp/coverage/binaries.list | ||
done | ||
fi | ||
- name: Run rust tests | ||
env: | ||
NEXTEST_RETRIES: 3 | ||
run: | | ||
PQ_LIB_DIR=$(pwd)/pg_install/v16/lib | ||
export PQ_LIB_DIR | ||
LD_LIBRARY_PATH=$(pwd)/pg_install/v16/lib | ||
export LD_LIBRARY_PATH | ||
#nextest does not yet support running doctests | ||
cargo test --doc $CARGO_FLAGS $CARGO_FEATURES | ||
for io_engine in std-fs tokio-epoll-uring ; do | ||
NEON_PAGESERVER_UNIT_TEST_VIRTUAL_FILE_IOENGINE=$io_engine ${cov_prefix} cargo nextest run $CARGO_FLAGS $CARGO_FEATURES | ||
done | ||
# Run separate tests for real S3 | ||
export ENABLE_REAL_S3_REMOTE_STORAGE=nonempty | ||
export REMOTE_STORAGE_S3_BUCKET=neon-github-ci-tests | ||
export REMOTE_STORAGE_S3_REGION=eu-central-1 | ||
${cov_prefix} cargo nextest run $CARGO_FLAGS $CARGO_FEATURES -E 'package(remote_storage)' -E 'test(test_real_s3)' | ||
# Run separate tests for real Azure Blob Storage | ||
# XXX: replace region with `eu-central-1`-like region | ||
export ENABLE_REAL_AZURE_REMOTE_STORAGE=y | ||
export AZURE_STORAGE_ACCOUNT="${{ secrets.AZURE_STORAGE_ACCOUNT_DEV }}" | ||
export AZURE_STORAGE_ACCESS_KEY="${{ secrets.AZURE_STORAGE_ACCESS_KEY_DEV }}" | ||
export REMOTE_STORAGE_AZURE_CONTAINER="${{ vars.REMOTE_STORAGE_AZURE_CONTAINER }}" | ||
export REMOTE_STORAGE_AZURE_REGION="${{ vars.REMOTE_STORAGE_AZURE_REGION }}" | ||
${cov_prefix} cargo nextest run $CARGO_FLAGS $CARGO_FEATURES -E 'package(remote_storage)' -E 'test(test_real_azure)' | ||
- name: Install postgres binaries | ||
run: cp -a pg_install /tmp/neon/pg_install | ||
|
||
- name: Upload Neon artifact | ||
uses: ./.github/actions/upload | ||
with: | ||
name: neon-${{ runner.os }}-${{ runner.arch }}-${{ inputs.build-type }}-artifact | ||
path: /tmp/neon | ||
|
||
# XXX: keep this after the binaries.list is formed, so the coverage can properly work later | ||
- name: Merge and upload coverage data | ||
if: inputs.build-type == 'debug' | ||
uses: ./.github/actions/save-coverage-data | ||
|
||
regress-tests: | ||
# Run test on x64 only | ||
if: inputs.arch == 'x64' | ||
needs: [ build-neon ] | ||
runs-on: ${{ fromJson(format('["self-hosted", "{0}"]', inputs.arch == 'arm64' && 'large-arm64' || 'large')) }} | ||
container: | ||
image: ${{ inputs.build-tools-image }} | ||
credentials: | ||
username: ${{ secrets.NEON_DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.NEON_DOCKERHUB_PASSWORD }} | ||
# for changed limits, see comments on `options:` earlier in this file | ||
options: --init --shm-size=512mb --ulimit memlock=67108864:67108864 | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
pg_version: [ v14, v15, v16 ] | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
fetch-depth: 1 | ||
|
||
- name: Pytest regression tests | ||
uses: ./.github/actions/run-python-test-set | ||
timeout-minutes: 60 | ||
with: | ||
build_type: ${{ inputs.build-type }} | ||
test_selection: regress | ||
needs_postgres_source: true | ||
run_with_real_s3: true | ||
real_s3_bucket: neon-github-ci-tests | ||
real_s3_region: eu-central-1 | ||
rerun_flaky: true | ||
pg_version: ${{ matrix.pg_version }} | ||
env: | ||
TEST_RESULT_CONNSTR: ${{ secrets.REGRESS_TEST_RESULT_CONNSTR_NEW }} | ||
CHECK_ONDISK_DATA_COMPATIBILITY: nonempty | ||
BUILD_TAG: ${{ inputs.build-tag }} | ||
PAGESERVER_VIRTUAL_FILE_IO_ENGINE: tokio-epoll-uring | ||
|
||
# Temporary disable this step until we figure out why it's so flaky | ||
# Ref https://github.com/neondatabase/neon/issues/4540 | ||
- name: Merge and upload coverage data | ||
if: | | ||
false && | ||
inputs.build-type == 'debug' && matrix.pg_version == 'v14' | ||
uses: ./.github/actions/save-coverage-data |
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
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
Oops, something went wrong.
df07482
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
3164 tests run: 3043 passed, 0 failed, 121 skipped (full report)
Flaky tests (2)
Postgres 14
test_duplicate_creation
: debugtest_subscriber_restart
: releaseCode coverage* (full report)
functions
:32.8% (7008 of 21370 functions)
lines
:50.0% (55810 of 111575 lines)
* collected from Rust tests only
df07482 at 2024-07-29T17:52:28.488Z :recycle: