Skip to content

Latest commit

 

History

History
267 lines (172 loc) · 12.7 KB

README.MD

File metadata and controls

267 lines (172 loc) · 12.7 KB

Tutorial Git

Crear repo

Utilizaremos github en este tutorial pero puede utilizarse gitlab en su lugar o cualquier otro servicio de git similar.

  1. Ir a github.com
  2. Loguearse al sitio con su cuenta. Si aún no tiene una cuenta cree una gratuita.
  3. Crear un nuevo repostorio haciendo click en el botón de la imagen

Nuevo Repo 4. Ingresar datos e información inicial del repositorio.

  • Elegir un nombre para el repositorio.
  • Opcionalmente ingrese una escripción.
  • Indicar si desea que sea publico o privado (en este tutorial usaremos uno público).
  • No crearemos readme, gitignore ni licencia ya que queremos un repositorio vació e inicializarlo localmente.
  • Finalmente cree el repositorio presionando el botón de la imagen

datos repo 5. Nos mostrará el siguiente contenido para confirmar que el repositorio se ha creado

confirmacion repo 6. A continuación invitaremos a nuestros compañeros de equipo como colaboradores en el repositorio.

  • Seleccionamos la pestaña Settings.
  • Allí a la izquierda elegimos la opción Collaborators
  • Por cada compañero ingresamos el nombre de usuario de nuestros compañeros y hacemos clic en el botón Add collaborator.

agregar colaborador 7. Una vez que completamos esta acción nuestros compañeros recibiran un email para aceptar nuestra invitación a colaborar.

Uso de Git en IDE

Utilizaremos eclipse for java ee developers que ya cuenta con EGit incluido. En caso de no contar con esta versión de eclipse puede agregarse el plugin de EGit.

Para representar dos usuarios diferentes y simplificar comprender que acciones relizaría cada uno utilizaremos dos eclipse con diferentes Themes (Dark y Light) y llamaremos a los usuarios de dicho eclipse con el mismo nombre respectivamente. Es decir usuario "dark" y usuario "light".

Crear, inicializar y pushear una versión inicial de nuestro proyecto.

Para este caso hemos creado usando Eclipse un proyecto llamado tutorial el cual sólo cuenta con una clase HelloWorld que muestra por consola "Hello World"

Con el usuario dark

  1. Vemos la siguiente estructura en el proyecto:

project structure 2. Crear e inicializar el repositorio:

  • Hacemos clic derecho sobre el proyecto.
  • Vamos a la opción Team > Share Project...

share project 3. Seleccionamos la ubicación de nuestro proyecto para el proyecto de git y creamos un repositorio allí

  • En la ventana que se abre seleccionamos la opción Use or create repository in parent folder of project
  • Seleccionamos en la lista el proyecto y su ubicación, no nos permite tildar la casilla de verificación y vemos que dicha ubicación se completa en el cuadro de texto del fondo.

git init

  • Hacemos click en Create Repository y veremos que se tilda la casilla de verificación del proyecto.
  • Hacemos click en finish

repositorio creado

  1. Revisamos el status en git

Vemos en el Project/Package explorer que junto a los íconos del proyecto se muestra un pequeño cilindro amarillo y junto a la carpeta src, el package tutorial y el archivo HelloWorld.java se muestra un ícono de ?

Esto indica que el proyecto tiene un repositori git asociado pero existen cambios sin agregar al index de git.

git status after init

  1. Agregar los cambios en index
  • Hacemos click con el botón derecho en el proyecto.
  • Vamos a la opción Team > Add to Index

add to index

  • Vemos en el Project/Package explorer que los íconos de antes ahora cambiaron por un * blanco (significa cambios en la estructura) en el proyecto, carpeta source y package y un + verde (significa agregado) en el archivo HelloWorld.java

git status after add 6. A continuación commiteamos los cambios a git

  • Hacemos click derecho sobre el proyecto.
  • Vamos a la opción Team > Commit...

git commit

  • Aparecerá la pestaña Git Staging

En este punto podemos ver a la izquierda en la parte inferior los archivos modificados que se encuentran en el index (Staged Changes) y en la parte superior los archivos modificados que NO se han agregdos al index (Unstaged Changes). Al hacer commit sólo se incluirán los cambios que si se hayan agregado al index.

A su vez en Commit Message DEBEMOS agregar un comentario que no de una idea de que cambio se realizó.

Debajo en Author y Commiter esta información va en la configuración de Git pero puede modificarse para el commit actual o dentro de eclipse. (Véase anexos)

git commit message

  • Luego de esto podemos hacer click en Commit and Push o Commit. Nosotros sólo haremos commit para mostrar como proceder si falla el push o no se cuenta con conexión en ese momento.

  • Una vez que el presionamos Commit vemos en el Project/Package explorer.

git status after commit

  1. Pusheamos los cambios del proyecto a github.
  • Nos dirigimos a la página del repositorio, allí seleccionamos la opción para la url del repo. Usaremos https por simplicidad, si tienen configurado una key ssh puede usar la opción ssh.

  • Seleccionamos la opción HTTPS y hacemos clic en el botón a la derecha para copiar la url o la copiamos a mano. repo url

  • Hacemos click derecho sobre el proyecto.

  • Seleccionamos la opción Team > Push Branch 'master'...

    Nota: Sólo la primera vez, a continuación debemos usar Push to Upstream

primer push

  • Aparecerá una ventana para configurar el repositorio remoto.

