mon-entreprise/CONTRIBUTING.md

5.1 KiB
Raw Blame History

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. 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 ». 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 !

Descriptions des packages

  • mon-entreprise : le site mon-entreprise.urssaf.fr
  • modele-social : les règles de calculs des cotisations sociales, des impôts et des droits sociaux
  • api : l'API qui expose les calculs des simulateurs de mon-entreprise
  • exoneration-covid (archivé) : les règles de calculs de l'exonérations de cotisations sociales liées à la crise sanitaire (2021)
  • server : un petit serveur qui gère un proxy pour les retours utilisateurs ainsi qu'un bot mattermost pour les standups de l'équipe (plus utilisé)

Technologies

Nous utilisons :

  • Eslint qui permet par exemple d'éviter de garder des variables inutilisées
  • Prettier 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 cette configuration est automatique.
  • Publicodes pour la gestion des règles métiers
  • React pour la gestion de l'interface utilisateur
  • Redux pour gérer le “state” de l'application côté client
  • TypeScript 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.
  • ViteJS pour le “bundling” et le serveur de développement
  • Vitest et Cypress pour l'execution des tests. Plus d'informations dans la section consacrée aux tests.
  • Yarn pour la gestion des dépendances (à la place de NPM qui est souvent utilisé dans les applications JavaScript)

Tests

Vérification syntaxique :

yarn lint

Pour corriger les erreurs automatiquement :

yarn lint:fix

Vérification du typage :

yarn test:type

Pour avoir les erreurs de type en direct dans la console, utilisez le paramètre --watch :

yarn test:type --watch

Tests unitaires

yarn test

CI/CD

  • Nous utilisons des Github actions pour faire tourner les builds et les tests.
  • Netlify, s'occupe de lhébergement du site sur Internet avec gestion des DNS.
  • L'API est quand à elle hébergée sur Scalingo

Retours utilisateurs

Nous gérons les retours utilisateurs avec plusieurs outils :

  • Crisp pour recevoir et répondre aux messages
  • Github pour suivre le développement des demandes
  • et ATInternet, notre outil de statistiques, pour suivre la notation des pages

Nous recevons les messages des utilisateurs sur Crisp. Si la demande concerne une nouvelle fonctionnalité, nous ouvrons un ticket sur Github avec l'étiquette retour utilisateur. Cela nous permet de récupérer la liste des demandes avec l'API Github pour l'afficher sur le site.

Crisp permet également d'ajouter une étiquette au message, ce qui nous permet de l'associer au ticket Github correspondant. Avec l'API Crisp, nous pouvons ainsi compter le nombre de demandes sur une fonctionnalité donnée. Enfin quand le ticket est fermé sur Github un petit robot nous rappelle de prévenir les utilisateurs qui nous on fait le retour, ainsi on peut revenir vers eux même plusieurs mois après pour leur indiquer que leur demande a été intégrée.

Quant à la notation des pages avec des smileys, elle fonctionne via des événements personnalisés remontés sur notre outil de statistiques. Nous récupérons le nombre d'événements par page avec l'API fournie pour la présenter sur notre page statistique dédiée.

Là-aussi nous utilisons l'API fournie pour récupérer les valeurs par page et les présenter sur notre page statistiques.