Skip to content

Latest commit

 

History

History
86 lines (61 loc) · 2.43 KB

README.md

File metadata and controls

86 lines (61 loc) · 2.43 KB

Basic Pocket Calculator

A very basic pocket calculator implementation, which is implemented against the following libraries / tech stack:

  • ReactJS ^17.0.2
  • TypeScript ^4.5.5
  • SASS ^1.49.7
  • React Testing Library ^12.1.2
  • Cypress ^10.3.0

The environment with which this project was implemented on:

  • Node 16.13.2
  • NPM 8.1.2
  • and initially scaffolded from create-react-app 5.0.0

Running the Project


To run the project locally, run

npm start

Running the Unit Tests (Jest / React Testing Library)


To run unit tests on this project, run

npm test

Running the Component Tests (Cypress)


Component Testing is a new testing feature facility provided by Cypress since version 10, under the Beta flag. This new testing feature is intended to test components in isolation, much like the popular user-oriented testing tool; React-Testing-Library.

However with Component Testing in Cypress, the tests can be visually verified within the browser, much like with Cypress E2E tests, and also provides improved debugging facilities (eg. Chrome Dev Tools). Component Tests can also be run headless (no visuals) for quickly running your component tests and normally run as part of CI jobs.

Further reading, or watch the video demonstration (~1 hour).

Now to run the Component Tests interactively, run

npm run ct

Or, to run the Component Tests headlessly, run

npm run ct:headless

Running the E2E Tests (Cypress)


⚠️ As a pre-requisite, the main project application must already be running, before attempting to run the E2E tests.

To run the E2E tests interacively, run

npm run e2e

To run the E2E tests headlessly, run

npm run e2e:headless

Browsers


The following browsers were successfully tested on:

  • Chrome 103.0.5060.114
  • Edge 103.0.1264.62
  • Firefox 96.0.2
  • Safari 15.2

Demo


Here is a GIF demonstrating of what to expect when you run the project, and a glimpse of the interactions with the web-based pocket calculator.

GIF: Basic Pocket Calculator

Future Additions For Consideration


  • Implement Redux to centrally and globally manage the basic state