Skip to content

Commit

Permalink
Merge pull request #898 from bcgov/test
Browse files Browse the repository at this point in the history
Create Latest Release
  • Loading branch information
ikethecoder authored Sep 18, 2023
2 parents af1fc8c + 3077112 commit c2b3f70
Show file tree
Hide file tree
Showing 137 changed files with 3,798 additions and 1,652 deletions.
34 changes: 32 additions & 2 deletions .github/workflows/aps-cypress-e2e.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ name: Build and Deploy Cypress and Execute Tests

on:
push:
branches: ['test', 'cypress/*']
branches: ['test', 'cypress*']

env:
DASHBOARD_PROJECT_ID: ${{ secrets.CY_DASHBOARD_PRJ_ID }}
Expand All @@ -20,14 +20,43 @@ jobs:
steps:
- name: Build GWA API Image
run: |
git clone https://github.com/bcgov/gwa-api.git -b master
git clone https://github.com/bcgov/gwa-api.git
cd gwa-api/microservices/gatewayApi
docker build -t gwa-api:e2e .
- name: Checkout Portal
uses: actions/checkout@v2


- name: Determine Download file name
id: set_variable
run: |
echo ${{ runner.arch }}
if [ "${{ runner.arch }}" == "X64" ]; then
echo "::set-output name=my_variable::gwa_Linux_x86_64.tgz"
elif [ "${{ runner.arch }}" == "ARM64" ]; then
echo "::set-output name=my_variable::gwa_Linux_arm64.tgz"
else
echo "unsupported architecture"
fi
- name: Download Binar
uses: robinraju/[email protected]
with:
repository: "bcgov/gwa-cli"
latest: true
fileName: ${{ steps.set_variable.outputs.my_variable }}
out-file-path: "${{ github.workspace }}/e2e"

- name: Unzip file
run: |
cd ${{ github.workspace }}/e2e
tar xvzf ${{ steps.set_variable.outputs.my_variable }}
- name: Build Docker Images
run: |
docker-compose build
- name: Spin up API Services Portal and Run E2E Tests
run: |
export CY_EXECUTION_ENV=${{ env.EXECUTION_ENV }}
Expand All @@ -40,6 +69,7 @@ jobs:
export CY_REPO_URL=${{ env.GIT_REPO_URL }}
export CY_COMMIT_AUTHOR_EMAIL=$(git --no-pager show -s --format='%ae' ${{ env.GIT_COMMIT_SHA }})
docker-compose up -d
- name: Execute Tests & Clean Up
run: |
while true; do
Expand Down
11 changes: 11 additions & 0 deletions .github/workflows/jira.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
name: Sync GitHub issues to Jira
on: [issues, issue_comment]

jobs:
sync-issues:
name: Sync issues to Jira
runs-on: ubuntu-latest
steps:
- uses: ikethecoder/sync-issues-github-jira@dev
with:
webhook-url: ${{ secrets.JIRA_WEBHOOK_URL }}
4 changes: 3 additions & 1 deletion e2e/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,16 @@ FROM cypress/included:12.4.0
WORKDIR /e2e

RUN apt-get -y update; apt-get -y install curl

COPY cypress.config.ts /e2e
COPY tsconfig.json /e2e
COPY package.json /e2e
COPY package-lock.json /e2e
COPY *.yml /e2e
COPY entrypoint.sh /tmp
COPY gwa /usr/local/bin
ADD cypress /e2e/cypress

RUN npm install


