- 메뉴를 생성할 수 있다.
- 가격은 0원 이상이어야 한다.
- 등록된 메뉴 그룹에 포함되어야 한다.
- 메뉴 상품은 모두 등록된 상품이어야 한다.
- 메뉴의 가격은 메뉴 상품 가격의 합보다 작아야 한다.
- 메뉴 목록을 조회할 수 있다.
- 메뉴 그룹을 생성할 수 있다.
- 메뉴 그룹 목록을 조회할 수 있다.
- 주문을 생성할 수 있다.
- 최소 1개의 주문 항목이 존재해야 한다.
- 주문 항목에 포함된 메뉴들은 모두 존재해야 한다.
- 주문 테이블은 등록된 테이블이어야 한다.
- 주문 목록을 조회할 수 있다.
- 주문 상태를 변경할 수 있다.
- 주문이 완료된 상태에는 주문 상태 변경이 불가능하다.
- 주문 테이블을 생성할 수 있다.
- 주문 테이블 목록을 조회할 수 있다.
- 주문 테이블으 빈 좌석 여부에 대해 변경할 수 있다.
- 주문 테이블은 단체 지정이 되어 있지 않아야 한다.
- 주문 테이블의 주문 상태는 조리 중이거나 식사 중이면 안된다.
- 주문 테이블에 방문 고객 수를 변경할 수 있다.
- 주문 테이블의 방문 고객 수는 0명 이상이어야 한다.
- 주문 테이블은 빈 좌석이 아니어야 한다.
- 상품을 등록할 수 있다.
- 상품의 가격은 0원 이상이어야 한다.
- 상품의 목록을 조회할 수 있다.
- 단체 지정을 할 수 있다.
- 등록된 주문 테이블들이 2개 이상 필요하다.
- 주문 테이블들은 비어있어야 한다.
- 주문 테이블들은 단체 지정이 되어있지 않아야 한다.
- 단체 지정을 해제할 수 있다.
- 주문 테이블들의 상태가 조리 중이거나 식사중이면 안된다.
한글명 | 영문명 | 설명 |
---|---|---|
상품 | product | 메뉴를 관리하는 기준이 되는 데이터 |
메뉴 그룹 | menu group | 메뉴 묶음, 분류 |
메뉴 | menu | 메뉴 그룹에 속하는 실제 주문 가능 단위 |
메뉴 상품 | menu product | 메뉴에 속하는 수량이 있는 상품 |
금액 | amount | 가격 * 수량 |
주문 테이블 | order table | 매장에서 주문이 발생하는 영역 |
빈 테이블 | empty table | 주문을 등록할 수 없는 주문 테이블 |
주문 | order | 매장에서 발생하는 주문 |
주문 상태 | order status | 주문은 조리 ➜ 식사 ➜ 계산 완료 순서로 진행된다. |
방문한 손님 수 | number of guests | 필수 사항은 아니며 주문은 0명으로 등록할 수 있다. |
단체 지정 | table group | 통합 계산을 위해 개별 주문 테이블을 그룹화하는 기능 |
주문 항목 | order line item | 주문에 속하는 수량이 있는 메뉴 |
매장 식사 | eat in | 포장하지 않고 매장에서 식사하는 것 |
- 키친포스 요구사항 작성
- 키친포스 테스트 코드 작성
- 단위 테스트 가능한 코드에 대해 단위 테스트를 구현한다.
- Menu
- MenuGroup
- MenuProduct
- Order
- OrderLineItem
- OrderStatus
- OrderTable
- Product
- TableGroup
- JPA로 Migration
- Menu
- MenuGroup
- MenuProduct
- Order
- OrderLineItem
- OrderStatus
- OrderTable
- Product
- TableGroup
-
이전 단계에서 객체 지향 설계를 의식하였다면 아래의 문제가 존재한다. 의존성 관점에서 설계를 검토해 본다.
-
메뉴의 이름과 가격이 변경되면 주문 항목도 함께 변경된다. 메뉴 정보가 변경되더라도 주문 항목이 변경되지 않게 구현한다.
-
클래스 간의 방향도 중요하고 패키지 간의 방향도 중요하다. 클래스 사이, 패키지 사이의 의존 관계는 단방향이 되도록 해야 한다.
-
데이터베이스 스키마 변경 및 마이그레이션이 필요하다면 아래 문서를 적극 활용한다.
- DB도 형상관리를 해보자!
- Gradle의 멀티 모듈 개념을 적용해 자유롭게 서로 다른 프로젝트로 분리해 본다.
- 컨텍스트 간의 독립된 모듈로 만들 수 있다.
- 계층 간의 독립된 모듈로 만들 수 있다.
- 의존성 주입, HTTP 요청/응답, 이벤트 발행/구독 등 다양한 방식으로 모듈 간 데이터를 주고받을 수 있다.