Note: This task should take no longer than 2 hours to complete.
This is a boilerplate for displaying price data using react, redux and react-router with the help of webpack.
Contains:
- ES6 - 7 Support with Babel
- Redux dev tools to help you keep track of the app's state
- Routing
- hot module replacement support so you can change modules or react components without having to reload the browser
- a webpack production config so you can build the app and make it ready for production
- Sass support, just import your styles wherever you need them
- eslint to keep your js readable
- A suitable IDE, ie WebStorm, VSCode etc
- Ideally a cygwin, or bash terminal
- Node, NPM
- If you're on a windows platform, you will need to run the following command:
npm install --global --production windows-build-tools
(using a privileged command prompt)
- Open a new bash shell
- cd react-coding-test/streaming-service
npm install
npm run start
- Open a new bash shell
- cd react-coding-test
npm install
npm run start
Once running, if you want to hide the redux dev monitor: CTRL+H
or move it with CTRL+Y
- Open a new bash shell
- cd react-coding-test
npm run test_watch
We need you to implement a solution to display some price ticker data on the UI in realtime. Price data is available from a locally running service. Any additional visuallisations to indicate how prices have changed would be a plus. Testing is also an important part to this exercise.
There are four parts to this application that need implementing, we suggest that the candidate time box their efforts in each section.
- Service interaction: The application contains local streaming service to run on your machine that will publish prices for a given ticker at an interval of 0.5 seconds. We want to be able see these prices rendered on the ui. Although the service api exists it is not connected yet.
- Data: We need to be able convey the service api results to the UI
- UI: To render UI results you need to implement components, reducers and actions using thunk middleware. Any additional visual effects to highlight positive or negative changes in the prices would be a bonus.
- Testing: We need test coverage for any code implemented. Chai, Sinon, Mocha, Enzyme are already included as libraries, however feel free to implement any tests in your choice of framework. The existing tests should be running according to the instructions above.
Apple Inc. (AAPL)
Simply replace AAPL in the URL with a valid ticker symbol. Price tickers are real-time.
{
"ticker": "AAPL",
"exchange": "NASDAQ",
"price": "116.60",
"change": "-0.46",
"change_percent": "-0.39",
"last_trade_time": "Oct 21, 4:00PM EDT",
"dividend": "0.57",
"yield": "1.96"
}
- Commit and Push your code to your new repository
- Send us a pull request. We will review your code and get back to you