This project is a template for the lab sessions of the Master 2 IDOD course at the University of Le Havre.
The purpose of this template is to ease the completion and testing of labs.
Ce travail est en 3 parties :
- rédiger des tests unitaires et compléter un modèle objet très simple, utilisant le pattern de creation
Object.create
- Créer un modèle objet pour la gestion de biens immobiliers à partir de données géographiques (appelé ici le module
Shapes
) - Création de tests assynchrones pour le module
Shapes
et tests avec un fichier de données au format JSON.
Le module SpeedCheck (voir app/scripts/modules/SpeedCheck.js
) est un modèle de données simpliste de gestion de contraventions générique, pouvant être étendu pour différents pays en fonction de leur réglementation (plaque d'immatriculation et vitesse maximum authorisée).
- Rédiger des tests unitaires pour tester individuellement toutes les fonctionnalités du modèle.
- Compléter le code manquant dans le module (repéré par un commentaire
/* TODO */
)
Considering a JSON dataset containing geographical map data, one want to create a read only model (no write access) which represents the various geographical objects.
We want to be able to create javascript objects according to the following class model.
Here are some constraints:
-
The
Shapes
module is to be created in theapp/scripts/modules
folder (see previous lab for example). -
The
Shapes
uses to Functional Pattern in order to create the Object Model. -
The
nodes
attribute is an array of objects ([{x:23,y:45},{x:3,y:5},{x:12,y:0}]
) that can be simplified into an array of arrays ([[23,45],[3,5],[12,0]]
). UseArray.map()
to do it. -
The
toSvgPath()
method should return a string such as:"M 23 45 L 3 5 L 12 0"
for a node like the above one. AgainArray.map()
would be useful. -
From the previous UML Model create read only objects with protected/hidden data.
-
The created module must validate the unit tests written in
tests/test.js
.
The Object model must be able to create object given data such as the one in the JSON file : app/data/eure.json
. Here is a sample :
[
{
"_id": "-630059",
"building": true,
"nodes": [
{
"x": 608.0,
"y": 302.0
},
{
"x": 610.0,
"y": 305.0
},
{
"x": 608.0,
"y": 302.0
}
]
},
{
"_id": "-630043",
"building": false,
"name": "Bassin Paul Vatine",
"natural": "water",
"nodes": [
{
"e": "e"
}
]
},
{
"_id": "-630016",
"building": false,
"highway": "residential",
"name": "Place D\u00e9sir\u00e9 Rebeuf",
"nodes": [
{
"x": 633.0,
"y": 453.0
},
{
"x": 677.0,
"y": 438.0
}
]
},
...
]
- Building, Road, Amenity, and Natural objects are created based on the JSON data downloaded.
- When testing with the JSON file, store new objects in containers (Arrays).
- Compute the overall and average surface of available buildings and include it in the tests.
- Write JUnit test that are asynchronous. They first load the JSON file then create as much objects there are in the JSON file. Then do some tests on the number of objects created, the surfaces, etc.
Knowing the assignment, follow the steps below in order to complete the lab.
(Just do this step once for all labs)
This project uses the Grunt task runner to run the project. Client side dependencies are handled with the Bower package manager. Grunt and Bower have to be installed with node
and npm
.
- First install NodeJS. You should have
node
ornodejs
as well asnpm
in your path. - Then install Grunt and Bower:
npm install -g grunt-cli npm install -g bower
When you fork a project, a copy of its repository with all the history is created for you. You become the owner of this new project and have write access to it.
Inside the Project's main folder, install its dependencies:
npm install
bower install
Once the project is installed, it can be run via grunt:
grunt serve
This will launch a Web server and open the index page of the project on your browser.
The app/
folder contains the HTML
CSS
and JavaScript
of the application. Depending on the lab (see the "Assignment" section) you will have to write code in these parts.
Unit test are kept in the tests/
folder. The tests/test.js
file contains all the assertions that will be tested. It is formatted with the QUnit testing framework. You will have to write unit tests in this file.
- Use
grunt testBrowser
to test on your browser. - Use
grunt testCI
to test on PhantomJS, the headless browser. This will be use by the Continuous Integration system.
Once completed with all unit tests passing, you can send me back you assignment as a pull request. The pull request will trigger a build of the project in the Continuous Integration framework TravisCI. For this you will have to commit your changes.
Note that you can also use Travis with your own project.