Skip to content
This repository has been archived by the owner on Aug 7, 2024. It is now read-only.

whichdigital/fe-techtest

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Which? Front-end Exercise

This repository provides information and a project boilerplate for completing the test exercise sent to candidates applying for front-end roles at Which?.

Getting up and running

This repository provides a starting point for the test but if you'd rather start from scratch with your own setup that's fine too, as long as you complete the exercise.

We have provided a Webpack and Babel based development environment which can compile and bundle your source code. It also includes a server which will automatically reload your code changes in the browser.

Which? primarily uses React and TypeScript in our front-end projects but you can use vanilla JavaScript or other tools if you prefer. We have not provided any tooling to work with anything beyond vanilla JavaScript.

We have provided Jest to test your code which is a fully featured testing framework. It includes a test runner, assertions, and mock functions.

Requirements

To get started you'll need to make sure you have the following software tools installed:

  • Git
  • Node.js (version 12 or higher is required)
  • npm (this should be installed along with Node.js)

Installation and setup

  1. Clone this Git repository and change to the new directory that has been created:

    git clone https://github.com/whichdigital/fe-techtest.git --depth 1
    cd fe-techtest
  2. Install all of the project dependencies using npm:

    npm install
  3. Once installed you can run the Webpack development server:

    npm start

    Now open http://localhost:8080/ in your browser and you should see a basic HTML page.

    If you open the developer console in the browser, you should see a welcome message which confirms everything is loading and running correctly.

    To stop the server when no longer needed, you can press ctrl + c in the terminal.

  4. And to run your tests use the following command:

    npm test

The exercise

Goal

We would like you to create a client-side web application to help a child understand multiplication. Your application will display a grid of numbers. When a child selects a number, the multiples of that chosen number should be highlighted.

Functional requirements

  • The application must display numbers from 1 to 144.
  • When a number is clicked, all numbers which are a multiple of the chosen number must be highlighted.
  • When a subsequent number is clicked, all numbers which are a multiple of the new number must be highlighted. Any numbers which are not multiples of the new number should no longer be highlighted.

Visual requirements

  • Each number must be within a large clickable box.
  • Each number must be horizontally and vertically centered within their clickable box.
  • The boxes must be laid out evenly within a grid.
  • On mobile and small screen devices, one number must be displayed in each grid row.
  • On tablet and middle sized devices, two numbers must be displayed in each grid row.
  • On desktop and large screen devices, three numbers must be displayed in each grid row.
  • The grid should have a maximum width so that the clickable boxes do not get too large.
  • The grid should be horizontally centered on the screen.

Other

Please update this readme with additional information about your solution. Things to mention might include the tools used, alternative solutions considered, improvements you'd like to make, or things you'd do differently if you had more time.

Criteria for assessment

Your completed test exercise will be marked according to a score sheet. We will focus on the following areas:

  • That your solution meets the requirements.
  • How usable your application is when using assistive technology.
  • Your approach to testing the application.
  • The use of responsive design.
  • Clear project structure and conventions.
  • How readable and understandable your code is.
  • The performance of your completed application.

You won’t be assessed on the appearance of the app beyond the visual requirements and accessibility criteria.