Ce guide explique comment intégrer les résultats ESLint dans vos requêtes d'extraction Bitbucket à l'aide de Bitbucket Pipelines. Vous apprendrez à générer des rapports ESLint au format JSON, à les publier sous forme d'annotations en ligne à l'aide de l'API Bitbucket Reports and Annotations et à configurer un pipeline Bitbucket pour exécuter automatiquement ESLint.
Tout d'abord, vous devrez exécuter ESLint et afficher les résultats au format JSON. Ce fichier sera ensuite utilisé pour créer un rapport et des annotations.
Ajoutez les arguments -f et -o à votre commande eslint. Par exemple :
eslint . --ext .ts -f json -o eslint-report.json
Pour afficher les résultats d'ESLint directement dans vos demandes d'extraction, vous utiliserez l'API de rapport et l'API d'annotations de Bitbucket.
const fs = require('fs') const path = require('path') const util = require('util') // External ID must be unique per report on a commit const EXTERNAL_ID = 'com.yorcompany.reports.eslint' const BB_USER = 'YOUR_USER' const BB_REPO = 'YOUR_REPO' const BB_URL = 'https://api.bitbucket.org/2.0' // This is available by default in the pipeline. const COMMIT = process.env.BITBUCKET_COMMIT // For this to be availble you need to create an access token with read access to the repo // and set it an environment variable in the pipeline. const TOKEN = process.env.BITBUCKET_TOKEN // Map ESLint severities to Bitbucket report severities const severities = { 0: 'LOW', 1: 'MEDIUM', 2: 'HIGH' } // Read the ESLint JSON report const data = await util.promisify(fs.readFile)(path.join(process.cwd(), 'eslint-report.json'), 'utf8') .catch(err => { console.error('Error reading eslint-report.json:', err) throw err }) const eslintOutput = JSON.parse(data) let totalErrorCount = 0 let totalWarningCount = 0 const annotations = [] let i = 1 eslintOutput.forEach(file => { totalErrorCount += file.errorCount totalWarningCount += file.warningCount const relativePath = path.relative(process.cwd(), file.filePath) file.messages.forEach(message => { annotations.push({ external_id: `${EXTERNAL_ID}.${COMMIT}.${i++}`, path: relativePath, annotation_type: 'CODE_SMELL', summary: message.message, line: message.line, severity: severities[message.severity] }) }) }) // Prepare the report const report = { title: 'ESLint Report', details: 'Results from ESLint analysis', report_type: 'TEST', logoUrl: 'https://eslint.org/img/logo.svg', data: [ { title: 'Error Count', type: 'NUMBER', value: totalErrorCount }, { title: 'Warning Count', type: 'NUMBER', value: totalWarningCount } ] } try { // Post the report to Bitbucket const reportUrl = `${BB_URL}/repositories/${BB_USER}/${BB_REPO}/commit/${COMMIT}/reports/${EXTERNAL_ID}` let response = await fetch(reportUrl, { method: 'PUT', body: JSON.stringify(report), headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': `Bearer ${TOKEN}` } }) if (!response.ok) { console.error(await response.text()) throw new Error(`Error posting report: ${response.statusText}`) } console.log('Report posted successfully!') console.log(await response.json()) // Post annotations if any if (annotations.length > 0) { const annotationsUrl = `${BB_URL}/repositories/${BB_USER}/${BB_REPO}/commit/${COMMIT}/reports/${EXTERNAL_ID}/annotations` response = await fetch(annotationsUrl, { method: 'POST', body: JSON.stringify(annotations), headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'Authorization': `Bearer ${TOKEN}` } }) if (!response.ok) { console.error(await response.text()) throw new Error(`Error posting annotations: ${response.statusText}`) } console.log('Annotations posted successfully!') console.log(await response.json()) } } catch (error) { console.error('Error posting insights:', error.response ? error.response.data : error.message) }
Pour automatiser ce processus dans le cadre de votre flux de travail CI/CD, vous pouvez configurer un pipeline Bitbucket pour exécuter ESLint, générer le rapport JSON et publier les résultats. Vous trouverez ci-dessous un exemple de fichier bitbucket-pipelines.yml pour vous aider à démarrer :
image: node:18.13.0 pipelines: default: - step: name: ESLint caches: - node script: - npm install - npx eslint . --ext .ts -f json -o eslint-report.json # Run ESLint and save the report after-script: - node post-eslint-results.js # Post results to Bitbucket artifacts: - eslint-report.json
Le rapport est publié sur Bitbucket après le script car les scripts suivants ne seront pas appelés si eslint renvoie un code de sortie différent de 0 (si ESLint contient des erreurs).
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!