Skip to main content

En savoir plus sur les outils des exemples d’applications

Remarque

Remarque

Vous souhaitez apprendre en français ? Commencez le défi dans un Trailhead Playground en français et utilisez les traductions fournies entre crochets pour naviguer. Copiez et collez uniquement les valeurs en anglais, car les validations de défi reposent sur les données en anglais. Si vous ne réussissez pas le défi dans votre organisation en français, nous vous recommandons (1) de définir le paramètre régional sur les États-Unis, (2) de définir la langue sur l’anglais en suivant les instructions ici, puis (3) de cliquer à nouveau sur le bouton « Vérifier le défi ».

Consultez le badge Trailhead dans votre langue pour découvrir comment profiter de l’expérience Trailhead traduite.

Dans cette étape, nous passons en revue les configurations et les outils communs à la plupart des exemples d’applications. Pour ce faire, nous allons examiner les outils de l’exemple d’application LWC Recipes (Recettes LWC). 

  1. Sur votre navigateur, accédez à github.com/trailheadapps.
  2. Sur la vignette de l’application Recettes LWC, cliquez sur le titre LWC Recipes (Recettes LWC) pour accéder au référentiel lwc-recipes.

Configurations pour les projets Salesforce

Tout d’abord, familiarisez-vous avec la configuration du projet Salesforce dans le fichier de configuration sfdx-project.json.

Fichier sfdx-project.json dans GitHub

  1. Cliquez sur le lien pour afficher le contenu du fichier sfdx-project.json.
{
  "packageDirectories": [
    {
      "path": "force-app",
      "default": true,
      "package": "LWCRecipes",
      "versionName": "Summer '23",
      "versionNumber": "58.0.0.NEXT"
    }
  ],
  "namespace": "",
  "sourceApiVersion": "58.0",
  "sfdcLoginUrl": "https://login.salesforce.com",
  "packageAliases": {
    "LWCRecipes": "0Ho3t000000KywNCAS",
    "LWCRecipes@57.0.0-2": "04t3t000002wSUgAAM",
    "LWCRecipes@58.0.0-5": "04t3t0000037toQAAQ",
    "LWCRecipes@58.0.0-6": "04t3t0000037tozAAA",
    "LWCRecipes@58.0.0-7": "04t3t0000037tp9AAA",
    "LWCRecipes@58.0.0-8": "04t3t0000037tpEAAQ"
  }
}
  1. Regardez la configuration packageDirectories, où vous pouvez voir que nous avons configuré des packages déverrouillés pour cette application. Elle contient les configurations pour le nom du package, le chemin d’accès au fichier des métadonnées du package et les informations de version.
  2. Notez également la configuration sourceApiVersion. En règle générale, nous mettons à jour les exemples d’applications avec la version d’API pour la version majeure actuelle, y compris pour le fichier de configuration et l’ensemble des métadonnées. C’est pourquoi vous pouvez voir une valeur différente pour sourceApiVersion.
  3. Cliquez sur le bouton Back (Retour) de votre navigateur.

Nous allons maintenant voir les outils de contrôle qualité que avons mis en place pour le code. 

Configuration de l’outil de contrôle qualité pour le code

En plus des outils inclus dans la ligne de commande Salesforce, nous utilisons des outils exécutés avec npm. Ainsi, bien que la plupart des projets n’utilisent pas Node.js dans leur code d’exécution Salesforce, nous avons toujours un fichier package.json pour importer et configurer les outils de développement avec npm.  

Remarque

npm est le gestionnaire de packages par défaut pour Node.js. Il se compose d’un registre de packages, d’une interface de ligne de commande (CLI) et du site Web npmjs.com. Il est largement utilisé pour créer des applications en vue d’implémenter des outils de développement et même des outils de ligne de commande à usage général, dont Salesforce CLI et le modèle Open CLI Framework (OCLIF).

Dans nos exemples d’applications, nous utilisons la ligne de commande npm avec plusieurs outils de développement qui assurent le linting et la mise en forme du code, les tests unitaires et l’automatisation de la gestion du cycle de vie des applications (ALM). Le moyen le plus simple d’installer npm consiste à installer Node.js, qui comprend npm. Pour en savoir plus sur npm, rendez-vous sur le site npmjs.com

  1. Cliquez sur le lien pour afficher le contenu de package.json.
  2. Vous remarquerez que dependencies n’apparaît pas, car nous n’utilisons que des outils de développement.
  3. La configuration devDependencies indique les packages que nous utilisons dans le cadre de nos outils.
  4. Les packages généraux que nous utilisons sont :
    • prettier : pour la mise en forme du code
    • eslint : pour le linting du code
    • @salesforce/sfdx-lwc-jest : l’extension Jest pour tester les composants Web Lightning
    • husky : pour exécuter des actions qui vérifient le code avant de valider ce dernier dans le contrôle de version
  5. Nous avons ici également encapsulé certaines commandes courantes dans la configuration scripts. Dans chaque cas, la commande est exécutée en utilisant npm run (course npm). Regardez par exemple la clé de script test:unit. Vous pouvez exécuter vos tests unitaires de composant Web Lightning en exécutant npm run test:unit à partir de la ligne de commande. Voici un aperçu du résultat :