ENTRYPOINT ["npm", "run", "cy:run:html"]
5 changes: 3 additions & 2 deletions e2e/cypress.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,11 @@ export default defineConfig({
'./cypress/tests/10-*/*.ts',
'./cypress/tests/11-*/*.ts',
'./cypress/tests/12-*/*.ts',
'./cypress/tests/13-*/*.ts',
'./cypress/tests/13-*/*.ts',
'./cypress/tests/14-*/*.ts',
'./cypress/tests/15-*/*.ts',
'./cypress/tests/16-*/*.ts'
'./cypress/tests/16-*/*.ts',
'./cypress/tests/17-*/*.ts'
]
return config
},
Expand Down
150 changes: 128 additions & 22 deletions e2e/cypress/fixtures/api.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,36 @@
"title": "Planning and Innovation Division"
},
"orgName": "ministry-of-health",
"expectedScope": ["Dataset.Manage", "GroupAccess.Manage", "Namespace.Assign"],
"expectedScope": [
"Dataset.Manage",
"GroupAccess.Manage",
"Namespace.Assign"
],
"expectedNamespace": {
"name": "newplatform",
"orgUnit": "planning-and-innovation-division"
"name": "gw-3a443",
"orgUnit": "planning-and-innovation-division",
"enabled": true
},
"expectedRoles": {
"organization-admin": {
"label": "Organization Administrator",
"permissions": [
{
"resourceType": "organization",
"scopes": [
"GroupAccess.Manage",
"Namespace.Assign",
"Dataset.Manage"
]
},
{
"resourceType": "namespace",
"scopes": [
"Namespace.View"
]
}
]
}
},
"body": {
"name": "ministry-of-health",
Expand All @@ -24,7 +50,9 @@
"id": "janis@idir",
"email": "[email protected]"
},
"roles": ["organization-admin"]
"roles": [
"organization-admin"
]
}
]
}
Expand All @@ -44,7 +72,10 @@
"order": 0,
"isPublic": true,
"isComplete": true,
"tags": ["tag1", "tag2"]
"tags": [
"tag1",
"tag2"
]
}
},
"apiDirectory": {
Expand All @@ -65,18 +96,25 @@
"title": "Dataset for Test API",
"isInCatalog": "false",
"isDraft": "false",
"tags": ["gateway", "kong"],
"tags": [
"gateway",
"kong"
],
"organization": "ministry-of-health",
"organizationUnit": "planning-and-innovation-division"
},
"directory": {
"name": "api-auto-test-product",
"title": "API Auto Test Product",
"notes": "API Gateway Services provides a way to configure services on the API Gateway, manage access to APIs and get insight into the use of them.",
"license_title": "Access Only",
"view_audience": "Government",
"security_class": "LOW-PUBLIC",
"tags": ["gateway", "kong", "openapi"],
"name": "gwa-auto-test-product",
"title": "GWA Auto Test Product",
"notes": "For Test Purpose",
"license_title": "Open Government Licence - British Columbia",
"view_audience": "Public",
"security_class": "PUBLIC",
"record_publish_date": "2017-09-05",
"tags": [
"tag1",
"tag2"
],
"organization": {
"name": "ministry-of-health",
"title": "Ministry of Health"
Expand All @@ -87,12 +125,18 @@
},
"products": [
{
"name": "API Auto Test Product",
"id": "2",
"name": "GWA Auto Test Product",
"environments": [
{
"name": "dev",
"active": true,
"flow": "kong-api-key-acl"
"flow": "kong-api-key-only"
},
{
"name": "test",
"active": true,
"flow": "client-credentials"
}
]
}
Expand All @@ -105,7 +149,11 @@
"license_title": "Access Only",
"view_audience": "Government",
"security_class": "LOW-PUBLIC",
"tags": ["gateway", "kong", "openapi"],
"tags": [
"gateway",
"kong",
"openapi"
],
"organization": {
"name": "ministry-of-health",
"title": "Ministry of Health"
Expand Down Expand Up @@ -174,6 +222,46 @@
],
"isShared": true
},
"shared_gwa": {
"name": "Gold Shared IdP",
"description": "A Shared IdP for Teams to use",
"flow": "client-credentials",
"clientAuthenticator": "client-secret",
"mode": "auto",
"environmentDetails": [
{
"environment": "test",
"issuerUrl": "http://keycloak.localtest.me:9080/auth/realms/master",
"clientRegistration": "managed",
"clientId": "gwa-api",
"clientSecret": "18900468-3db1-43f7-a8af-e75f079eb742"
}
],
"isShared": true
},
"shared_gwa_publish": {
"name": "Gold Shared IdP",
"description": "A Shared IdP for Teams to use",
"flow": "client-credentials",
"mode": "auto",
"clientAuthenticator": "client-secret",
"environmentDetails": [
{
"clientId": "gwa-api",
"clientRegistration": "managed",
"clientSecret": "****",
"environment": "test",
"issuerUrl": "http://keycloak.localtest.me:9080/auth/realms/master",
"exists": true
}
],
"clientRoles": [],
"clientMappers": [],
"availableScopes": [],
"resourceScopes": [],
"isShared": true,
"apiKeyName": "X-API-KEY"
},
"shared_IDP_body": {
"name": "Sample Shared IdP new",
"description": "A Shared IdP for Teams to use",
Expand All @@ -194,8 +282,12 @@
"shared_IDP_inheritFrom": {
"environmentDetails": [],
"mode": "auto",
"clientRoles": ["administrator"],
"clientMappers": ["test-audience"],
"clientRoles": [
"administrator"
],
"clientMappers": [
"test-audience"
],
"flow": "client-credentials",
"clientAuthenticator": "client-secret",
"name": "my-auth-client-secret-1",
Expand All @@ -218,8 +310,12 @@
"clientId": "ap-my-auth-client-secret-1-test"
}
],
"clientRoles": ["administrator"],
"clientMappers": ["test-audience"],
"clientRoles": [
"administrator"
],
"clientMappers": [
"test-audience"
],
"isShared": false,
"apiKeyName": "X-API-KEY",
"inheritFrom": {
Expand Down Expand Up @@ -282,11 +378,21 @@
"name": "CredentialIssuer.Admin"
}
],
"permDomains": [".api.gov.bc.ca"],
"permDomains": [
".api.gov.bc.ca"
],
"permDataPlane": "local.dataplane",
"permProtectedNs": "deny",
"org": "ministry-of-health",
"orgUnit": "planning-and-innovation-division"
},
"userDefinedNamespace": {
"name": "gwanelatform",
"displayName": "Test for GWA test"
},
"inValidNamespace": {
"name": "gwa",
"displayName": "Test for GWA test"
}
}
}
}
Loading

0 comments on commit c2b3f70

Please sign in to comment.