|
| 1 | +name: CI |
| 2 | +on: |
| 3 | + push: |
| 4 | + branches: |
| 5 | + - master |
| 6 | + - release-[6-9].* |
| 7 | + pull_request: |
| 8 | + branches-ignore: |
| 9 | + - release-[0-5].* |
| 10 | + workflow_dispatch: |
| 11 | +env: |
| 12 | + DOTNET_NOLOGO: true |
| 13 | +jobs: |
| 14 | + build: |
| 15 | + name: ${{ matrix.os-name }}-${{ matrix.engine }} |
| 16 | + runs-on: ${{ matrix.os }} |
| 17 | + strategy: |
| 18 | + matrix: |
| 19 | + os: [ windows-2019, ubuntu-20.04 ] |
| 20 | + engine: [ SqlServer, MySql, PostgreSql ] |
| 21 | + include: |
| 22 | + # Add os-name alias for job name |
| 23 | + - os: windows-2019 |
| 24 | + os-name: Windows |
| 25 | + - os: ubuntu-20.04 |
| 26 | + os-name: Linux |
| 27 | + # Additional permutatations for Oracle |
| 28 | + - os: ubuntu-20.04 |
| 29 | + os-name: Linux |
| 30 | + engine: Oracle |
| 31 | + - os: [self-hosted, windows, oracle] |
| 32 | + os-name: Windows |
| 33 | + engine: Oracle |
| 34 | + fail-fast: false |
| 35 | + steps: |
| 36 | + - name: Check for secrets |
| 37 | + env: |
| 38 | + SECRETS_AVAILABLE: ${{ secrets.SECRETS_AVAILABLE }} |
| 39 | + shell: pwsh |
| 40 | + run: exit $(If ($env:SECRETS_AVAILABLE -eq 'true') { 0 } Else { 1 }) |
| 41 | + - name: Checkout |
| 42 | + uses: actions/checkout@v2.4.0 |
| 43 | + with: |
| 44 | + fetch-depth: 0 |
| 45 | + - name: Setup .NET SDK |
| 46 | + uses: actions/setup-dotnet@v1.9.0 |
| 47 | + with: |
| 48 | + dotnet-version: | |
| 49 | + 5.0.x |
| 50 | + 3.1.x |
| 51 | + - name: Build |
| 52 | + run: dotnet build src --configuration Release |
| 53 | + - name: Upload packages |
| 54 | + uses: actions/upload-artifact@v2.2.4 |
| 55 | + with: |
| 56 | + name: NuGet packages |
| 57 | + path: nugets/ |
| 58 | + retention-days: 7 |
| 59 | + - name: Azure login |
| 60 | + uses: azure/login@v1.3.0 |
| 61 | + if: matrix.engine == 'PostgreSQL' |
| 62 | + with: |
| 63 | + creds: ${{ secrets.AZURE_ACI_CREDENTIALS }} |
| 64 | + - name: Setup SQL Server |
| 65 | + if: matrix.engine == 'SqlServer' |
| 66 | + uses: Particular/install-sql-server-action@v1.0.0 |
| 67 | + with: |
| 68 | + connection-string-env-var: SQLServerConnectionString |
| 69 | + catalog: nservicebus |
| 70 | + - name: Setup PostgreSql |
| 71 | + id: setup-postgresql |
| 72 | + if: matrix.engine == 'PostgreSql' |
| 73 | + shell: pwsh |
| 74 | + run: | |
| 75 | + echo "Getting the Azure region in which this workflow is running..." |
| 76 | + $hostInfo = curl -H Metadata:true --noproxy "*" "http://169.254.169.254/metadata/instance?api-version=2021-02-01" | ConvertFrom-Json |
| 77 | + $region = $hostInfo.compute.location |
| 78 | + echo "Actions agent running in Azure region: $region" |
| 79 | +
|
| 80 | + $name = "postgres-$(Get-Random)" |
| 81 | + $packageTag = "Package=SqlPersistence" |
| 82 | + $runnerOsTag = "RunnerOS=$($Env:RUNNER_OS)" |
| 83 | + $dateTag = "Created=$(Get-Date -Format "yyyy-MM-dd")" |
| 84 | +
|
| 85 | + $password = [guid]::NewGuid().ToString("n") |
| 86 | + echo "::add-mask::$password" |
| 87 | +
|
| 88 | + echo "Creating PostgreSQL container $name (This can take a while)" |
| 89 | + $details = az container create --image postgres:14 --name $name --location $region --dns-name-label $name --resource-group GitHubActions-RG --cpu 2 --memory 8 --ports 5432 --ip-address public --environment-variables POSTGRES_PASSWORD="$password" | ConvertFrom-Json |
| 90 | + echo "::set-output name=name::$name" |
| 91 | +
|
| 92 | + echo "Tagging container" |
| 93 | + $ignore = az tag create --resource-id $details.id --tags $packageTag $runnerOsTag $dateTag |
| 94 | +
|
| 95 | + $fqdn = $details.ipAddress.fqdn |
| 96 | + echo "::add-mask::$fqdn" |
| 97 | +
|
| 98 | + $connectionString = "User ID=postgres;Password=$password;Host=$fqdn;Port=5432;Database=postgres;" |
| 99 | + echo "PostgreSqlConnectionString=$connectionString" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 100 | +
|
| 101 | + $env:PGPASSWORD = $password |
| 102 | +
|
| 103 | + # psql not in PATH on Windows |
| 104 | + if ($Env:RUNNER_OS -eq 'Windows') { |
| 105 | + $Env:PATH = $Env:PATH + ';' + $Env:PGBIN |
| 106 | + } |
| 107 | +
|
| 108 | + for ($i = 0; $i -lt 24; $i++) { ## 2 minute timeout |
| 109 | + echo "Checking for PostgreSQL connectivity $($i+1)/30..." |
| 110 | + $ignore = psql --host $fqdn --username=postgres --list |
| 111 | + if ($?) { |
| 112 | + echo "Connection successful" |
| 113 | + break; |
| 114 | + } |
| 115 | + sleep 5 |
| 116 | + } |
| 117 | +
|
| 118 | + - name: Setup MySQL |
| 119 | + id: setup-mysql |
| 120 | + if: matrix.engine == 'MySql' |
| 121 | + shell: pwsh |
| 122 | + run: | |
| 123 | + echo '[client] |
| 124 | + user=root |
| 125 | + host=localhost' >> mysql-login |
| 126 | +
|
| 127 | + if ($Env:RUNNER_OS -eq 'Windows') { |
| 128 | + echo "Installing MySQL from Chocolatey" |
| 129 | + choco install mysql --limitoutput |
| 130 | + echo 'password=' >> mysql-login |
| 131 | + } else { |
| 132 | + echo "Starting MySQL service preinstalled on Linux agent" |
| 133 | + sudo systemctl start mysql.service |
| 134 | + echo 'password=root' >> mysql-login |
| 135 | + } |
| 136 | +
|
| 137 | + for ($i = 0; $i -lt 30; $i++) { ## 2.5 minute timeout |
| 138 | + echo "Checking for MySQL connectivity $($i+1)/30..." |
| 139 | + $ignore = mysql --defaults-extra-file=mysql-login -e "show databases;" |
| 140 | + if ($?) { |
| 141 | + echo "Connection successful" |
| 142 | + break; |
| 143 | + } |
| 144 | + sleep 5 |
| 145 | + } |
| 146 | +
|
| 147 | + echo "Creating nservicebus database" |
| 148 | + mysql --defaults-extra-file=mysql-login -D mysql -e "create database if not exists nservicebus ;" |
| 149 | + echo "Creating user particular" |
| 150 | + mysql --defaults-extra-file=mysql-login -D mysql -e "create user particular identified by 'Welcome1' ;" |
| 151 | + echo "Giving user particular access to schema nservicebus" |
| 152 | + mysql --defaults-extra-file=mysql-login -D mysql -e "grant all on *.* to particular@'%' ;" |
| 153 | +
|
| 154 | + $connectionString = "Data Source=localhost;Initial Catalog=nservicebus;User ID=particular;Password=Welcome1;AllowUserVariables=True;AutoEnlist=false;Connect Timeout=60" |
| 155 | + echo "MySQLConnectionString=$connectionString" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 156 | +
|
| 157 | + - name: Setup Oracle |
| 158 | + id: setup-oracle |
| 159 | + if: matrix.engine == 'Oracle' |
| 160 | + shell: pwsh |
| 161 | + run: | |
| 162 | + if ( $Env:RUNNER_OS -eq 'Windows') { |
| 163 | + echo "Adding environment variables for Oracle connection strings" |
| 164 | + echo "OracleConnectionString=User Id=particular;Password=Welcome1;Data Source=127.0.0.1:1521/nservicebus;Enlist=dynamic" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 165 | + echo "OracleConnectionString_Particular2=User Id=particular2;Password=Welcome1;Data Source=127.0.0.1:1521/nservicebus;Enlist=dynamic" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 166 | + } |
| 167 | +
|
| 168 | + if ( $Env:RUNNER_OS -eq 'Linux' ) { |
| 169 | + echo "Running Oracle using Docker" |
| 170 | + docker run --name oracle -d -p 1521:1521 -e ORACLE_PASSWORD=Welcome1 gvenzl/oracle-xe:21 |
| 171 | +
|
| 172 | + for ($i = 0; $i -lt 24; $i++) { ## 2 minute timeout |
| 173 | + echo "Checking for Oracle connectivity $($i+1)/24..." |
| 174 | + docker exec oracle ./healthcheck.sh |
| 175 | + if ($?) { |
| 176 | + echo "Connection successful" |
| 177 | + break; |
| 178 | + } |
| 179 | + sleep 5 |
| 180 | + } |
| 181 | +
|
| 182 | + cat ./.github/workflows/scripts/oracle-setup-linux.sql | docker exec -i oracle sqlplus / as sysdba |
| 183 | +
|
| 184 | + echo "Adding environment variables for Oracle connection strings" |
| 185 | + echo "OracleConnectionString=Data Source=(DESCRIPTION=(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521)))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = XE)));User Id=particular; Password=Welcome1; Enlist=dynamic" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 186 | + echo "OracleConnectionString_Particular2=Data Source=(DESCRIPTION=(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521)))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = XE)));User Id=particular2; Password=Welcome1; Enlist=dynamic" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append |
| 187 | + } |
| 188 | +
|
| 189 | + - name: Run tests |
| 190 | + uses: Particular/run-tests-action@v1.0.0 |
| 191 | + - name: Teardown infrastructure |
| 192 | + if: ${{ always() }} |
| 193 | + shell: pwsh |
| 194 | + run: | |
| 195 | + if ('${{ matrix.engine }}' -eq 'PostgreSql') { |
| 196 | + echo "Removing container ${{ steps.setup-postgresql.outputs.name }}" |
| 197 | + $ignore = az container delete --resource-group GitHubActions-RG --name ${{ steps.setup-postgresql.outputs.name }} --yes |
| 198 | + echo "Removal complete" |
| 199 | + } |
0 commit comments