To play Blackjack, you will first need to run the following commands in Terminal:
- npm install (to install dependencies)
- npm run start (to run the node server)
Next direct your browser to http://localhost:3000
JavaScript felt like the wild west after neat and tidy Ruby, and I really enjoyed the contrast. This time the project was tackled as a group of 4 over 5 days. Given interdependence of the component parts, we opted for primarily mob programming which enabled us to plan and problem solve together effectively. I encountered a few interesting challenges:
- The issue of asynchronicity, for example getting the game to wait for an API request to return an additional card before checking the new total. Solved with the use of Promise objects.
- Planning of intricate dealer logic. By using Activity Diagrams, pseudocode and PubSub we were able to break this task up into small chunks, find patterns and use PubSub broadcasts to trigger events for various scenarios.
- Hiding the dealer card on initial deal. In order to achieve this, I designed the Dealer View to render it's current cards in different ways, depending on which PubSub channel was broadcast to.
Much unanticipated learning came from building this project as a team. I came to better appreciate mob programming, which was new to me, as well as the value of tools such as User Personas, user testing and MoSCoW.
Many thanks to my co-collaborators Iain Floyd, Jackie Farr and Mike Griffin.
- Game checks for Blackjack upon initial deal.
- Dealer draws on a total of 16 or less.
- It's currently possible to run out of cards. If the game appears to stop responding, try getting a freshly shuffled deck with the provided button (this will reset totals).
- This game is playable online on Heroku (not yet suited to mobile) : https://blackjack-js-game.herokuapp.com/