164 lines
7.9 KiB
Markdown
164 lines
7.9 KiB
Markdown
# How to create a class for the Central Data Model
|
||
|
||
This document explains the steps to follow if you want to contribute to the city data model by adding new classes or new attributes.
|
||
Use this document after having a clear idea of how your data model should look like already integrated in the Central Data Model.
|
||
Please, refer to the [cerclibs.pdf](https://liveconcordia.sharepoint.com/:b:/s/CERC-Next-GenCities-Platform/EfPNAGXexCFOju2sKBr6pNMBcwnvLin1Wio1Ahpfu4cxag?e=rhkdca)
|
||
to integrate your data model with the Central Data Model.
|
||
|
||
## Starting with the basics
|
||
- Install all requirements and download the Libs project. [Here](WINDOWS_INSTALL.md) how to do it for windows.
|
||
In order to maintain a good quality code, we will work in branches. New codes will need to pass quality standards before being accepted in the main branch.
|
||
- Check and follow our [coding style](PYGUIDE.md).
|
||
- Don’t forget to create unit tests and ensure that the old ones pass normally after your changes.
|
||
- Imperative! Document your work using comments in the code and, if needed, adding text files with extended explanations.
|
||
|
||
If the code doesn't pass the quality review, it will be rejected.
|
||
|
||
## Adding new parameters to existing classes
|
||
|
||
Adding a new parameter is an easy task. Open the desired class, for example, CityObject:
|
||
data:image/s3,"s3://crabby-images/7eba9/7eba92a995d8f4b4331a502a62ffc71db3669789" alt="city object"
|
||
|
||
Add the name of your new parameter to the list at the constructor and initialize it as desired:
|
||
data:image/s3,"s3://crabby-images/f7185/f71857aa892de1fdef090de71ba579d02a85c99f" alt="new parameter"
|
||
|
||
At the end of the class, add the corresponding getter and setter. It is very important that they are documented!
|
||
data:image/s3,"s3://crabby-images/212cf/212cf1fb3536d2c5fe1884363e4a121b440bc85c" alt="getter and setter"
|
||
|
||
You will see that the name of the file (city_object.py) changes from white to blue. That means that your version is different
|
||
from that one in the git. Once you finish doing your changes, you should commit and push them to your branch. The name of the file will turn back white.
|
||
|
||
## Creating a new class
|
||
|
||
Create a new class in the corresponding folder (if it does not exist, create a new folder ad hoc).
|
||
data:image/s3,"s3://crabby-images/9b7b0/9b7b078fb31bb1bf8d0cd51189c2faeceab1ea97" alt="new folder"
|
||
data:image/s3,"s3://crabby-images/06a90/06a90f942d19734d1351c53d37c19831984b0eb2" alt="new file"
|
||
data:image/s3,"s3://crabby-images/cb757/cb757ab522b70ffb1a346179f95b05bb8508ad36" alt="add to git"
|
||
|
||
And add it to git (the name of the file will turn from red to green).
|
||
Every new class must have:
|
||
- A header with the following information:
|
||
|
||
```python
|
||
|
||
"""
|
||
My New Data Class module
|
||
SPDX - License - Identifier: LGPL - 3.0 - or -later
|
||
Copyright © 2022 Concordia CERC group
|
||
Project Coder Name of Project Coder name.project.coder@concordia.ca
|
||
"""
|
||
```
|
||
|
||
- A brief explanation of what it is, what it does, what it can be used for, etc. under its name:
|
||
|
||
```python
|
||
|
||
"""
|
||
MyNewDataClass class
|
||
This class models this and does that
|
||
"""
|
||
```
|
||
|
||
- All imported libraries together at the beginning.
|
||
|
||
data:image/s3,"s3://crabby-images/4a5fe/4a5fe76314fbe9063de842d0ae1dba63bdb7dee4" alt="new class"
|
||
|
||
A data class contains properties that describe the data model. Therefore, it should be mainly composed by getters and setters.
|
||
We would like to avoid having methods in the data classes. All those methods that could be done in the factories must be written there.
|
||
The properties can be divided into two groups, those that can be modified during the use of the model, and those that
|
||
are set only once and stay unchangeable. The line that divides these to groups is sometimes difficult to draw.
|
||
An example to get a taste of this difference could be the following. A building is formed by surfaces, the list of surfaces
|
||
is something that defines the building and, for our purposes, is unchangeable. On the other hand, if one of our studies is
|
||
to show the effect of the construction on the building demand, we may want to modify this during the run, so the construction
|
||
becomes changeable. This is important because those parameters that are static (unchangeable), must be provided for the
|
||
initialization and don’t have setter, while the others are initialized at None and do have setter:
|
||
|
||
It is important to highlight that all setters and getters (@property) must have comments to describe the parameters, as shown in the previous image.
|
||
|
||
data:image/s3,"s3://crabby-images/a6eac/a6eac9cca08b0038f8233af0ff1cf19ad93791fc" alt="new class getters and setters"
|
||
|
||
Once you finish doing your changes, you should commit and push them to your branch. The name of the new files will change from green to white.
|
||
|
||
## Requesting a merge to the main branch
|
||
### Add a plugin
|
||
First, it is required to install a plugin for such purpose. We recommend [GitLab Merge Requests](https://plugins.jetbrains.com/plugin/18689-gitlab-merge-requests),
|
||
but you are free to choose the one you prefer. In order to install the plug, be sure that you have the latest pycharm version.
|
||
Go to Help -> Check for Updates... It will ask you to Update the new version, click on Update and Restart and follow the instructions.
|
||
|
||
data:image/s3,"s3://crabby-images/1476f/1476f96fcf2877061bf1b66e36f1b472dff0880c" alt="update pycharm"
|
||
|
||
Don't forget to look in the bottom-right corner, there you always find the instructions, warnings, errors, announcements...
|
||
|
||
data:image/s3,"s3://crabby-images/d92b5/d92b504e3d82d942c3db7062fa3b963b9780ab1b" alt="pycharm announcement"
|
||
|
||
Once you updated pycharm, go to File -> Settings... -> Plugins and search for _GitLab Merge Request_ and press Install.
|
||
|
||
data:image/s3,"s3://crabby-images/4d965/4d9652e927538ca4ca3d9a9bbd4c726eb55cdce5" alt="pycharm plugins"
|
||
|
||
### Select the project
|
||
This step needs to be done only the first time.
|
||
|
||
Once the plugin is installed, it will appear a new tab at the bottom list called Gitlab Merge Requests as in the image:
|
||
|
||
data:image/s3,"s3://crabby-images/20702/20702bdbd907e94d7e5cc92183401322981174e2" alt="new tab"
|
||
|
||
Click on _Clik to discover servers_ and select the gitlab.concordia.ca.
|
||
|
||
data:image/s3,"s3://crabby-images/8857b/8857b5861e4b1234211648b9755c5b80e9fcc225" alt="new server"
|
||
|
||
Observe that in the top-right corner of the tab, the message has changed from _No Repository_ to _Repo: /Guille/libs_.
|
||
|
||
data:image/s3,"s3://crabby-images/edf20/edf2076ebca7bc26cf2c8989e5a278a375cbdee0" alt="new repo"
|
||
|
||
If you now click on Refresh Merge Request (see previous image), you will get a message asking for a token. As you don't have one yet, click on Create token.
|
||
|
||
data:image/s3,"s3://crabby-images/bbd85/bbd85b5727fcd02e7cfa073737ebfbe06eb9ce1e" alt="create token"
|
||
|
||
You will be sent to the gitlab repository to create a new token. Give a name to it and check all options.
|
||
You are creating a token that has the same permits as your gitlab account has.
|
||
|
||
data:image/s3,"s3://crabby-images/15583/15583ea5c0a3a6bb5584c0d8fda5e7e278ac4d58" alt="create token in gitlab"
|
||
|
||
A new personal access token will be created. Copy and paste it in the Access Token box.
|
||
A token is a personal and no-transferable key. Don't show it to anyone!
|
||
|
||
data:image/s3,"s3://crabby-images/11acf/11acf352f6204be248f74bed3571fd830401dda4" alt="copy token"
|
||
|
||
data:image/s3,"s3://crabby-images/b7fa8/b7fa87da586d2943b610be17e8567deda5afbdbc" alt="paste token"
|
||
|
||
### Create merge request
|
||
Every time you want to send some changes to the main branch (merge your branch to the main one)
|
||
you will need to follow these steps.
|
||
|
||
Right clic on the blanc area and select + Create Merge Request.
|
||
|
||
data:image/s3,"s3://crabby-images/90ffd/90ffd2c6adc96aa48e2c7b526114c84270815659" alt="new merge request"
|
||
|
||
A window will appear with the information of the request:
|
||
|
||
data:image/s3,"s3://crabby-images/7b0f3/7b0f3cf05f6932a8b1c4237e991698a5b4f6e0cc" alt="request info"
|
||
|
||
Clic on Assignees + and look for the project owner, in this case, Guillermo Gutierrez Morote.
|
||
Select him as assignee and clic OK.
|
||
|
||
This action will send a request for the merge. Now wait until this is accepted or rejected. You will receive an email to
|
||
the email account you use for gitlab with the answer.
|
||
|
||
Once the changes are accepted, go back to the main branch by selecting the Git tab (bottom-left). Right clic on Master and select Checkout.
|
||
|
||
data:image/s3,"s3://crabby-images/894ca/894ca74a35f97990da0044bdd3ba5067ebd5a86e" alt="checkout master"
|
||
|
||
Now pull (blue arrow), and delete the branch.
|
||
|
||
data:image/s3,"s3://crabby-images/ace83/ace83fcf67512b67e7c0415e016004ea27bbcbe5" alt="erase branch"
|
||
|
||
Now you have again the same version as in gitlab. For new changes, create a new branch and repeat the process.
|
||
|
||
## Documentation and authoring
|
||
There can be two types of authors, that one who created the model and that one who coded it. If they are not the same person,
|
||
in the headers of the classes must be just the name of the coder, who is the reference person to ask anything about the code,
|
||
and the one in charge of maintaining it, and interacting with the git.
|
||
|
||
The author of the data model will appear in the official documentation of the Insel4Cities platform. In those documents,
|
||
a larger explanation of the data model should be also added.
|