Exécution de tests unitaires avec npm run test:unit.

  1. Terminez votre exploration de package.json en cliquant sur le bouton Back (Retour) de votre navigateur.

Vous pouvez voir comment chacun de ces scripts vous permet d’exécuter différents outils installés dans le projet. 

Configuration des tests unitaires

Regardons la configuration de certains de ces tests. Nous utilisons la bibliothèque de tests Jest pour exécuter les tests unitaires des composants Web Lightning. Dans notre cas, Salesforce a créé une extension spécialement conçue pour LWC appelée sfdx-lwc-jest. 

  1. Cliquez sur le lien pour afficher le contenu de jest.config.js.
  2. Vous pouvez étendre les simulations par défaut fournies avec sfdx-lwc-jest en utilisant l’objet JavaScript moduleNameMapper. Ces extensions fictives sont définies ici.
moduleNameMapper: {
  /* CSS library import fix in test context. See:
  https://github.com/salesforce/sfdx-lwc-jest/issues/288) */
  '^c/cssLibrary$':
      '/force-app/main/default/lwc/cssLibrary/cssLibrary.css',
  // Jest mocks
  '^@salesforce/apex$': '/force-app/test/jest-mocks/apex',
  '^@salesforce/schema$': '/force-app/test/jest-mocks/schema',
  '^lightning/navigation$':
      '/force-app/test/jest-mocks/lightning/navigation',
  '^lightning/platformShowToastEvent$':
      '/force-app/test/jest-mocks/lightning/platformShowToastEvent',
  '^lightning/uiRecordApi$':
      '/force-app/test/jest-mocks/lightning/uiRecordApi',
  '^lightning/messageService$':
      '/force-app/test/jest-mocks/lightning/messageService',
  '^lightning/actions$':
      '/force-app/test/jest-mocks/lightning/actions',
  '^lightning/alert$':
      '/force-app/test/jest-mocks/lightning/alert',
  '^lightning/confirm$':
      '/force-app/test/jest-mocks/lightning/confirm',
  '^lightning/prompt$':
      '/force-app/test/jest-mocks/lightning/prompt',
  '^lightning/modal*':
      '/force-app/test/jest-mocks/lightning/modal'
},
  1. Notez que la clé ^lightning/navigation$ définit <rootDir>/force-app/test/jest-mocks/lightning/navigation comme emplacement de sa simulation. Allons chercher ce code JS fictif dans le référentiel GitHub.
  2. Cliquez sur le bouton Back (Retour) de votre navigateur.
  3. Cliquez sur les liens force-app, test/jest-mocks et lightning pour trouver toutes les simulations de services des composants Web Lightning.
  4. Cliquez sur le lien pour ouvrir le contenu des fichiers navigation.js.
  5. Vous pouvez ici voir comment certaines des fonctions exportées fournies par Lightning NavigationMixin ont été simulées pour être utilisées dans les tests Jest.
  6. Cliquez quatre fois sur le bouton Back (Retour) de votre navigateur pour revenir à la racine de votre projet.

Configuration de la mise en forme automatique du code

Maintenant que nous avons vu comment configurer l’outil sfdx-lwc-jest, jetons un œil aux configurations de l’outil de mise en forme du code Prettier. À l’inverse de sfdx-lwc-jest, qui sert uniquement à tester les LWC, Prettier effectue la mise en forme du code sur de nombreux types de fichiers différents. Nous avons même ajouté des plug-ins pour XML et Apex. Des règles de mise en forme propres à LWC sont fournies avec Prettier.

Si vous regardez de nouveau dans package.json, vous pouvez voir dans les scripts que nous avons configuré le script Prettier pour qu’il soit exécuté sur de nombreux types de fichiers différents dans cette ligne : 

"prettier": "prettier --write \"**/*.{cls,cmp,component,css,html,js,json,md,page,trigger,xml,yaml,yml}\""

Voyons comment configurer l’outil Prettier. Vous trouverez plus d’informations sur ce sujet dans la documentation Prettier. 

  1. Cliquez sur le résultat pour ouvrir le fichier .prettierrc.
  2. Jetez un œil aux configurations pour vois comment configurer Prettier en vue formater le code (application de virgules de fin, autorisation des guillemets simples, largeur des tabulations, etc.).
  3. Vous pouvez aussi utiliser la clé overrides pour créer des règles d’analyse personnalisées. Nous utilisons par exemple l’analyseur lwc pour gérer les attributs HTML entourés d’accolades.
