Skip to content

hoon25/ddd-tactical-design

 
 

Repository files navigation

키친포스

DDD 리팩토링 작업 내역

  • 상품
    • ASIS : java.kitchenpos.product
    • TOBE : kotlin.kitchenpos.product.tobe
    • PR : next-step#353
  • 메뉴
    • ASIS : java.kitchenpos.menu
    • TOBE : kotlin.kitchenpos.menu.tobe
    • PR : next-step#371
  • 매장식사
    • ASIS : java.kitchenpos.order.eatinorder
    • TOBE : kotlin.kitchenpos.order.tobe.eatinorder
    • PR : next-step#375

퀵 스타트

cd docker
docker compose -p kitchenpos up -d

요구 사항

상품

  • 상품을 등록할 수 있다.
  • 상품의 가격이 올바르지 않으면 등록할 수 없다.
    • 상품의 가격은 0원 이상이어야 한다.
  • 상품의 이름이 올바르지 않으면 등록할 수 없다.
    • 상품의 이름에는 비속어가 포함될 수 없다.
  • 상품의 가격을 변경할 수 있다.
  • 상품의 가격이 올바르지 않으면 변경할 수 없다.
    • 상품의 가격은 0원 이상이어야 한다.
  • 상품의 가격이 변경될 때 메뉴가격이 메뉴금액보다 크면 메뉴가 비노출된다.
  • 상품의 목록을 조회할 수 있다.

메뉴 그룹

  • 메뉴 그룹을 등록할 수 있다.
  • 메뉴 그룹의 이름이 올바르지 않으면 등록할 수 없다.
    • 메뉴 그룹의 이름은 비워 둘 수 없다.
  • 메뉴 그룹의 목록을 조회할 수 있다.

메뉴

  • 1 개 이상의 등록된 상품으로 메뉴를 등록할 수 있다.
  • 상품이 없으면 등록할 수 없다.
  • 메뉴에 속한 상품의 수량은 0 이상이어야 한다.
  • 메뉴의 가격이 올바르지 않으면 등록할 수 없다.
    • 메뉴의 가격은 0원 이상이어야 한다.
  • 메뉴에 속한 상품 금액의 합은 메뉴의 가격보다 크거나 같아야 한다.
  • 메뉴는 특정 메뉴 그룹에 속해야 한다.
  • 메뉴의 이름이 올바르지 않으면 등록할 수 없다.
    • 메뉴의 이름에는 비속어가 포함될 수 없다.
  • 메뉴의 가격을 변경할 수 있다.
  • 메뉴의 가격이 올바르지 않으면 변경할 수 없다.
    • 메뉴의 가격은 0원 이상이어야 한다.
  • 메뉴에 속한 상품 금액의 합은 메뉴의 가격보다 크거나 같아야 한다.
  • 메뉴를 노출할 수 있다.
  • 메뉴의 가격이 메뉴에 속한 상품 금액의 합보다 높을 경우 메뉴를 노출할 수 없다.
  • 메뉴를 숨길 수 있다.
  • 메뉴의 목록을 조회할 수 있다.

주문 테이블

  • 주문 테이블을 등록할 수 있다.
  • 주문 테이블의 이름이 올바르지 않으면 등록할 수 없다.
    • 주문 테이블의 이름은 비워 둘 수 없다.
  • 빈 테이블을 해지할 수 있다.
  • 빈 테이블로 설정할 수 있다.
  • 완료되지 않은 주문이 있는 주문 테이블은 빈 테이블로 설정할 수 없다.
  • 방문한 손님 수를 변경할 수 있다.
  • 방문한 손님 수가 올바르지 않으면 변경할 수 없다.
    • 방문한 손님 수는 0 이상이어야 한다.
  • 빈 테이블은 방문한 손님 수를 변경할 수 없다.
  • 주문 테이블의 목록을 조회할 수 있다.

