Skip to content

Commit

Permalink
Merge branch 'main' into git_introduction
Browse files Browse the repository at this point in the history
  • Loading branch information
mahesh-panchal authored Apr 17, 2024
2 parents d66a743 + 1595f23 commit 7791338
Show file tree
Hide file tree
Showing 6 changed files with 140 additions and 11 deletions.
5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
# Training-Tech-shorts

Short lessons, training various technologies useful to our work.

Lessons located at https://nbisweden.github.io/Training-Tech-shorts/.
Lessons are located at https://nbisweden.github.io/Training-Tech-shorts/.

The schedule is the [schedule page](https://nbisweden.github.io/Training-Tech-shorts/schedule.html).

## Background

Expand Down
2 changes: 1 addition & 1 deletion _quarto.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ book:
search: true
chapters:
- index.qmd
- intro.qmd
- schedule.qmd
- part: "Git"
chapters:
- git/git_intro.qmd
Expand Down
74 changes: 74 additions & 0 deletions github/gh-collaboration.qmd
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
# How to collaborate on Github

This section is a guide describing one method of collaborating on Github. We focus on
the framework that we use to make reference material for future us and others new to the team.

## Making a branch (Teacher)

- On the main page of the repository go to the file tree view on the left and click on the branch dropdown menu.
- Click on view all branches
- Click New branch, give it a name and select the branch source.
- Finally, click create branch

You also have the possibility to directly make a branch by clicking on the drop-down menu and give a unique name in the "Find or create branch..." field, followed by clicking Create branch.
This will give the exact same result as the steps above.

This short description might be confusing since there are more than one way of doing this.
A step-by-step guide with pictures is available here (https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/creating-and-deleting-branches-within-your-repository)

## Making changes (Learner)

- Fork the whole target repository to your own account, by selecting "Fork" -> include all the branches (i.e., untick "Copy the main branch only") -> "Create fork".
- On your fork, first go into the correct branch for making edits by clicking the branch drop down menu and selecting it.
- To edit a file that already exists, navigate to it then click the pencil symbol to go into edit mode.
- If instead you need to make a new file in the branch, click the "Add file" drop down -> "create new file". Give the file a meaningful name and extension. When naming files you can make new directories by adding forward slashes in the title, e.g., "github/myfile.qmd" will create the folder github also.
- Add the file contents in edit mode.
- When finished, click "Commit changes..."

## Making a draft pull request (Learner)

After making and committing changes as described above, navigate to
the Pull requests tab. Click "New pull request" which will produce a
"Comparing changes" page with four drop-down lists. The leftmost two
drop-down lists refer to the target repository of the pull request and
should be set to NBISweden/Training-Tech-shorts, followed by the
target branch. The two rightmost drop-down lists refer to the pull
request source and should point to your repository and, importantly,
the branch that you are editing (and make sure it matches the target
branch!). By default, only the branches of the target repository are
shown. To find the updated branch from the forked repository, one has
to click on "If you need to, you can also compare across forks.". Once
done, change the green drop-down button "Create pull request" to
"Create draft pull request". This will generate a draft pull request
page where your review partner can make comments on your PR.

## Code review (Review partner)

- navigate to the top menu and click on `Pull requests`
- by default all open pull requests are listed, you can further filter down the list. e.g. via clicking on `Reviews` and afterwards select `Awaiting review from you` in the drop down menu. This shows then only PRs where you are tagged as reviewer.
- click on a pull request of your choice
- the following window has 4 tabs:
* Conversation: gives an overview about the PR
* Commits: list all commits of the PR
* Check:
* Files changed: lists all files which were modified
- click on the `Files changed` tab and go through the files and changes
* you can comment on a line by hovering over a line and click on the plus symbol
* in case you want to comment on a block of lines: click and hold at the line number of the start of the block and release at the end of the block. Now you need to click on the plus symbol of the last line, in order to comment on the full block of lines
* afterwards you can either:
a) click on the `Add single comment` button which makes your comment or suggestion immediately visible
OR
b) click on the `Start a review` button, which keeps your comment or suggestion in a pending state (invisible to anybody). This gives you the chance to add further comments and suggestions.
* when done with the full review click on the `Finish your review` button on the top right corner of the page:
- you can comment on your review and choose one of the following options `Comment`, `Approve`, `Request changes`. Select the approprate option and click on `Submit review`.

