Github auto-assign: Pull Request 시 특정 assigner 지정
깃에 PR(Pull Request)할 때 자동으로 검토자를(assigner) 설정할 수 있는 방법을 다루어보겠습니다. 자주 커밋을 하는 경우 또는 동일한 사람이 PR 승인자로 있는 경우 유용하게 사용할 수 있는 기능입니다. 참고로 깃허브 자체적으로 설정하는 것과는 다릅니다. 깃허브에서는 브랜치 오너가 들어가게는 설정할 수 있지만 특정 사람을 계속 지정할 수 있는 설정은 없습니다.
auto assign 지정 순서는 아래와 같습니다.
1. auto-assign 플러그인 설치
2. .github/auto_assign.yml 파일 추가 + 작성
3. 주의사항!!
01 auto-assign 플러그인 설치
아래 링크로 접속하여 플러그인 설치를 누르면 간단하게 설치된다.
https://github.com/apps/auto-assign
설치되면 해당 파일에 대한 권한도 부여된다.
02 .github/auto_assign.yml 파일 추가
해당 기능을 사용할 레파지토리를 선택한 뒤 새로운 파일 생성
'레파지토리'/.github/auto_assign.yml
만약 다른 경로에 파일을 생성하면 실행되지 않는다.
이때는 따로 해당 파일을 실행시켜줄 수 있는 파일을 추가하여 경로를 지정해줘야 한다.
파일 내용은 아래와 같이 입력한다.
# Set to true to add reviewers to pull requests
addReviewers: true
# Set to true to add assignees to pull requests
addAssignees: true
# A list of reviewers to be added to pull requests (GitHub user name)
reviewers:
- reviewerA
- reviewerB
- reviewerC
# A list of keywords to be skipped the process that add reviewers if pull requests include it
skipKeywords:
- wip
# A number of reviewers added to the pull request
# Set 0 to add all the reviewers (default: 0)
numberOfReviewers: 0
예상할 수 있듯이 reviewer에 리뷰어의 깃 아이디를 기재하면 된다.
해당 기능을 사용하는 이유는 깃허브 자체에서도 assigner를 지정할 수 있지만,
그렇게 하면 소스 작성자가 자동으로 들어가기 때문에 특정인을 지정할 수 없다.
결국 플러그인으로 해당 기능을 구현해줘야 한다.
만약 assigner를 그룹 형태로 관리하고 싶다면 아래와 같이 구성할 수도 있다.
# Set to true to add reviewers to pull requests (required)
addReviewers: true
# Set to true to add assignees to pull requests
addAssignees: false
# A list of reviewers to be added to pull requests (GitHub user name) (required)
reviewers:
- reviewerA
- reviewerB
- reviewerC
# A number of reviewers added to the pull request (required)
# Set 0 to add all the reviewers (default: 0)
numberOfReviewers: 0
# A list of assignees, overrides reviewers if set
# assignees:
# - assigneeA
# A number of assignees to add to the pull request
# Set to 0 to add all of the assignees.
# Uses numberOfReviewers if unset.
# numberOfAssignees: 2
# Set to true to add reviewers from different groups to pull requests
# useReviewGroups: true
# A list of reviewers, split into different groups, to be added to pull requests (GitHub user name)
# reviewGroups:
# groupA:
# - reviewerA
# - reviewerB
# - reviewerC
# groupB:
# - reviewerD
# - reviewerE
# - reviewerF
# Set to true to add assignees from different groups to pull requests
# useAssigneeGroups: false
# A list of assignees, split into different froups, to be added to pull requests (GitHub user name)
# assigneeGroups:
# groupA:
# - assigneeA
# - assigneeB
# - assigneeC
# groupB:
# - assigneeD
# - assigneeE
# - assigneeF
# A list of keywords to be skipped the process that add reviewers if pull requests include it
# skipKeywords:
# - wip
주석에 설명이 자세히 있어서 따로 설명 드리지는 않겠습니다 :)
03 Auto Assigner 주의사항!!
주의사항입니다.
첫번째로 파일명은 반드시 위 이름으로 하셔야 인식됩니다. 만약 다른 경로에 다른 이름으로 할 경우 액션 파일을 추가해서 경로를 직접 잡아줘야 합니다.
두번째로는 깃허브에 계정 말고 사용자 명을 추가로 만들었다면 사용자 명으로 입력해야 인식됩니다. 화면 우측 상단에 프로필 아이콘을 클릭하면 확인할 수 있습니다.
마지막으로 reviewer는 Pull Request를 작성할 때는 보이지 않습니다. 작성 후 request를 올리면 그때 뜹니다. 저는 이것도 모르고 왜 PR 작성할 때 안뜨는지 이해가 안되서 시간을 무지 낭비했습니다.
그리고 auto_assigner.yml 외에도 CODEOWNER 파일을 추가해서 지정하는 방법도 있지만, 레파지토리를 관리하는 관점에서는 위에서 소개한 방식으로 하는 것이 적절해 보입니다.
그럼 모두 즐거운 개발 되세요~