Skip to content

Latest commit

 

History

History
155 lines (115 loc) · 5.96 KB

README.md

File metadata and controls

155 lines (115 loc) · 5.96 KB

python-frawework

Python framework coverage Code style: black Ruff

This is my python framework for new code challenges that requires to develop an API or small projects that requires to have a minimal API service. It is based on FastAPI, and it is dockerized. Also supports a minimal frontend, based on nodejs & vite.

From here, you can start to develop your own API, and add new endpoints, or new services. It acts as a boilerplate, and it is ready to be used in any environment. See some of the features:

  • README.md template
  • Docker & docker compose
  • FastAPI & pydantic implementation
  • fixed code structure
  • fixed docs structure
  • pytest & coverage

User Experience

This is a boilerplate, so it is not intended to be used as a final product. It is intended to be used as a starting point for new projects. It should support a backend by default, and a frontend if needed.

Requirements

Backend is based on FastAPI, as it provides by default with swagger, so endpoint documentation is ready to be used. Also, it provides with a lot of features, like security. Very is easy to develop.

Description

My personal boilerplate for new projects. It is based on FastAPI, using docker to build in any machine without any issues.

My goal with this project is to gather in one place all the knowledge I have regarding a python project, and to have a starting point for new projects, which sometimes can be a little bit overwhelming. It provides a starting point, with a fixed structure that can be improve at any time, to have a standard way of developing new projects. I keep all my knowledge in one place, and it is the perfect playground for new features that can be included in the future.

Project structure

Project structure is fixed, and it is based on the following structure:

  • .github/workflows/: folder to manage and gather files related to github actions
  • backend/: folder to manage and gather files related to the backend
    • src/: folder to manage and gather python files related to the application
    • tests/: folder for tests
    • main.py: main file to start the application
    • requirements.txt: file to manage python dependencies
    • pyproject.toml/setup.cfg: files to manage project configuration
  • docker: folder to manage and gather files related to docker and docker compose
  • docs/: folder to manage and gather files related to the documentation
    • adr: folder to manage and gather files related to the architecture decision record
    • flows: folder to manage and gather files related to the flows
    • assets: folder to manage and gather assets related to the documentation
    • templates: folder to manage and gather templates
  • frontend: folder to manage and gather files related to the frontend
  • README.md: main file to start the application
  • .gitignore: file to manage git ignore
  • .pre-commit-config.yaml: file to manage pre-commit hooks

Getting started

For this project, you will need to have docker and docker compose installed. Please install in your machine using the instructions provided in the links.

docker & docker compose utils

If you are new to docker compose, and love to use the terminal like me, please see below some of the most used commands:

  • build images: docker compose build
  • start containers: docker compose up -d <name>
  • remove containers: docker compose down
  • list all containers: docker compose ps
  • stop containers: docker compose stop <name>
  • enter inside the container: docker exec -it <container_id> bash
  • to see the logs in real time: docker logs -f <container_id>
  • list all images: docker images
  • remove an image: docker rmi <image_id>

Installation and usage

  • step 1: docker compose build
  • step 2: docker compose up -d
  • step 3: go to your browser and open http://localhost:8000/docs. If not opening, docker logs -f <container_id> to see the logs for errors.
  • step 4: start coding

Architecture Decision Record

A decision record is a document that captures an important architectural decision made along with its context and consequences.

Below is a list of the ADRs for this project:

Contribution

Use conventional commit to your commit messages.

As only one developer (myself) is expected to work at the same time in this project (backend and frontend), every commit goes to master (Trunk-based development). No need to create new branches and make pull-request (unless breaking changes are introduced, such as new contracts to the app, big refactors...).

Install pre-commit hooks to include automatic tools to review code:

Testing

I do believe that unit test are the most important part of a project, to keep the code clean, and avoid adding breaking code to a piece of software that is working. A good coverage of the application indicates that services are robust. TDD Test-Driven Development is my ideal development methodology.

Unit testing and functional is available. E2E testing is not yet available.

Go inside docker container:

  • pytest -> run all tests.
  • pytest --cov-report=html -> run all tests and generate a coverage report in html format.

CI/CD

Not applicable.

Monitoring

Not applicable.

Troubleshooting

Not applicable.