주문

  • 1개 이상의 등록된 메뉴로 배달 주문을 등록할 수 있다.
  • 1개 이상의 등록된 메뉴로 포장 주문을 등록할 수 있다.
  • 1개 이상의 등록된 메뉴로 매장 주문을 등록할 수 있다.
  • 주문 유형이 올바르지 않으면 등록할 수 없다.
  • 메뉴가 없으면 등록할 수 없다.
  • 매장 주문은 주문 항목의 수량이 0 미만일 수 있다.
  • 매장 주문을 제외한 주문의 경우 주문 항목의 수량은 0 이상이어야 한다.
  • 배달 주소가 올바르지 않으면 배달 주문을 등록할 수 없다.
    • 배달 주소는 비워 둘 수 없다.
  • 빈 테이블에는 매장 주문을 등록할 수 없다.
  • 숨겨진 메뉴는 주문할 수 없다.
  • 주문한 메뉴의 가격은 실제 메뉴 가격과 일치해야 한다.
  • 주문을 접수한다.
  • 접수 대기 중인 주문만 접수할 수 있다.
  • 배달 주문을 접수되면 배달 대행사를 호출한다.
  • 주문을 서빙한다.
  • 접수된 주문만 서빙할 수 있다.
  • 주문을 배달한다.
  • 배달 주문만 배달할 수 있다.
  • 서빙된 주문만 배달할 수 있다.
  • 주문을 배달 완료한다.
  • 배달 중인 주문만 배달 완료할 수 있다.
  • 주문을 완료한다.
  • 배달 주문의 경우 배달 완료된 주문만 완료할 수 있다.
  • 포장 및 매장 주문의 경우 서빙된 주문만 완료할 수 있다.
  • 주문 테이블의 모든 매장 주문이 완료되면 빈 테이블로 설정한다.
  • 완료되지 않은 매장 주문이 있는 주문 테이블은 빈 테이블로 설정하지 않는다.
  • 주문 목록을 조회할 수 있다.

용어 사전

상품

한글명 영문명 설명
상품 product 메뉴를 관리하는 기준이 되는 데이터
상품가격 product price 상품의 가격
이름 name 음식을 상상하게 만드는 중요한 요소

메뉴

한글명 영문명 설명
메뉴 menu 메뉴 그룹에 속하는 실제 주문 가능 단위
메뉴가격 menu price 메뉴의 가격
메뉴금액 menu amount 메뉴상품가격 * 수량
메뉴 그룹 menu group 각각의 메뉴를 성격에 따라 분류하여 묶어둔 그룹
메뉴 상품 menu product 메뉴에 속하는 수량이 있는 상품
노출 메뉴 displayed menu 손님에게 보이는 메뉴
비노출 메뉴 not displayed menu 손님에게 보이지 않는 메뉴
이름 name 음식을 상상하게 만드는 중요한 요소

매장 주문

한글명 영문명 설명
매장 주문 eat in order 매장에서 제공되는 주문
서빙 served 조리가 완료되어 음식이 나갈 수 있는 단계
완료 completed 고객이 모든 식사를 마치고 결제를 완료한 단계
접수 accepted 주문을 받고 음식을 조리하는 단계
접수 대기 waiting 주문이 생성되어 매장으로 전달된 단계
주문 order 매장에서 식사하는 고객 대상. 손님들이 매장에서 먹을 수 있도록 조리된 음식을 가져다준다.
주문 상태 order status 주문이 생성되면 매장에서 주문을 접수하고 고객이 음식을 받기까지의 단계를 표시한다.
손님 수 number of guests 식기가 필요한 사람 수. 필수 사항은 아니며 주문은 0명으로 등록할 수 있다.
주문 테이블 order table 매장에서 주문이 발생하는 영역
주문 테이블 상태 order table status 주문테이블의 등록여부 상태(EmptyTable, OccupiedTable)
빈 테이블 empty table 주문을 등록할 수 없는 주문 테이블
점유 테이블 occupied table 주문을 등록할 수 있는 손님이 앉은 주문테이블
주문 항목 order line item 주문에 속하는 수량이 있는 메뉴

배달 주문

한글명 영문명 설명
배달 delivering 배달원이 매장을 방문하여 배달 음식의 픽업을 완료하고 배달을 시작하는 단계
배달 대행사 delivery agency 준비한 음식을 고객에게 직접 배달하는 서비스
배달 완료 delivered 배달원이 주문한 음식을 고객에게 배달 완료한 단계
서빙 served 조리가 완료되어 음식이 나갈 수 있는 단계
완료 completed 배달 및 결제 완료 단계
접수 accepted 주문을 받고 음식을 조리하는 단계
접수 대기 waiting 주문이 생성되어 매장으로 전달된 단계
주문 order 집이나 직장 등 고객이 선택한 주소로 음식을 배달한다.
주문 상태 order status 주문이 생성되면 매장에서 주문을 접수하고 고객이 음식을 받기까지의 단계를 표시한다.
주문 항목 order line item 주문에 속하는 수량이 있는 메뉴

포장 주문

한글명 영문명 설명
서빙 served 조리가 완료되어 음식이 나갈 수 있는 단계
완료 completed 고객이 음식을 수령하고 결제를 완료한 단계
접수 accepted 주문을 받고 음식을 조리하는 단계
접수 대기 waiting 주문이 생성되어 매장으로 전달된 단계
주문 order 포장하는 고객 대상. 고객이 매장에서 직접 음식을 수령한다.
주문 상태 order status 주문이 생성되면 매장에서 주문을 접수하고 고객이 음식을 받기까지의 단계를 표시한다.
주문 항목 order line item 주문에 속하는 수량이 있는 메뉴

