Skip to content

Commit

Permalink
Merge pull request #55 from wri/sync/staging-to-prod
Browse files Browse the repository at this point in the history
Sync prod to staging
  • Loading branch information
MuhammadIsmailShahzad authored Oct 26, 2023
2 parents cc3fc25 + 7f9a33c commit 52dd271
Show file tree
Hide file tree
Showing 184 changed files with 12,258 additions and 129 deletions.
9 changes: 8 additions & 1 deletion .github/workflows/cost-splitting-report.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,13 +51,20 @@ jobs:
key: venv-${{ hashFiles('poetry.lock') }}
- name: Install the project dependencies
run: poetry install
- name: Extract branch name
shell: bash
run: echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> $GITHUB_OUTPUT
id: extract_branch
- name: Run the report creation
run: poetry run python script.py
env:
BRANCH_NAME: ${{ steps.extract_branch.outputs.branch }}
- name: Commit files
run: |
git config --local user.email "action@github.com"
git config --local user.name "GitHub Action"
git commit --allow-empty -m "Updating the storage report" -a
git add .
git commit --allow-empty -m "Updating the storage report"
- name: Push changes
uses: ad-m/github-push-action@master
with:
Expand Down
47 changes: 34 additions & 13 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ on:
push:
branches:
- prod
pull_request:
branches:
- prod
env:
PROJECT_NAME: wri-odp
BRANCH_NAME: prod
Expand All @@ -28,23 +31,36 @@ jobs:
mask-password: 'true'
- name: Add CKAN url to hosts
run: sudo echo "127.0.0.1 ckan-dev" | sudo tee -a /etc/hosts
- name: Build and push image to ECR
- name: Build and push CKAN image to ECR
env:
REGISTRY: ${{ steps.login-ecr.outputs.registry }}
CKAN_REPO: ${{ secrets.ECR_CKAN_REPO}}
IMAGE_TAG: ${{ github.sha }}
run: |
mv ckan-backend-dev/src/ckanext-wri deployment/ckan/
docker build -t $REGISTRY/$CKAN_REPO:$IMAGE_TAG deployment/ckan
docker push $REGISTRY/$CKAN_REPO:$IMAGE_TAG
- name: Build and push Frontend image to ECR
env:
REGISTRY: ${{ steps.login-ecr.outputs.registry }}
REPOSITORY: ckan-dev-ecr
FRONTEND_REPO: ${{ secrets.ECR_FRONTEND_REPO}}
IMAGE_TAG: ${{ github.sha }}
run: |
docker build -t $REGISTRY/$REPOSITORY:$IMAGE_TAG ckan-deployment/ckan
docker push $REGISTRY/$REPOSITORY:$IMAGE_TAG
docker build -t $REGISTRY/$FRONTEND_REPO:$IMAGE_TAG \
--build-arg NEXTAUTH_SECRET=${{ secrets.PROD_FRONTEND_NEXTAUTH_SECRET }} \
--build-arg NEXTAUTH_URL=${{ secrets.PROD_FRONTEND_NEXTAUTH_URL }} \
--build-arg CKAN_URL=${{ secrets.PROD_FRONTEND_CKAN_URL }} \
deployment/frontend
docker push $REGISTRY/$FRONTEND_REPO:$IMAGE_TAG
- name: Set up Docker Containers
env:
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/ckan-dev-ecr:${{ github.sha }}'
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/${{ secrets.ECR_CKAN_REPO }}:${{ github.sha }}'
run: docker compose -f docker-compose.test.yml --env-file .env.example up --build -d
working-directory: ./ckan-backend-dev
working-directory: ./ckan-backend-dev
- name: Cypress Install and CKAN setup
uses: cypress-io/github-action@v6
with:
wait-on: 'http://localhost:5000'
wait-on: 'http://ckan-dev:5000'
wait-on-timeout: 120
node-version: 18
runTests: false
Expand All @@ -65,19 +81,19 @@ jobs:
working-directory: ./ckan-backend-dev
- name: Fix s3filestore test.ini for minio
env:
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/ckan-dev-ecr:${{ github.sha }}'
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/${{ secrets.ECR_CKAN_REPO }}:${{ github.sha }}'
run: docker compose -f docker-compose.test.yml --env-file .env.example exec -T ckan-dev /bin/bash -c "/srv/app/fix_s3filestore_test_ini.sh"
working-directory: ./ckan-backend-dev
- name: Run Unit Tests 🧪
env:
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/ckan-dev-ecr:${{ github.sha }}'
CKAN_IMAGE: '${{ steps.login-ecr.outputs.registry }}/${{ secrets.ECR_CKAN_REPO }}:${{ github.sha }}'
run: docker compose -f docker-compose.test.yml --env-file .env.example exec -T ckan-dev /bin/bash -c "/srv/app/run_unit_tests.sh"
working-directory: ./ckan-backend-dev
- name: Run Trivy Vulnerability Scanner 🧪
uses: aquasecurity/trivy-action@master
env:
REGISTRY: ${{ steps.login-ecr.outputs.registry }}
REPOSITORY: ckan-dev-ecr
REPOSITORY: ${{ secrets.ECR_CKAN_REPO }}
with:
image-ref: '${{ env.REGISTRY }}/${{ env.REPOSITORY }}:${{ github.sha }}'
format: 'table'
Expand All @@ -95,6 +111,7 @@ jobs:
runs-on: ubuntu-latest
needs:
- buildandtest
if: github.event_name != 'pull_request'
steps:
- name: Checkout
uses: actions/checkout@v4
Expand All @@ -111,10 +128,12 @@ jobs:
- name: Run Templater and update values.yaml
env:
REGISTRY: ${{ steps.login-ecr.outputs.registry }}
REPOSITORY: ckan-dev-ecr
CKAN_REPO: ${{ secrets.ECR_CKAN_REPO}}
FRONTEND_REPO: ${{ secrets.ECR_FRONTEND_REPO}}
DATAPUSHER_REPO: ${{ secrets.ECR_DATAPUSHER_REPO }}
IMAGE_TAG: ${{ github.sha }}
run: |
cd ckan-deployment
cd deployment
curl https://raw.githubusercontent.com/datopian/devops-tools/master/scripts/templater.sh > /tmp/templater.sh
bash /tmp/templater.sh helm-templates/values.yaml.$BRANCH_NAME.template > helm-templates/values.yaml
- name: Configure Kubeconfig
Expand All @@ -131,4 +150,6 @@ jobs:
token: ${{ secrets.GITHUB_TOKEN }}
id: install
- name: 'Deploy using Helm Upgrade'
run: helm upgrade -i dx-helm-wri-$BRANCH_NAME-release ./ckan-deployment/helm-templates -f ./ckan-deployment/helm-templates/values.yaml -n $PROJECT_NAME-$BRANCH_NAME --create-namespace --wait
run: |
set -e
helm upgrade -i dx-helm-wri-$BRANCH_NAME-release ./deployment/helm-templates -f ./deployment/helm-templates/values.yaml -n $PROJECT_NAME-$BRANCH_NAME --create-namespace --wait
2 changes: 1 addition & 1 deletion .github/workflows/test-cost-splitting.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ name: "Test cost splitting"
on:
push:
branches:
- dev
- prod
defaults:
run:
shell: bash
Expand Down
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -167,4 +167,5 @@ integration-tests/cypress/videos
integration-tests/cypress/screenshots
integration-tests/cypress.json

