github 에서 팀 프로젝트를 위해서 팀장이 레포지토리를 생성하고 팀원을 참여자로 추가한다. 그리고 팀원은 fork 를 통해서 클론해서 프로젝트에 참여 작업을 이어 나갈 수 있다.
data:image/s3,"s3://crabby-images/75dcc/75dcccf809d748a21f7c05e086dd4dee7d98ba77" alt=""
레포지토리 생성 (팀장)
data:image/s3,"s3://crabby-images/37325/3732532bb0b24abff8b369307ec1fdcbf03a7855" alt=""
참여자 관리 (팀장)
프로젝트 레포지토리에 팀원을 추가해 준다. 레포지토리 Settings 에서 Collaborators 페이지에서 참여자를 관리할 수 있다.
data:image/s3,"s3://crabby-images/32125/3212599c433d13deec18f2ba3e3d8258bb94bc13" alt=""
Collaborator 에 추가할 github 사용자를 검색
data:image/s3,"s3://crabby-images/c1f10/c1f109f76be6ea3184640481415d2d1f5470cf01" alt=""
Collaborators 추가 사용자 목록
data:image/s3,"s3://crabby-images/af941/af941c6da9346a29723e2534a2c31e03ed465d1a" alt=""
참여자 알림 확인
사용자는 알림에 Collaborator 에 추가되어 허용할지를 등록
data:image/s3,"s3://crabby-images/945e5/945e5460aaaf68b7c4d453d59a1b431402de118f" alt=""
요청받은 collaborator 을 받아들인다
data:image/s3,"s3://crabby-images/38fdc/38fdc2957f4a74281e5dd05afb78e2b7936ac4bf" alt=""
Fork & Pull Request, Merge
깃헙을 통해 프로젝트를 수행한다면 레포지토리 fork, pull-request, commit 을 통해서 여러 참여자/기여자의 코드를 동기화 할 수 있다.
https://www.tomasbeuzen.com/post/git-fork-branch-pull/
팀장이 공유할 레포지토리를 만든다
data:image/s3,"s3://crabby-images/37325/3732532bb0b24abff8b369307ec1fdcbf03a7855" alt=""
팀원이 프로젝트 레포지토리를 fork 한다
data:image/s3,"s3://crabby-images/f9196/f91963b44623bc684fdf34e8a7f0fc58d8462781" alt=""
fork 하는 레포지토리 정보를 입력한다
data:image/s3,"s3://crabby-images/27855/27855392401994f111953cb771dc323b24359999" alt=""
포크한 레포지토리에 새 파일을 추가한다.
팀원 레포지토리로 포크한 프로젝트 레포지토리에 새 파일을 추가한다.
github desktop으로 하는 예제는 마지막에 있다.
data:image/s3,"s3://crabby-images/5a2ad/5a2ad3d30d5443ee818cd14ef27e50b0152c0e6c" alt=""
팀원, 포크한 레포지토리에 새 파일이 추가되었다
data:image/s3,"s3://crabby-images/4645b/4645b539c1987ed22d85d9f9538fc4cba8434919" alt=""
팀원, 변경 사항을 Open Pull Request 한다
data:image/s3,"s3://crabby-images/a65c1/a65c148ad088ffb9047ad7990ca5d2a34f6133fb" alt=""
팀원, Pull Request 내용을 적는다
data:image/s3,"s3://crabby-images/b9c24/b9c24d4326a9afbbe985ade37dc92949e5fddf46" alt=""
팀원, 변경 사항을 Open Pull Request 한다
data:image/s3,"s3://crabby-images/33788/33788f54cc9fd17af2e5e4ae214a0f4a445a89be" alt=""
팀장, Pull Request 를 확인한다.
data:image/s3,"s3://crabby-images/bf8da/bf8da398a334d2f52ddec61e462c74ca04bc4ece" alt=""
팀장, Pull Request 를 확인한다.
data:image/s3,"s3://crabby-images/ac707/ac707546b56d9b4fa83791e2272c4b845ab4d4ec" alt=""
팀장, Merge 한다.
data:image/s3,"s3://crabby-images/de8e4/de8e4c4fc6b75d073a49c7b32d548bbf750e42d6" alt=""
data:image/s3,"s3://crabby-images/7832c/7832c86720bb972ba47114f2117a6bce486bf9ba" alt=""
프로젝트 레포지토리에 팀원이 추가한 파일이 추가 되었다.
data:image/s3,"s3://crabby-images/d2914/d2914e6b2c19249163305a46710457fc5d9d0ded" alt=""
포크한 레포지토리를 Sync 해서 동기화를 한다.
data:image/s3,"s3://crabby-images/8d2f6/8d2f69d6745bb2a26c5fc04ad82cf2581eef9dd8" alt=""
Sync 해서 동기화로 upstream 과 commit 을 일치시킨다
data:image/s3,"s3://crabby-images/10294/102949e447c4e45e365a554b1b2342f47f4b2af6" alt=""
클라이언트에서 fork 레포지토리 작업
팀 레포지토리에 참여한 사용자가 원격 레포지토리를 클론해서 로컬에서 작업을 할 수 있다. 작업한 결과는 Push를 통해서 원격레포지토리에 동기화를 한다.
fork한 레포지토리를 로컬에 클론한다
Github desktop을 이용해서 레포지토리를 선택해서 클론을 수행한다.
data:image/s3,"s3://crabby-images/50c4b/50c4bef7030cc9071f204182daefaebfcf444e5d" alt=""
클론 레포지토리를 저장할 위치를 정한다.
data:image/s3,"s3://crabby-images/4b3dc/4b3dcf23c75607e1d1886a953ddbcdbafc29d221" alt=""
Git desktop은 직접 Upstream에 pull request 를 할 수 있도록 지원하고 있지만 여기서는 Push 를 사용하겠다.
data:image/s3,"s3://crabby-images/56d1d/56d1d52eab4270fbc4356297cdc5f5659fc490a2" alt=""
클론한 로컬 레포지토리에서 새파일 작업을 한다
data:image/s3,"s3://crabby-images/e3b1e/e3b1ebea26f96dcbe776801303a623c102ac0276" alt=""
레포지토리에 변경 사항을 커밋을 한다.
data:image/s3,"s3://crabby-images/ac00f/ac00f848b951b5e3864cdaf152a96340c8949781" alt=""
로컬의 커밋 변경을 PUSH 한다
data:image/s3,"s3://crabby-images/86e53/86e531a5722015fcd1630d664e826e361158f09d" alt=""
github upstream에 pull request 한다
data:image/s3,"s3://crabby-images/ed93d/ed93ddc3fd38b44b2662c143471104d8a7b737eb" alt=""