diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..17abb26 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,46 @@ +name: Build + +on: + push: + pull_request: + schedule: + - cron: "0 4 * * 0" + +jobs: + build-boleto-cnab-api: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Login to ghcr.io + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + - name: Build image + uses: docker/build-push-action@v5 + with: + context: . + file: Dockerfile + tags: | + ghcr.io/${{ github.repository }}:build-boleto-cnab-api-latest + cache-from: type=registry,ref=ghcr.io/build-boleto-cnab-api-latest + cache-to: type=local,dest=/tmp/.buildx-cache + load: true + - name: Install test pre-requisites + run: pip install pytest + - name: Test + run: pytest -v tests + - name: Push image + uses: docker/build-push-action@v5 + with: + context: . + file: Dockerfile + tags: | + ghcr.io/${{ github.repository }}:build-boleto-cnab-api-latest + cache-from: type=local,src=/tmp/.buildx-cache + cache-to: type=inline + push: true + if: ${{ github.repository_owner == 'akretion' && github.ref == 'refs/heads/master' }} diff --git a/tests/__init__.py b/tests/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/tests/test_run.py b/tests/test_run.py new file mode 100644 index 0000000..9d80b16 --- /dev/null +++ b/tests/test_run.py @@ -0,0 +1,74 @@ +import json +import tempfile +from pathlib import Path +import os +import subprocess +import requests +import time + + +PARENT_DIR = Path(__file__).parent.parent + + +def test_run(): + cmd = ["docker", "build", "-t", "akretion/boleto_cnab_api", "."] + result = subprocess.run( + cmd, check=False, capture_output=True, text=True, cwd=PARENT_DIR + ) + assert result.returncode == 0, result.stderr + "\n" + result.stdout + + cmd = [ + "docker", + "run", + "-d", + "-p", + "9292:9292", + "--name=boleto_cnab_api", + "akretion/boleto_cnab_api", + ] + result = subprocess.run(cmd, check=False, capture_output=True, text=True) + assert result.returncode == 0, result.stderr + "\n" + result.stdout + time.sleep(5) + remessa_values = [ + { + "valor": 5.0, + "cedente": "Kivanio Barbosa", + "documento_cedente": "12345678912", + "sacado": "Claudio Pozzebom", + "sacado_documento": "12345678900", + "agencia": "0810", + "conta_corrente": "53678", + "convenio": 12387, + "nosso_numero": "12345678", + "bank": "itau", + }, + { + "valor": 10.00, + "cedente": "PREFEITURA MUNICIPAL DE VILHENA", + "documento_cedente": "04092706000181", + "sacado": "João Paulo Barbosa", + "sacado_documento": "77777777777", + "agencia": "1825", + "conta_corrente": "0000528", + "convenio": "245274", + "nosso_numero": "000000000000001", + "bank": "caixa", + }, + ] + content = json.dumps(remessa_values) + with open(tempfile.mktemp(), "w") as f: + file_name = f.name + f.write(content) + files = {"data": open(file_name, "rb")} + result = requests.post( + "http://localhost:9292/api/boleto/multi", + data={ + "type": "pdf", + }, + files=files, + ) + assert str(result.status_code)[0] == "2" + + cmd = ["docker", "rm", "-f", "boleto_cnab_api"] + result = subprocess.run(cmd, check=False, capture_output=True, text=True) + assert result.returncode == 0, result.stderr + "\n" + result.stdout