Skip to main content

This util creates new service of python. This one has some additional command cli for control of development

Project description

# Tamplar

Tamplar is service generator. This project can to help you control your development. We think, you should development with isolated environment. Therefore we creates docker-compose for local debugging and testing.

Now, we use [this](https://github.com/U-Company/python-service-layout) python layout.

# Installing

pip install tamplar

If you want local environments, you need a docker. Please install:

sudo apt-get install docker.io

We don’t use docker-compose as console util. We build docker-compose from source and we use docker API into python code.

# Usage

tamplar can work with:

  • pip

  • publishing package to pypi registry

  • publishing docker to docker registry

  • docker-compose for local development

# Console running

### Init

Go to empty directory and init your first project

tamplar init

After that, you get [FastAPI](https://fastapi.tiangolo.com/) service with healthcheck methods. FastAPI is ASGI framework instead of [Flask](https://flask.palletsprojects.com/).

If you want reinitialize, tamplar ask you about cleaning repo. If you works with JetBrains IDE, while initialization we ignore .idea files.

### Deps

We use default excellent library for logging. This is [loguru](https://github.com/Delgan/loguru). Loguru is a very useful wrapper over standart python [logger](https://docs.python.org/3.8/library/logging.html). After initilize you can install all dependencies:

tamplar deps

This command uses pip and requirements.

### Upload (Not implemented)

You can upload your package to concrete pypi registry and docker registry

tamplar upload –docker=True –pypi=True –namespace=<your-namespace from .pypirc>

After that, it built your docker image, pypi registry and push to the registry with latest version from info.py. Registry is selected by namespace parameter.

### Validate (Not implemented)

This command checks struct of project by [python-service-layout](https://github.com/U-Company/python-service-layout).

tamplar validate

### Run full

This command build and run docker with services with environment (dependencies of services)

tamplar run –mode=full

We implement execute docker-compose by python library docker-compose internal API. After run, it run docker-compose file or you get status code error

### Run env

This command build and run docker WITHOUT services with environment (dependencies of services)

tamplar run –mode=env

We implement execute docker-compose by python library docker-compose internal API. After run, it run docker-compose file or you get status code error

### Clean

Clean is command for cleaning your building files:

tamplar clean

# Dependency

If you want to add new service as dependency, you need to go to the deployment/docker-compose.*.yml. After that, you need new service to your docker-compose files.

# Test

Tamplar have a lot of good tests. But we have not any integration tests, because it is very difficult emulate python’s environment. Therefore we change integration tests to unit tests mixed integration tests (we creates and deletes files) while tests:

make test

If you want to execute test from IDE, you need to go tests/__init__.py and change deep=2.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

tamplar-0.5.1-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file tamplar-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: tamplar-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.7

File hashes

Hashes for tamplar-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9c0aa43746c5c6ffe70194a16994bc673e9109e92bf79c9c6d118839ab5153c1
MD5 e0f60605e70591c24026dbf593a8009b
BLAKE2b-256 e1b4380a0d0a3b09b07949ef89350a89a6f6987bade44b309523c9b8e59268f5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page