configure origin

  • En el Remote name dejaremos origin por convención.

  • Pegamos allí la url del repo que copiamos antes, se autocompletará casi toda la información.

  • Ingresamos usuario y contraseña de github.

    Nota: si utiliza una PC compartida no almacene la contraseña en el Secure Store

  • Hacer click en Next >

  • Configuramos como branch remota para sincronizar el mismo nombre (en este caso master)

  • Seleccionamos la opción Configure upstream for push and pull.

  • Elegimos la acción default a realizar el pull como Merge

  • NO seleccionamos el Force overwrite branch in remote if it exists and has diverged para evitar perder los cambios realizados por otros.

remote config

  • Veremos entonces la confirmación del push

push confirmation

  • Veremos una ventana para confirmar el push que deseamos realizar, allí hacemos click en Finish

refresh repo url

Clonar el repositorio, realizar cambios y pushearlos.

Para este caso abrimos eclipse en un workspace diferente para simular otro usuario.

Con el usuario light

  1. Vamos a github.com, accedemos al repositorio y copiamos la url del repositorio para clonar.
  • Accedemos a la página de github del repo.
  • Hacemos click en el botón Clone or download.
  • Elegimos la opción HTTPS.
  • Copiamos el enlace.

url for clone 2. Clonamos el repositorio

  • En eclipse vamos al menu Window >

other perspectives

  • Seleccionamos la perspectiva Git

select git

  • Vemos entonces la siguiente perspectiva, allí podemos hacer click en la opción Clone a Git repository o hacerlo en la misma opcion del menú de herramientas

git perspective

  • Se abrirá la siguiente ventana
  • Pegamos la url que copiamos del repositorio donde indica URI
  • Completamos lo datos de usuario y contraseña
  • Hacemos click en Next

source repo

  • Nos mostratrá la lista de branch que deseamos clonar.
  • Dejamos seleccionada master.
  • Hacemos click en Next

branch list

  • Nos mostrará la siguiente ventana
  • IMPORTANTE: En Destination > Directory reemplazamos la ubicación propuesta por el directorio donde se creará el proyecto, es decir la ubicación del workspace que utilizamos en eclipse (en este ejemplo /home/adrian/gittuto/workspace2/) acompañado del nombre del repositorio (en este caso tutorial)
  • Seleccionamos master como la rama inicial
  • Para la definición del nombre del repositorio remoto (el que se encuentra en github) usaremos origin (por convenición)
  • IMPORTANTE: seleccionamos la opción import all existing Eclipse projects after clone finishes para asegurarnos que el proyecto se agregue al Project/Package explorer
  • Hacemos click en Finish

local destination

  • Nos aparecerá ahora el repositorio agregado a la lista de repositorios de la pestaña Git Repositories

repositories list

  • En la parte superior derecha podemos ver las distintas perspectivas, elegimos la de Java o Java EE para ver el proyecto y el código fuente

perspectives

  • Navengando en el Project/Package explorer y veremos lo siguiente source code
  1. Realizar cambios
  • Realizamos una edición en el código y vemos que mientras no guardemos los cambios git no muestra cambios en los archivos del project/package explorer ni la pestaña de git staging.

unsaved changes

  • Una vez que guardamos los cambios vemos en el project/package explorer que delante del archivo modificado y en la estructura del proyecto un signo > para mostrar ar./img/33-addToIndex.pngchivos con cambios que no se han agregado al index. También vemos en la pestaña de git staging el archivo modificado.

unstaged changes

  1. Agregar cambios al index.
  • Hacemos click derecho sobre el proyecto y elegimos la opción Team > Add to Index

add to index

  • En el project/package explorer vemos que ahora se muestra un * en los archivos modificados cuyos cambios se han agregado al index de git. A su vez en git staging vemos al archivo en la pestaña de git staging en la sección Staged Changes

staged changes

  1. Commit
  • Hacemos click derecho sobre el proyecto y seleccionamos la opción Team > Commit

pre commit changes

  • Si aún no tenemos abierta la ventana de git staging se abrirá. Allí ingresamos un mensaje de commit y presionamos commit

commit changes

  • Veremos entonces en el project/package explorer el archivo y la estructura pasan a tener nuevamente un cilindro amarillo junto al ícono y junto al proyecto vemos una flecha en dirección ascendente con un 1 a la derecha. Esto indica que localmente hemos hecho un commit que no hemos pusheado aún.

pending push

  1. Pull

Nota: no es necesario realizar un pull antes de push, pero en caso que haya cambios en el repositorio remoto hecho por otro compañero si no hacemos pull antes del push veremos un mensaje de error y deberemos hacer pull antes del push.

  • Para hacer pull hacemos click derecho sobre el proyecto y seleccionamos la opcion Team > Pull

pull

  • Veremos la siguiente ventana de confirmación, en este caso sin cambios.

pull confirmation

  1. Push
  • Para realizar push hacemos click derecho sobre el proyecto y seleccionamos la opción Team > Push to upstream

push

  • Vemos la siguiente ventana de confirmación

push confirmation

Obtener cambios realizados por otro miembro del equipo.

Para este caso abrimos eclipse en el workspace original para simular nuestro primer usuario.

Con el usuario dark

  1. Pull
  • Abrimos el proyecto original y vemos el código sin modificar.

old working tree

  • Hacemos click derecho sobre el proyecto y seleccionamos la opción Team > Pull

pull

  • Vemos la siguiente ventana de confirmación con los cambios recibidos sin conflicto pull confirmation

  • Vemos el nuevo código fuente after pull

Anexo

Configurar usuario y mail para push

  1. Hacemos click en el menú Window > Preferences si se abrirá la ventana de preferencias
  2. Completamos en la búsqueda "git"
  3. En la opción Configuration ingresamos el valor que deseemos en user email y name egit config
  4. Presionamos Apply and Close