Giter Club home page Giter Club logo

js-vending-machine's Introduction

자바스크립트와 Cypress로 구현하는 자판기

template version

📝 요구사항

공통

  • 기존 HTML Template을 활용한다.
  • 필요하다면 선택자를 참고한다.
  • 상단에 메뉴가 존재하며 각 탭에 따라 적절한 기능을 수행한다.
    • 상품 관리탭은 자판기가 보유하고 있는 물품을 추가하는 기능을 수행한다.
    • 잔돈 충전탭은 자판기가 보유할 금액을 충전하는 기능을 수행한다.
    • 상품 구매탭은 사용자가 금액을 충전할 수 있으며, 금액에 맞춰 상품을 구매하고, 남은 금액에 대해서는 잔돈을 반환하는 기능을 수행한다.
  • 다른 탭으로 이동했다 돌아와도 기존 탭의 상태가 유지되어야 한다.
  • localStorage를 이용하여, 새로고침하더라도 가장 최근에 작업한 정보들을 불러올 수 있도록 한다.

상품 관리

  • 상품 관리탭에서, 다음과 같은 규칙을 바탕으로 상품을 추가한다.
  • 최초 상품 목록은 비워진 상태이다. (이미지 첨부)
  • 상품명, 금액, 수량을 추가할 수 있다.
    • 상품 추가 입력 폼에 상품명, 금액, 수량을 차례로 입력한다.
    • 상품명, 금액, 수량은 공백이 불가능하다.
    • 상품의 최소 수량은 1개여야 한다.
    • 상품의 최소 가격은 100원이며, 10원으로 나누어 떨어져야 한다.
      • 예) 콜라 / 110원 / 5개
      • 예) 사이다 / 100원 / 100개
  • 같은 상품명의 데이터를 추가하면 기존의 상품에 해당하는 데이터는 새로운 상품으로 대체된다.
    • 콜라 / 1000원 / 12개(전) -> 콜라 / 1500원 / 10개(후) => 콜라 / 1500원 / 10개(결과)
  • 사용자는 추가한 상품을 확인할 수 있다.
    • 상품의 이름, 가격, 수량 순으로 상품 목록이 보여진다. (이미지 첨부)
  • 상품 목록은 탭을 이동하여도 기존의 상품 목록이 유지되어야 한다.

상품추가

잔돈 충전 (자판기 보유 동전)

  • 잔돈 충전 탭에서, 다음과 같은 규칙으로 자판기 보유 금액을 충전한다.
  • 잔돈 충전 페이지에서 최초 자판기가 보유한 금액은 0원이며, 각 동전의 개수는 0개이다.
  • 관리자는 잔돈 충전 입력 요소에 충전할 금액을 입력한 후, 자판기 동전 충전 버튼을 눌러 자판기가 보유한 금액을 충전할 수 있다.
    • 최소 충전 금액은 100원이며, 10원으로 나누어 떨어지는 금액만 충전이 가능하다.
    • 자판기가 보유한 금액은 {금액}원 형식으로 나타낸다. (이미지)
      • 예) 1000원 (o) / 1000 원 (x) / 1000 (x)
  • 관리자는 잔돈을 누적하여 충전할 수 있다.
    • 1000원 충전 -> 500원 충전 => 총 1500원 분량의 동전이 생성됨. (추가)
  • 자판기가 보유한 금액 만큼의 동전이 무작위로 생성된다.
    • 동전은 500원, 100원, 50원, 10원의 동전만 생성된다.
  • 동전의 개수를 나타내는 정보는 {개수}개 형식으로 나타낸다.
    • 예) 1개 (o) / 1 개 (x) / 1 (x)
  • 다른 탭을 클릭하여도 자판기가 보유한 금액은 유지되어야 한다.

잔돈충전

상품 구매

  • 상품 구매탭에서, 다음과 같은 규칙을 바탕으로 금액을 충전하고, 상품을 구매하며, 잔돈을 반환한다.
  • 상품 구매 페이지 에서 최초 충전 금액은 0원이며, 반환된 각 동전의 개수는 0개이다.
  • 사용자는 금액 충전 입력 요소에 충전할 금액을 입력한 후, 구매 금액 충전버튼을 이용하여 금액을 충전한다.
    • 최소 충전 금액은 10원이다.
    • 금액은 10원으로 나누어 떨어지는 금액만 충전이 가능하다.
    • 자판기가 보유한 금액은 {금액}원 형식으로 나타낸다. (이미지)
      • 예) 1000원 (o) / 1000 원 (x) / 1000 (x)
  • 금액은 누적으로 충전이 가능하다.
    • 1000원 충전 -> 500원 충전 => 1500원
  • 사용자는 충전한 금액을 바탕으로 상품을 구매할 수 있다.
    • 상품 구매에 성공하면, 충전한 금액이 상품 금액만큼 차감 된다. 또한 상품의 수량도 차감된다.
    • 수량이 0인 상품은 구매할 수 없다.
    • 구매하려는 상품 가격이 보유하고 있는 금액보다 높은 경우 상품을 구매할 수 없다.
  • 사용자는 반환하기 버튼을 통해 잔돈을 반환 받을 수 있다.
    • 잔돈 반환 규칙은 잔돈 계산 모듈 요구사항의 규칙을 따른다.

상품구매-구매

상품 구매 / 잔돈 계산 모듈

  • 상품 구매 탭에서, 잔돈 반환 시 다음과 같은 규칙을 통해 잔돈을 반환한다.
  • 최소 개수의 동전으로 잔돈을 돌려준다.
    • 예) 자판기가 보유한 동전 100원 5개, 500원 1개인 상태이고, 500원을 거슬러줘야 한다면 500원 1개를 반환한다.
    • 예) 자판기가 보유한 동전 100원 5개, 500원 2개인 상태이고, 1000원을 거슬러줘야 한다면 500원 2개를 반환한다.
    • 예) 자판기가 보유한 동전 100원 6개, 500원 1개인 상태이고, 1000원을 거슬러줘야 한다면 100원 5개 500원 1개를 반환한다.
  • 지폐를 잔돈으로 반환하는 경우는 없다고 가정한다.
  • 모든 금액에 대해 잔돈을 반환할 수 없는 경우 잔돈으로 반환할 수 있는 금액만 반환한다.
    • 예) 자판기가 보유한 동전 500원 2개인 상태이고, 800원을 거슬러줘야 한다면 500원 1개만 반환한다. 나머지 300원에 해당하는 금액은 반환하지 않는다. (이미지 첨부)
  • 동전의 개수를 나타내는 정보는 {개수}개 형식으로 나타낸다.
    • 예) 1개 (o) / 1 개 (x) / 1 (x)
  • 반환한 동전만큼 사용자가 충전한 금액이 차감된다.
  • 반환한 동전만큼 자판기가 보유하고 있는 동전도 차감된다.
  • 반환한 동전의 결과는 누적되지 않는다.

js-vending-machine's People

Contributors

pocojang avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.