"trailingComma": "none",
"singleQuote": true,
"tabWidth": 4,
"overrides": [
    {
        "files": "**/lwc/**/*.html",
        "options": { "parser": "lwc" }
    },
    {
        "files": "*.{cmp,page,component}",
        "options": { "parser": "html" }
    }
]
  1. Cliquez sur le bouton Back (Retour) pour revenir au répertoire racine.

Pour ignorer des éléments

De nombreux outils vous permettent de créer des exceptions pour les fichiers sur lesquels ils sont exécutés. Des éléments tels que Git, Prettier, ESLint et Salesforce CLI doivent tous savoir quels fichiers ils peuvent ignorer. Regardons l’un des fichiers de configuration. 

Lors du développement d’un projet Salesforce, certaines organisations (organisations tests) sont surveillées à la source, ce qui signifie qu’une API surveille les modifications apportées localement et dans l’organisation. La synchronisation de l’organisation avec le projet local peut ensuite être effectuée automatiquement à l’aide de sf project deploy start ou de sf project retrieve start. Toutes les parties de votre projet dont vous souhaitez empêcher la synchronisation automatique sont configurées dans un fichier appelé .forceignore

  1. Regardez les fichiers .forceignore, .gitignore, et .prettierignore. Ils définissent les règles ignore à appliquer aux différents outils.
  2. Cliquez sur .forceignore pour en visualiser le contenu.
  3. Les éléments définis dans .forceignore ne seront ni surveillés ni synchronisés par l’API SourceSync.
  4. Veuillez noter que nous ne synchronisons pas non plus les métadonnées settings, parmi d’autres éléments de notre configuration de projet.
  5. Cliquez sur le bouton Back (Retour) pour revenir au répertoire racine.

Actions GitHub

Les bons outils peuvent également être invoqués automatiquement dans les processus CI/CD. Dans nos exemples d’applications, nous utilisons des actions GitHub pour automatiser l’utilisation de ces outils lorsque le code est fusionné et se déplace entre les branches. Découvrons où se trouvent ces fichiers et voyons comment ils utilisent les outils que nous avons étudiés. Nous examinerons également l’historique d’exécution de ces actions dans notre référentiel. 

Les actions GitHub sont une fonctionnalité intégrée de GitHub qui permet de définir l’ensemble de votre processus CI/CD dans GitHub. Les outils de développement Salesforce sont cepedendant indépendants des outils CI/CD. Consultez bien notre documentation, qui contient des références à d’autres référentiels de projets d’exemple si vous préférez un autre outil CI/CD. 

  1. Cliquez sur les liens du répertoire pour .github et workflows afin d’accéder aux fichiers YAML où se trouvent les flux de travail github CI.
  2. Cliquez sur le lien pour ci-pr.yml afin d’afficher le contenu du fichier.
  3. Parcourez le fichier et trouvez la ligne qui indique run:npm run prettier:verify
  4. C’est à ce point du processus CI que Prettier vérifie que le code est conforme aux règles de mise en forme spécifiées dans sa configuration.
  5. En haut de l’interface utilisateur GitHub, sélectionnez l’onglet Actions.

Onglet Actions GitHub.

  1. La liste de tous les flux de travail d’actions GitHub se trouve sur la gauche. Cliquez sur CI pour voir toutes les fois où le flux de travail a été exécuté.

Vous avez maintenant fini d’explorer la configuration des outils dans le référentiel GitHub lwc-recipes. Vous êtes prêt(e) à utiliser les outils de l’un des exemples d’applications. Nous maintenons une configuration des outils aussi uniforme que possible. Il arrive cependant que certaines applications utilisent une configuration différente. Pour en savoir plus sur ces applications, menez à bien les autres projets de ce parcours.

Un mot sur le code en source ouverte chez Salesforce

Les exemples trouvés dans l’organisation github trailheadapps sont développés et maintenus par l’équipe DevRel de Salesforce. Nous les avons conçus en suivant les meilleures pratiques. Toutes nos applications présentent également des outils conformes à ce que l’on attend d’un projet réel.

Après avoir exploré ces exemples d’applications, nous vous encourageons à approfondir et à découvrir plus de code des équipes Salesforce. Vous pouvez trouver du code en source ouverte sur notre page d’exemples de code et de SDK.

Nous ne passerons pas vos travaux en revue lors de cette étape. Cliquez sur Vérifier l’étape pour gagner 100 points et terminer le projet.

Partagez vos commentaires sur Trailhead dans l'aide Salesforce.

Nous aimerions connaître votre expérience avec Trailhead. Vous pouvez désormais accéder au nouveau formulaire de commentaires à tout moment depuis le site d'aide Salesforce.

En savoir plus Continuer à partager vos commentaires