De Axe DevTools Linter GitHub Actie Gebruiken

This page is not available in the language you requested. You have been redirected to the English version of the page.
Link to this page copied to clipboard

Hoe de Axe DevTools Linter GitHub-acties te gebruiken om pull-aanvragen te controleren op toegankelijkheidsfouten

Free Trial
Not for use with personal data

Dit artikel laat je zien hoe je de Axe DevTools Linter GitHub-actie van Deque kunt gebruiken om je code te controleren op toegankelijkheidsfouten bij het maken van een GitHub pull-aanvraag. Nadat de actie is uitgevoerd, zal de pull-aanvraag opmerkingen bevatten met de toegankelijkheidsfouten in de vastgelegde bestanden.

De volgende secties tonen de stappen voor het instellen van deze GitHub-actie met je repo.

note

Enkele stappen zijn alleen vereist als je de SaaS-versie van de Axe DevTools Linter gebruikt. Daarom, als je de on-premises versie gebruikt, kun je de stappen overslaan die zijn aangeduid als Alleen SaaS.

Stap 1: Verkrijg een API-sleutel (Alleen SaaS)

Voor Axe DevTools Linter SaaS moet je een API-sleutel verkrijgen. Je kunt er een krijgen door de stappen te volgen op Een Axe DevTools Linter SaaS API-sleutel verkrijgen, of je kunt een bestaande API-sleutel gebruiken van de instellingenpagina voor je Axe-account. Als je problemen ondervindt bij het verkrijgen van een API-sleutel, neem dan contact op met Deques helpdesk.

Stap 2: Maak een Repository Secret voor je API-sleutel (Alleen SaaS)

Als je Axe DevTools Linter SaaS gebruikt, moet je je API-sleutel toevoegen aan de geheimen van je repository, wat je kunt doen door naar de Instellingen pagina van je repo op GitHub te gaan. Voor meer informatie, zie Versleutelde geheimen maken voor een repository op GitHub Docs.

Voor de voorbeeldworkflow in de volgende stap, zouden de geheimen als volgt moeten worden genoemd:

  • AXE_LINTER_API_KEY voor de API-sleutel

Stap 3: Maak de Workflow

Vervolgens moet je een workflow creëren om je bestanden te controleren op toegankelijkheidsfouten. Je kunt een bestand met de naam axe-linter.yml in de map van je repo aanmaken .github/workflows directory.

Je kunt dit bestand online maken als een nieuwe workflow onder het tabblad Acties op de webpagina van je repo (klik op stel zelf een workflow in onder de sectie Aan de slag met GitHub Actions bovenaan de Acties pagina) of maak het lokaal en commit het naar je repo.

tip

De meest recente versie van de YAML-workflow is te vinden in het README.Md-bestand in de GitHub Actierepo.

De axe-linter-action wordt aangeroepen in de workflow wanneer een pull-aanvraag wordt aangemaakt (on: [pull_request]). De workflow maakt gebruik van twee afhankelijkheden:

  • actions/checkout@v4
  • dequelabs/axe-linter-action@v1

De volgende secties tonen voorbeelden van .github/workflows/axe-linter.yml die je kunt gebruiken voor SaaS- of on-prem-versies van de Axe DevTools Linter:

Voor SaaS

De SaaS-versie van de workflow bevat de api_key parameter maar bevat niet de axe_linter_url parameter:

name: Linting for accessibility issues

on: [pull_request]

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - uses: dequelabs/axe-linter-action@v1
        with:
          api_key: ${{ secrets.AXE_LINTER_API_KEY }}          github_token: ${{ secrets.GITHUB_TOKEN }}

Voor On-Prem

De on-prem versie van de workflow bevat de axe_linter_url parameter maar bevat niet de api_key parameter:

name: Linting for accessibility issues

on: [pull_request]

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - uses: dequelabs/axe-linter-action@v1
        with:
          github_token: ${{ secrets.GITHUB_TOKEN }}
          axe_linter_url: $AXE_LINTER_URL

De waarde voor axe_linter_url wordt in dit voorbeeld uit de shell-omgeving gelezen als AXE_LINTER_URL.

Voor de on-premises versie van Axe DevTools Linter heeft u geen API-sleutel nodig, maar uw instantie van Axe DevTools Linter moet via een netwerkverbinding bereikbaar zijn voor GitHub-workflows.

