Skip to content

TDD Kata to create a bowling scoreboard with React + Jest/Enzyme

Notifications You must be signed in to change notification settings

mpsyscons/react-bowling-kata

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A fun template to practice Test-driven development in React with Jest+Enzyme. Inspired by Uncle Bob's famous Bowling Game Kata

Welcome to React Bowling

The local bowling alley needs an app to keep a score on their bowling games. You figure this could be your big break into the world of Bowling Software!

You show up at the Bowling alley and see that they have an initial design up for their app, but with no functionality :O

As it is they have a list of requirements ready:

Requirements

  • rolling Clicking any of the numbered buttons should update the scoreboard with the number of pins knocked down for the roll.

  • game score The game consists of 10 frames. In each frame the player has two opportunities to knock down 10 pins. The score for the frame is the total number of pins knocked down, plus bonuses for strikes and spares.

  • spare A spare is when the player knocks down all 10 pins in two tries. The bonus for that frame is the number of pins knocked down by the next roll. So in frame 3 above, the score is 10 (the total number knocked down) plus a bonus of 5 (the number of pins knocked down on the next roll.)

  • strike A strike is when the player knocks down all 10 pins on his first try. The bonus for that frame is the value of the next two balls rolled.

  • 10th frame In the tenth frame a player who rolls a spare or strike is allowed to roll the extra balls to complete the frame. However no more than three balls can be rolled in tenth frame.

Scripts used in project

In the project directory, you can run:

npm start

Runs the app in the development mode. Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits. You will also see any lint errors in the console.

npm test

Launches the test runner in the interactive watch mode. See the section about running tests for more information.

Tools for testing

The project uses two frameworks to allow Test-driven development

Jest is the default test runner with create-react-app. Combined with Enzyme it's a powerful toolbox to create unit tests for React Components:

it('App should render a ScoreBoard component', () => {
  const wrapper = shallow(<App/>);
  expect(wrapper.find(ScoreBoard)).toBeDefined();
});

it('ScoreBoard should render ten Frame components', () => {
  var wrapper = shallow(<ScoreBoard/>)
  expect(wrapper.find(Frame).length).toEqual(10);
});

This project was bootstrapped with Create React App.

About

TDD Kata to create a bowling scoreboard with React + Jest/Enzyme

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 48.5%
  • CSS 31.1%
  • HTML 20.4%