형상관리/Git & GitHub

[GitHub] 깃허브로 1인 워크플로우 만들기

jalynneyoon 2021. 7. 22. 21:13

요즘 만들어보고 싶은 앱이 있어서 새로운 프로젝트를 시작하게 되었습니다. 개인프로젝트이지만 꼼꼼하게 관리해보고 싶다는 생각이 들어 다양한 자료를 참조하여 워크플로우를 형성하였습니다. 이번 글에서는 제가 요즘 하고 있는 방식을 소개해보고자 합니다.

( 좋은 방법이 있다면 추천부탁드립니다 💛)

1. project 만들어 할일 관리하기

노션에서 표를 사용하면서 칸반보드를 사용해보신 분이 있으시다면 익숙하실 텐데요, project board를 사용하면 TodoIn progress, Done으로 구분되는 Project를 Repository 내에 만들어두면 한눈에 할 일을 정리해둘 수 있습니다.

특히 project를 생성하여 관리할 때 좋은 점은 isssue가 생성되고 이슈를 만들 때 있는 프로젝트 선택 칸에서 만들어둔 프로젝트를 선택하면 자동으로 To do에 들어온다는 것이었습니다. 또한 보드 내에서 만들어둔 카드를 이슈로 전환하는 것도 가능합니다.

2. issue 만들기

저는 이슈템플릿을 만들어두고 기능구현/버그 등의 이슈가 생길 때마다 이슈를 만들거나 열어서 사용하고 있습니다. 앞서 말한 것처럼 이슈를 만들면 project의 Todo에 자동으로 반영이 되는데 처리해야 할 이슈가 있다면 project의 In progress에 옮겨둡니다.

3. branch 나누기

main브랜치는 배포가능한 상태만 남기고, 기능 개발 시에는 최신상태를 반영한(git pull)한 develop 브랜치에서 feature/이슈번호_간략한설명이름으로 브랜치를 분기합니다.

4. Pull Request & Merge 하기

그리고 해당 feature 브랜치에서 이슈번호를 넣어가며 커밋을 하고, push를 합니다. (git push -u origin "브랜치명") 그러면 Pull Reqeust를 날릴 수 있습니다. 그러면 PR에 간단한 메시지와 해당이슈를 닫도록하는 문구(Closes #5) 를 써서 날리고, 이를 받은 develop의 관리자..는 역시 저이므로 슥 보고(approve) approve 되었으니 다시 Merge를 해줍니다. 그러면 develop브랜치에 방금 구현한 내용이 적용됩니다. 그리고 병합된 브랜치를 삭제하고, 로컬의 브랜치도 삭제해줍니다.

이렇게 하면 해당 이슈는 닫히고, project에서 Done으로 옮겨집니다.


이 같은 워크플로우에 익숙해진다면 협업을 할 때도 프로젝트를 관리하기에 용이할 것 같습니다.

도움이 되셨기를 바라면서 저는 버그를 수정하러 가보겠습니다...ㅜㅜ 그럼 이만 총총..