20
Intro Git and github 💻
¿Qué es git y github?
Git es un sistema de control de versiones distribuido que utilizan los desarrolladores de software que contribuyen a un mismo proyecto o software. Básicamente ayuda a los usuarios a rastrear los diferentes cambios realizados en el software por diferentes usuarios.
Github es una plataforma que proporciona alojamiento y control de versiones para su código y cualquiera puede colaborar en cualquier proyecto en todo el mundo.
Cómo empezar a usar Github
Lo primero que tenemos que hacer es configurar el entorno, por lo que necesitamos descargar git. Para cualquier sistema operativo podemos descargarlo aqui
Una vez que hayamos instalado correctamente git, podemos abrir la terminal y escribir el siguiente comando para comprobarlo.
Después de esto podemos ir al sitio web de Github y crear una cuenta si no tenemos.
La cuenta se verá similar a algo como esto:
Configurar git con nombre de usuario y correo electrónico.
Ahora que tenemos Git en el sistema, queremos personalizar el entorno de Git. Sólo es necesario hacer estas cosas una vez; se mantendrán entre actualizaciones. También podemos cambiarlas en cualquier momento volviendo a ejecutar los comandos correspondientes.
Lo primero que debemos hacer cuando instalamos Git es establecer nuestro nombre de usuario y dirección de correo electrónico. Esto es importante porque las confirmaciones de cambios (commits) en Git usan esta información, y es introducida en cada commit que hagamos:
Abrir un terminal/shell:
Si queremos comprobar la configuración, podemos usar el comando git config --list para listar todas las propiedades que Git ha configurado:
Listo! Ya tenes github configurado!
Hay ciertos pasos que debemos seguir para empezar a contribuir en tu trabajo, proyectos propios u Open Source:
- Creación de un repositorio.
- Fork de un repositorio.
- Clone de un repositorio.
- Creando commits.
- Push código.
- Creando una rama(branch).
- Creando issues.
- Crear un pull request.
- Actualizando el contenido del repo.
Creación de un repositorio.
Un repositorio es una carpeta única que contiene los archivos necesarios para el proyecto, podemos decir que es un nombre alternativo para directorio. Para crear un repositorio podemos ver la esquina superior derecha de tu ventana donde tenemos una opción para crear repositorio como se muestra en la imagen de abajo:
Una vez que hayamos hecho click, tendremos que ingresar información sobre el repositorio, como su nombre, si queremos incluir el archivo Readme (archivo de nuestro repositorio en donde podríamos contarle a la comunidad de GitHub de que trata nuestro proyecto.), o incluir algún archivo, etc.
Otra forma de hacerlo es con Git Init
Este comando se usa para crear un nuevo repositorio en Git. Nos crea un repositorio de manera local y lo hará en la carpeta donde estamos posicionados o se le puede pasar [nombre_de_la_carpeta] y creará la carpeta con ese nombre.
Fork de un repositorio.
Un fork es un clon del repo en github y que funciona como un branch del original y es la forma principal por la cual alguien puede proponer cambios a un repositorio que no creo.
Si queremos contribuir en algún proyecto de otra persona, el primer paso es hacer un fork del proyecto para crear una copia de los archivos de ese proyecto en nuestra cuenta de github.
Clone de un repositorio.
Para poder trabajar y modificar un proyecto, el primer paso es descargar los archivos en su PC para ejecutarlos. Este proceso se conoce como clonación de un repo. Debemos abrir la terminal, posicionarnos en la carpeta donde queremos descargar los archivos (Ej: desktop) y ejecutar el siguiente comando:
Hecho esto, tendremos una copia del proyecto en nuestra PC.
Creando commits.
El comando "commit" guardará todos los cambio hechos en la zona de montaje o área de preparación (staging area), junto con una breve descripción del usuario, en un "commit" al repositorio local.
Para agregar el o los archivos al Staging Area vamos a usar el comando add:
Ahora en verde nos indica que tenemos un archivo o mas listos para hacer un commit en nuestro repositorio, hasta que no hagamos un commit nuestros archivos permanecerán en “el limbo” en el estado Ready justo antes de enviar nuestro archivo a nuestros repositorio.
Push código.
Nuestro repositorio local ya tiene nuestros cambios, ahora si queremos enviarlos a nuestro repositorio remoto (ya sea un fork, clone o propio), vamos a usar un comando llamado git push, vamos a empujar nuevos cambios. Podemos hacerlo con el siguiente comando:
Creando una rama(branch).
Como sabemos, cada vez que desarrollamos cualquier software o proyecto, a menudo creamos nuevas features o corregimos un error(fix), por lo que utilizamos ramas para ello.
Las ramas son caminos que puede tomar cualquier desarrollador dentro del proyecto, que agrupan commits y que pueden volver a unirse al camino principal de la aplicación.
Es básicamente una manera de mantener la diferencia en el código original con respecto a la nueva features o fix.
Para comprobar la rama existente en el proyecto podemos escribir el siguiente comando:
Para crear una nueva rama podemos ejecutar el siguiente comando en el terminal:
Para comprobar o cambiar la rama actual puede utilizar el siguiente comando:
Es una buena práctica crear una nueva rama para cada issue creado.
Creando issues.
En la solapa "Issues” los diferentes colaboradores del proyecto pueden remarcar y alertar acerca de diferentes “bugs” o “problemas” dentro del proyecto.
Si queremos trabajar en alguna issue podemos comentar en ese mismo que estamos interesados en trabajar. El administrador del proyecto o los maintainers nos asignarán el issue, y entonces podremos empezar a trabajar en él.
En el caso del Open Source, suele haber una guia para contribuidores que explica el formato preferido de Issues, pull request y commits.
Crear un pull request.
Para que los colaboradores revisen los cambios que hemos hecho y los aprueben en el repositorio original, necesitamos crear una solicitud de revisión o pull request.
Actualizando el contenido del repo.
Al ser git un sistema donde múltiples personas colaboran, puede ser que necesitemos mantener nuestro repositorio local actualizado.
Para ello hay dos maneras en que podemos hacerlo:
- Usando git pull.
- Usando rebase.
En la opción 1, usamos el siguiente comando:
aquí upstream es la ubicación desde la que necesitamos actualizar el contenido y main es la rama de la que hay que hacer pull.
Para la opción 2, podemos utilizar el siguiente comando:
Rebase es preferible en comparación con pull, ya que pull es una combinación de git fetch y git merge que fusiona los cambios locales con las actualizaciones.
20