This action handles the setup and teardown of a PostgreSQL database.
See action.yml
steps:
- name: Setup Postgres
uses: Particular/[email protected]
with:
connection-string-name: <my connection string name>
tag: <my tag>
init-script: /path/to/init-posgres.sql
registry-login-server: index.docker.io
registry-username: ${{ secrets.DOCKERHUB_USERNAME }}
registry-password: ${{ secrets.DOCKERHUB_TOKEN }}}}
connection-string-name
and tag
are required. init-script
is optional.
For logging into a container registry when running on Windows:
registry-login-server
defaults toindex.docker.io
and is not required if logging into Docker Hub.registry-username
andregistry-password
are optional and will result in pulling the container anonymously if omitted.
The scripts and documentation in this project are released under the MIT License.
Open the folder in Visual Studio Code. If you don't already have them, you will be prompted to install remote development extensions. After installing them, and re-opening the folder in a container, do the following:
Log into Azure
az login
az account set --subscription SUBSCRIPTION_ID
Run the npm installation
npm install
When changing index.js
, either run npm run dev
beforehand, which will watch the file for changes and automatically compile it, or run npm run prepare
afterwards.
To test the setup action an .env.setup
file in the root directory with the following content
# Input overrides
INPUT_CONNECTION-STRING-NAME=PostgresConnectionString
INPUT_TAG=setup-postgres-action
# Runner overrides
# Use LINUX to run on Linux
RUNNER_OS=WINDOWS
RESOURCE_GROUP_OVERRIDE=yourResourceGroup
REGION_OVERRIDE=West Europe
then execute the script
node -r dotenv/config dist/index.js dotenv_config_path=.env.setup
To test the cleanup action add a .env.cleanup
file in the root directory with the following content
# State overrides
STATE_IsPost=true
STATE_containerName=nameOfPreviouslyCreatedContainer
node -r dotenv/config dist/index.js dotenv_config_path=.env.cleanup
To test the setup action set the required environment variables and execute setup.ps1
with the desired parameters.
$Env:RUNNER_OS=Windows
$Env:RESOURCE_GROUP_OVERRIDE=yourResourceGroup
$Env:REGION_OVERRIDE=yourRegion
.\setup.ps1 -ContainerName psw-postgres-1 -ConnectionStringName PostgresConnectionString -Tag setup-postgres-action
To test the cleanup action set the required environment variables and execute cleanup.ps1
with the desired parameters.
$Env:RUNNER_OS=Windows
$Env:RESOURCE_GROUP_OVERRIDE=yourResourceGroup
.\cleanup.ps1 -ContainerName psw-postgres-1 -StorageName psworacle1 -ConnectionStringName PostgresConnectionString -Tag setup-postgres-action