Skip to main content

Conhecer as ferramentas de aplicativos de exemplo

Nota

Nota

Deseja aprender em português (Brasil)? Comece o desafio em um Trailhead Playground de português (Brasil) e use as traduções fornecidas entre parênteses para navegar. Copie e cole somente os valores em inglês porque as validações dos desafios dependem de dados em inglês. Se você não passar no desafio em sua organização de português (Brasil), recomendamos que (1) mude o local para os Estados Unidos, (2) mude o idioma para inglês, seguindo as instruções aqui, e (3) clique novamente no botão “Validar o desafio”.

Consulte o emblema Trailhead no seu idioma para saber mais sobre como aproveitar a experiência de Trailhead em outros idiomas.

Nesta etapa, vamos percorrer as várias ferramentas e configurações que são oferecidas na maioria dos aplicativos de exemplo. Faremos isso examinando as ferramentas no aplicativo de exemplo LWC Recipes. 

  1. Usando seu navegador, navegue até github.com/trailheadapps.
  2. No bloco do aplicativo LWC Recipes, clique no título LWC Recipes e navegue até o repositório lwc-recipes.

Configurações de projeto do Salesforce

Primeiro, conheça a configuração do projeto do Salesforce no arquivo de configuração sfdx-project.json.

arquivo sfdx-project.json no GitHub

  1. Clique no link para exibir o conteúdo de 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. Observe a configuração packageDirectories onde você pode ver que configuramos pacotes desbloqueados para esse aplicativo. Eles contêm configurações para o nome do pacote, o caminho de arquivo dos metadados do pacote e as informações de versão.
  2. Observe também a configuração sourceApiVersion. Via de regra, atualizamos os aplicativos de exemplo com a versão de API da versão principal atual, no arquivo de configuração e em todos os metadados. Por isso, você poderá ver um valor diferente em sourceApiVersion.
  3. Clique no botão Back (Voltar) do seu navegador.

A seguir, veremos como configuramos as ferramentas de qualidade do código. 

Configuração de ferramenta de qualidade do código

Além das ferramentas incluídas na linha de comando do Salesforce, usamos algumas ferramentas executadas com npm. Ou seja, ainda que a maioria dos projetos não use Node.js em nenhum código do Salesforce no tempo de execução, ainda temos que importar um package.json e configurar as ferramentas de desenvolvedor com npm.  

Nota

npm é o gerenciador de pacotes padrão do Node.js. Ele consiste em um registro de pacote, uma interface de linha de comando (CLI) e o site npmjs.com. Ele é amplamente adotado para criar aplicativos que implementam ferramentas de desenvolvedor e até ferramentas de linha de comando de uso geral, incluindo a Salesforce CLI e a Open CLI Framework (OCLIF).

Nos nossos aplicativos de exemplo, estamos usando a linha de comando npm com várias ferramentas de desenvolvedor que fazem lint e formatação de código, teste de unidade e automação de gerenciamento de ciclo de vida do aplicativo. A maneira mais fácil de instalar o npm é instalar o Node.js, que vem com npm. Para saber mais sobre npm, visite npmjs.com

  1. Clique no link para exibir o conteúdo de package.json.
  2. Observe que, como estamos apenas usando ferramentas de desenvolvedor, não há dependencies.
  3. Examine a configuração devDependencies e veja os pacotes que estamos usando como parte das nossas ferramentas.
  4. Os pacotes gerais que usamos são:
    • prettier: para formatar código
    • eslint: para fazer lint de código
    • @salesforce/sfdx-lwc-jest: a extensão Jest para testar componentes Web do Lightning
    • husky: para executar ações que verificam código antes de confirmar no controle de versão
  5. Também encapsulamos determinados comandos comuns aqui na configuração scripts. Em cada caso, o comando é executado usando npm run. Por exemplo, observe a chave de script test:unit. Você pode executar seus testes de unidade do componente Web do Lightning executando npm run test:unit na linha de comando. Veja como fica:

Executar testes de unidade com npm run test:unit.

  1. Termine seu tour de package.json clicando no botão Back (Voltar) do seu navegador.

Você pode ver como cada um desses scripts permite executar ferramentas diferentes instaladas no projeto. 

Configuração de testes de unidade

Vamos ver como alguns deles estão configurados. Usamos a biblioteca de testes Jest para executar testes de unidade de componente Web do Lightning. No nosso caso, o Salesforce criou uma extensão sob medida para LWC chamada sfdx-lwc-jest. 

  1. Clique no link para exibir o conteúdo de jest.config.js.
  2. Você pode estender as simulações padrão que vêm com sfdx-lwc-jest usando o objeto JavaScript moduleNameMapper. Essas extensões simuladas são definidas aqui.
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. Observe que a chave ^lightning/navigation$ define a localização de sua simulação como <rootDir>/force-app/test/jest-mocks/lightning/navigation. Vamos encontrar esse código JS simulado no repositório do GitHub.
  2. Clique no botão Back (Voltar) do navegador.
  3. Clique nos links force-app, test/jest-mocks e lightning para encontrar todas as simulações de serviços de Componentes Web do Lightning.
  4. Clique no link para abrir o conteúdo do arquivo navigation.js.
  5. Aqui você pode ver como algumas das funções exportadas fornecidas pelo NavigationMixin do Lightning foram simuladas para uso em testes do Jest.
  6. Clique no botão Back (Voltar) do seu navegador quatro vezes a fim de voltar para o diretório raiz do projeto.

Configuração de formatação de código automatizada

