Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/guligon90/packiot-fsc
Technical assessment for the position of full-stack software developer at PackIOT
https://github.com/guligon90/packiot-fsc
docker docker-compose pgadmin4 postgresql prospector python3 sql sqlfluff
Last synced: about 2 months ago
JSON representation
Technical assessment for the position of full-stack software developer at PackIOT
- Host: GitHub
- URL: https://github.com/guligon90/packiot-fsc
- Owner: guligon90
- License: mit
- Created: 2021-08-20T21:53:11.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-08-30T20:23:25.000Z (over 3 years ago)
- Last Synced: 2023-03-11T05:11:20.528Z (almost 2 years ago)
- Topics: docker, docker-compose, pgadmin4, postgresql, prospector, python3, sql, sqlfluff
- Language: Python
- Homepage:
- Size: 173 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# PackIOT FSC :: Challenge #1
Technical assessment for the position of full-stack software developer at [PackIOT](https://packiot.com/).
## 0. Table of contents
- [1. Preliminaries](#1-preliminaries)
- [1.1. Installing pip and virtualenv](#11-installing-pip-and-virtualenv)
- [1.2. Virtual environment](#12-virtual-environment)
- [2. Building and running](#2-building-and-running)
- [2.1. PostgreSQL server](#21-postgresql-server)
- [2.1.1 For building](#211-for-building)
- [2.1.2 For running](#212-for-running)
- [2.2. pgAdmin 4](#22-pgadmin-4)
- [3. Where to now?](#3-where-to-now)## 1. Preliminaries
In order to build the project, you must have already installed and configured in your workspace:
* [Docker](https://docs.docker.com/engine/install/ubuntu/)
* [Docker Compose](https://docs.docker.com/compose/install/)
* [Python (3.8)](https://www.python.org/downloads/release/python-3810/)
* [pip](https://pip.pypa.io/en/stable/installation/)
* [virtualenv](https://virtualenv.pypa.io/en/latest/) (or any other suitable virtual environment manager for Python)### 1.1. Installing pip and virtualenv
With the correct Python distribution, at the terminal, execute the following commands:
```bash
$ sudo apt install python3-pip python3-virtualenv
```
### 1.2. Virtual environmentAfter you cloned this project, you must install its Python dependencies. So, at the project's root, execute in the terminal:
```bash
$ virtualenv --python=python3 venv # Creates the virtual env
$ source venv/bin/activate # Make it active inside the project
$ pip install --upgrade pip --no-cache-dir # Upgrade the package manager
$ pip install -r requirements.txt --no-cache-dir # Install dependencies listed in the .txt file
```## 2. Building and running
To construct the containers which encapsulate the [PostgreSQL](https://www.postgresql.org/) database server and the
[pgAdmin 4](https://www.pgadmin.org/download/) web application, a suite of scripts was implemented in Python, in order
to automate the users' interaction with the Docker and Compose actions. The documentation about these scripts can be found [here](./scripts/README.md).The aforementioned containers and its associated images are built with Docker Compose, where the corresponding services are all declared
in the [YAML file](./docker-compose.yaml), at the project's root. These services are:* `pgsqlserver`: Runs the container that encapsulates a proper PostgreSQL server. The image for this container (`Dockerfile`) was implemented locally, for reasons of database automation;
* `pgadmin`: The web interface that consumes the PostgreSQL database, and for that it can not run without the previous service been built. It uses an officially distributed image, downloaded from [Docker Hub](https://hub.docker.com/r/dpage/pgadmin4/).### 2.1. PostgreSQL server
We use here the automation script to perform building and runnning. At the project's root, execute in the terminal:
#### 2.1.1. For building:
```bash
$ ./scripts/devenv.py build pgsqlserver```
#### 2.1.2. For running:
```bash
$ ./scripts/devenv.py startwlogs pgsqlserver # Starts the container in detached mode and shows the logs
```**Note**: The database for this challenge (`packiotfscdb`) is created when the container is started (you can see in the logs). More information on how to interact with it can be found [here](./database/README.md#1-introduction).
### 2.2. pgAdmin 4
Similarly, we use the automation script to build and run this service, with the difference that the building part is not done separatedly, because the image for this container is obtained externally, i.e., there is no `Dockerfile`. So, you just need to run in the terminal:
```bash
$ ./scripts/devenv.py startwlogs pgadmin
```With the container up and running, you can now access the pgAdmin's UI via [browser](http://localhost:15432). The credentials for signing in are defined in the container's [.env file](./database/pgadmin/docker/.pgadmin.env).
To access the database and its respective schema, you'll have to add a server and set up the connection to it. To do that, you can check out the official pgAdmin 4 [documentation](https://www.pgadmin.org/docs/pgadmin4/latest/connecting.html). It's pretty straightforward. The necessary database credentials are defined in the `pgsqlserver` container's [.env file](./database/postgresql/docker/.pgsql.env).
**Note**: When specifying the hostname in the connection dialog, you must enter the name of the service listed in the Docker Compose YAML file, i.e., (`pgsqlserver`).
## 3. Where to now?
* [Database](./database/README.md)
* [Scripts](./scripts/README.md)
* [Table of contents](#0-table-of-contents)