1. 개요
Extreme Programming. 줄여서 XP(eXtreme Programming).1999년 켄트 벡이 발표한 프로그램 개발 방식으로, 빠르게 고객과 소통하며 개발할 수 있는 방법이다. 의사소통, 단순성, 피드백, 용기, 존중을 가치로 내세우고 있다.
2. 기본 원칙
기본 원칙은 다음과 같다.- 조금씩, 하지만 자주 발표한다.
- 사이클을 반복해서 돌리면서 개발한다.
- 스펙에 없는 것은 절대 집어넣지 않는다.
- 테스트 코드를 먼저 만든다.
- 야근은 하지 마라. 항상 정규 일과 시간에만 작업한다.
- 기회가 생기는 족족 언제 어디서든 코드를 개선한다.
- 모든 테스트를 통과하기 전에는 어떤 것도 발표하지 않는다.
- 조금씩 발표하는 것을 기반으로 하여 현실적인 작업 계획을 만든다.
- 모든 일을 단순하게 처리한다.
- 두 명씩 팀을 편성하고 모든 사람이 대부분의 코드를 알 수 있도록 돌아가면서 작업한다.
근데 말이 좋아 이런 거지, 극단적으로 보면
- 짜증나게 자주 업데이트한다.[1]
- 셔틀 돌린다.
- 말한 것만 짠다.
- 코드 짜기도 전에 테스트한다.
- 근로기준법을 준수하라!
이건 당연한 말이다. - 시도때도 없이 고친다.
- 허들 넘기
- 안 될 계획은 아예 세우지도 않는다
- 단순
- 파트너와 함께
아무튼 이러한 이유로 처음 등장했을 때 충격과 공포를 안겨주었지만 현재는 프로그래머들 사이에서 큰 인기를 얻고 있다.
3. 성공 이유
우선, 기본적으로 프로그래머는 프로그래밍을 좋아한다. 비프로그래머를 위해 설명하자면 프로그래밍도 일종의 창작 과정이기 때문에 그 결과를 얻을 때 희열을 얻는 것은 마찬가지다. 작가가 시 한편을 써 낸 후의 기쁨을 생각해보면 쉬울 듯싶다.또한 정신적으로 강도 높은 노동인 코딩을 하는 동안 다른 한 사람이 아이디어도 주고 알고리즘도 찾아 보고 하는 것 역시 효율적이다. 어떤 경우에는 한 사람이 코딩을 하는 동안 다른 사람이 코딩 과정을 평가 또는 지원해 줄 수도 있는데, 이는 따로 페어 프로그래밍(Pair Programming)이라고도 한다. 얼핏 보면 시간이 2배로 낭비되는 것 같아 보이지만, 실제로 낭비되는 시간은 의외로 적다.
의문의 '테스트 코드를 먼저 만든다.' 부분은, 먼저 출력이 어떻게 되어야 할 지 테스트 코드를 쓴 다음 그것을 만족하게 프로그램을 만든다는 것이다.[2] 테스트를 통과하면 이제 다시 테스트 코드를 개선한다. 이런 식으로 반복한다. 이 방법은 테스트 주도 개발이라는 다른 개발 방법론으로 넘어간다.
[1] 적어도 하루 1회, 심하면 3~4회의 발표를 하루 내에 하는 경우도 있다. 아예 원탁에 둘러 앉아 서로 바라보면서 끊임없이 의사소통을 하는 팀들도 있고, 어떤 팀은 앉지도 않고 아예 서서 의사소통을 하기도 한다.[2] 테스트 코딩이 어려운 경우에는 테스트 시나리오를 쓰기도 한다.