## Making a ready for review pull request (Learner)

- Once you and your review partner have agreed on the code review (i.e. Your review partner has approved your draft pull request), covert your draft pull request to ready to review.
- On the right side panel, you should invite the teacher to review your pull request.
- The teacher will go through the changes that you made on the original file and suggest changes through code review as your review partner did.

## Merges pull requests (Teacher)

- Once both teacher and learner are satisfied with the updates, the teacher merges the learner's pull request into their lesson branch.
- Once the teacher has updated their lesson branch with the input from all learners, the teacher merges the lesson branch into the main branch, after fixing any consistency or potential rendering issues.
49 changes: 45 additions & 4 deletions index.qmd
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,53 @@ This is a series of short lessons in various technologies useful to our work.

The first step is to read over the lesson Github Collaboration.

### Summary

1. Make a branch for your lesson.
2. Create a Quarto markdown document with `## Objectives` and `## Key points` and add it to that branch.
3. Add the document to the `_quarto.yml`.
4. Teach your topic to your team for 30-45 mins.
5. Each learner selects a key point to contribute material on. Make an issue for that topic and assign
4. Teach your topic to your team for 30-45 mins. Please remember to record the lesson.
5. Each learner selects a key point to contribute material on. Use the lesson issue for that topic to assign
yourself and another learner to review your contribution.
6. Make a draft pull request to the lesson branch and ask the other learner assigned to review. Make changes until you're both happy.
6. Make a draft pull request to the lesson branch and ask the other learner assigned to review. Make changes until you're both happy.
7. Mark the pull request as ready, and request the instructor to review.
8. The instructor reviews and merges the lesson branch when all contributions have been received.
8. When the instructor is happy with the changes they should merge the learners
contribution back into their lesson branch.
9. The instructor reviews and merges the lesson branch when all contributions
have been received. It is the responsibility of the teacher to make sure
contributions have been received after two weeks.

### Review lessons

Each lesson should be followed up by a review lesson the following week.
Here, the teacher should review and discuss points that they notice
learners had difficulty with.

### Sequence diagram

```{mermaid}
sequenceDiagram
box transparent Learners
actor Learner1
actor Learner2
end
actor Teacher
Teacher ->> GitHub: New branch for lesson
Teacher ->> GitHub: New lesson file
Teacher ->> GitHub: Add key points
Teacher ->> Learner1: Demonstrates tool
Learner1 ->> Teacher: Volunteers to write up keypoint 2
Learner2 ->> Teacher: Volunteers to write up keypoint 1
Learner1 ->> GitHub: Make branch from lesson branch
Learner1 ->> GitHub: Add notes for keypoint 2
Learner2 ->> GitHub: Add notes for keypoint 1
Learner1 ->> GitHub: Request Learner2 to review text
Learner2 ->> GitHub: Request Learner1 to review text
Learner1 ->> GitHub: Provide code review
Learner1 ->> GitHub: Update notes from review
Learner1 ->> Teacher: Request code review
Learner1 ->> GitHub: Update notes
Teacher ->> GitHub: Merges notes into lesson branch
Teacher ->> GitHub: Merges lesson branch into main
GitHub ->> GitHub: Automated website build
```
5 changes: 0 additions & 5 deletions intro.qmd

This file was deleted.

16 changes: 16 additions & 0 deletions schedule.qmd
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# Schedule {.unnumbered}

Dates for each lesson, listed in reverse chronological order.
Meetings are over Zoom, Tuesdays at 13.00. Meeting links are
provided by the teacher.

- 24/05/14: Tomas - Review: Quarto to Confluence.
- 24/05/07: Tomas - Quarto to Confluence.
- 24/04/30: No lesson - Reduced working day.
- 24/04/23: Per - Review: Quarto Introduction.
- 24/04/16: Per - Quarto Introduction.
- 24/04/09: No lesson - NBIS retreat.
- 24/04/02: Mahesh - Review: Introduction to Git.
- 24/03/26: Mahesh - Review: Collaboration in Github.
- 24/03/19: Mahesh - Introduction to Git.
- 24/03/12: Mahesh - Collaboration in Github.

0 comments on commit 7791338

Please sign in to comment.