Contenidos
Cómo agregar Lighthouse a un sistema de integración continua, como GitHub Actions.
Tiempos de carga rápidos
CI headlight es un conjunto de herramientas para utilizar Lighthouse durante la integración continua. Lighthouse CI se puede incorporar a los flujos de trabajo de los desarrolladores de muchas formas diferentes. Esta guía cubre los siguientes temas:
- Using the Lighthouse CI CLI.
- Configuración de su proveedor de CI para ejecutar Lighthouse CI.
- Set up a Acción de GitHub and
comprobación del estado
para Lighthouse CI. Esto mostrará automáticamente los resultados de Lighthouse en las solicitudes de extracción de GitHub. - Creación de un panel de rendimiento y un almacén de datos para informes Lighthouse.
Visión general
Lighthouse CI es un conjunto de herramientas gratuitas que facilitan el uso de Lighthouse para la supervisión del rendimiento. Un solo informe Lighthouse proporciona una instantánea del rendimiento de una página web en el momento en que se ejecuta; Lighthouse CI muestra cómo estos hallazgos han cambiado con el tiempo. Esto se puede usar para identificar el impacto de cambios de código particulares o garantizar que se cumplan los umbrales de rendimiento durante los procesos de integración continua. Aunque la supervisión del rendimiento es el caso de uso más común de Lighthouse CI, se puede utilizar para supervisar otros aspectos del informe Lighthouse, por ejemplo, SEO o accesibilidad.
La funcionalidad principal de Lighthouse CI la proporciona la interfaz de línea de comandos de Lighthouse CI. (Nota: esta es una herramienta separada de la Lighthouse CLI.) The Lighthouse CI CLI provides a set of
commands
to use Lighthouse CI. For example, him autorun
El comando ejecuta múltiples ejecuciones de Lighthouse, identifica el informe medio de Lighthouse y carga el informe para su almacenamiento. Este comportamiento se puede personalizar en gran medida pasando indicadores adicionales o personalizando el archivo de configuración de Lighthouse CI, lighthouserc.js
.
Aunque la funcionalidad principal de Lighthouse CI se encapsula principalmente en la CLI de Lighthouse CI, Lighthouse CI se utiliza normalmente a través de uno de los siguientes enfoques:
- Ejecución de Lighthouse CI como parte de la integración continua
- Uso de una acción Lighthouse CI GitHub que se ejecuta y comenta en cada solicitud de extracción
- Seguimiento del rendimiento a lo largo del tiempo a través del panel proporcionado por Lighthouse Server.
All of these approaches are based on the Lighthouse CI CLI.
Las alternativas a Lighthouse CI incluyen servicios de monitoreo de rendimiento de terceros o escribir su propio script para recopilar datos de rendimiento durante el proceso de CI. Debería considerar el uso de un servicio de terceros si prefiere dejar que otra persona se encargue de la administración de su servidor de monitoreo de rendimiento y dispositivos de prueba, o si desea capacidades de notificación (como correo electrónico o integración de Slack) sin tener que crearlas. características usted mismo.
Use Lighthouse CI locally
Esta sección explica cómo ejecutar e instalar la CLI de Lighthouse CI localmente y cómo configurar lighthouserc.js
. Ejecutar la CLI de Lighthouse CI localmente es la forma más fácil de asegurarse de que su lighthouserc.js
está configurado correctamente.
-
Install the Lighthouse CI CLI.
npm install -g @ lhci / cli
Lighthouse CI is configured by placing a
lighthouserc.js
archivo en la raíz del repositorio de su proyecto. Este archivo es obligatorio y contendrá información de configuración relacionada con Lighthouse CI. Aunque Lighthouse CI puede configured to be used without a git repository, las instrucciones de este artículo asumen que el repositorio de su proyecto está configurado para usar git. -
En la raíz de su repositorio, cree un
lighthouserc.js
archivo de configuración.touch lighthouserc.js
-
Agregue el siguiente código a
lighthouserc.js
. Este código es una configuración de Lighthouse CI vacía. Agregará a esta configuración en pasos posteriores.module . exports = {
ci : {
collect : {
} ,
upload : {
} ,
} ,
} ; -
Cada vez que se ejecuta Lighthouse CI, inicia un servidor para servir su sitio. Este servidor es lo que permite a Lighthouse cargar su sitio incluso cuando no hay otros servidores en ejecución. Cuando Lighthouse CI termine de ejecutarse, apagará automáticamente el servidor. Para asegurarse de que la publicación funcione correctamente, debe configurar el
staticDistDir
properties.
Si su sitio es estático, agregue el
staticDistDir
property toci.collect
objeto para indicar dónde se encuentran sus archivos estáticos. Lighthouse CI utilizará su propio servidor para servir estos archivos mientras prueba su sitio. Si su sitio no es estático, agregue elstartServerCommand
property to
ci.collect
objeto para indicar el comando que inicia su servidor. Lighthouse CI iniciará un nuevo proceso de servidor durante la prueba y lo apagará después.
collect : {
staticDistDir : './public' ,
}
collect : {
startServerCommand : 'npm run start' ,
} -
Añade el
url
property to
ci.collect
object to indicate URL (s) where Lighthouse CI should run Lighthouse. The value of theurl
la propiedad debe proporcionarse como una matriz de URL; esta matriz puede contener una o más URL. De forma predeterminada, Lighthouse CI ejecutará Lighthouse tres veces en cada URL.collect : {
url : [ 'http: // localhost: 8080' ]
}Nota: El servidor que configuró en el paso anterior debería poder publicar estas URL. Por lo tanto, si está ejecutando Lighthouse CI localmente, estas URL probablemente deberían incluir
localhost
en lugar de su host de producción. -
Añade el
target
property to
ci.upload
object and set the value to
'temporary-public-storage'
. Los informes de Lighthouse recopilados por Lighthouese CI se cargarán en un almacenamiento público temporal. El informe permanecerá allí durante siete días y luego se eliminará automáticamente. Esta guía de configuración utiliza la opción de carga de «almacenamiento público temporal» porque es rápida de configurar. Para obtener información sobre otras formas de almacenar informes Lighthouse, consulte la
documentación.upload : {
target : 'temporary-public-storage' ,
}La ubicación de almacenamiento del informe será similar a esta:
https://storage.googleapis.com/lighthouse-infrastructure.appspot.com/reports/1580152437799-46441.report.html
(Esta URL no funcionará porque el informe ya se eliminó).
-
Run the Lighthouse CI CLI from the terminal using the
autorun
mando. Esto ejecutará Lighthouse tres veces y cargará el informe de Lighthouse mediano.lhci autorun
Si ha configurado correctamente Lighthouse CI, la ejecución de este comando debería producir un resultado similar a este:
✅ .lighthouseci/ directory writable
✅ Configuration file found
✅ Chrome installation found
⚠️ GitHub token not set
Healthcheck passed!Started a web server on port 65324...
Running Lighthouse 3 time(s) on http://localhost:65324/index.html
Run
Run
Run
Done running Lighthouse!Uploading median LHR of http://localhost:65324/index.html...success!
Open the report at https://storage.googleapis.com/lighthouse-infrastructure.appspot.com/reports/1591720514021-82403.report.html
No GitHub token set, skipping GitHub status check.Done running autorun.
You can ignore the
GitHub token not set
mensaje en la salida de la consola. Un token de GitHub solo es necesario si desea utilizar Lighthouse CI con una acción de GitHub. Más adelante en este artículo se explica cómo configurar una acción de GitHub.By clicking the link in the output that begins with
https: //storage.googleapis.com ...
lo llevará al informe de Lighthouse correspondiente a la carrera mediana de Lighthouse.The default values used by
autorun
se puede anular a través de la línea de comando o
lighthouserc.js
. For example, himlighthouserc.js
La configuración siguiente indica que se deben recopilar cinco ejecuciones de Lighthouse cada vezautorun
run. -
To update
lighthouserc.js
use thenumberOfRuns
property:module . exports = {
collect : {
numberOfRuns : 5
} ,
} ,
} ; -
Run the
autorun
command:lhci autorun
The terminal output should show that Lighthouse has been run five times instead of the default three:
✅ .lighthouseci/ directory writable
✅ Configuration file found
✅ Chrome installation found
⚠️ GitHub token not set
Healthcheck passed!Automatically determined ./dist as `staticDistDir`.
Set it explicitly in lighthouserc.json if incorrect.Started a web server on port 64444...
Running Lighthouse 5 time(s) on http://localhost:64444/index.html
Run
Run
Run
Run
Run
Done running Lighthouse!Uploading median LHR of http://localhost:64444/index.html...success!
Open the report at https://storage.googleapis.com/lighthouse-infrastructure.appspot.com/reports/1591716944028-6048.report.html
No GitHub token set, skipping GitHub status check.Done running autorun.
Para conocer otras opciones de configuración, consulte Lighthouse CI
documentación de configuración.
Configure your CI process to run Lighthouse CI
Lighthouse CI can be used with your favorite CI tool. the Configure your CI provider
La sección de la documentación de Lighthouse CI contiene ejemplos de código que muestran cómo incorporar Lighthouse CI en los archivos de configuración de herramientas de CI comunes. Específicamente, estos ejemplos de código muestran cómo ejecutar Lighthouse CI para recopilar medidas de rendimiento durante el proceso de CI.
El uso de Lighthouse CI para recopilar medidas de rendimiento es un buen lugar para comenzar con la supervisión del rendimiento. Sin embargo, los usuarios avanzados pueden querer ir un paso más allá y usar Lighthouse CI para fallar en las compilaciones si no cumplen con los criterios predefinidos, como aprobar auditorías específicas de Lighthouse o cumplir con todos los presupuestos de desempeño. Este comportamiento se configura a través del
assert
property of the lighthouserc.js
proceedings.
Lighthouse CI supports three levels of assertions:
off
: ignore assertionswarn
: print faults in stderrerror
- Print faults to stderr and exit Lighthouse CI with a non-zero value
código de salida
A continuación se muestra un ejemplo de lighthouserc.js
configuración que incluye aserciones. Establece afirmaciones para las puntuaciones de las categorías de accesibilidad y rendimiento de Lighthouse. Para probar esto, agregue las afirmaciones que se muestran a continuación a su lighthouserc.js
and then run Lighthouse CI again.
module . exports = {
ci : {
collect : {
} ,
assert : {
assertions : {
'categories: performance' : [ 'warn' , { minScore : 1 } ] ,
'categories: accessibility' : [ 'error' , { minScore : 1 } ]
}
} ,
upload : {
} ,
} ,
} ;
La salida de la consola que genera se ve así:
Para obtener más información sobre las afirmaciones de Lighthouse CI, consulte la
documentación.
Configurar una acción de GitHub para ejecutar Lighthouse CI
Esta sección asume que está familiarizado con las solicitudes de extracción de git, GitHub y GitHub.
A Acción de GitHub se puede utilizar para ejecutar Lighthouse CI. Esto generará un nuevo informe Lighthouse cada vez que se envíe un cambio de código a cualquier rama de un repositorio de GitHub. Use esto junto con un comprobación del estado
para mostrar estos resultados en cada solicitud de extracción.
-
En la raíz de su repositorio, cree un directorio llamado
.github / workflows
. the
workflows
para su proyecto irá en este directorio. Un flujo de trabajo es un proceso que se ejecuta en un momento predeterminado (por ejemplo, cuando se envía un código) y se compone de una o más acciones.mkdir .github
mkdir .github / workflows -
In
.github / workflows
create a file calledlighthouse-ci.yaml
. Este archivo contendrá la configuración para un nuevo flujo de trabajo.touch lighthouse-ci.yaml
-
Add the following text to
lighthouse-ci.yaml
.name : Build project and run Lighthouse CI
on : [ push ]
jobs :
lhci :
name : Lighthouse CI
runs-on : ubuntu - latest
steps :
- uses : actions / checkout @ v1
- name : Use Node.js 10.x
uses : actions / setup - node @ v1
with :
node-version : 10.x
- name : npm install
run : |
npm install
- name : run Lighthouse CI
run : |
npm install -g @ lhci / cli @ 0.3.x
lhci autorun --upload.target = temporary-public-storage || echo "LHCI failed!"Esta configuración establece un flujo de trabajo que consta de un único trabajo que se ejecutará cada vez que se envíe un nuevo código al repositorio. Este trabajo tiene cuatro pasos:
- Consulte el repositorio en el que se ejecutará Lighthouse CI
- Install and configure Node
- Install the required npm packages
- Ejecute Lighthouse CI y cargue los resultados en un almacenamiento público temporal.
-
Confirme estos cambios y envíelos a GitHub. Si ha seguido correctamente los pasos anteriores, enviar código a GitHub activará la ejecución del flujo de trabajo que acaba de agregar.
-
Para confirmar que Lighthouse CI se ha activado y ver el informe que generó, vaya a la Behavior pestaña de su proyecto. Deberías ver el
Build project and run Lighthouse CI flujo de trabajo enumerado en su confirmación más reciente.
Puede navegar hasta el informe Lighthouse correspondiente a una confirmación en particular desde el Behavior lengüeta. Haga clic en el compromiso, haga clic en el CI headlight
step of the workflow, then expand the results of the run Lighthouse CI He passed.
Acaba de configurar una acción de GitHub para ejecutar Lighthouse CI. Esto será más útil cuando se use junto con un GitHub comprobación del estado.
Configurar una verificación de estado de GitHub
Una verificación de estado, si está configurada, es un mensaje que aparece en cada RP y generalmente incluye información como los resultados de una prueba o el éxito de una compilación.
Los pasos siguientes explican cómo configurar una verificación de estado para Lighthouse CI.
-
Go to the Página de la aplicación Lighthouse CI GitHub and click Set up.
-
(Opcional) Si formas parte de varias organizaciones en GitHub, elige la organización propietaria del repositorio para el que quieres usar Lighthouse CI.
-
Please select All repositories if you want to enable Lighthouse CI in all repositories or select Select only repositories si solo desea usarlo en repositorios específicos, y luego seleccione los repositorios. Luego haga clic en
Install and authorize. -
Copie el token que se muestra. Lo usará en el siguiente paso.
-
To add the token, navigate to Configurations página de su repositorio de GitHub, haga clic en Mysteries, then click Add a new secret.
-
Select the Name field to
LHCI_GITHUB_APP_TOKEN
and configure the Value
campo al token que copió en el último paso y luego haga clic en el Add secret botón. -
La verificación de estado está lista para usarse. Para probarlo, crear una nueva solicitud de extracción
o enviar una confirmación a una solicitud de extracción existente.
Configure the Lighthouse CI Server
El servidor Lighthouse CI proporciona un panel para explorar los informes históricos de Lighthouse. También puede actuar como un almacén de datos privado a largo plazo para los informes Lighthouse.
- Elija qué compromisos comparar.
- La cantidad que ha cambiado la puntuación de Lighthouse entre las dos confirmaciones.
- Esta sección solo muestra las métricas que han cambiado entre las dos confirmaciones.
- Regressions are highlighted in pink.
- Las mejoras están resaltadas en azul.
Lighthouse CI Server se adapta mejor a los usuarios que se sienten cómodos implementando y administrando su propia infraestructura.
Para obtener información sobre cómo configurar el servidor Lighthouse CI, incluidas las recetas para usar Heroku y Docker para la implementación, consulte estos
instructions.
Know more