Vimos como configurar a ferramenta sfdx-lwc-jest; agora, vamos examinar as configurações da ferramenta de formatação de código Prettier. Enquanto sfdx-lwc-jest serve apenas para testar LWCs, o Prettier faz formatação de código em vários arquivos diferentes. Chegamos até a adicionar plug-ins para XML e Apex. As regras de formatação específicas de LWC vêm com o Prettier.

Se você olhar novamente o package.json, verá nos scripts que configuramos o script Prettier para ser executado em vários tipos de arquivo nesta linha aqui: 

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

Vamos ver como configuramos a ferramenta Prettier. Mais informações sobre essas configurações podem ser encontradas na documentação do Prettier. 

  1. Clique no link para abrir o arquivo .prettierrc.
  2. Anote as configurações de como configurar o Prettier para formatar código, por exemplo, impondo vírgulas no final, permitindo aspas únicas e largura de tabulação.
  3. Você também pode usar a chave overrides para criar regras de análise personalizadas. Por exemplo, usamos o analisador lwc para processar atributos HTML envolvidos por símbolos de chaves.
"trailingComma": "none",
"singleQuote": true,
"tabWidth": 4,
"overrides": [
    {
        "files": "**/lwc/**/*.html",
        "options": { "parser": "lwc" }
    },
    {
        "files": "*.{cmp,page,component}",
        "options": { "parser": "html" }
    }
]
  1. Clique no botão Back (Voltar) do navegador a fim de voltar para o diretório raiz.

Ignorar isso

Muitas ferramentas permitem a você criar exceções para os arquivos em que elas serão executadas. Git, Prettier, ESLint e a Salesforce CLI, entre outras, precisam saber quais arquivos podem ignorar. Vamos ver um dos arquivos de configuração. 

Ao desenvolver um projeto do Salesforce, algumas organizações (organizações temporárias) têm rastreamento de origem, o que significa que uma API rastreia as alterações feitas localmente e na organização. Em seguida, a sincronização da organização para o projeto local pode ser feita automaticamente com sf project deploy start ou sf project retrieve start. As partes do seu projeto que você quer impedir de sincronizar automaticamente são configuradas em um arquivo chamado .forceignore

  1. Observe os arquivos .forceignore, .gitignore e .prettierignore. Eles definem regras de desconsideração para ferramentas diferentes.
  2. Clique em .forceignore para exibir seu conteúdo.
  3. Os itens definidos em .forceignore não serão rastreados ou sincronizados pela API SourceSync.
  4. Observe que dentre outros itens em nossa configuração de projeto, não sincronizamos metadados de settings.
  5. Clique no botão Back (Voltar) do navegador a fim de voltar para o diretório raiz.

Ações do GitHub

Boas ferramentas também permitem sua invocação automática nos processos de CI/CD. Em nossos aplicativos de exemplo, usamos ações do GitHub para automatizar o uso dessas ferramentas conforme o código é mesclado e se move entre ramificações. Vamos procurar onde estão esses arquivos e ver como eles usam as ferramentas que vimos. Também vamos ver o histórico de execução dessas ações em nosso repositório. 

As ações do GitHub são um recurso interno do GitHub para definir todo o seu processo de CI/CD no GitHub. No entanto, as ferramentas de desenvolvedor do Salesforce não dependem das ferramentas de CI/CD. Leia a documentação, que tem referências a outros repositórios de projeto de exemplo, caso você tenha preferência por uma ferramenta de CI/CD diferente. 

  1. Clique nos links de diretório de .github e workflows para ver os arquivos YAML onde residem os fluxos de trabalho de CI do github.
  2. Clique no link de ci-pr.yml para ver o conteúdo do arquivo.
  3. Percorra o arquivo e encontre a linha com: run:npm run prettier:verify
  4. Esse é o ponto no processo de CI em que o Prettier verifica se o código está de acordo com as regras de formatação especificadas na configuração.
  5. No topo da IU do GitHub, selecione a guia Actions (Ações).

Guia de Ações do GitHub.

  1. A lista de todos os fluxos de trabalho de ações do GitHub está à esquerda. Clique em CI para ver todas as vezes em que esse fluxo de trabalho foi executado.

Agora você já viu a configuração das ferramentas no repositório lwc-recipes do GitHub. Você já pode se aprofundar no uso das ferramentas em qualquer um dos aplicativos de exemplo. Mantemos a configuração de ferramentas o mais uniforme possível. No entanto, alguns aplicativos podem usar configurações diferentes. Saiba mais sobre esses aplicativos concluindo os outros projetos nesta trilha.

Algumas considerações sobre código aberto no Salesforce

Os exemplos encontrados na organização github trailheadapps são desenvolvidos e mantidos pela equipe de relações com desenvolvedores do Salesforce. Nós os criamos seguindo as melhores práticas. Todos os nossos aplicativos demonstram ferramentas que estão alinhadas com o que esperaríamos de um projeto no mundo real.

Depois de explorar esses aplicativos de exemplo, incentivamos você a se aprofundar e ver mais códigos das equipes do Salesforce. Você pode encontrar códigos abertos na página da Web Exemplos de código e SDKs.

Não vamos verificar seu trabalho nesta etapa. Clique em Verify step to earn 100 points (Verificar etapa para ganhar 100 pontos) a fim de concluir o projeto.

Compartilhe seu feedback do Trailhead usando a Ajuda do Salesforce.

Queremos saber sobre sua experiência com o Trailhead. Agora você pode acessar o novo formulário de feedback, a qualquer momento, no site Ajuda do Salesforce.

Saiba mais Continue compartilhando feedback