2015년 1월 20일 화요일
비대면 코드리뷰를 위한 review board 활용 방안
1. 개요
리뷰보드에 대한 일반적인 설명과 간략한 사용법을 정리하여 프로젝트나 프로덕트 개발시의 비대면 코드리뷰를 돕고자 정리 하였습니다.
2. Review Board
Review Board 는 web 환경을 이용한 code review 툴 로서 다양한 Repository를 지원하는 툴입니다. 소스 관리에 가장 많이 사용되는 SVN(subversion)도 지원이 됩니다. 코드 리뷰가 무엇인지 그리고 리뷰보드가 어떤 것인지는 하기의 링크를 참조 하시기 바랍니다.
- Code Review 관련 참조
- Review Board 홈페이지
2.1 Review Board 를 사용한 Code Review Cycle
- Review Request 생성
- Reviewer 지정 및 Publish
- Reviewer는 해당 Request에 대한 Review 진행
- Review 및 Comment 전달
- Submiter는 Review 및 Comment 를 참조하여 수정사항 반영 및 Request를 업데이트
- Reviewer는 필요한 경우 추가 Comment를 하고 없는 경우 ship it
- Submiter는 ship it counter가 충분한 경우 Submit을 하여 해당 Code(Document)에 대한 Review 종료
3. Review Board의 사용법
관리자 모드로 설정된 사용자를 기준으로 하여 설명 하겠습니다. 이하 설명의 편의성을 위하여 존대말과 반말들이 혼용 될수 있으니 양해 부탁드립니다.
3.1 등록
- Username : 사용자의 이름 (로그인 시 사용)
- Password : 사용자의 암호 (로그인 시 사용)
- E-mail address : 리뷰에 대한 notify를 전달 받는데 사용되는 이메일
- First name , Last name : 사용자의 이름
- My Dashboard : 현재 보이는 초기 화면으로 필요한 로그인한 사용자와 관련된 리뷰 정보들을 모아서 보여준다.
- New Review Request : 나에게 새로 할당된 리뷰를 모아서 보여준다.
- All Review Request : 리뷰 보드에 등록되고 진행 중 혹은 진행 완료된 리뷰들을 보거나 검색 할 수 있다.
- Group : 리뷰 그룹의 정보를 볼 수 있다.
- Submitters : 현재 Review Board를 사용하는 사용자의 정보를 모아서 볼 수 있다.
- My account : 로그인한 계정의 정보확인 및 수정
- Admin : 관리자 메뉴로 접근 ( 관리자 권한이 존재하는 경우 보임)
- Log out : 일반적인 로그아웃
- Support : 리뷰 보드의 홈페이지로 연결되어 공식 문서 확인 및 지원을 요청 할 수 있음
- Starred Reviews : 즐겨찾기한 리뷰 목록 보기
- Outgoing Reviews : 내가 생성하여 다른 리뷰어에게 할당한 리뷰 목록 보기
- Incomming Reviews : 나에게 리뷰를 요청한 목록, 그룹으로 할당 되거나, 직접 나에게 할당 된(To Me) 목록
- All My Requests : Outgoing + Incomming Review
3.3 리뷰 요청 작성
- Repository : 리뷰 대상 코드가 저장된 Repository를 선택한다. Repository는 Admin에서 설정 가능 하다.
- Base Directory : 리뷰 대상 코드가 있는 SVN에서의 절대 경로 해당 소스가 있는 local directory로 이동 후
> svn info
위의 command를 통하여 정보 확인 Repository Root를 제외한 나머지 경로가 Base
Directory이다.
ex) /SRC/Client/trunk/myproject/src/com/pointi/testprj
Directory이다.
ex) /SRC/Client/trunk/myproject/src/com/pointi/testprj
- Diff : Diff 생성 방법은 다음과 같다.
svn diff [대상파일명] 을 사용하면 해당 파일과 SVN의 HEAD버전과의 차이점을
화면에 보여 준다. 해당 내용을 복사하여 저장하거나
> svn diff [대상파일명] > current_version.diff
위와 같이 io redirection을 사용하여 파일로 기록 한다.
SVN diff 관련한 상세설명은 다음의 링크를 참조
- http://jujubong.tistory.com/113 의 6) svn diff가 좀 직관적으로 알 수 있게 정리 되어 있다.
- Create Review Request : 신규 Code 리뷰를 생성한다.
- Publish : 해당 리뷰를 공개 한다. Publish를 하기 전까지는 Reviewer들에게 리뷰가 할당되지 않는다. 즉 해당 리뷰는 작성 중(Draft) 상태로 남게 된다.
- Discard Review Request : 작성 중인 리뷰를 버린다.
- Summary : 해당 리뷰의 제목을 입력한다. Issue Tracker를 통하여 할당된 업무를 통한 작업인 경우 이슈 트랙커의 link 또는 번호를 적는 것도 좋을 것 같다.
- Reviewers : 해당 Code를 실제로 리뷰 할 리뷰어를 지정한다.
- Group : 미리 생성된 그룹에 할당한다.
- People : 특정인을 지정하여 할당한다. 복수도 가능하다.
(통상적으로 2~4명이 적당하다 되도록이면 4명을 넘지 않도록 한다.)
- Description : 해당 코드의 상세내역을 기재 한다. 리뷰의 목적은 코드의 결함 발견도 있겠지만 코드의 공유의 목적도 있기 때문에 대한 Description 에 리뷰 대상 코드에 대한 상세한 설명을 기재 하는 것이 좋다. 그렇지 않으면 리뷰 하는 사람도 좋은 리뷰를 진행 할 수 없기 때문에 아니면 Code내에 Comment를 잘 활용하는 것도 방법 중 하나일 듯 하다. 목적은 수정한 코드에 대하여 정확하게 설명하는 것이다.
3.3 Code Review 진행
- Close : 해당 리뷰를 종료 하기 위한 메뉴 제공 (Submmiter에게 제공된다. 관리자 권한이기 때문에 노출됨)
- Submmited : 해당 리뷰가 완료됨
- Discarded : 해당 리뷰를 버림 (버린 이력 및 버린 시점 까지의 리뷰는 이력으로 남아서 확인 가능하다.)
- Delete Permanetly : 해당 리뷰를 완전 삭제 함
- Update : 리뷰의 대상인 코드 및 소스 파일을 추가하여 리뷰 대상을 수정함
- Update diff : 리뷰를 기준으로 소스를 다시 수정 후 해당 소스의 diff를 다시 업데이트하여 리뷰어에게 전달함
- Add file : 리뷰에 필요한 파일을 추가함
- Download diff : 업로드된 diff파일을 내려받음
- Review : 해당 리뷰의 전체 의견을 생성 할 수 있는 화면을 제공함
- Ship it : 체크하는 경우 Publish Review 할 때에 자동으로 Ship it! 설정
- Publish Review : 작성한 리뷰 내용을 공개 한다.
- Discard Review : 작성한 리뷰 내용을 버린다.
- Cancel : 이전 화면으로 돌아가기
- Save : 작성 내용을 임시 저장 한다. Submmiter 및 다른 사람들에게 공개 되지 않는다.
- Ship it! : 리뷰어가 더 이상 수정이 필요 없는 경우 Ship it을 통하여 통과 함. (Submmiter는 특정 수 이상의 ship it! 이 발생한 경우 해당 코드를 적용하는 것이 좋을 것 같다. )
- View Diff: 코드의 수정된 부분에 대하여 Display 하며 코드에 line by line으로 Comment를 생성할 수 있음 생성된 Comment를 참조하여 Submmiter는 코드 및 로직을 수정하거나 해당 comment에 reply 함으로서 Reviewer에게 코드의 목적을 설명한다. 수정된 내용을 화명에 보여 준다. 초록은 추가 된 부분 붉은 색은 삭제된 부분. 라인(숫자가 존재하는 부분) 을 클릭하거나 Drag하면 해당 부분에 Comment를 추가 할 수 있고 해당 Comment는 Review의 (Open an issue 체크 시)Issue로 관리 할 수 있다. Issue 로 생성된 Comment는 Submmiter 에 위와 같이 보여지며 수정을 하거나 Drop을 선택 할 수 있다. 해당 선택을 하기 이전에 add comment는 해당 comment 에 대하여 Submmiter가 설명을 추가 할 경우 사용한다.
Reviewer가 리뷰를 완료 하고 Ship it! 클릭하는 경우 해당 Count가 증가한다.
ship it!이 일정 수 이상 된다면 해당 reviewed를 closed->submmit을 통하여 리뷰를 종료 하도록 한다. 해당 활동은 강제가 아니므로 submmited의 시점은 각 Submmiter가 판단한다.
3.4 Admin
우측 상단의 Admin을 통하여 관리자 화면을 접근 하는 경우 아래와 같은 화면을 볼수 있다.
다른 부분은 특별히 설정에 대하여 설명할 부분이나 사용할 부분이 없어서
- Name: 사용자에게 보여질 이름
- Hosting service : 외부의 알려진 호스팅을 사용하는 경우 선택
- Repository type : SCM 의 종류를 선택한다. 개발 3팀의 경우 SVN을 사용하므로 “subversion”을 선택 해야 함
- Path : 해당 Repository의 경로
- Username, Password 해당 Repository를 access 할 수 있는 계정 정보
위의 정보들을 입력 후 Save 버튼을 선택하면 Repository가 생성되며 이후 해당 Repository에서 수정된 Code에 대한 리뷰를 진행 할 수 있다.
5. 맺음 - 작성후기(?)
Code review를 같이 모여서 하기 보다 하루에 조금씩의 시간을 들여서 하는 편이 효율 적일 것 같아서 on-line 툴을 선택 하였습니다.
강제로 시켜서 하기 보다 자신의 코드에 대한 안전장치(?)라고 생각하여 자발적으로 적극 적으로 활용하면 좋을 것 같습니다.
Reviewer는 가급적이면 24시간 내에 리뷰를 한다. 등의 내부적인 룰이 있으면 더욱 원활히 운영 될 수 있을것 같습니다.
Submmiter는 리뷰 요청 시 상세히 “어떤 부분을 봐주었으면 한다.” 라고 상세히 요청 하면 좋을 것 같습니다.
위와 같이 하기 위하여서는 작은 단위로 리뷰를 생성하는 것이 좀더 원활히 운영 될것 같습니다.
코드의 모두 상세히 보기는 Reviewer에게 너무나 부담이 되는 부분 입니다. 물론 동작에 대한 검증을 위하여서는 전체를 볼 수 밖에 없겠지만 설명을 좀 잘 한다면 쉽게 볼 수 있을 것 같습니다.
코드리뷰는 결함이나 문제점만을 찾는 행위가 아닙니다. 해당 코드를 읽고 공유하며 좀 더 간결하고 좋은 코드를 작성하기 위한 절차 입니다.
다시한번 이글의 작성의 계기가 된 아래의 슬라이드를 꼭 한번 읽어 보시길 바라며 본 글이 코드리뷰를 도입함에 도움이 되었길 바랍니다.
추가로 오류사항이나 수정해야 할사항은 jaewon@pointi.com 으로 전달해주세요
2015년 1월 16일 금요일
Bluetooth Spec
Bluetooth Spec
Bluetooth 4.0 Dual-mode
HS 고속 통신
- 블루투스망을 따라서 전송하는것이 아닌 블루투스로 데이터를 전송할 기기를 확인한후 더 빠른 속도의 802.11(와이파이 AMP)로 대신 접속해서 데이터를 전송하는것
Unicast connectionless data
- L2CAP 채널대신에 소량의 데이터 전송 가능케하여 사용자의 동작과 재접속/데이터
전송 사이 틈틈이 보낼수 있다
부호화 일시 중지/재개(Encryption
Pause Resume)
- 암호를 다시 설정했을 경우, 장치 간에 더욱 강력한 암호화로
최소 23.3시간 이상의 연결을 유지
Bluetooth 4.0 Single-mode
- 심장 박동 검사기 같은 주변 기기 (ble 전용)
Bluetooth 4.0 Dual-mode
- 스마트 단말기 이용
Enhanced Power control
- 초과 송신된 전력의 통제는 물론 통신 상태의 안정성을 개선시키며 더욱 효율적인 전력 소비를 지원
RSSI
- 주변 노드가 전달한 데이터의 전파 세기를 측정한 값을 의미 (수신감도)
AFH(Adaptive Frequency Hopping)
- 채널상태를 파악한 후, 새로운 직교코드에 의해서 간섭신호가 없는
채널로 호핑을 하는 방식 (간섭 최소화)
2015년 1월 15일 목요일
Base64란?
Base64
Base64 인코딩은 8비트 이진 데이터(예를 들어 실행 파일이나, ZIP 파일 등)를 문자 코드에 영향을 받지 않는 공통 ASCII 영역의 문자들로만 이루어진 일련의 문자열로 바꾸는 인코딩 방식을 가리키는 개념이다.
Base64를 글자 그대로 번역하여 보면 64진법이란 뜻이다. 64가 2의 제곱수(64 = 2^6^)이며, 2의 제곱수들에기반한 진법들 중에서 화면에 표시되는 ASCII 문자들을 써서 표현할 수 있는 가장 큰 진법이기 때문이다.
즉, 다음 제곱수인 128진법에는 128개의 기호가 필요한데 화면에 표시되는 ASCII 문자들은 128개가 되지 않는다. 그런 까닭에 이 인코딩은 전자 메일을 통한 이진 데이터 전송 등에 많이 쓰이고 있다.
일반적으로 Base64는 바이너리 데이터를 문자열로 변환 해 준다고 생각하면 된다. 변환 되는 문자열을 다음과 같이 64개의 문자로 이루어진다. "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" 위에서 볼 수 있듯이 64개의 문자는 A~9까지 일반적인 알파벳 대소문자와 숫자 그리고 "+" 와 "/" 두가지의 기호로 이루어진다.
Base64 인코딩 과정
1. 바이너리 데이터는 아래와 같이 8bit씩 나누어져 있다
- 00110011 | 01110010 | 01101011 | 00001010
(왜 6bit인가? 이유는 64개의 문자이기때문에 2^6^으로 표현할 수 있기때문이다)
- 001100 | 110111 | 001001 | 101011 | 000010 | 10
(정답은 남은부분을 "0"으로 채워주는 것이다)
- 001100 | 110111 | 001001 | 101011 | 000010 | 10 0000
- 위와같이 "0"으로 채워주는 경우가 있을때에는 남는 bit에 따라서 패딩문자 "=" 한개 또는 "==" 두개를 붙여준다. (2bit가 남으면 "=" , 4bit가 남으면 "==")
4. 6bit로 나눠진 비트들을 각각 정수로 변환해 위의 64개의 문자(첫번째부터 차례대로 0 ~ 63)에 맞춰 문자를
만들어준다.
Example
"Pointi"라는 글자를 Base64 인코딩을 해보자.
1. 먼저 각각의 문자를 2진수(8bit)로 변환한다.
2. 만들어진 2진수 값들은 아래와 같다.
01010000 | 01101111 | 01101001 | 01101110 | 01110100 | 01101001
3. 이것들은 6bit로 나눠준다.
010100 | 000110 | 111101 | 101001 | 011011 | 100111 | 010001 | 101001
4. 나눠진 6bit로 이루어진 2진수는 아래와 같이 정수로 바꿔준다.
20 | 6 | 61 | 41 | 27 | 47 | 17 | 41
5. 아래의 표에 맞춰 문자를 만들어준다.
6. 결과는 UG9pbnRp 이다.
피드 구독하기:
글 (Atom)