Saltar al contenido principal

Pull Requests

Configurando tu entorno local

Paso 1: Fork

Haga Fork del proyecto on GitHub y clone su fork localmente.

$ git clone git@github.com:username/electron.git
$ cd electron
$ git remote add upstream https://github.com/electron/electron.git
$ git fetch upstream

Paso 2: Compilado

Pasos de compilado y dependencias difieren ligeramente dependiendo de su sistema operativo. Ver estas guías detalladas en compilacion local de Electron:

Una vez que has compilado el proyecto localmente, ¡Estas listo para empezar a hacer cambios!

Paso 3: Rama

Para mantener tu entorno de desarrollo organizado, crea ramas locales para retener tu trabajo. Estos deben ser ramificados directamente de la rama main.

$ git checkout -b mi-rama -t upstream/main

Haciendo Cambios

Paso 4: Código

La mayoría de los pull requests abiertos contra el repositorio electron/electron incluyen cambios al código C/C++ ne la carpeta shell/, el código JavaScript en la carpeta lib/, la documentación en docs/api/ o a los tests en la carpeta spec/.

Por favor asegúrate de correr npm run lint de vez en cuando en cualquier cambio de código para asegurar que estos siguen el estilo de código del proyecto.

Ver estilo de codificación para mas información acerca de la mejor práctica cuando se esta modificando el código en diferentes partes del proyecto.

Paso 5: Commit

Se le recomienda mantener sus cambios agrupados lógicamente dentro de commits individuales. Muchos contribuyentes encuentras mas fácil el revisar los cambios que son divididos entre multiples commits. No hay límite en el número de commits en un pull request.

$ git add my/changed/files
$ git commit

Note that multiple commits get squashed when they are landed.

Directrices de mensaje commit

Un buen mensaje de commit debe describir que ha cambiado y por qué. El proyecto Electron usa semantic commit messages para racionalizar el proceso de lanzamiento.

Antes de que una solicitud de pull pueda ser fusionada, debe tener un título de pull request con un prefijo semántico.

Ejemplos de mensajes de confirmación con prefijos semánticos:

  • fix: don't overwrite prevent_default if default wasn't prevented
  • feat: add app.isPackaged() method
  • docs: app.isDefaultProtocolClient is now available on Linux

Prefijos usuales:

  • fix: Una corrección de error
  • feat: Una nueva característica
  • docs: Cambios en la documentación
  • test: Agrega pruebas faltantes o corrige las pruebas exixtentes
  • build: Cambios que afectan el sistema de construccion
  • ci: Cambios a nuestros archivos de configuración y scripts CI
  • perf: Un cambio en el código que mejora el rendimiento
  • refactor: Un cambio en el código que no corrige un error ni agrega una característica
  • style: Cambios que no afectan el significado del código (linting)

Otras cosas para tener en mente cuando se escribe un mensaje de commit:

  1. La primera linea debe:
    • contener una breve descripción del cambio (preferiblemente de 50 caracteres o menos, y no más de 72 caracteres)
    • estar completamente en minúsculas con la excepción de nombres propios, acrónimos, y las palabras que refieren a un código, como nombres de función/variables
  2. Mantén la segunda linea vacía.
  3. Ajuste todas las otras linea en 72 columnas.

Restaurar archivos borrados

Un commit que tiene el texto BREAKING CHANGE: al principio de su sección opcional de cuerpo o pie de página introduce un cambio de ruptura en el API (correlacionando con el Major en versionado semántico). Un cambio de ruptura puede ser parte de los commits de cualquier tipo. ejemplo, los tipos fix:, feat: & chore: serían válidos, ademas de cualquier otro tipo.

Vea conventionalcommits.org para más detalles.

Paso 6: Reorganizar

Una vez hayas asignado tus cambios, es una buena idea el usar git rebase (no git merge) para sincronizar tu trabajo con el repositorio principal.

$ git fetch upstream
$ git rebase upstream/main

Esto asegura que tu rama de trabajo tiene los últimos cambios de la rama principal electron/electron.

Paso 7: Prueba

Las características y reparaciones de un error deben siempre ser dadas con pruebas. Una guía de prueba ha sido proporcionado para facilitar el proceso. Mirar otras pruebas para ver como deberían ser estructuradas también puede ayudar.

