237 lines
9.6 KiB
Markdown
237 lines
9.6 KiB
Markdown
# Comment contribuer ?
|
||
|
||
Merci de prendre le temps de contribuer ! 🎉
|
||
|
||
Voici quelques informations pour démarrer :
|
||
|
||
## Rapport de bug, nouvelles fonctionnalités
|
||
|
||
Nous utilisons GitHub pour suivre tous les bugs et discussions sur les nouvelles fonctionnalités. Pour rapporter un bug ou proposer une évolution vous pouvez [ouvrir une nouvelle discussion](https://github.com/betagouv/mon-entreprise/issues/new). N'hésitez pas à utiliser la recherche pour vérifier si le sujet n'est pas déjà traité dans une discussion ouverte.
|
||
|
||
## Développement
|
||
|
||
Si vous voulez participer au développement de nouvelles fonctionnalités, vous pouvez consulter la liste des «[good first issue](https://github.com/betagouv/mon-entreprise/issues?q=is%3Aopen+is%3Aissue+label%3A%22%3Anew%3A+good+first+issue%22) ». Ce sont des fonctionnalités intéressantes qui ne sont normalement pas trop complexe à implémenter. N'hésitez pas à poser toutes vos questions sur ces issues !
|
||
|
||
### Technologies
|
||
|
||
L'application est écrite en JavaScript, elle est exécuté uniquement côté client — il n'y a pas de serveur applicatif, nous générons des fichiers `.html` statiques
|
||
|
||
Nous utilisons :
|
||
|
||
- [TypeScript](https://www.typescriptlang.org) pour ajouter un système de typage à notre code JavaScript. Le typage n'est pas utilisé partout et il n'est pas obligatoire de le prendre en compte pour contribuer.
|
||
- [Yarn](https://yarnpkg.com/fr) pour la gestion des dépendances (à la place de NPM qui est souvent utilisé dans les applications JavaScript)
|
||
- [React](https://reactjs.org) pour la gestion de l'interface utilisateur
|
||
- [Redux](https://redux.js.org) pour gérer le “state” de l'application côté client
|
||
- [Prettier](https://prettier.io/) pour formater le code source, l'idéal est de configurer votre éditeur de texte pour que les fichiers soit formatés automatiquement quand vous sauvegardez un fichier. Si vous utilisez [VS Code](https://code.visualstudio.com/) cette configuration est automatique.
|
||
- [Webpack](https://webpack.js.org) pour le “bundling”
|
||
- [Eslint](http://eslint.org) qui permet par exemple d'éviter de garder des variables inutilisées
|
||
- [Ramda](https://ramdajs.com) comme libraire d'utilitaires pour manipuler les listes/objects/etc (c'est une alternative à lodash ou underscore)
|
||
- [Mocha](https://mochajs.org), [Jest](https://jestjs.io) et [Cypress](https://www.cypress.io) pour les l'execution des tests. Plus d'informations dans la section consacrée aux tests.
|
||
|
||
### Démarrage
|
||
|
||
Si possible, assurez-vous d'avoir toutes les clés d'API nécessaires dans votre fichier
|
||
`site/.env` (un template est disponible dans `site/.env.template`).
|
||
**NB : ne vous inquiétez pas, ceci n'est pas nécessaire pour effectuer une première contribution à
|
||
la base de code !** Cependant, vous en aurez besoin pour la commande `yarn prepare` et pour les
|
||
commandes de traduction automatique français -> anglais. Si vous êtes confronté à ce type de besoin,
|
||
demandez l'aide des contributeurs du projet.
|
||
|
||
Si l'historique des commits est trop volumineux, vous pouvez utiliser le paramètre `depth` de git pour ne télécharger que les derniers commits.
|
||
|
||
```
|
||
# Clone this repo on your computer
|
||
git clone --depth 100 git@github.com:betagouv/mon-entreprise.git
|
||
|
||
# Mettre à jour votre config git locale
|
||
git config blame.ignoreRevsFile .git-blame-ignore-revs
|
||
|
||
# Install the Javascript dependencies through Yarn
|
||
yarn install
|
||
|
||
# Download some data
|
||
yarn prepare
|
||
|
||
# Run the dev server for mon-entreprise
|
||
yarn start
|
||
```
|
||
|
||
L'application est exécutée sur http://localhost:3000/mon-entreprise pour la version française et
|
||
http://localhost:3000/infrance pour la version anglaise.
|
||
|
||
Pour activer le traçage Redux:
|
||
|
||
```
|
||
REDUX_TRACE=true yarn start
|
||
```
|
||
|
||
### Messages de commit
|
||
|
||
A mettre sans retenue dans les messages de commit :
|
||
|
||
- 🎨 `:art:` pour une modification de l'UI
|
||
- 🐎 `:racehorse:` pour une amélioration de performance
|
||
- 🐛 `:bug:` pour une correction de bug
|
||
- 🔥 `:fire:` pour une suppression de code ou de fichier
|
||
- 💚 `:green_heart:` pour une correction de CI
|
||
- ✅ `:white_check_mark:` pour un ajout de test
|
||
- ⬆️ `:arrow_up:` pour une mise à jour de dépendances
|
||
- ✨ `:sparkles:` pour une ré-organisation du code
|
||
- ⚙ `:gear:` pour une contribution sur le moteur publicodes
|
||
- 🔨 `:hammer:` pour une contribution à la base de règles
|
||
- 📆 `:calendar:` pour un changement de règle du à une évolution temporelle (en attendant mieux)
|
||
- 📈 `:chart_with_upwards_trend:` pour une amélioration du tracking
|
||
- 👽 `:alien:` pour ajouter des traductions
|
||
- ♿ `:wheelchair:` pour corriger les problèmes liés à l'accessibilité
|
||
- 🖋 `:fountain_pen:` pour séparer les commits liés à la modification du contenu
|
||
- 🔍 `:mag:` pour les modifications liées au référencement naturel
|
||
|
||
### Tests
|
||
|
||
#### Vérification syntaxique :
|
||
|
||
```sh
|
||
yarn lint
|
||
```
|
||
|
||
Pour corriger les erreurs automatiquement :
|
||
|
||
```sh
|
||
yarn lint:fix
|
||
```
|
||
|
||
#### Vérification du typage :
|
||
|
||
```sh
|
||
yarn test:type
|
||
```
|
||
|
||
Pour avoir les erreurs de type en direct dans la console, utilisez le paramètre `--watch` :
|
||
|
||
```sh
|
||
yarn test:type --watch
|
||
```
|
||
|
||
#### Tests unitaires
|
||
|
||
```sh
|
||
yarn test
|
||
```
|
||
|
||
#### Tests de non-regression (snapshots)
|
||
|
||
```sh
|
||
yarn test:regressions
|
||
```
|
||
|
||
Si vous souhaitez mettre à jour les snapshots vous pouvez utiliser le paramètre `--updateSnapshot`, son raccourci `-u`, ou encore le [mode interactif](https://jestjs.io/docs/en/snapshot-testing#interactive-snapshot-mode).
|
||
|
||
#### Tests d'integrations
|
||
|
||
Pré-requis:
|
||
|
||
- le browser chromium doit être installé. Les builds peuvent être trouvés sur
|
||
le [site de Cypress](https://chromium.cypress.io/)
|
||
- le serveur doit être lancé via `yarn start`
|
||
|
||
```sh
|
||
yarn workspace site test:dev-e2e:mon-entreprise
|
||
yarn workspace site test:dev-e2e:mycompanyinfrance
|
||
```
|
||
|
||
### Traduction 👽
|
||
|
||
Le site est disponible en français, et en anglais sur https://mycompanyinfrance.urssaf.fr
|
||
|
||
Les traductions se trouvent dans le répertoire `site/source/locales`.
|
||
|
||
La librairie utilisée pour la traduction de l'UI est
|
||
[react-i18next](https://react.i18next.com/).
|
||
|
||
Lorsque l'on introduit une nouvelle chaîne de caractère dans l'UI il faut
|
||
systématiquement penser à gérer sa traduction, via un composant `<Trans>`, ou
|
||
via la fonction `t`
|
||
|
||
Le circle-ci fait une analyse statique du code pour repérer les chaînes non
|
||
traduites, dans le moteur et l'UI :
|
||
|
||
```sh
|
||
yarn run i18n:check
|
||
```
|
||
|
||
Pour traduire automatiquement les chaînes manquantes via l'api Deepl :
|
||
|
||
```sh
|
||
yarn run i18n:rules:translate
|
||
yarn run i18n:ui:translate
|
||
|
||
# ou bien pour les deux commandes d'un coup
|
||
yarn run i18n:translate
|
||
```
|
||
|
||
N'oubliez pas de vérifier sur le diff que rien n'est choquant.
|
||
|
||
### CI/CD
|
||
|
||
- Nous utilisons des [Github actions](https://github.com/features/actions) pour faire tourner les builds et
|
||
tests.
|
||
- [Netlify](https://www.netlify.com/), s'occupe de l’hébergement du site sur Internet avec gestion des DNS.
|
||
|
||
### Prévisualisation
|
||
|
||
Il est possible de simuler localement le comportement de l'application après le build complet, y compris le pré-rendu statique et les redirection Netlify, avec les commandes suivantes (à éxécuter dans le répertoire `site`):
|
||
|
||
```sh
|
||
yarn run build:preview
|
||
```
|
||
|
||
```sh
|
||
yarn preview:mon-entreprise
|
||
yarn preview:infrance
|
||
```
|
||
|
||
### Worker en développement
|
||
|
||
Nous utilisons [vite](https://vitejs.dev/) pour le serveur de développement et comme bundler. Aucun bundling n'est fait en développement, ce qui accélère considérablement le temps de rechargement de l'app à chaque modification. Pour cela, la syntaxe ESModule est utilisée partout, y compris dans les worker. Malheureusement, tous les navigateurs ne [supportent pas encore cette fonctionalité](https://caniuse.com/mdn-api_worker_worker_ecmascript_modules) (en particulier [Firefox](https://bugzilla.mozilla.org/show_bug.cgi?id=1247687)).
|
||
|
||
Par conséquent, les workers ne fonctionnent pas en mode développement sous firefox. Ce n'est pas critique mais il faut le savoir.
|
||
|
||
### Tests
|
||
|
||
Pour tester les règles, il est recommandé de:
|
||
|
||
- faire tourner un simulateur et vérifier à la main l'adéquation des règles avec les normes
|
||
traduites ;
|
||
- créer des cas de tests de non-régression sous la forme de nouveaux snapshots (cf.
|
||
`site/test/regressions`).
|
||
|
||
En local, le moteur de recherche n'est pas mis à jour automatiquement et la liste des règles
|
||
est exposée ici: http://localhost:8080/mon-entreprise/documentation/dev
|
||
|
||
## Publicodes
|
||
|
||
### Documentation
|
||
|
||
La documentation de publicodes est disponible sur https://publi.codes.
|
||
|
||
Un wiki contenant des informations intéressantes sur publicodes et le
|
||
raisonnement ayant abouti à ce langage sont dispos sur le repository
|
||
[betagouv/publicodes](https://github.com/betagouv/publicodes/wiki)
|
||
|
||
Pour se familiariser avec les règles, vous pouvez jeter un œil aux fichiers
|
||
contenant les règles elles-mêmes (dans le dossier `modele-social`) mais cela
|
||
peut s'avérer assez abrupt.
|
||
|
||
Essayez plutôt de jeter un œil [aux tests](https://github.com/betagouv/publicodes/tree/master/core/test/m%C3%A9canismes)
|
||
dans un premier temps, et pourquoi pas à [à l'implémentation des mécanismes](https://github.com/betagouv/publicodes/tree/master/core/source/mecanisms).
|
||
|
||
### Traduction des normes (lois) en règles Publicodes
|
||
|
||
Checklist:
|
||
|
||
- [ ] Lire les articles de vulgarisation (sur le site de l'URSSAF, des impôts, etc.).
|
||
- [ ] Utiliser un moteur de recherche spécialisé, comme [RFPaye](https://rfpaye.grouperf.com/).
|
||
- [ ] [Lire les normes][wiki normes] et noter leurs référence dans les règles Publicodes.
|
||
|
||
[wiki normes]: https://github.com/betagouv/mon-entreprise/wiki/Comment-lire-les-normes-(la-loi)-efficacement-pour-r%C3%A9diger-des-r%C3%A8gles-Publicodes%3F
|