ckan-backend-dev/src/*
ckan-backend-dev/src/ckan*
!ckan-backend-dev/src/ckanext-wri
16 changes: 14 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*
**Table of Contents**

- [WRI ODP](#wri-odp)
- [CKAN Backend Development](#ckan-backend-development)
- [CKAN Deployment](#ckan-deployment)
- [Updating READMEs](#updating-readmes)

<!-- END doctoc generated TOC please keep comment here to allow auto update -->

Expand All @@ -13,8 +15,18 @@ The WRI Open Data Portal monorepo

## CKAN Backend Development

See the [CKAN Backend Development README](ckan-backend-dev/README.md) for instructions on how to set up a local Docker CKAN backend development environment.
See the [CKAN Backend Development README](ckan-backend-dev/README.md) for instructions on how to set up a local Docker CKAN backend development environment. Note: the `ckanext-wri` extension in the root of this repo is a symlink to `ckanext-wri` in `ckan-backend-dev/src`. See the README above and the [WRI Extension README](ckan-backend-dev/src/ckanext-wri/README.md) for more information.

## CKAN Deployment

See the [CKAN Deployment README](ckan-deployment/README.md) for instructions on how to deploy CKAN to EKS.

## Updating READMEs

The table of contents in the READMEs are generated using generated using [DocToc](https://github.com/thlorenz/doctoc). You can install it globally by running:

npm install -g doctoc

Then, to update the table of contents in a markdown file, for example, `README.md`, run:

doctoc README.md
6 changes: 3 additions & 3 deletions ckan-backend-dev/.env.example
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ DATAPUSHER_REWRITE_RESOURCES=True
DATAPUSHER_REWRITE_URL=http://ckan-dev:5000

# Extensions
CKAN__PLUGINS=image_view text_view webpage_view resource_proxy datatables_view datastore datapusher activity s3filestore scheming_datasets scheming_organizations scheming_groups envvars
CKAN__PLUGINS=image_view text_view webpage_view resource_proxy datatables_view datastore datapusher activity s3filestore scheming_datasets scheming_organizations scheming_groups wri auth envvars
CKAN__VIEWS__DEFAULT_VIEWS=image_view text_view webpage_view datatables_view
CKAN__HARVEST__MQ__TYPE=redis
CKAN__HARVEST__MQ__HOSTNAME=redis
Expand All @@ -102,7 +102,7 @@ CKANEXT__S3FILESTORE__AWS_SECRET_ACCESS_KEY=${MINIO_ROOT_PASSWORD}
CKANEXT__S3FILESTORE__HOST_NAME=http://minio:9000

# scheming
CKAN___SCHEMING__DATASET_SCHEMAS=ckanext.scheming:ckan_dataset.yaml
CKAN___SCHEMING__DATASET_SCHEMAS=ckanext.wri.schema:ckan_dataset.yaml
CKAN___SCHEMING__ORGANIZATION_SCHEMAS=ckanext.scheming:custom_org_with_address.json
CKAN___SCHEMING__GROUP_SCHEMAS=ckanext.scheming:custom_group_with_status.json
CKAN___SCHEMING__PRESETS=ckanext.scheming:presets.json
CKAN___SCHEMING__PRESETS=ckanext.wri.schema:presets.json
2 changes: 1 addition & 1 deletion ckan-backend-dev/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*
**Table of Contents**

- [CKAN Backend Development Environment](#ckan-backend-development-environment)
- [Make Commands](#make-commands)
Expand Down
22 changes: 17 additions & 5 deletions ckan-backend-dev/ckan/Dockerfile.dev
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@ RUN pip3 install -e 'git+https://github.com/datopian/ckanext-scheming.git@ckan-2
pip3 install -r 'https://raw.githubusercontent.com/datopian/ckanext-scheming/ckan-2.10/test-requirements.txt' && \
pip3 install -e 'git+https://github.com/datopian/ckanext-s3filestore.git@wri/cost-splitting-orgs#egg=ckanext-s3filestore' && \
pip3 install -r 'https://raw.githubusercontent.com/datopian/ckanext-s3filestore/wri/cost-splitting-orgs/requirements.txt' && \
pip3 install -r 'https://raw.githubusercontent.com/datopian/ckanext-s3filestore/wri/cost-splitting-orgs/dev-requirements.txt'
pip3 install -r 'https://raw.githubusercontent.com/datopian/ckanext-s3filestore/wri/cost-splitting-orgs/dev-requirements.txt' && \
pip3 install -e 'git+https://github.com/datopian/ckanext-auth.git@v2.9#egg=ckanext-auth'

# Update ckanext-s3filestore test.ini with minio credentials
RUN sed -i "s|ckanext.s3filestore.aws_access_key_id = test-access-key|ckanext.s3filestore.aws_access_key_id = ${AWS_ACCESS_KEY_ID}|g" src/ckanext-s3filestore/test.ini && \
Expand Down Expand Up @@ -60,9 +61,20 @@ COPY setup/start_ckan_development.sh.override ${APP_DIR}/start_ckan_development.
RUN chmod +x ${APP_DIR}/start_ckan_development.sh
RUN chown ckan:ckan ${APP_DIR}/start_ckan_development.sh

COPY setup/jwtRS256.key ${APP_DIR}/jwtRS256.key
COPY setup/jwtRS256.key.pub ${APP_DIR}/jwtRS256.key.pub
RUN chown ckan:ckan ${APP_DIR}/jwtRS256.key
RUN chown ckan:ckan ${APP_DIR}/jwtRS256.key.pub
#COPY setup/jwtRS256.key ${APP_DIR}/jwtRS256.key
#COPY setup/jwtRS256.key.pub ${APP_DIR}/jwtRS256.key.pub
#RUN chown ckan:ckan ${APP_DIR}/jwtRS256.key
#RUN chown ckan:ckan ${APP_DIR}/jwtRS256.key.pub

RUN apk --no-cache add openssl

RUN openssl genpkey -algorithm RSA -out ${APP_DIR}/jwtRS256.key && \
openssl rsa -in ${APP_DIR}/jwtRS256.key -pubout -outform PEM -out ${APP_DIR}/jwtRS256.key.pub && \
chown ckan:ckan ${APP_DIR}/jwtRS256.key && \
chown ckan:ckan ${APP_DIR}/jwtRS256.key.pub

#RUN ckan config-tool ${CKAN_INI} "api_token.jwt.algorithm = RS256" && \
# ckan config-tool ${CKAN_INI} "api_token.jwt.encode.secret = file:${APP_DIR}/jwtRS256.key" && \
# ckan config-tool ${CKAN_INI} "api_token.jwt.decode.secret = file:${APP_DIR}/jwtRS256.key.pub"

CMD ["sh", "-c", "${APP_DIR}/start_ckan_development.sh"]
45 changes: 33 additions & 12 deletions ckan-backend-dev/ckan/scripts/run_unit_tests.sh
Original file line number Diff line number Diff line change
@@ -1,20 +1,18 @@
#!/bin/bash

# Initialize a file to collect test outputs
echo "CKAN and Extension Test Results" > test_results.txt
echo "Test Summary" > test_summary.txt
ROOT_DIR=$(pwd)

echo "CKAN and Extension Test Results" > "$ROOT_DIR/test_results.txt"
echo "Test Summary" > "$ROOT_DIR/test_summary.txt"

# Run CKAN Core tests
# Replace the command below with the one you use for CKAN core tests
# pytest --ckan-ini=test-core.ini >> test_results.txt
# if [ $? -eq 0 ]; then
# echo "CKAN Core: Passed" >> test_summary.txt
# else
# echo "CKAN Core: Failed" >> test_summary.txt
# fi

# Loop through each extension directory to run tests

cd src

for dir in ckanext-*; do
Expand All @@ -26,18 +24,41 @@ for dir in ckanext-*; do

cd $dir

pytest --ckan-ini=test.ini ckanext/${dir#ckanext-}/tests 2>&1 | tee -a ../test_results.txt
pytest --ckan-ini=test.ini ckanext/${dir#ckanext-}/tests 2>&1 | tee -a "$ROOT_DIR/test_results.txt"
PYTEST_EXIT_CODE=${PIPESTATUS[0]}

if [ $? -eq 0 ]; then
echo "$dir: Passed" >> ../test_summary.txt
if [ $PYTEST_EXIT_CODE -eq 0 ]; then
echo "$dir: Passed" >> "$ROOT_DIR/test_summary.txt"
else
echo "$dir: Failed" >> ../test_summary.txt
echo "$dir: Failed" >> "$ROOT_DIR/test_summary.txt"
fi

cd ..

fi
done

# Display summary
cat test_summary.txt
cd ..

if [ -d "src_extensions/ckanext-wri" ]; then
cd src_extensions/ckanext-wri

pytest --ckan-ini=test.ini ckanext/wri/tests 2>&1 | tee -a "$ROOT_DIR/test_results.txt"
PYTEST_EXIT_CODE=${PIPESTATUS[0]}

if [ $PYTEST_EXIT_CODE -eq 0 ]; then
echo "ckanext-wri: Passed" >> "$ROOT_DIR/test_summary.txt"
else
echo "ckanext-wri: Failed" >> "$ROOT_DIR/test_summary.txt"
fi

cd ..

fi

cat "$ROOT_DIR/test_summary.txt"

# GitHub Actions failure exit code
if grep -q "Failed" "$ROOT_DIR/test_summary.txt"; then
exit 1
fi
51 changes: 0 additions & 51 deletions ckan-backend-dev/ckan/setup/jwtRS256.key

This file was deleted.

14 changes: 0 additions & 14 deletions ckan-backend-dev/ckan/setup/jwtRS256.key.pub

This file was deleted.

Empty file added ckan-backend-dev/src/.gitkeep
Empty file.
5 changes: 5 additions & 0 deletions ckan-backend-dev/src/ckanext-wri/.coveragerc
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
[report]
omit =
*/site-packages/*
*/python?.?/*
ckan/*
Loading

0 comments on commit 52dd271

Please sign in to comment.