Update README with suggestions from Show HN post (https://news.ycombi… #100
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
name: Package | |
on: | |
push: | |
branches: | |
- main | |
tags: | |
- 'v*' | |
workflow_dispatch: | |
env: | |
RUST_BACKTRACE: 1 | |
CARGO_INCREMENTAL: "false" | |
jobs: | |
Debian: | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: false # We want all of them to run, even if one fails | |
matrix: | |
pg: [ "12", "13", "14", "15", "16" ] | |
os: [ { distribution: "debian", release: "bullseye" }, { distribution: "debian", release: "bookworm" } ] | |
permissions: | |
contents: write | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Ensure all history for tags and branches is fetched | |
- name: Extract PL/PRQL version | |
run: | | |
# Find the latest tag | |
LATEST_TAG=$(git describe --tags --abbrev=0) | |
# Get the short SHA of the current commit | |
COMMIT_SHORT_SHA=$(git rev-parse --short=8 HEAD) | |
# Determine if the latest push is exactly the latest tag | |
if [[ "refs/tags/$LATEST_TAG" == "$GITHUB_REF" ]]; then | |
# If the push is for the latest tag, use the tag as the version | |
PLPRQL_VERSION=${LATEST_TAG#v} | |
else | |
# If the push is not for a tag, append the current commit's short SHA to the latest tag | |
PLPRQL_VERSION="${LATEST_TAG#v}-$COMMIT_SHORT_SHA" | |
fi | |
echo "PLPRQL_VERSION=$PLPRQL_VERSION" >> $GITHUB_ENV | |
echo "Version is $PLPRQL_VERSION" | |
- name: Package PL/PRQL .deb for PostgreSQL ${{ matrix.pg }} on ${{ matrix.os.distribution }} ${{ matrix.os.release }} | |
run: | | |
docker build \ | |
--build-arg PG_MAJOR_VERSION=${{ matrix.pg }} \ | |
--build-arg PLPRQL_VERSION=$PLPRQL_VERSION \ | |
--build-arg DEBIAN_RELEASE=${{ matrix.os.release }} \ | |
-t "plprql-$PLPRQL_VERSION-pg-${{ matrix.pg }}-${{ matrix.os.distribution }}-${{ matrix.os.release }}" \ | |
-f ".github/docker/Dockerfile.${{ matrix.os.distribution }}" \ | |
. | |
- name: Extract .deb | |
run: | | |
CONTAINER_ID=$(docker create plprql-$PLPRQL_VERSION-pg-${{ matrix.pg }}-${{ matrix.os.distribution }}-${{ matrix.os.release }}) | |
docker cp $CONTAINER_ID:/artifacts /home/runner | |
docker rm -v $CONTAINER_ID | |
- name: Verify Install | |
run: | | |
CONTAINER_ID=$(docker run -d -e POSTGRES_HOST_AUTH_METHOD=trust postgres:${{ matrix.pg }}-${{ matrix.os.release }}) | |
docker cp /home/runner/artifacts $CONTAINER_ID:/tmp | |
ls -R /home/runner/artifacts | |
docker exec $CONTAINER_ID ls -R /tmp | |
docker exec $CONTAINER_ID bash -c 'dpkg -i /tmp/artifacts/plprql*.deb' | |
max_tries=30 | |
count=0 | |
until docker exec $CONTAINER_ID pg_isready -U postgres; do | |
count=$((count+1)) | |
echo "Waiting for PostgreSQL to start (attempt $count of $max_tries)" | |
sleep 1 | |
if [ $count -ge $max_tries ]; then | |
echo "PostgreSQL failed to start" | |
exit 1 | |
fi | |
done | |
docker exec $CONTAINER_ID psql -U postgres -c "create extension plprql;" | |
docker exec $CONTAINER_ID psql -U postgres -c "select prql_to_sql('from table');" | |
docker stop $CONTAINER_ID | |
docker rm -v $CONTAINER_ID | |
- name: Upload .deb | |
if: startsWith(github.ref, 'refs/tags/v') | |
uses: softprops/action-gh-release@v1 | |
with: | |
files: /home/runner/artifacts/plprql*.deb | |
Bash: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install PostgreSQL headers | |
run: sudo apt-get install postgresql-server-dev-14 | |
- name: Install cargo-pgrx | |
run: | | |
PGRX_VERSION=$(cargo metadata --format-version 1 | jq -r '.packages[]|select(.name=="pgrx")|.version') | |
cargo install --locked --version=$PGRX_VERSION cargo-pgrx --debug --force | |
cargo pgrx init --pg14 $(which pg_config) | |
- name: Run install.sh | |
run: | | |
cd scripts | |
chmod +x install.sh | |
./install.sh --pg-config $(which pg_config) | |
- name: Start PostgreSQL | |
run: | | |
sudo systemctl start postgresql.service | |
pg_isready | |
# superuser (-s), can create databases (-d) and roles (-r), no password prompt (-w) named runner | |
sudo -u postgres createuser -s -d -r -w runner | |
- name: Verify install | |
run: | | |
createdb -U runner runner | |
psql -U runner -c "create extension plprql;" | |
psql -U runner -c "select prql_to_sql('from table');" |