Skip to content
Dématérialiser et simplifier les démarches administratives
Branch: dev
Clone or download
n-b Merge pull request #3988 from betagouv/fix-pj-migration-notifications
PJ Migration : ensure creating an empty champ doesn’t display a notification
Latest commit 3d2e658 Jun 24, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci specs: precompile Webpack assets before running the specs suite Jun 3, 2019
app tasks: ensure creating an empty champ doesn’t display a notification Jun 24, 2019
bin bin: run after_party tasks on bin/update Mar 28, 2019
config add duplicate rules as fallback Jun 20, 2019
db Add BillSignature Model Jun 17, 2019
lib Remove orphaned piece_justificatives Jun 20, 2019
log First Commit Aug 10, 2015
public Add rel=noopener to links with target=_blank Mar 5, 2019
spec tasks: ensure creating an empty champ doesn’t display a notification Jun 24, 2019
vendor/assets/stylesheets Use leaflet and freedraw from npm Oct 5, 2018
.browserslistrc Update webpacker and replace vue with react Apr 3, 2019
.editorconfig Add poor man’s ASN1 parsing Jun 17, 2019
.eslintrc.js Update webpacker and replace vue with react Apr 3, 2019
.gitignore Ignore Rubymine project files Apr 8, 2019
.haml-lint.yml Bump development gems Jan 23, 2018
.prettierrc.js Add webpacker and use it for new_design Jul 25, 2018
.rspec First Commit Aug 10, 2015
.rubocop.yml Enable the Rails/InverseOf cop and add missing `inverse_of` Jun 17, 2019
.ruby-version Ruby 2.6.1 Feb 25, 2019
.scss-lint.yml Add the direct_upload JS ans SCSS files Feb 15, 2018
CONTRIBUTING.md doc: clarify wording in CONTRIBUTING.md Jun 17, 2019
Gemfile Fix irb_context in rails console May 20, 2019
Gemfile.lock build(deps): bump chartkick from 3.0.2 to 3.2.0 Jun 12, 2019
Guardfile Remove a useless comment Jan 5, 2019
LICENSE.txt Rename license file Apr 2, 2019
Procfile Force port to 3000 when running on overmind Oct 26, 2018
README.md Add OperationsSignatureJob Jun 17, 2019
Rakefile Extract the deploy_ha task in a dedicated file Sep 20, 2018
babel.config.js Update webpacker and replace vue with react Apr 3, 2019
config.ru Delete redis and actioncable Oct 12, 2017
package.json Upgrade js dependencies May 15, 2019
postcss.config.js Update webpacker and replace vue with react Apr 3, 2019
yarn.lock javascript: fix dependancies compilation using yarn 1.16.0 Jun 17, 2019

README.md

demarches-simplifiees.fr

Contexte

demarches-simplifiees.fr est un site web conçu afin de répondre au besoin urgent de l'État d'appliquer la directive sur le 100 % dématérialisation pour les démarches administratives.

Comment contribuer ?

demarches-simplifiees.fr est un logiciel libre sous licence AGPL.

Vous souhaitez y apporter des changements ou des améliorations ? Lisez notre guide de contribution.

Installation pour le développement

Dépendances techniques

Tous environnements

  • postgresql

Développement

Tests

Création des rôles de la base de données

Les informations nécessaire à l'initialisation de la base doivent être pré-configurées à la main grâce à la procédure suivante :

su - postgres
psql
> create user tps_development with password 'tps_development' superuser;
> create user tps_test with password 'tps_test' superuser;
> \q

Initialisation de l'environnement de développement

Afin d'initialiser l'environnement de développement, exécutez la commande suivante :

bin/setup

Lancement de l'application

overmind start

L'application tourne à l'adresse http://localhost:3000.

Utilisateurs de test

En local, un utilisateur de test est créé automatiquement, avec les identifiants test@exemple.fr/this is a very complicated password !. (voir db/seeds.rb)

Programmation des jobs

AutoArchiveProcedureJob.set(cron: "* * * * *").perform_later
WeeklyOverviewJob.set(cron: "0 7 * * 1").perform_later
AutoReceiveDossiersForProcedureJob.set(cron: "* * * * *").perform_later(procedure_declaratoire_id, Dossier.states.fetch(:en_instruction))
SendinblueUpdateAdministrateursJob.set(cron: "0 10 * * *").perform_later
FindDubiousProceduresJob.set(cron: "0 0 * * *").perform_later
Administrateurs::ActivateBeforeExpirationJob.set(cron: "0 8 * * *").perform_later
WarnExpiringDossiersJob.set(cron: "0 0 1 * *").perform_later
GestionnaireEmailNotificationJob.set(cron: "0 10 * * 1,2,3,4,5,6").perform_later
PurgeUnattachedBlobsJob.set(cron: "0 0 * * *").perform_later
OperationsSignatureJob.set(cron: "0 6 * * *").perform_later

Voir les emails envoyés en local

Ouvrez la page http://localhost:3000/letter_opener.

Mise à jour de l'application

Pour mettre à jour votre environnement de développement, installer les nouvelles dépendances et faire jouer les migrations, exécutez :

bin/update

Exécution des tests (RSpec)

Les tests ont besoin de leur propre base de données et certains d'entre eux utilisent Selenium pour s'exécuter dans un navigateur. N'oubliez pas de créer la base de test et d'installer chrome et chromedriver pour exécuter tous les tests.

Pour exécuter les tests de l'application, plusieurs possibilités :

  • Lancer tous les tests

      bin/rake spec
      bin/rspec
    
  • Lancer un test en particulier

      bin/rake spec SPEC=file_path/file_name_spec.rb:line_number
      bin/rspec file_path/file_name_spec.rb:line_number
    
  • Lancer tous les tests d'un fichier

      bin/rake spec SPEC=file_path/file_name_spec.rb
      bin/rspec file_path/file_name_spec.rb
    

Ajout de taches à exécuter au déploiement

    rails generate after_party:task task_name

Debug

Une fois overmind lancé, et un breakpoint byebug inséré dans le code, il faut se connecter au process server dans un nouveau terminal afin d'intéragir avec byebug :

overmind connect server

Linting

Le projet utilise plusieurs linters pour vérifier la lisibilité et la qualité du code.

  • Faire tourner tous les linters : bin/rake lint
  • AccessLint tourne automatiquement sur les PRs

Régénérer les binstubs

bundle binstub railties --force
bin/rake rails:update:bin

Déploiement

  • Tout nouveau commit ajouté à la branche dev est automatiquement déployé en intégration
  • Tout nouveau commit ajouté à la branche master est automatiquement déployé en production

Tâches courantes

Tâches de gestion des comptes super-admin

Des tâches de gestion des comptes super-admin sont prévues dans le namespace superadmin. Pour les lister : bin/rake -D superadmin:.

Tâches d’aide au support

Des tâches d’aide au support sont prévues dans le namespace support. Pour les lister : bin/rake -D support:.

Compatibilité navigateurs

L'application supporte les navigateurs récents : Firefox, Chrome, Safari, Edge et Internet Explorer 11 (voir config/browser.rb).

La compatibilité est testée par Browserstack.

Performance

View performance data on Skylight

Nous utilisons Skylight pour suivre les performances de notre application.

You can’t perform that action at this time.