In order to successfully complete this exam, you will need to have node v6 or greater installed on your machine.
- Install project dependencies:
yarn install
- To start the application:
yarn start
- To run the tests:
yarn test
These are the only commands you should have to worry about. Running yarn start
will start a local webserver and you can access the page from http://localhost:8080
Once you are finished with the exam, please delete the node_modules directory, zip the folder, and email it to the exam coordinator.
We expect that you will complete this test in an honest fashion. You should not copy and paste code from stack overflow or blogs in order to complete it and you should implement it without the aid of anyone else. Successful completion will include an implementation for each of the following requirements. Extra credit will be given for tests (which use mocha, code, and enzyme), refactoring, efficient usage of relevant algorithms, and styles, weighted in that order.
Babel 6 is already included along with the complimentary build configuration. You should not need to make any changes to this. Also, regarding testing, jsdom and the appropriate enzyme adapter are already setup to automatically run before your tests and should not need to be interacted with directly.
You will only need to worry about supporting the latest version of Chrome for your solution.
Though React is included in this assessment, this can absolutely be done with or without the usage of any javascript frameworks or additional libraries other than the ones included in the package.json
.
- Given a list of pizzas available at '/pizza.json'
- When the server returns a response
- Then the list of pizzas should be shown
- And a filter input is shown
- And a sort button is shown
- Given the user has loaded the page
- When the page waits for data to load
- Then the text "Loading" should be shown
- And no other elements should be shown
- Given the page is shown with a list of pizzas
- When the user enters filter text
- Then only the pizzas that include the filter text should be shown
- Given the page is shown with a list of pizzas
- When the user enters filter text
- Then the list of pizzas should be filtered in a case insensitive way
- Given the page is shown with a list of pizzas
- When the user clicks the sort button
- Then the list of pizzas will be sorted in reverse alphabetic order
- Given the user has entered text into the filter input
- When the user clicks the sort button
- The the sorted list of pizzas should also be filtered according to the input