-
Notifications
You must be signed in to change notification settings - Fork 442
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into yuchen/handle-decompression-outside-vectored…
…-read-blobs
- Loading branch information
Showing
54 changed files
with
5,765 additions
and
742 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 |
---|---|---|
|
@@ -13,6 +13,7 @@ | |
# Directories | ||
!.cargo/ | ||
!.config/ | ||
!compute/ | ||
!compute_tools/ | ||
!control_plane/ | ||
!libs/ | ||
|
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,102 @@ | ||
name: Cloud Regression Test | ||
on: | ||
schedule: | ||
# * is a special character in YAML so you have to quote this string | ||
# ┌───────────── minute (0 - 59) | ||
# │ ┌───────────── hour (0 - 23) | ||
# │ │ ┌───────────── day of the month (1 - 31) | ||
# │ │ │ ┌───────────── month (1 - 12 or JAN-DEC) | ||
# │ │ │ │ ┌───────────── day of the week (0 - 6 or SUN-SAT) | ||
- cron: '45 1 * * *' # run once a day, timezone is utc | ||
workflow_dispatch: # adds ability to run this manually | ||
|
||
defaults: | ||
run: | ||
shell: bash -euxo pipefail {0} | ||
|
||
concurrency: | ||
# Allow only one workflow | ||
group: ${{ github.workflow }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
regress: | ||
env: | ||
POSTGRES_DISTRIB_DIR: /tmp/neon/pg_install | ||
DEFAULT_PG_VERSION: 16 | ||
TEST_OUTPUT: /tmp/test_output | ||
BUILD_TYPE: remote | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_DEV }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_KEY_DEV }} | ||
|
||
runs-on: us-east-2 | ||
container: | ||
image: neondatabase/build-tools:pinned | ||
options: --init | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
submodules: true | ||
|
||
- name: Patch the test | ||
run: | | ||
cd "vendor/postgres-v${DEFAULT_PG_VERSION}" | ||
patch -p1 < "../../compute/patches/cloud_regress_pg${DEFAULT_PG_VERSION}.patch" | ||
- name: Generate a random password | ||
id: pwgen | ||
run: | | ||
set +x | ||
DBPASS=$(dd if=/dev/random bs=48 count=1 2>/dev/null | base64) | ||
echo "::add-mask::${DBPASS//\//}" | ||
echo DBPASS="${DBPASS//\//}" >> "${GITHUB_OUTPUT}" | ||
- name: Change tests according to the generated password | ||
env: | ||
DBPASS: ${{ steps.pwgen.outputs.DBPASS }} | ||
run: | | ||
cd vendor/postgres-v"${DEFAULT_PG_VERSION}"/src/test/regress | ||
for fname in sql/*.sql expected/*.out; do | ||
sed -i.bak s/NEON_PASSWORD_PLACEHOLDER/"'${DBPASS}'"/ "${fname}" | ||
done | ||
for ph in $(grep NEON_MD5_PLACEHOLDER expected/password.out | awk '{print $3;}' | sort | uniq); do | ||
USER=$(echo "${ph}" | cut -c 22-) | ||
MD5=md5$(echo -n "${DBPASS}${USER}" | md5sum | awk '{print $1;}') | ||
sed -i.bak "s/${ph}/${MD5}/" expected/password.out | ||
done | ||
- name: Download Neon artifact | ||
uses: ./.github/actions/download | ||
with: | ||
name: neon-${{ runner.os }}-${{ runner.arch }}-release-artifact | ||
path: /tmp/neon/ | ||
prefix: latest | ||
|
||
- name: Run the regression tests | ||
uses: ./.github/actions/run-python-test-set | ||
with: | ||
build_type: ${{ env.BUILD_TYPE }} | ||
test_selection: cloud_regress | ||
pg_version: ${{ env.DEFAULT_PG_VERSION }} | ||
extra_params: -m remote_cluster | ||
env: | ||
BENCHMARK_CONNSTR: ${{ secrets.PG_REGRESS_CONNSTR }} | ||
|
||
- name: Create Allure report | ||
id: create-allure-report | ||
if: ${{ !cancelled() }} | ||
uses: ./.github/actions/allure-report-generate | ||
|
||
- name: Post to a Slack channel | ||
if: ${{ github.event.schedule && failure() }} | ||
uses: slackapi/slack-github-action@v1 | ||
with: | ||
channel-id: "C033QLM5P7D" # on-call-staging-stream | ||
slack-message: | | ||
Periodic pg_regress on staging: ${{ job.status }} | ||
<${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}|GitHub Run> | ||
<${{ steps.create-allure-report.outputs.report-url }}|Allure report> | ||
env: | ||
SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }} | ||
|
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
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,21 @@ | ||
This directory contains files that are needed to build the compute | ||
images, or included in the compute images. | ||
|
||
Dockerfile.compute-node | ||
To build the compute image | ||
|
||
vm-image-spec.yaml | ||
Instructions for vm-builder, to turn the compute-node image into | ||
corresponding vm-compute-node image. | ||
|
||
etc/ | ||
Configuration files included in /etc in the compute image | ||
|
||
patches/ | ||
Some extensions need to be patched to work with Neon. This | ||
directory contains such patches. They are applied to the extension | ||
sources in Dockerfile.compute-node | ||
|
||
In addition to these, postgres itself, the neon postgres extension, | ||
and compute_ctl are built and copied into the compute image by | ||
Dockerfile.compute-node. |
Oops, something went wrong.