├── .gitignore ├── README.md ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat ├── settings.gradle └── src ├── main ├── java │ └── pairmatching │ │ └── Application.java └── resources │ ├── backend-crew.md │ └── frontend-crew.md └── test └── java └── pairmatching └── ApplicationTest.java /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | .gradle 3 | /build/ 4 | !gradle/wrapper/gradle-wrapper.jar 5 | /out/ 6 | /target/ 7 | 8 | ### STS ### 9 | .apt_generated 10 | .classpath 11 | .factorypath 12 | .project 13 | .settings 14 | .springBeans 15 | bin/ 16 | 17 | ### IntelliJ IDEA ### 18 | .idea 19 | *.iws 20 | *.iml 21 | *.ipr -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # 미션 - 페어매칭관리 애플리케이션 2 | 3 | ## 🔍 진행방식 4 | 5 | - 미션은 **기능 요구사항, 프로그래밍 요구사항, 과제 진행 요구사항** 세 가지로 구성되어 있다. 6 | - 세 개의 요구사항을 만족하기 위해 노력한다. 특히 기능을 구현하기 전에 기능 목록을 만들고, 기능 단위로 커밋 하는 방식으로 진행한다. 7 | - 기능 요구사항에 기재되지 않은 내용은 스스로 판단하여 구현한다. 8 | 9 | ## ✉️ 미션 제출 방법 10 | 11 | - 미션 구현을 완료한 후 GitHub을 통해 제출해야 한다. 12 | - GitHub을 활용한 제출 방법은 [프리코스 과제 제출 문서](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse) 를 참고해 제출한다. 13 | - GitHub에 미션을 제출한 후 [우아한테크코스 지원 플랫폼](https://apply.techcourse.co.kr) 에 접속하여 프리코스 과제를 제출한다. 14 | - 자세한 방법은 [링크](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse#제출-가이드) 를 참고한다. 15 | - **Pull Request만 보내고, 지원 플랫폼에서 과제를 제출하지 않으면 최종 제출하지 않은 것으로 처리되니 주의한다.** 16 | 17 | ## ✔️ 과제 제출 전 체크리스트 - 0점 방지 18 | 19 | - 터미널에서 `java -version`을 실행해 자바 8인지 확인한다. 또는 Eclipse, IntelliJ IDEA와 같은 IDE의 자바 8로 실행하는지 확인한다. 20 | - 터미널에서 맥 또는 리눅스 사용자의 경우 `./gradlew clean test`, 윈도우 사용자의 경우 `gradlew.bat clean test` 명령을 실행했을 때 모든 테스트가 아래와 같이 통과하는지 확인한다. 21 | 22 | ``` 23 | BUILD SUCCESSFUL in 0s 24 | ``` 25 | 26 | --- 27 | 28 | ## 🚀 기능 요구사항 29 | - 우테코의 미션은 페어 프로그래밍으로 진행된다. 30 | - 미션을 함께할 페어를 관리해주는 애플리케이션을 완성하시오. 31 | 32 | ### 도메인 설명 33 | - 우테코에서 운영하는 과정은 현재 백엔드 과정과 프론트엔드 과정이 있다. 34 | - 각 과정은 5단계로 나누어 진행이 되는데 이를 레벨이라고 한다. 35 | - 미션을 수행하며 각 레벨에서 전달하고자 하는 내용을 학습하는데 이 과정을 페어 프로그래밍으로 진행한다. 36 | - 미션을 시작하기 전 페어를 매칭하는데 다양한 페어를 만나기 위해서 같은 레벨 동안은 같은 페어를 만나지 않는다. 37 | 38 | ### 페어 매칭 기능 39 | - 페어 매칭 조건 40 | ``` 41 | - 미션을 함께 수행할 페어를 두명씩 매칭한다. 42 | - 페어 매칭 대상이 홀수인 경우 한 페어는 3인으로 구성한다. 43 | - 같은 레벨에서 이미 페어를 맺은 크루와는 다시 페어로 매칭될 수 없다. 44 | ``` 45 | 46 | - 페어 매칭 구현 방법 47 | ``` 48 | - 크루들의 이름 목록을 List 형태로 준비한다. 49 | - 크루 목록의 순서를 랜덤으로 섞는다. 이 때 `camp.nextstep.edu.missionutils.Randoms`의 shuffle 메서드를 활용해야 한다. 50 | - 랜덤으로 섞인 페어 목록에서 페어 매칭을 할 때 앞에서부터 순서대로 두명씩 페어를 맺는다. 51 | - 홀수인 경우 마지막 남은 크루는 마지막 페어에 포함시킨다. 52 | - 같은 레벨에서 이미 페어로 만난적이 있는 크루끼리 다시 페어로 매칭 된다면 크루 목록의 순서를 다시 랜덤으로 섞어서 매칭을 시도한다. 53 | - 3회 시도까지 매칭이 되지 않거나 매칭을 할 수 있는 경우의 수가 없으면 에러 메시지를 출력한다. 54 | ``` 55 | 56 | ```java 57 | > 코드 예시 58 | 59 | List crewNames; // 파일에서 로드한 크루 이름 목록 60 | List shuffledCrew = Randoms.shuffle(crewNames); // 섞인 크루 이름 목록 61 | 62 | // 페어 매칭 & 검증 63 | 64 | ... 65 | ``` 66 | 67 | - 페어 재매칭 시도 68 | ``` 69 | - 안내 문구를 출력 후 매칭을 진행한다. 70 | - 아니오를 선택할 경우 코스, 레벨, 미션을 다시 선택한다. 71 | ``` 72 | 73 | ### 페어 조회 기능 74 | - 과정, 레벨, 미션을 선택하면 해당 미션의 페어 정보를 출력한다. 75 | - 매칭 이력이 없으면 매칭 이력이 없다고 안내한다. 76 | 77 | ``` 78 | [ERROR] 매칭 이력이 없습니다. 79 | ``` 80 | --- 81 | 82 | ## 💾 사전 제공 정보 83 | - 크루 정보는 src/resources 하위에 md 파일로 제공되며 변경이 가능하다. 84 | - 과정, 레벨, 미션 정보는 아래에 제공하는 그대로 사용해야 한다. 85 | 86 | ``` 87 | ## 과정 88 | - 백엔드 89 | - 프론트엔드 90 | 91 | ## 레벨 92 | - 레벨1 93 | - 레벨2 94 | - 레벨3 95 | - 레벨4 96 | - 레벨5 97 | 98 | ## 미션 99 | ### 레벨1 100 | - 자동차경주 101 | - 로또 102 | - 숫자야구게임 103 | 104 | ### 레벨2 105 | - 장바구니 106 | - 결제 107 | - 지하철노선도 108 | 109 | ### 레벨3(없음) 110 | 111 | ### 레벨4 112 | - 성능개선 113 | - 배포 114 | 115 | ### 레벨5 (없음) 116 | ``` 117 | 118 | --- 119 | ## ✍🏻 입출력 요구사항 120 | 121 | ### 파일 입출력 122 | - 페어 매칭에 필요한 크루들의 이름을 파일 입출력을 통해 불러온다. 123 | - `src/main/resources/backend-crew.md`과 `src/main/resources/frontend-crew.md` 파일을 이용한다. 124 | - 두 파일의 내용은 수정이 가능하다. 수정 시 크루들의 이름은 중복될 수 없다. 125 | - 파일 입출력 방법은 `자바 파일 읽기`나 `자바 파일 입출력`과 같은 키워드로 구글링해서 찾을 수 있다. 126 | 127 | ### 에러 처리 128 | - 사용자가 잘못된 값을 입력할 경우 `IllegalArgumentException`를 발생시키고, `[ERROR]`로 시작하는 에러 메시지를 출력 후 해당 부분부터 다시 입력을 받는다. 129 | - 아래의 프로그래밍 실행 결과 예시와 동일하게 입력과 출력이 이루어져야 한다. 130 | 131 | ### 기능 선택 132 | - 프로그램을 시작하면 기능의 종류를 출력하고 그 중 하나의 입력을 받는다. 133 | ``` 134 | 기능을 선택하세요. 135 | 1. 페어 매칭 136 | 2. 페어 조회 137 | 3. 페어 초기화 138 | Q. 종료 139 | ``` 140 | 141 | ### 페어 매칭 142 | - 과정와 미션을 출력하고 매칭하고자 하는 과정, 레벨, 미션을 입력 받는다. 143 | ``` 144 | ############################################# 145 | 과정: 백엔드 | 프론트엔드 146 | 미션: 147 | - 레벨1: 자동차경주 | 로또 | 숫자야구게임 148 | - 레벨2: 장바구니 | 결제 | 지하철노선도 149 | - 레벨3: 150 | - 레벨4: 성능개선 | 배포 151 | - 레벨5: 152 | ############################################ 153 | 과정, 레벨, 미션을 선택하세요. 154 | ex) 백엔드, 레벨1, 자동차경주 155 | ``` 156 | 157 | - 매칭이 정상적으로 수행되면 결과가 출력된다. 158 | - 출력되는 페어의 순서는 `camp.nextstep.edu.missionutils.Randoms`의 shuffle 메서드의 결과 순서로 정렬한다. 159 | 160 | ``` 161 | 페어 매칭 결과입니다. 162 | 용팔 : 대만 163 | 대협 : 덕규 164 | 치수 : 준호 165 | 태웅 : 백호 166 | 달재 : 태산 167 | 한나 : 수겸 168 | 태섭 : 대남 169 | 준섭 : 소연 170 | 현준 : 호열 171 | 구식 : 경태 172 | ``` 173 | 174 | ### 프로그래밍 실행 결과 예시 175 | 176 | ``` 177 | 기능을 선택하세요. 178 | 1. 페어 매칭 179 | 2. 페어 조회 180 | 3. 페어 초기화 181 | Q. 종료 182 | 1 183 | 184 | ############################################# 185 | 과정: 백엔드 | 프론트엔드 186 | 미션: 187 | - 레벨1: 자동차경주 | 로또 | 숫자야구게임 188 | - 레벨2: 장바구니 | 결제 | 지하철노선도 189 | - 레벨3: 190 | - 레벨4: 성능개선 | 배포 191 | - 레벨5: 192 | ############################################ 193 | 과정, 레벨, 미션을 선택하세요. 194 | ex) 백엔드, 레벨1, 자동차경주 195 | 프론트엔드, 레벨1, 자동차경주 196 | 197 | 페어 매칭 결과입니다. 198 | 다비 : 신디 199 | 쉐리 : 덴버 200 | 제키 : 로드 201 | 라라 : 윌터 202 | 니콜 : 이브 203 | 린다 : 시저 204 | 보노 : 제시 : 제키 205 | 206 | 기능을 선택하세요. 207 | 1. 페어 매칭 208 | 2. 페어 조회 209 | 3. 페어 초기화 210 | Q. 종료 211 | 1 212 | 213 | ############################################# 214 | 과정: 백엔드 | 프론트엔드 215 | 미션: 216 | - 레벨1: 자동차경주 | 로또 | 숫자야구게임 217 | - 레벨2: 장바구니 | 결제 | 지하철노선도 218 | - 레벨3: 219 | - 레벨4: 성능개선 | 배포 220 | - 레벨5: 221 | ############################################ 222 | 과정, 레벨, 미션을 선택하세요. 223 | ex) 백엔드, 레벨1, 자동차경주 224 | 프론트엔드, 레벨1, 자동차경주 225 | 226 | 매칭 정보가 있습니다. 다시 매칭하시겠습니까? 227 | 네 | 아니오 228 | 아니오 229 | 230 | 과정, 레벨, 미션을 선택하세요. 231 | ex) 백엔드, 레벨1, 자동차경주 232 | 프론트엔드, 레벨1, 자동차경주 233 | 매칭 정보가 있습니다. 다시 매칭하시겠습니까? 234 | 네 | 아니오 235 | 네 236 | 237 | 페어 매칭 결과입니다. 238 | 이브 : 윌터 239 | 보노 : 제키 240 | 신디 : 로드 241 | 제시 : 린다 242 | 시저 : 라라 243 | 니콜 : 다비 244 | 리사 : 덴버 : 제키 245 | 246 | 기능을 선택하세요. 247 | 1. 페어 매칭 248 | 2. 페어 조회 249 | 3. 페어 초기화 250 | Q. 종료 251 | 2 252 | 253 | ############################################# 254 | 과정: 백엔드 | 프론트엔드 255 | 미션: 256 | - 레벨1: 자동차경주 | 로또 | 숫자야구게임 257 | - 레벨2: 장바구니 | 결제 | 지하철노선도 258 | - 레벨3: 259 | - 레벨4: 성능개선 | 배포 260 | - 레벨5: 261 | ############################################ 262 | 과정, 레벨, 미션을 선택하세요. 263 | ex) 백엔드, 레벨1, 자동차경주 264 | 프론트엔드, 레벨1, 자동차경주 265 | 266 | 페어 매칭 결과입니다. 267 | 이브 : 윌터 268 | 보노 : 제키 269 | 신디 : 로드 270 | 제시 : 린다 271 | 시저 : 라라 272 | 니콜 : 다비 273 | 리사 : 덴버 : 제키 274 | 275 | 기능을 선택하세요. 276 | 1. 페어 매칭 277 | 2. 페어 조회 278 | 3. 페어 초기화 279 | Q. 종료 280 | 3 281 | 282 | 초기화 되었습니다. 283 | 284 | 기능을 선택하세요. 285 | 1. 페어 매칭 286 | 2. 페어 조회 287 | 3. 페어 초기화 288 | Q. 종료 289 | Q 290 | ``` 291 | 292 | --- 293 | ## 🎱 프로그래밍 요구사항 294 | 295 | - 프로그램을 실행하는 시작점은 `Application`의 `main()`이다. 296 | - JDK 8 버전에서 실행 가능해야 한다. **JDK 8에서 정상 동작하지 않을 경우 0점 처리**한다. 297 | - 자바 코드 컨벤션을 지키면서 프로그래밍한다. 298 | - https://naver.github.io/hackday-conventions-java 299 | - indent(인덴트, 들여쓰기) depth를 3이 넘지 않도록 구현한다. 2까지만 허용한다. 300 | - 예를 들어 while문 안에 if문이 있으면 들여쓰기는 2이다. 301 | - 힌트: indent(인덴트, 들여쓰기) depth를 줄이는 좋은 방법은 함수(또는 메소드)를 분리하면 된다. 302 | - 3항 연산자를 쓰지 않는다. 303 | - 함수(또는 메소드)의 길이가 15라인을 넘어가지 않도록 구현한다. 304 | - 함수(또는 메소드)가 한 가지 일만 잘 하도록 구현한다. 305 | - else 예약어를 쓰지 않는다. 306 | - 힌트: if 조건절에서 값을 return하는 방식으로 구현하면 else를 사용하지 않아도 된다. 307 | - else를 쓰지 말라고 하니 switch/case로 구현하는 경우가 있는데 switch/case도 허용하지 않는다. 308 | - build.gradle 파일을 변경할 수 없고, 외부 라이브러리를 사용하지 않는다. 309 | - 프로그램 종료 시 `System.exit()`를 호출하지 않는다. 310 | - 프로그래밍 요구사항에서 별도로 변경 불가 안내가 없는 경우 파일 수정과 패키지 이동을 자유롭게 할 수 있다. 311 | 312 | ### 프로그래밍 요구사항 - Randoms, Console 313 | 314 | - JDK에서 기본 제공하는 Random, Scanner API 대신 `camp.nextstep.edu.missionutils`에서 제공하는 `Randoms`, `Console` API를 활용해 구현해야 한다. 315 | - Random 값 추출은 `camp.nextstep.edu.missionutils.Randoms`의 `shuffle()`를 활용한다. 316 | - 사용자가 입력하는 값은 `camp.nextstep.edu.missionutils.Console`의 `readLine()`을 활용한다. 317 | - 프로그램 구현을 완료했을 때 `src/test/java` 디렉터리의 `ApplicationTest`에 있는 모든 테스트 케이스가 성공해야 한다. **테스트가 실패할 경우 0점 처리한다.** 318 | 319 | --- 320 | ## ❗️ 힌트 321 | - 아래의 힌트를 참고하여 진행해도 좋다. 322 | - 반드시 아래의 힌트를 따라해야하는 것은 아니며 사용하지 않아도 되고 수정도 가능하다. 323 | 324 | ### 과정 325 | ```java 326 | public enum Course { 327 | BACKEND("백엔드"), 328 | FRONTEND("프론트엔드"); 329 | 330 | private String name; 331 | 332 | Course(String name) { 333 | this.name = name; 334 | } 335 | 336 | // 추가 기능 구현 337 | } 338 | ``` 339 | 340 | ### 레벨 341 | ```java 342 | public enum Level { 343 | LEVEL1("레벨1"), 344 | LEVEL2("레벨2"), 345 | LEVEL3("레벨3"), 346 | LEVEL4("레벨4"), 347 | LEVEL5("레벨5"); 348 | 349 | private String name; 350 | 351 | Level(String name) { 352 | this.name = name; 353 | } 354 | 355 | // 추가 기능 구현 356 | } 357 | ``` 358 | 359 | ### 크루 360 | ```java 361 | public class Crew { 362 | private Course course; 363 | private String name; 364 | } 365 | 366 | ``` 367 | 368 | --- 369 | 370 | ## 📈 과제 진행 요구사항 371 | 372 | - 미션은 [java-pairmatching-precourse](https://github.com/woowacourse/java-pairmatching-precourse) 저장소를 Fork/Clone해 시작한다. 373 | - **기능을 구현하기 전에 java-pairmatching-precourse/docs/README.md 파일에 구현할 기능 목록을 정리**해 추가한다. 374 | - **Git의 커밋 단위는 앞 단계에서 README.md 파일에 정리한 기능 목록 단위**로 추가한다. 375 | - [AngularJS Commit Message Conventions](https://gist.github.com/stephenparish/9941e89d80e2bc58a153) 참고해 commit log를 남긴다. 376 | - 과제 진행 및 제출 방법은 [프리코스 과제 제출 문서](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse) 를 참고한다. 377 | -------------------------------------------------------------------------------- /build.gradle: -------------------------------------------------------------------------------- 1 | plugins { 2 | id 'java' 3 | } 4 | 5 | group 'camp.nextstep.edu' 6 | version '1.0-SNAPSHOT' 7 | 8 | repositories { 9 | mavenCentral() 10 | maven { url 'https://jitpack.io' } 11 | } 12 | 13 | dependencies { 14 | implementation 'com.github.woowacourse-projects:mission-utils:1.0.0' 15 | } 16 | 17 | java { 18 | toolchain { 19 | languageVersion = JavaLanguageVersion.of(8) 20 | } 21 | } 22 | 23 | test { 24 | useJUnitPlatform() 25 | } -------------------------------------------------------------------------------- /gradle.properties: -------------------------------------------------------------------------------- 1 | org.gradle.jvmargs=-Dfile.encoding=UTF-8 2 | org.gradle.console=plain -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/woowacourse/java-pairmatching-precourse/6aa2570bfc76a32792ab44220bad774d8843a241/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | distributionBase=GRADLE_USER_HOME 2 | distributionPath=wrapper/dists 3 | distributionUrl=https\://services.gradle.org/distributions/gradle-6.8.1-bin.zip 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | -------------------------------------------------------------------------------- /gradlew: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env sh 2 | 3 | # 4 | # Copyright 2015 the original author or authors. 5 | # 6 | # Licensed under the Apache License, Version 2.0 (the "License"); 7 | # you may not use this file except in compliance with the License. 8 | # You may obtain a copy of the License at 9 | # 10 | # https://www.apache.org/licenses/LICENSE-2.0 11 | # 12 | # Unless required by applicable law or agreed to in writing, software 13 | # distributed under the License is distributed on an "AS IS" BASIS, 14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 | # See the License for the specific language governing permissions and 16 | # limitations under the License. 17 | # 18 | 19 | ############################################################################## 20 | ## 21 | ## Gradle start up script for UN*X 22 | ## 23 | ############################################################################## 24 | 25 | # Attempt to set APP_HOME 26 | # Resolve links: $0 may be a link 27 | PRG="$0" 28 | # Need this for relative symlinks. 29 | while [ -h "$PRG" ] ; do 30 | ls=`ls -ld "$PRG"` 31 | link=`expr "$ls" : '.*-> \(.*\)$'` 32 | if expr "$link" : '/.*' > /dev/null; then 33 | PRG="$link" 34 | else 35 | PRG=`dirname "$PRG"`"/$link" 36 | fi 37 | done 38 | SAVED="`pwd`" 39 | cd "`dirname \"$PRG\"`/" >/dev/null 40 | APP_HOME="`pwd -P`" 41 | cd "$SAVED" >/dev/null 42 | 43 | APP_NAME="Gradle" 44 | APP_BASE_NAME=`basename "$0"` 45 | 46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' 48 | 49 | # Use the maximum available, or set MAX_FD != -1 to use that value. 50 | MAX_FD="maximum" 51 | 52 | warn () { 53 | echo "$*" 54 | } 55 | 56 | die () { 57 | echo 58 | echo "$*" 59 | echo 60 | exit 1 61 | } 62 | 63 | # OS specific support (must be 'true' or 'false'). 64 | cygwin=false 65 | msys=false 66 | darwin=false 67 | nonstop=false 68 | case "`uname`" in 69 | CYGWIN* ) 70 | cygwin=true 71 | ;; 72 | Darwin* ) 73 | darwin=true 74 | ;; 75 | MINGW* ) 76 | msys=true 77 | ;; 78 | NONSTOP* ) 79 | nonstop=true 80 | ;; 81 | esac 82 | 83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar 84 | 85 | 86 | # Determine the Java command to use to start the JVM. 87 | if [ -n "$JAVA_HOME" ] ; then 88 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then 89 | # IBM's JDK on AIX uses strange locations for the executables 90 | JAVACMD="$JAVA_HOME/jre/sh/java" 91 | else 92 | JAVACMD="$JAVA_HOME/bin/java" 93 | fi 94 | if [ ! -x "$JAVACMD" ] ; then 95 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME 96 | 97 | Please set the JAVA_HOME variable in your environment to match the 98 | location of your Java installation." 99 | fi 100 | else 101 | JAVACMD="java" 102 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 103 | 104 | Please set the JAVA_HOME variable in your environment to match the 105 | location of your Java installation." 106 | fi 107 | 108 | # Increase the maximum file descriptors if we can. 109 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then 110 | MAX_FD_LIMIT=`ulimit -H -n` 111 | if [ $? -eq 0 ] ; then 112 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then 113 | MAX_FD="$MAX_FD_LIMIT" 114 | fi 115 | ulimit -n $MAX_FD 116 | if [ $? -ne 0 ] ; then 117 | warn "Could not set maximum file descriptor limit: $MAX_FD" 118 | fi 119 | else 120 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" 121 | fi 122 | fi 123 | 124 | # For Darwin, add options to specify how the application appears in the dock 125 | if $darwin; then 126 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" 127 | fi 128 | 129 | # For Cygwin or MSYS, switch paths to Windows format before running java 130 | if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then 131 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` 132 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` 133 | 134 | JAVACMD=`cygpath --unix "$JAVACMD"` 135 | 136 | # We build the pattern for arguments to be converted via cygpath 137 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` 138 | SEP="" 139 | for dir in $ROOTDIRSRAW ; do 140 | ROOTDIRS="$ROOTDIRS$SEP$dir" 141 | SEP="|" 142 | done 143 | OURCYGPATTERN="(^($ROOTDIRS))" 144 | # Add a user-defined pattern to the cygpath arguments 145 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then 146 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" 147 | fi 148 | # Now convert the arguments - kludge to limit ourselves to /bin/sh 149 | i=0 150 | for arg in "$@" ; do 151 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` 152 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option 153 | 154 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition 155 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` 156 | else 157 | eval `echo args$i`="\"$arg\"" 158 | fi 159 | i=`expr $i + 1` 160 | done 161 | case $i in 162 | 0) set -- ;; 163 | 1) set -- "$args0" ;; 164 | 2) set -- "$args0" "$args1" ;; 165 | 3) set -- "$args0" "$args1" "$args2" ;; 166 | 4) set -- "$args0" "$args1" "$args2" "$args3" ;; 167 | 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; 168 | 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; 169 | 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; 170 | 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; 171 | 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; 172 | esac 173 | fi 174 | 175 | # Escape application args 176 | save () { 177 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done 178 | echo " " 179 | } 180 | APP_ARGS=`save "$@"` 181 | 182 | # Collect all arguments for the java command, following the shell quoting and substitution rules 183 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" 184 | 185 | exec "$JAVACMD" "$@" 186 | -------------------------------------------------------------------------------- /gradlew.bat: -------------------------------------------------------------------------------- 1 | @rem 2 | @rem Copyright 2015 the original author or authors. 3 | @rem 4 | @rem Licensed under the Apache License, Version 2.0 (the "License"); 5 | @rem you may not use this file except in compliance with the License. 6 | @rem You may obtain a copy of the License at 7 | @rem 8 | @rem https://www.apache.org/licenses/LICENSE-2.0 9 | @rem 10 | @rem Unless required by applicable law or agreed to in writing, software 11 | @rem distributed under the License is distributed on an "AS IS" BASIS, 12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 | @rem See the License for the specific language governing permissions and 14 | @rem limitations under the License. 15 | @rem 16 | 17 | @if "%DEBUG%" == "" @echo off 18 | @rem ########################################################################## 19 | @rem 20 | @rem Gradle startup script for Windows 21 | @rem 22 | @rem ########################################################################## 23 | 24 | @rem Set local scope for the variables with windows NT shell 25 | if "%OS%"=="Windows_NT" setlocal 26 | 27 | set DIRNAME=%~dp0 28 | if "%DIRNAME%" == "" set DIRNAME=. 29 | set APP_BASE_NAME=%~n0 30 | set APP_HOME=%DIRNAME% 31 | 32 | @rem Resolve any "." and ".." in APP_HOME to make it shorter. 33 | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi 34 | 35 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 36 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" 37 | 38 | @rem Find java.exe 39 | if defined JAVA_HOME goto findJavaFromJavaHome 40 | 41 | set JAVA_EXE=java.exe 42 | %JAVA_EXE% -version >NUL 2>&1 43 | if "%ERRORLEVEL%" == "0" goto execute 44 | 45 | echo. 46 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 47 | echo. 48 | echo Please set the JAVA_HOME variable in your environment to match the 49 | echo location of your Java installation. 50 | 51 | goto fail 52 | 53 | :findJavaFromJavaHome 54 | set JAVA_HOME=%JAVA_HOME:"=% 55 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 56 | 57 | if exist "%JAVA_EXE%" goto execute 58 | 59 | echo. 60 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 61 | echo. 62 | echo Please set the JAVA_HOME variable in your environment to match the 63 | echo location of your Java installation. 64 | 65 | goto fail 66 | 67 | :execute 68 | @rem Setup the command line 69 | 70 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 71 | 72 | 73 | @rem Execute Gradle 74 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* 75 | 76 | :end 77 | @rem End local scope for the variables with windows NT shell 78 | if "%ERRORLEVEL%"=="0" goto mainEnd 79 | 80 | :fail 81 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 82 | rem the _cmd.exe /c_ return code! 83 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 84 | exit /b 1 85 | 86 | :mainEnd 87 | if "%OS%"=="Windows_NT" endlocal 88 | 89 | :omega 90 | -------------------------------------------------------------------------------- /settings.gradle: -------------------------------------------------------------------------------- 1 | rootProject.name = 'java-pairmatching' 2 | 3 | -------------------------------------------------------------------------------- /src/main/java/pairmatching/Application.java: -------------------------------------------------------------------------------- 1 | package pairmatching; 2 | 3 | public class Application { 4 | public static void main(String[] args) { 5 | // TODO 구현 진행 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /src/main/resources/backend-crew.md: -------------------------------------------------------------------------------- 1 | 백호 2 | 태웅 3 | 치수 4 | 태섭 5 | 대만 6 | 준호 7 | 대협 8 | 덕규 9 | 태산 10 | 경태 11 | 수겸 12 | 현준 13 | 준섭 14 | 한나 15 | 소연 16 | 호열 17 | 대남 18 | 용팔 19 | 구식 20 | 달재 -------------------------------------------------------------------------------- /src/main/resources/frontend-crew.md: -------------------------------------------------------------------------------- 1 | 보노 2 | 시저 3 | 쉐리 4 | 신디 5 | 다비 6 | 덴버 7 | 이브 8 | 제시 9 | 라라 10 | 린다 11 | 리사 12 | 니콜 13 | 로드 14 | 윌터 15 | 제키 -------------------------------------------------------------------------------- /src/test/java/pairmatching/ApplicationTest.java: -------------------------------------------------------------------------------- 1 | package pairmatching; 2 | 3 | import static camp.nextstep.edu.missionutils.test.Assertions.assertShuffleTest; 4 | import static camp.nextstep.edu.missionutils.test.Assertions.assertSimpleTest; 5 | import static org.assertj.core.api.Assertions.assertThat; 6 | 7 | import camp.nextstep.edu.missionutils.test.NsTest; 8 | import java.util.Arrays; 9 | import org.junit.jupiter.api.Test; 10 | import pairmatching.Application; 11 | 12 | class ApplicationTest extends NsTest { 13 | 14 | private static final String ERROR_MESSAGE = "[ERROR]"; 15 | 16 | @Test 17 | void 짝수_인원_페어_매칭() { 18 | assertShuffleTest( 19 | () -> { 20 | run("1", "백엔드, 레벨1, 자동차경주", "Q"); 21 | assertThat(output()).contains("태웅 : 백호", "치수 : 태섭"); 22 | }, 23 | Arrays.asList("태웅", "백호", "치수", "태섭") 24 | ); 25 | } 26 | 27 | @Test 28 | void 없는_미션에_대한_예외_처리() { 29 | assertSimpleTest( 30 | () -> { 31 | runException("1", "백엔드, 레벨1, 오징어게임"); 32 | assertThat(output()).contains(ERROR_MESSAGE); 33 | } 34 | ); 35 | } 36 | 37 | @Override 38 | public void runMain() { 39 | Application.main(new String[]{}); 40 | } 41 | } 42 | --------------------------------------------------------------------------------