SIGA (Sistema Integral de Gestión de Aparcamientos (Integral Parking Management System)) pretends to be a solution for parkings problem at 21's century. Specifically, SIGA is designed for reserved parkings in public area, like authorities, ambulances or, its main aim, disabled parkings. It tries to get any kind of information about these parkings (location, parking type, occupation status), process the information and to serve it as easy as possible to all citizens and users.
This solution has two separated parts: the cloud, the main processing one, and the sensors (IoT) which are disposed in parkings attached to this project and provide the actual occupation status information to the solution. Due to that, this solution has to be a cloud system to be able to scale whatever part when more parkings are added.
The main information in this system is the parking occupation and location and users or vehicles which can park in these reserved parkings. Processing this information we have to get an historical occupation for each parking, automatic incident notifications, incident historical..., even to predict occupation status of parkings when a user uses the system to get a parking near a place.
This project has been tested to ensure the function of it self. In this case, this project has ben tested completely in Travis CI and only a test in Circle CI due to its free plans.
Starting with Circle CI, free plan has only 1 job so only we can test one language and one version of that. We have chosen GoLang language to test due to Circle CI doesn't have the last version of Python language (3.8). This test doesn't upload data to code coverage (CodeCov) so, the configuration is very simple:
version: 2
jobs:
build:
docker:
- image: circleci/golang:1.13
steps:
- checkout
- run: make goTest
Due to this project is a open source project, in Travis CI we don't have job restrictions and we can test all languages and versions. By default, Travis uses a matrix system to build jobs to test the code. Here, we have two languages for the time being so we couldn't use build matrix system without excluding and comparing each combination because configuration complexity.
We decided to create job per job, building stages manually to test all languages (Go an Python) and to test all versions we need. The configuration is:
jobs:
include:
- stage: test
name: "Go 1.13 tests"
language: go
go:
- "1.13"
script:
- make goTest
after_success:
- make goCoverage
- bash <(curl -s https://codecov.io/bash) -cF go
create one stage per language and version. After test success, test coverage will upload to CodeCov explaining the language.
In GoLang we have chosen almost all version, from 1.3 to 1.13 or lasted released, and in Python we have chosen only Python3, from 3.4 to 3.8-dev, because Python2 will retire on 2020 (in one day!!).
Due to this project is open source, we don't have to do anymore configuration but add the repository in Travis or CircleCI and add the above configuration file.
To start, we have chosen a common build tool between the both languages (GoLang and Python) because we don't have any dependencies right now and only run tests and coverage. Make is the chosen because is a free and open source tool installed in all distributions.
We want to separate every microservice and each one must to have each build tool. GoLang doesn't need an external tool but Tusk could ease the job. Python need an external tool and it could be DoIt because it's also free and open source.
buildtool: Makefile
In Make we have created two rules for each microservice: one for testing and other for coverage except in Users
that we have other to install dependencies but there isn't now.
To test all microservices of a language, there is another rule to make it easier. The same for coverage.
To sum all, the buildtool is make and the rules are:
<microserviceName>Test
: test that microservice.<microserviceName>Coverage
: test and coverage that microservice.<languageName>Test
: test that language (Go or Python).<languageName>Coverage
: test and coverage that language (Go or Python).