모델링

상품

속성

  • Product는 식별자와 price, name을 가진다.

공통 정책

  • Productname은 필수값이고, Profanities를 통해 Profanity가 포함되어 있지 않은지 확인한다.
  • Productprice는 0원 이상이어야 한다.

기능

  • Product를 등록
  • Product를 전체조회
  • Productprice를 변경
    • Product를 포함한 Menu들 중 MenuPrice > MenuAmountMenuNot Displayed된다

메뉴그룹

속성

  • MenuGroup는 식별자와 name을 가진다.

공통 정책

  • MenuGroupname은 필수값이다.

기능

  • MenuGroup를 등록
  • MenuGroup를 전체조회

메뉴

속성

  • Menu는 식별자와 MenuGroup, price, name, displayed, MenuProduct를 가진다.
  • MenuProductseqquantity를 가진다.

공통 정책

  • Productname은 필수값이고, Profanities를 통해 Profanity가 포함되어 있지 않은지 확인한다.
  • Menu는 1개의 MenuGroup에 반드시 속한다.
  • MenuMenuProduct는 1개 이상이어야 한다.
  • MenuProductquantity는 0개 이상이어야 한다.

기능

  • Menu를 전체조회
  • Menu를 등록
    • MenuPrice <= MenuAmount를 만족하지 못하면 Menu는 생성되지 못한다
  • Menuprice를 변경
    • MenuPrice <= MenuAmount를 만족하지 못하면 price는 변경되지 못한다
  • MenuDisplayed한다
    • MenuPrice <= MenuAmount를 만족하지 못하면 Displayed할 수 없다
  • MenuNotDisplayed한다

매장 주문

속성

  • OrderTable은 식별자, name, NumberOfGuests, OrderTableStatus를 가진다.
  • EatInOrder는 식별자, 주문시간, OrderStatus, OrderLineItems, OrderTableId를 가진다.
  • OrderLineItemseq, quantity, menuId를 가진다.

OrderTable 기능

  • OrderTable 생성
    • OrderTablename은 필수값이다.
    • OrderTable생성 시 초기값은 EmptyTable이다.
  • OrderTableNumberOfGuests 변경
    • NumberOfGuests는 0 이상이어야 한다.
    • EmptyTable인 경우 NumberOfGuests는 변경할 수 없다.
  • OrderTableEmptyTable 설정
    • Complete되지 않은 EatInOrder가 있는 경우 EmptyTable로 설정할 수 없다.
  • OrderTableOccupiedTable 설정

EatInOrder 기능

  • EatInOrder 생성
    • EatInOrderOrderLineItems는 1개 이상이어야 한다.
    • EatInOrderOrderLineItemsmenuDisplayed여야 한다.
    • EatInOrderOccupiedTable을 1개 가져야한다.
    • EatInOrder생성 시 OrderStatusWaiting이다.
  • EatInOrder 접수
    • EatInOrderWaiting일떄만 Accept할 수 있다.
  • EatInOrder 서빙
    • EatInOrderAccepted일때만 Served할 수 있다.
  • EatInOrder 완료
    • EatInOrderServed일때만 Complete할 수 있다.
    • EatInOrder이 가진 OrderTable의 모든 EatInOrderComplete되면 EmptyTable이 된다.

배달 주문

  • Order는 식별자와 OrderStatus, 주문 시간, 배달 주소, OrderLineItems를 가진다.
  • 메뉴가 노출되고 있으며 판매되는 메뉴 가격과 일치하면 Order가 생성된다.
  • Order는 접수 대기 ➜ 접수 ➜ 서빙 ➜ 배달 ➜ 배달 완료 ➜ 계산 완료 순서로 진행된다.
  • Order가 접수되면 DeliveryAgency가 호출된다.
  • OrderLineItem는 가격과 수량을 가진다.
  • OrderLineItem의 수량은 1보다 커야 한다.

포장 주문

  • Order는 식별자와 OrderStatus, 주문 시간, OrderLineItems를 가진다.
  • 메뉴가 노출되고 있으며 판매되는 메뉴 가격과 일치하면 Order가 생성된다.
  • Order는 접수 대기 ➜ 접수 ➜ 서빙 ➜ 계산 완료 순서로 진행된다.
  • OrderLineItem는 가격과 수량을 가진다.
  • OrderLineItem의 수량은 1보다 커야 한다.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • Java 52.7%
  • Kotlin 47.3%