GitHub Action Parameters

De dequelabs/axe-linter-action gebruikt de volgende parameters (gespecificeerd in de bovenstaande voorbeelden in de with clausule):

Naam Beschrijving
github_token Vereist voor authenticatie. Meestal ingesteld door de vooraf gedefinieerde GITHUB_TOKEN geheim. Zie Automatische Token Identificatie op GitHub Docs.
api_key (Alleen SaaS) Voor Axe DevTools Linter SaaS is een API-sleutel vereist om uw workflow te autoriseren. De sleutel wordt verkregen uit het AXE_LINTER_API_KEY geheim dat u in stap 2 hebt gemaakt.
axe_linter_url (Optioneel voor SaaS, vereist voor on-prem) Deze parameter stelt u in staat een andere server op te geven voor linting. De meeste gebruikers die de SaaS-versie gebruiken, hebben deze parameter niet nodig omdat ze de servers van Deque gebruiken voor linting. Gebruikers van de on-prem versie zullen echter deze parameter moeten specificeren. U moet of http: of https: als protocol specificeren, en tenzij u de standaardpoort voor http: (80) of https: (443) gebruikt en deze naar poort 3000 doorverwijst, moet u ook de poort opgeven. Bijvoorbeeld: http://example.com:3000.

Resultaten van de Workflow

De volgende screenshot toont het resultaat van het aanmaken van een pull-verzoek met een bestand dat een toegankelijkheidsfout bevat. Het bestand, bad-file.md, bevat kopniveaus die gaan van kopniveau 1 naar kopniveau 3 en kopniveau 2 overslaan, wat een toegankelijkheidsfout is.

Een pull-verzoek op GitHub en de fout gemarkeerd door de Axe DevTools Linter GitHub-actie. Het bestand aan de rechterzijde van de afbeelding bevat een toegankelijkheidsfout waarbij de koppen niveau 2 overslaan. Er is een foutmelding van de GitHub-actie met details over de fout.

Probleemoplossing

Fouten oplossen met GitHub-acties kan uitdagend zijn omdat de foutmeldingen vaak het onderliggende probleem niet nauwkeurig weergeven. Dit gedeelte bevat enkele voorbeelden van fouten die u kunt tegenkomen.

Onjuist Genaamd Geheim (Alleen SaaS)

Als de naam die u uw API-sleutelgeheim geeft niet overeenkomt met de naam in de workflow, kunt u fouten ontvangen over een ontbrekend commando in plaats van een fout dat het sleutel niet is gedefinieerd:

... line 41: Missing: command not found

Toestemmingsfouten

Er zijn veel plaatsen met GitHub-acties waar toestemmingen onjuist kunnen zijn. Bijvoorbeeld, als u verwijst naar een repo die niet openbaar is met een uses clausule, ontvangt u vaak de foutmelding dat de repo niet is gevonden in plaats van dat u er geen toegang toe heeft:

fatal: repository 'name' not found

Error: Resource not accessible by integration

Als uw workflow niet wordt uitgevoerd met de fout, Resource not accessible by integration, kunt u de volgende toestemmingen aan uw workflow toevoegen om dit op te lossen:

permissions:
  contents: read
  pull-requests: read 

Uw volledige workflow zou er dan als volgt uitzien:

on: [pull_request]

permissions:
  contents: read
  pull-requests: read

jobs:
  build:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v4
      - uses: dequelabs/axe-linter-action@v1
        with:
          api_key: ${{ secrets.AXE_LINTER_API_KEY }}
          github_token: ${{ secrets.GITHUB_TOKEN }}
note

GitHub staat toe annotaties toe te voegen aan pull-verzoeken zelfs met alleen-lezen toegang, zodat de workflow nog steeds toegankelijkheidsfouten in uw code kan annoteren.

Bestanden Gecontroleerd door de Actie

Bestanden met deze extensies worden gecontroleerd op toegankelijkheidsfouten:

  • .js
  • .jsx
  • .tsx
  • .html
  • .vue
  • .md
  • .markdown

Volgende Stappen

Voor informatie over de regels die door Axe DevTools Linter worden gebruikt om uw code te controleren, zie Toegankelijkheidsregels. Als u meer wilt weten over het voorkomen dat bestanden met toegankelijkheidsfouten in Git worden gecommit, zie Een Git Pre-Commit Hook Gebruiken.