Skip to content

Latest commit

 

History

History
72 lines (56 loc) · 3.3 KB

CONTRIBUTING.md

File metadata and controls

72 lines (56 loc) · 3.3 KB

Contributing to Paraunit

Dev environment

Paraunit comes with a containerized environment which makes contributing really easy. The project adopted Docker Compose and Docker as container technology, you can find an useful guide for the installation process here and here.

The container already has Composer installed globally, and OhMyZsh installed as shell for some nice autocompletion features.

To start contributing:

  • Clone the repo (or your fork):
git clone git@github.com:facile-it/paraunit.git
  • Move inside the repo folder:
cd paraunit
  • Open a shell, which will build the container as preparation:
make shell

Keep in mind that the build process will be cached by Docker, so it will be slow only the first time.

  • Now you are inside the container! You should install all the dependencies:
composer install
  • If you want, you can launch the testsuite to check if it's all ready! (the shell has ./bin in the $PATH env variable)
phpunit

And now your're ready! You should always use git commands (pull/commit/push) outside the container, since it does not have your GitHub credentials available.

Coding Standard

We follow STRICTLY PSR-1 and PSR-2:

Also, this project uses the Facile.it codestyle package, and requires stricter rules.

The code style is checked in the Travis CS build; you can check it locally with the composer cs-check command, and fix automatically all the issues with composer cs-fix; please do not commit badly formatted code!

Travis and other integrations

Paraunit has a Travis build integration in place: every time you open a PR (or each time you commit something, if you enable Travis on your account/fork) it will run all the tests to check if it's all ok!

We also have other integrations in place that runs on every PR and every commit on the master branch; namely:

Composer.lock file

We provide the composer.lock file with the project. This is due to the fact that a contributor shouldn't stumble on build failures that aren't caused by his contribution itself, and have a stable and defined set of dependencies that he can use to start with; the lock file is never considered when installing Paraunit as a dependency, so it's useful only in the Travis build and in the local dev environment.

To better understand this approach, see: