- Jest is a delightful JavaScript Testing Framework with a focus on simplicity.
- Jest aims to work out of the box, config free, on most JavaScript projects.
Ideally if time had been permitting, the JavaScript code could have been generated with the help of Jest for Test Driven Development (TDD). Here the tests would be written before the code, which means the tests initially fail. Just enough code would then be created in order to pass the test. The process continues incremently like this;
- write the next test
- fail the test
- write the next section of code to pass
- pass the test without breaking any previous tests
- improve or refactor the code until the project is completed. This process is called Red-Green-Refactor cycle.
By the end, a suite of tests can be run for the whole JavaScript app, just by typing one command into the terminal:
npm test
This is how Jest can be used for TDD and automated testing.
- Many tests can be run during a short period of time.
- Tests, if written by the programmer, can detect errors earlier.
- Tests can be very specific and edge cases accounted for.
- The tests are only as good as the questions asked. Care has to be taken, as 'always passing' tests are possible to write.
- The tests only check the programming function and do not test the user experience. Manual testing is also carried out in parallel to cover this.
Jest is based on a system called Node.JS. There are thousands of extra packages that can be installed to extend the basic functionality of Node. These are installed using the Node Package Manager (NPM).
- Firstly, initialize the Node environment by typing from terminal window:
npm init
and answer the resulting questions by pressing enter, to keep the defaults, except for answer "test command". Here, type jest. This tells NPM use Jest as the testing environment.
- Secondly, to installed Jest, from terminal window type:
npm install --save-dev jest@26.6.3
The --save-dev switch just tells Node to use Jest in a development environment. It adds Jest to a list called Dev Dependencies.
To run tests in the terminal for a specific JavaScript file, type (without the .test.js
extension):
npm test -- filename
app.js is the main game app, which:
- creates the game board
- generates a random moving target
- keeps score of hit targets
- speeds up the game depending on score
- terminates, resets, starts the game
Before running the tests, some modification is required to index.html and app.js:
- comment out the EmailJS scripts in index.html
- add the following line to bottom of app.js
module.exports = { GAME_CONFIG, createGrid, startGame };
- See Bugs 4 and 5 in the Bugs section below for the explanation of why the prerequisites are required.
It was decided to devise three tests. These were important to ensure that the initial view of the game page was correct. On loading, the Score and Time left must be at the default values, but the third test also checks that when the Start button is clicked, any values are immediately forced back to the defaults. The second test is very important for the foundation of the game - the grid must have 9 tiles and each tile must have the correct assigned id. Because this grid was built using JavaScript, it was important to test that it had been created as expected. The extra failing test for the tenth square was used to double check. Sometimes it is too easy to write tests that will never fail.
- Check that the score and time-left, have the correct initial values on loading game and before the start of play. The elements of ids 'score' and 'time-left' are accessed and checked that their values, via text content, are '0' and '60' respectively.
-
Check that the board grid has been built with correct ids. The board is made up of 9 tiles in a 3x3 grid. Each tile is is given a unique id between '0' and '8'. for this test set, all elements of the class 'tile' are accessed to check that there are actually 9 tiles and that they each have the expected id. Just to double check, if the following code is added, the tests will fail.
expect(squares[9].id).toEqual('9');
- Check that values for score and time-left will be returned back to default, when Start button (only) is clicked. Here, the score and time-left values are forced to be '88' and '8' respectively. On clicking the start button, checks are made to ensure the values return to game start defaults of '0' and '60' respectively.
The tests above give a flavour of how automated testing can be achieved. The test results are seen below with a test coverage report:
The site was built, tested and validated on the Chrome browser only.
No framework was used for building the site, only HTML5, CSS3 and JavaScript - see the supported browsers for HTML. - Chrome - Firefox - Safari - Opera - Edge
-
Devices supported:
- Mac
- Windows
- Android
- iOS
-
See the default breakpoints provided by W3 Schools for responsive building. Breakpoints are a representative of a subset of common device sizes and viewport dimensions—they don’t specifically target every use case or device. Instead, the ranges provide a strong and consistent foundation to build on for nearly any device.
Breakpoint Dimensions Extra small <600px Small ≥600px Medium ≥768px Large ≥992px Extra large ≥1200px
For this project it was only deemed necessary to use 2 breakpoints:
-
Mobile devices - Chrome Developer Tools supplies a suite of emulated devices for simulating how sites would appear for different mobile phone models. The following were used for manually testing the project:
-
The game was primarily built as a mobile app and developed mainly around the smallest device on the above list, the Galaxy Fold.
-
For all other devices, the font was scaled up as appropriate. It was not necessary to fully scale up for laptops and desktops, as this would have made the game board rather large and the game play too easy. As an extra future feature, a fully scaled up version could be built for those requiring an extra large game board.
-
Behavioural Driven Development (BDD) is manual testing and is based on the expected outcome of an action. It is used to test the useability of the site and tests the areas that automated testing cannot. No specific software tool is used and it is built upon the user stories. The application is tested to see if it behaves as expected. It is a descriptive way of testing. For example:
- as a user (role)
- I want an email feature (feature)
- so that I can contact the developer about my game idea (benefit)
As a role, I want a particular feature, so that I get a benefit. BDD expands on this by adding given, when, then:
- given a specific context: the user has filled in their details on the contact form
- when an action is performed: user clicks Send Email button
- then there is an observable consequence: site owner receives an email from the user
This behaviour is now testable and repeatable. Each test should only one thing at a time.
- As a visiting user, I would like to connect with the company via email.
- The emailing feature is provided by the JavaScript library, EmailJS. This service allows connection to a chosen email service (in this case Gmail), build an email template, and send it from JavaScript without any server code.
- As a visiting user, I would like to easily understand how to play the game.
- Instructions on how to play the game are included under the game board.
- As a visiting user, I would like to play with increasing difficulty.
- The randomly generated target moves quicker as the score increases, hence it becomes harder to hit the target and score points.
- As a visiting user, I would like to see my score.
These cases are included in order to help the next developer understand the design of the site and how to extend it. They document the look and functionality of each page.
Desktop/tablet/mobile screens:
Site View
Colour palette used on a Black background:
On loading the site, the user will be taken to index.html, the home page. Mobile, tablet and desktop views are the same, and the following features are visible to the user.
- Game board with:
- name of the game title Box Hunt in Electric Blue
- initial values for Score: 0 and Time Left: 60s. Words are in White and numbers in Persian Rose
- 3x3 Black game board with White grid lines
- active Start button (default HTML button without any extra styling)
- inactive Replay button (default greyed-out HTML button without any extra styling)
- Instructions of how to play the game and how points are accrued
- Instructions heading in Persian Rose
- list of instructions featuring an Electric Blue icon and White text
- Contact section where the user can email in a game idea, featuring:
- Email Us heading in Persian Rose
- name input box with Full Name placeholder text
- email address input box with Email placeholder text
- text area with Game Idea placeholder text
- Send My Idea button (default HTML button without any extra styling)
- Footer section with
- White text
- heart icon in Lavender Floral
- Lavender Floral GitHub icon with an active link (default HTML linking without any extra styling)
Site Actions
When the user selects an active area of the screen, the following results will be seen.
-
On the game area:
-
Clicking or tapping on the Start button will
- cause the Time left value to count down from 60 seconds
- cause a randomly generated Electric Blue square target to appear, initially every 1 second
- disable the Start button and change the fill colour from White to Grey
- enable the Replay button and change the fill colour from Grey to White
-
Clicking or tapping on the Electric Blue moving target will
- cause the Score to increment
- cause the target to speed up slightly
-
Given that the game is in play, when the Time left value is 0, then
- the Electric Blue text Game Over! will appear
- the target will be removed
- Clicking or tapping on the Replay button will
- remove the target
- change the Score value to 0
- change the Time left value to 60
- remove the Game Over! text above the grid, if the Time left value is 0
- immediately start the game again
-
-
On the Email Us form section:
-
Clicking or tapping on the input text boxes will:
- show an extra outer border in White
-
Clicking or tapping on the Send My Idea button will initiate the HTML basic error checking:
-
if no text is entered into the text boxes:
- error message = Please fill out this field.
-
if certain characters are missing from the email address, for example the @ symbol:
- error message = Please include an '@' in the email address.
-
if text is entered into all the text boxes with a valid email address:
- inputs boxes will clear and return to showing the placeholder text
- Electric Blue text, Idea submitted! will be visible
- the Send My Idea button will be disabled and the fill colour will change from White to Grey
- Email will be sent via EmailJS to the owner's Gmail account
-
-
-
On the footer section
- Clicking or tapping the Lavender Floral GitHub icon will:
- take the user to the site owner's GitHub account in another tab
- Clicking or tapping the Lavender Floral GitHub icon will:
Desktop/tablet/mobile screens:
Site View
On arriving at this page, the following features are visible to the user:
-
Coloured background in Magenta, Cyan, Yellow and White
-
Black title 404
-
Black text Are you lost? and Returning home in 3 seconds!
Site Actions
There is no active part of this page for user interaction. An automatic redirect will:
- send the user, using same tab, to the home page at https://janet-dev.github.io/ci-milestone-project-2/ after 3 seconds
-
HTML - No errors and 2 warnings were detected by W3C for pages:
- index.html PDF report : 5 errors, 6 warnings
- index.html PDF report : 0 errors, 2 warnings
- Warnings were caused by 2 headings where JavaScript would create the text content. Added aria-labels for accessibility - see WAVE section below.
- 404.html PDF report : 0 errors, 0 warnings
-
CSS - No errors and 1 warning was detected by Jigsaw (W3C) for:
Lighthouse is an automated tool for improving the quality of web page. It checks the current webpage for performance, accessibility, best practices and SEO.
index.html
404.html
The 404 page received a low score for accessibility because the page automatically directs the user back to the home page after 3 seconds.
I was not able use a 404 page with an active link for this project repository and I believe it would require a custom domain as stated by Stack Overflow user Daniel Powell.
Github have published the procedure to create a custom 404 page for the Pages site username.github.io, but not for any repository. I was able to publish the 404 page with an active link for my own Pages site janet-dev.github.io, but not for this project repository. The index.html link was unactive on deployment but not in Developer Tools and clicking on it would cause a redirection to janet-dev.github.io. Therefore I decided to build an automatic redirection from the 404 page to this repository's home page. As the project site has only one short page, I believe this not be an accessibility issue. If the user is on the 404 page, then they clearly shouldn't be there and the one page they should be on is the home page. Automatic redirection is an issue for sites of many pages but not a small one-page site.
JSHint is a community-driven tool that detects errors and potential problems in JavaScript code.
app.js
- No errors or warnings were detected.
- JavaScript PDF report
sendEmail.js
- No errors, 2 warnings were detected - 1 undefined variable and 1 unused variable. Both are used in the index.html EmailJS code.
WAVE Web Accessibility Evaluation Tools "help authors make their web content more accessible to individuals with disabilities. WAVE can identify many accessibility and Web Content Accessibility Guideline (WCAG) errors, but also facilitates human evaluation of web content. Our philosophy is to focus on issues that we know impact end users, facilitate human evaluation, and to educate about web accessibility."
Initially, the WAVE detected:
- 0 contrast errors - colour palette passed accessibility tests
- 6 errors:
- 3 missing form labels - where placeholder text was used instead of labels
- 2 empty headings - where headings would be generated by JavaScript for game over and email submission
- 1 empty link - where a link was attached to an icon rather than text
- WAVE Report 1 : Errors
- WAVE Report 2 : Errors
- Errors solved by adding aria-labels to the:
- form inputs
- empty headings
- a tag in the footer for the icon
- WAVE Report 1 : Errors Solved
- WAVE Report 2 : Errors Solved
Testing and validation was carried out on the Chrome browser with Windows 10, though the site was used through others to check continuing functionality. Checked that:
- game play functioned correctly
- emails could be sent
- landing on page 404 caused a redirection to the Home page
The following browsers and devices were checked live and not through any emulators - select the coloured text to see the screenshots:
Browser | OS | Device | Game Play | Email Received | 404 Redirect |
---|---|---|---|---|---|
Chrome | Android 9.1 | Honor 9 Lite | OK | Yes | OK |
Safari 16 | iOS 16.2 | iPhone 8 | OK | Yes | OK |
Safari | macOS 15.15 | MacBook Pro | OK | Yes | OK |
Brave | Windows 10 | Dell Desktop | OK | Yes | OK |
Chrome | Windows 10 | Dell Desktop | OK | Yes | OK |
Edge | Windows 10 | Dell Desktop | OK | Yes | OK |
Opera | Windows 10 | Dell Desktop | OK | Yes | OK |
- Missing favicon
- Solved by creating a custom favicon on favicon.cc
- Game non-responsive
- Solved by following the guidelines outlayed in the article Convert px to rem - An effective workflow by Swastik Yadav on DEV Community. Basically, the root font is set in the HTML as 62.5% for 10px (100% = 16px). This sets 1rem as 10px and makes it easier to define responsive dimensions for the grid and tiles.
- Grid width greater than body width for Galaxy Fold mobile
- Solved by decreasing the grid and tile widths, so that they were within the limits of the page body
- During Jest testing, a non-failing console-error was seen in the terminal
- Solved by commenting out the EmailJS scripts in index.html
- During Jest testing, a console error was seen in Chrome Developer tools
and a warning in JSHint
- Both solved by deleting the highlighted line below:
- Link to Home page on 404 page is inactive
- Solved by implementing in 404.html, an automatic redirect in 3 seconds, which gives enough time to read the message
- See 404 Page in Lighthouse section above for more information
- No HTML validation for inputing email address on contact form
- Solved by changing input type from text to email, as this will use standard HTML validation for entering email addresses
- After code review with mentor, app.js was found to have nested functions
- Solved by creating a initialiseGame() function for setting up the game prerequisites and creating the board, which runs when the DOMContentLoaded event is triggered
- Again sendEmail.js was found to have nested functions
- Solved by creating two functions, onSuccess() and onError() which are called from the email,js.send() function
- Pressing "Reset" button did not immediately restart game play, as the "Start" button had to be pressed. This is not standard game play.
- Solved by calling the startGame() function at the bottom of the resetGame() function. resetGame() is called when the "Replay" button is clicked.
- Also changed the "Reset" button to a "Restart" and amended the instructions
1 error, 1 warning and 1 possible improvement were detected.
-
The error was removed by running the site on Chrome in Incognito mode. Stack Overflow user Chrostip Schaejn advised that this error was cause by various Chrome extensions.
-
The warning was also absent from Chrome in Incognito mode Stack Overflow user Takash Futada advised that "GitHub hosted pages disable FLoC, which is Google's 3rd party cookie alternative. GitHub, Microsoft, doesn't seems to like it."
-
The possible improvement was still present Google Forum user Adrià Vilanova Martínez advised that "this only means that Chrome will provide less details about the user platform and Chrome version, since these are used by websites to fingerprint users."
Now only 1 possible improvement is detected by Chrome in Incognito mode. Source is:
https://cdn.jsdelivr.net/npm/@emailjs/browser@3/dist/email.min.js
- EmailJS
A huge thank you to the following people and organisations, because without you, the project would not have been produced in it's present form.
Jest Testing Walkthrough Tutorials from Code Institute
Red-Green-Refactor Cycle diagram from Code Institute tutorial.
Markdown Cheatsheet from Adam Pritchard
Although the code is the work of the author, some of the code has been sourced from or inspired by others.
How to ignore lines for code coverage in Jest on Stack Overflow
Jest from w3resource
ARE YOU STRUGGLING WITH NULL VALUES IN JEST? on Code Institute Slack Channel project-milestone-2 by Benjamin Kavanagh
Use Jest write unit testing for DOM manipulation by Clark on Dev.to
How to get the code coverage report using Jest? - answer by ccalvert on Stack Overflow
Jest CLI Options - Using with npm scripts by Jest Docs
aria-label from MDN Web Docs
Disallow aria-label misuse from HTML-validate by David Sveningsson