-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #18 from openimis/develop
v1.3
- Loading branch information
Showing
7 changed files
with
262 additions
and
58 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
name: Automated CI testing | ||
# This workflow run automatically for every commit on github it checks the syntax and launch the tests. | ||
# | grep . | uniq -c filters out empty lines and then groups consecutive lines together with the number of occurrences | ||
on: | ||
pull_request: | ||
workflow_dispatch: | ||
inputs: | ||
comment: | ||
description: Just a simple comment to know the purpose of the manual build | ||
required: false | ||
|
||
jobs: | ||
run_test: | ||
runs-on: ubuntu-latest | ||
services: | ||
mssql: | ||
image: mcr.microsoft.com/mssql/server:2017-latest | ||
env: | ||
ACCEPT_EULA: Y | ||
SA_PASSWORD: GitHub999 | ||
ports: | ||
- 1433:1433 | ||
# needed because the mssql container does not provide a health check | ||
options: --health-interval=10s --health-timeout=3s --health-start-period=10s --health-retries=10 --health-cmd="/opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P ${SA_PASSWORD} -Q 'SELECT 1' || exit 1" | ||
|
||
steps: | ||
- name: Set up Python 3.8 | ||
uses: actions/setup-python@v2 | ||
with: | ||
python-version: 3.8 | ||
- name: install linux packages | ||
run: | | ||
wget https://raw.githubusercontent.com/openimis/database_ms_sqlserver/main/Empty%20databases/openIMIS_ONLINE.sql -O openIMIS_ONLINE.sql | ||
wget https://raw.githubusercontent.com/openimis/database_ms_sqlserver/main/Demo%20database/openIMIS_demo_ONLINE.sql -O openIMIS_demo_ONLINE.sql | ||
curl https://packages.microsoft.com/keys/microsoft.asc | sudo apt-key add - | ||
curl https://packages.microsoft.com/config/ubuntu/20.04/prod.list | sudo tee /etc/apt/sources.list.d/msprod.list | ||
sudo apt-get update | ||
sudo ACCEPT_EULA=Y apt-get install -y mssql-tools build-essential dialog apt-utils unixodbc-dev -y | ||
python -m pip install --upgrade pip | ||
- name: pull openimis backend | ||
run: | | ||
rm ./openimis -rf | ||
git clone --depth 1 --branch develop https://github.com/openimis/openimis-be_py.git ./openimis | ||
- name: copy current branch | ||
uses: actions/checkout@v2 | ||
with: | ||
path: './current-module' | ||
- name: Update the configuration | ||
working-directory: ./openimis | ||
run: | | ||
export MODULE_NAME="$(echo $GITHUB_REPOSITORY | sed 's#^openimis/openimis-be-\(.*\)_py$#\1#')" | ||
echo "the local module called $MODULE_NAME will be injected in openIMIS .json" | ||
jq --arg name "$MODULE_NAME" 'if [.modules[].name == ($name)]| max then (.modules[] | select(.name == ($name)) | .pip)|="../current-module" else .modules |= .+ [{name:($name), pip:"../current-module"}] end' openimis.json | ||
echo $(jq --arg name "$MODULE_NAME" 'if [.modules[].name == ($name)]| max then (.modules[] | select(.name == ($name)) | .pip)|="../current-module" else .modules |= .+ [{name:($name), pip:"../current-module"}] end' openimis.json) > openimis.json | ||
- name: Install openIMIS Python dependencies | ||
working-directory: ./openimis | ||
run: | | ||
pip install -r requirements.txt | ||
python modules-requirements.py openimis.json > modules-requirements.txt | ||
cat modules-requirements.txt | ||
pip install -r modules-requirements.txt | ||
- name: Environment info | ||
working-directory: ./openimis | ||
run: | | ||
pip list | ||
- name: Initialize DB | ||
run: | | ||
/opt/mssql-tools/bin/sqlcmd -S localhost,1433 -U SA -P $SA_PASSWORD -Q 'DROP DATABASE IF EXISTS imis' | ||
/opt/mssql-tools/bin/sqlcmd -S localhost,1433 -U SA -P $SA_PASSWORD -Q 'CREATE DATABASE imis' | ||
/opt/mssql-tools/bin/sqlcmd -S localhost,1433 -U SA -P $SA_PASSWORD -d imis -i openIMIS_ONLINE.sql | grep . | uniq -c | ||
/opt/mssql-tools/bin/sqlcmd -S localhost,1433 -U SA -P $SA_PASSWORD -d imis -i openIMIS_demo_ONLINE.sql | grep . | uniq -c | ||
env: | ||
SA_PASSWORD: GitHub999 | ||
ACCEPT_EULA: Y | ||
|
||
# - name: Check formatting with black | ||
# run: | | ||
# black --check . | ||
|
||
- name: Django tests | ||
working-directory: ./openimis/openIMIS | ||
run: | | ||
export MODULE_NAME="$(echo $GITHUB_REPOSITORY | sed 's#^openimis/openimis-be-\(.*\)_py$#\1#')" | ||
python -V | ||
ls -l | ||
python manage.py migrate | ||
python init_test_db.py | grep . | uniq -c | ||
python manage.py test --keepdb $MODULE_NAME | ||
env: | ||
SECRET_KEY: secret | ||
DEBUG: true | ||
#DJANGO_SETTINGS_MODULE: hat.settings | ||
DB_HOST: localhost | ||
DB_PORT: 1433 | ||
DB_NAME: imis | ||
DB_USER: sa | ||
DB_PASSWORD: GitHub999 | ||
#DEV_SERVER: true | ||
SITE_ROOT: api | ||
REMOTE_USER_AUTHENTICATION: True |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,8 @@ jobs: | |
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: olegtarasov/[email protected] | ||
id: tagName | ||
- uses: actions/checkout@v2 | ||
- name: Set up Python | ||
uses: actions/setup-python@v2 | ||
|
@@ -21,11 +23,16 @@ jobs: | |
- name: Install dependencies | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install setuptools wheel twine | ||
pip install setuptools wheel twine jq | ||
- name: update setup.py | ||
run: | | ||
echo "tag to use $GIT_TAG_NAME" | ||
sed -i "s/version='.*'/version='$GIT_TAG_NAME'/g" setup.py | ||
- name: Build and publish | ||
env: | ||
TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} | ||
TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} | ||
TWINE_USERNAME: __token__ | ||
TWINE_PASSWORD: ${{secrets.PYPI_TOKEN}} | ||
run: | | ||
python setup.py sdist bdist_wheel | ||
twine upload dist/* | ||
twine upload dist/* |
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
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
from core.signals import Signal | ||
|
||
|
||
_check_formal_sector_for_policy_signal_params = ["user", "policy_id"] | ||
signal_check_formal_sector_for_policy = Signal(providing_args=_check_formal_sector_for_policy_signal_params) |
Oops, something went wrong.