Antes de enviar tus cambios en una pull request, siempre ejecute el paquete completo de pruebas. Para ejecutar las pruebas:

$ npm run test

Asegúrese de que el linter no reporta ningún inconveniente y que pasa todas pruebas. Por favor no envíe parches que fallan en cualquiera de las verificaciones.

Si usted esta actualizando pruebas y quiere correr un simple especificación para probarlas:

$ npm run test -match=menu

Lo anterior solo podrá ejecutar módulos específicos coincidentes menu, el cual es útil para cualquiera que esta trabajando en pruebas que podrían de lo contrario estar al final de un ciclo de prueba.

Paso 8: Push

Una vez que tus commits están listos -- ya pasadas las pruebas y el linting -- comienza el proceso de apertura de un pull request haciendo un push de tu rama de trabajo a tu fork en GitHub.

$ git push origin my-branch

Paso 9: Abriendo el Pull Request

Desde dentro de GitHub, abrir una nueva pull request te presentará con una plantilla que debe ser llenada. Se puede encontrar aquí.

Si no completa adecuadamente esta plantilla, es posible que tu PR se demore en ser fucionado ya que los mantenedores buscan más información o aclaran ambigüedades.

Paso: 10: Analizar y actualizar

Probablemente recibirás críticas o peticiones de cambios a tu pull request. ¡Esta es una gran parte del proceso de envío así que no te desanimes! Algunos contribuyentes pueden inmediatamente desistir del pull request. Otros pueden tener comentarios o críticas detalladas. Esto es una parte necesaria del proceso con el fin de evaluar si los cambios son correctos y necesarios.

Para realizar cambios a un pull request existente, realiza los cambios a tu rama loca, añade una nuevo commit con esos cambios, y haz a este nuevo commit un push hacia tu fork. GitHub actualizará automáticamente el pull request.

$ git add my/changed/files
$ git commit
$ git push origin my-branch

Existe un número de mecanismos mas avanzados para gestionar commits usando git rebase que puede ser usado, pero esta mas allá del alcance de esta guía.

Siéntete libre de postear un comentario en el pull request para avisar a los críticos si estas esperando una respuesta en algo. Si encuentras palabras o acrónimos que parecen desconocidas, consulte este glosario.

Aprobación y Solicitud de Cambios de Workflow

Todas las pull requests requieren de aprobación por parte de un Propietario de Códico del área que modificaste para aterrizar. Cada vez que un mantenedor revisa un pull request ellos pueden solicitar cambios. Estos pueden ser pequeños, tales como corregir un error tipográfico o puede implicar cambios sustanciales. Se espera que sean útiles, pero puede que a veces no lo sean, especialmente si no incluyen sugerencias concretas sobre cómo cambiarlas.

Trata de no estar desmotivado. Si tu sientes que una crítica es injusta, confórmate o busca la entrada de otro contribuyente del proyecto. A menudo ese tipo de comentarios son el resultado de un crítico que no toma el suficiente tiempo para revisar y no son mal intencionados. Estas dificultades a menudo pueden ser resueltas con un poco de paciencia. Dicho esto, se espera que los revisores ofrezcan una crítica útil.

Paso 11: Ejecutado

Con el fin de ejecutar, un pull request necesita se revisado y aprobado por al menos un Propietario de Código Electron y tarjeta CI. Después de eso, si no hay objeciones de otro contribuyentes, el pull request puede ser combinado.

¡Felicitaciones y gracias por tu contribución!

Prueba de Integración Continua

Cada pull request se prueva en el sistema de Integracion Continua (CI) para confirmar que funciona en plataformas compatibles con Electron.

Idealmente, el pull request pasara("ser verde") en todas las plataformas de CI. Esto quiere decir que pasa todas las pruebas y no hay errores linting. Sin embargo, no es infrecuente para la infraestructura de CI el fallar en plataformas específicas o como son llamadas pruebas "escamosas" a fallar ("be red"). Cada falla de CI debe ser inspeccionada manualmente para determinar la causa.

CI inicia automáticamente cuando abres una pull request, pero solo los mantenedores principales puede reiniciar una ejecución CI. Si crees que el CI está dando un falso negativo, pida a un mantenedor que reinicie las pruebas.