⌚ OpenOpeningstijden main server application
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
Bèr Kessels dafdab90a5 Merge branch 'release/0.3.0' il y a 1 an
app Include sundays in open_this_week attribute. il y a 1 an
bin Ensure we continue after a duplicate il y a 1 an
config Introduce pagination to indexes. il y a 1 an
data Import a lookup table with country names. il y a 2 ans
doc Add swagger doc and build HTML from it. il y a 2 ans
images Implement basic json serialisation for events with lat-lon pairs il y a 1 an
lib Ensure we always have a "city". Set it from geocoder if not provided il y a 1 an
public/images Turn status into :open, :closed or :unknown triplet. il y a 1 an
test Include sundays in open_this_week attribute. il y a 1 an
vendor Use local patched gems instead of vanilla il y a 1 an
.env.test Ensure we can set per-app-env ENV vars il y a 1 an
.gitignore Package all gems to ensure heroku uses our patched versions il y a 1 an
.rubocop.yml Add linter: rubocop il y a 2 ans
.ruby-version Update Ruby and Rubygems. il y a 1 an
.semver Add semver. il y a 2 ans
Gemfile Use local patched gems instead of vanilla il y a 1 an
Gemfile.lock Use local patched gems instead of vanilla il y a 1 an
LICENSE Add LICENSE il y a 2 ans
Makefile Allow make initiator to define the pattern of tests to be ran. il y a 1 an
Procfile Add a Procfile to run the Web and Processors. il y a 2 ans
README.md Add initial README file il y a 2 ans
Rakefile Change loading logic of entire suite in Rakefile il y a 1 an
config.ru Setup bootstrap basics il y a 1 an
mapping.yml Fill a database lookup table with administrative boundaries. il y a 2 ans



RESTful JSON API for opening hours

Getting Started

TODO: Finish Make Install TODO: Provide alternative in docker


A Linux machine that supports apt, preferably a recent Ubuntu LTS.

make install should ensure all dependencies are installed.

For machines that do not support Make, consider getting another OS, if anything, as a virtual machine.

For machines that do not have apt, we are open to help on making the Makefile more portable. Pull requests, suggestions and help is welcome. The ideal situation would be where all common POSIX compliant systems, will be able to run the Makefile and install dependencies.


Install all dependencies with

make install

Running the tests

Running the tests with

make test

Integration tests

Integration tests, or end to end tests, are tests that run expectations on the full application. It sets up, seeds and connects to a database and then makes requests through the REST HTTP interface.

These are slow, and will, nor cannot, cover all edge-cases, paths and exceptions. They cover the happy path, common situations and important features.

Currently ran inside the entire test-suite. If the suite grows too large, we will extract these and make them runnable separately.

Unit tests

The unit tests isolate a module and test that in isolation. Unfortunately, JavaScript, nor node, nor its ecosystem of packages are very clean and test-oriented. Many features, packages or libraries will inject their behaviour in the global namespace, making it very hard, sometimes impossible to mock or stub.

There are quite some tests, but not near as much as I would like.


Deploying depends on your environment. Anywhere where NodeJS is supported will probably run this software.

TODO: describe what config to change in order to deploy to your servers.

make deploy

Built With




We use SemVer for versioning. For the versions available, see the release-tags on this repository


  • Bèr Kessels


This project is licensed under the MIT License - see the LICENSE.md file for details


TODO: describe YoHours, openstreetmap, imposm, opening_hours etc.