GitHub

LCOGT/lcogtsnpipe

Supernova

<user>/lcogtsnpipe

Supernova

/supernova/git/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Developing a New Feature

  • If repository does not exist:
    • git clone git@github.com:LCOGT/lcogtsnpipe.git
  • cd to lcogtsnpipe directory

"origin"

clone

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Access your local copy

  • If repository does not exist:
    • git clone git@github.com:LCOGT/lcogtsnpipe.git
  • cd to lcogtsnpipe directory
  • Check that you are on the master* branch
    • ​​git branch
  • Check that when you say "origin" your repository points to LCOGT/lcosnpipe on GitHub
    • ​git remote -v

 

 

 

 

 

 

* More recent repositories have changed the default branch from master to main

"origin"

master

master

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Make a Clean Start

  • If repository does not exist:
    • git clone git@github.com:LCOGT/lcogtsnpipe.git
  • cd to lcogtsnpipe directory
  • Check that you are on the master* branch
    • ​​git branch
  • Check that when you say "origin" your repository points to LCOGT/lcosnpipe on GitHub
    • ​git remote -v
  • Make sure your master branch is up to date with LCOGT/lcosnpipe on GitHub
    • ​​git pull origin master
    • fetch the master branch from origin
    • merge the master branch from origin into your current branch (which we checked was master)

* More recent repositories have changed the default branch from master to main

"origin"

master

master

origin/master

fetch
merge

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Branching

  • Create a copy of the master branch
    • ​git branch new_feature
    • copies all files that have been committed at least once
  • Check that the new branch was created:
    • ​git branch
  • Switch to new branch
    • ​git checkout new_feature
  • Check you are on the new_feature branch
    • ​git branch

master

new_features

c1m

c2m

c3m

c3m=c1nf

merge

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Developing Your New Feature

  • Modify code on new_feature branch
  • Save changes incrementally to new_feature branch
    • check you are on the new_feature branch
      • git branch
    • Save changes:
      • git add <modified_filename>
      • git commit -m "commit message"

master

new_features

c1m

c2m

c3m

c3m=c1nf

c2nf

c3nf

add
commmit

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Updating Your Branch

  • Update your branch with the latest master branch
    • git checkout master
    • git pull origin master
    • git checkout new_feature
    • git merge master
    • Merge and pull always merge into your current branch

master

new_features

c1m

c2m

c3m

c3m=c1nf

c2nf

c3nf

c4m=c8gh+c3m

c8gh

git pull

c4nf=c4m+c3nf

merge

master

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Testing your code

  • Test your new code as it will run on production
  • create a new conda test env
  • switch to new test env
  • delete the build directory in lcogtsnpipe
  • run python setup.py install
  • you new have the new pipeline running in your test env

master

new_features

c1m

c2m

c3m

c3m=c1nf

c2nf

c3nf

c4m=c8gh+c3m

c8gh

git pull

c4nf=c4m+c3nf

merge

master

GitHub

LCOGT/lcogtsnpipe

Your Workstation

<user>/lcogtsnpipe

Push your code to GitHub

  • Push your branch (new_feature) to create a new branch on GitHub that is an identical copy
    • git push -u origin new_feature

master

new_features

c1m

c2m

c3m

c3m=c1nf

c2nf

c3nf

c4m=c8gh+c3m

c8gh

git pull

c4nf=c4m+c3nf

merge

master

GitHub

LCOGT/lcogtsnpipe

Creating a Pull Request

On GitHub:

  • Compare and Pull Request: 
  • Check changes:
    • look at commits
    • look at files changed
    • check actual changes
    • check branches:
    • LCOGT/lcogtsnpipe/new_features into LCOGT/lcogtsnpipe/master
  • Create Pull Request 

c8gh

master

new_feature

c4nf

Let's try it

 

Testing a PR

PR from LCOGT/lcosnpipe

  • git fetch origin
  • git checkout BRANCH_NAME
  • create test conda env
  • python setup.py install
  • test

GitHub

LCOGT/

lcosnpipe

Megan

LCOGT/

lcosnpipe

Supernova

user/

lcosnpipe

make branch

change code

push to GitHub (create remote branch)

1.

fetch remote branch

checkout remote branch

install

test

Open PR

merge PR

2.

3.

4.

PR from fork with diff branch name

  • git fetch origin pull/ID/head:BRANCH_NAME
  • git checkout BRANCH_NAME
  • create test conda env
  • python setup.py install
  • test

GitHub

LCOGT/

lcosnpipe

Megan

drmegan/

lcosnpipe

Supernova

LCOGT/

lcosnpipe

make branch

change code

push to GitHub (create remote branch)

1.

fetch remote branch

checkout remote branch

install

test

Open PR

merge PR

2.

3.

4.

GitHub

drmegan/

lcosnpipe

* this has the advantage of not having to add a remote

PR from fork w/ diff branch name

  • git remote add ALIAS THEIR_REPO_URL
  • git fetch ALIAS
  • git checkout PR_BRANCH
  • create test conda env
  • ...

GitHub

LCOGT/

lcosnpipe

Megan

drmegan/

lcosnpipe

Supernova

LCOGT/

lcosnpipe

make branch

change code

push to GitHub (create remote branch)

1.

fetch remote branch

checkout remote branch

install

test

Open PR

merge PR

2.

3.

4.

GitHub

drmegan/

lcosnpipe

* this has the advantage of being able to incorporate changes

PR from fork w/ same branch name

  • git remote add ALIAS THEIR_REPO_URL
  • git fetch ALIAS
  • git checkout -b LOCAL_BRANCH ALIAS/PR_BRANCH
  • create test conda env
  • ...

GitHub

LCOGT/

lcosnpipe

Megan

drmegan/

lcosnpipe

Supernova

LCOGT/

lcosnpipe

make branch

change code

push to GitHub (create remote branch)

1.

fetch remote branch

checkout remote branch

install

test

Open PR

merge PR

2.

3.

4.

GitHub

drmegan/

lcosnpipe

LCO-training

By abostroem

LCO-training

  • 160