Skip to content

Commit

Permalink
Reworking a bit to be able to do everything using docker
Browse files Browse the repository at this point in the history
  • Loading branch information
Fenkiou committed Feb 15, 2023
1 parent fa78f8e commit f902d26
Show file tree
Hide file tree
Showing 12 changed files with 496 additions and 305 deletions.
12 changes: 6 additions & 6 deletions .env.template
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
export AWS_ACCESS_KEY_ID="<key-id>"
export AWS_SECRET_ACCESS_KEY="<secret-key>"

export FLASK_APP=lightsoff_api
export DATABASE_URI=postgresql://username:password@host:port/database_name
export CORS_ALLOWED_ORIGINS="*"

export SERVER_NAME=0.0.0.0:5000
export FLASK_APP=lightsoff_ape
FLASK_HOST=0.0.0.0
FLASK_PORT=5000
FLASK_APP=lightsoff_api
FLASK_DEBUG=True
DATABASE_URI=postgresql://username:password@host:port/database_name
CORS_ALLOWED_ORIGINS="*"
27 changes: 23 additions & 4 deletions .github/workflows/zappa.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,26 @@ jobs:

defaults:
run:
shell: bash
shell:
bash
#

services:
# Label used to access the service container
postgres:
# Docker Hub image
image: postgres:15-alpine
# Provide the password for postgres
env:
POSTGRES_USER: lightsoff
POSTGRES_PASSWORD: lightsoff
POSTGRES_DB: lightsoff
# Set health checks to wait until postgres has started
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Checkout
Expand All @@ -46,7 +65,7 @@ jobs:
run: |
curl -sSL https://install.python-poetry.org | python3 -
poetry install
poetry run pytest
DATABASE_URI=postgresql://lightsoff:lightsoff@postgres:5432/lightsoff poetry run pytest
zappa-staging:
name: "Zappa Staging"
Expand All @@ -71,7 +90,7 @@ jobs:
- name: Zappa deploy
run: |
curl -sSL https://install.python-poetry.org | python3 -
poetry install --no-dev --no-root
poetry install --no-dev --no-root --with=zappa
cp zappa_settings.template.json zappa_settings.json
echo $(jq '.ENVIRONMENT.s3_bucket = "${{ secrets.S3_BUCKET }}"' zappa_settings.json) > zappa_settings.json
echo $(jq '.ENVIRONMENT.aws_environment_variables.DATABASE_URI = "${{ secrets.DATABASE_URI }}"' zappa_settings.json) > zappa_settings.json
Expand Down Expand Up @@ -107,7 +126,7 @@ jobs:
- name: Zappa deploy
run: |
curl -sSL https://install.python-poetry.org | python3 -
poetry install --no-dev --no-root
poetry install --no-dev --no-root --with=zappa
cp zappa_settings.template.json zappa_settings.json
echo $(jq '.ENVIRONMENT.s3_bucket = "${{ secrets.S3_BUCKET }}"' zappa_settings.json) > zappa_settings.json
echo $(jq '.ENVIRONMENT.aws_environment_variables.DATABASE_URI = "${{ secrets.DATABASE_URI }}"' zappa_settings.json) > zappa_settings.json
Expand Down
6 changes: 5 additions & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
FROM python:3.9

RUN mkdir /app
COPY . /app
WORKDIR /app
ENV PYTHONPATH=${PYTHONPATH}:${PWD}

RUN pip3 install poetry
COPY ./pyproject.toml .
COPY ./poetry.lock .
RUN poetry config virtualenvs.create false
RUN poetry install

COPY ./ .
28 changes: 19 additions & 9 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,15 +1,25 @@
.PHONY: all install update uninstall
.PHONY: start stop clean run_migrations create_migration run_tests

all:
@docker compose run --rm --entrypoint '' api flask db upgrade
start:
@docker compose up --build --detach --remove-orphans

install:
@docker compose up --detach --remove-orphans
stop:
@docker compose stop

update:
@docker compose pull
@docker compose up --force-recreate --build --detach
watch:
@docker compose logs --tail 100 --follow

uninstall:
clean:
@docker compose stop
@docker compose rm --volumes --force

run_migrations:
@docker compose run -d database
@docker compose run --rm --entrypoint '' api flask db upgrade

create_migration: run_migrations
@docker compose run --rm --entrypoint '' api flask db migrate -m "Reword me"

run_tests:
@docker compose run -d database
@docker compose run -e DATABASE_NAME=lightsoff_test --rm --entrypoint '' api pytest
22 changes: 20 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,24 @@
Copy environment file: `cp .env.template .env`

```console
make
make install
make start
make run_migrations
```

Go to http://localhost:5000/openapi/

## Running tests

```console
make run_tests
```

## Generating a migration file

```console
make create_migration
```

## Deployment

This is handled by [Zappa](https://github.com/zappa/Zappa) in the `zappa.yml` github workflow
5 changes: 3 additions & 2 deletions compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,9 @@ services:
- 5000:5000
depends_on:
- database
entrypoint: flask run --debug
entrypoint: python lightsoff_api/__init__.py
environment:
- DATABASE_URI=postgresql://lightsoff:lightsoff@database:5432/lightsoff
- SERVER_NAME=0.0.0.0:5000

database:
image: postgres:15-alpine
Expand All @@ -21,3 +20,5 @@ services:
- POSTGRES_DB=lightsoff
ports:
- 5054:5432
volumes:
- ./db-init-scripts:/docker-entrypoint-initdb.d
1 change: 1 addition & 0 deletions db-init-scripts/add-test-database.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
CREATE DATABASE lightsoff_test;
19 changes: 18 additions & 1 deletion lightsoff_api/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@
from flask_sqlalchemy import SQLAlchemy
from pydantic import BaseModel, Field, root_validator

from dotenv import load_dotenv

load_dotenv()

servers = (
[
Server(url=f"/{os.environ.get('STAGE')}"),
Expand All @@ -23,6 +27,15 @@
app = OpenAPI(__name__, servers=servers)
app.config["SQLALCHEMY_DATABASE_URI"] = os.environ.get("DATABASE_URI")

if os.environ.get("DATABASE_NAME"):
app.config["SQLALCHEMY_DATABASE_URI"] = (
app.config["SQLALCHEMY_DATABASE_URI"].removesuffix(
app.config["SQLALCHEMY_DATABASE_URI"].split("/")[-1],
)
+ os.environ["DATABASE_NAME"]
)


CORS(app, origins=os.environ.get("CORS_ALLOWED_ORIGINS", "").split(","))
db = SQLAlchemy(app)
migrate = Migrate(app, db)
Expand Down Expand Up @@ -215,4 +228,8 @@ def increase_place_contacted_count(path: PlacePath):


if __name__ == "__main__":
app.run()
app.run(
host=os.environ.get("FLASK_HOST"),
port=os.environ.get("FLASK_PORT"),
debug=os.environ.get("FLASK_DEBUG"),
)
Loading

0 comments on commit f902d26

Please sign in to comment.