Welcome to the Technical Test for Bunk!
For this technical test we expect candidates to spend between 1-3 hours to look through this README and the code and then make a number of commits associated to the following tasks.
Candidates will not only be judged on their coding strengths, but also on their ability to make good commits, spot areas of code that could be improved and proactiveness, among other things.
- Clone this repository
git clone git@github.com:rentbunk/bunk-gaming.git
- Remove this repository from remote
git remote remove origin
- Create a new repository using your own GitHub account named
bunk-gaming
(feel free to ) - Add your own remote
git remote add origin git@github.com:GITHUB_USERNAME/bunk-gaming.git
- Push to your own repository
git push -u origin main
- Add
alexpchin
andchazuk
to the list of collaborators https://github.com/GITHUB_USERNAME/bunk-gaming/settings/access
Candidates are expected to complete at least TWO of the following tasks:
- Complete a selection of example User Stories and Tasks
- Update and improve the Developer Experience of the codebase and document that changes that will effect other developers
- Analyse the codebase and create a number of GitHub Issues to be undertaken by the team (in the style of a Jira ticket you'd expect to work on)
- Implement a feature that would showcase a particular expertise or talent and document the feature to present to stakeholders
After you have completed the test, please make sure that all code is on the main branch, and update the README with any instructions, thoughts and feedback you deem necessary.
As a user, I want to be able to see a list of games for each developer so that I can easily find games created by my favorite developers.
- Clicking on a Developer should take the user to the games by developer page.
- Present the developers name and information from the API.
- Present a list of games associated with that developer from the API.
- The list should include the title, image and any other information you think is relevant.
- Ensure the feature is responsive and accessible on various devices and screen sizes.
- Clicking on a Game should take the user to the associated games page
As a user, I want the Game page to have an updated design so that I can enjoy a more visually appealing and user-friendly experience when exploring game information.
- The updated design should match the provided design specifications in terms of layout and interactive elements.
- Implement a responsive design to ensure the Game page looks and functions well on various devices and screen sizes.
- Ensure that all interactive elements (buttons, links, etc.) have appropriate accessibility features (e.g., keyboard navigation, screen reader compatibility).
- Add a screenshots section underneath the detail section.
- OPTIONAL Include new sections for additional information returned from the API to provide users with more comprehensive game information.
As a user, I want to navigate through the list of games using pagination so that I can easily access a large catalog without overwhelming load times or scrolling issues.
- The pagination feature should be implemented at both the frontend (Angular) and backend to efficiently manage data fetching.
- Users should be able to navigate through pages using "Previous" and "Next" buttons (selecting specific page numbers directly is not required).
- The UI for the pagination should be responsive and match the current design language of the application.
- Ensure that the current page number is clearly indicated.
- OPTIONAL Implement lazy loading or a similar strategy to further improve the performance and user experience of navigating the list.
There are a number of tests that are currently blocking us from deploying the latest features to production.
The Home page and Platform Games page both show a list of Games, but each has it's own custom styling. This should be refactored to use a single component to display Game Cards and a list of Games.
There is a proposed design below, but most of the information can be excluded for the simple card.
- All tests must pass when running
npm run test
To get access to the RAWG API you'll need to complete the following steps:
- Sign up to RAWG
- Navigate to your Developer Dashboard
- Complete the form with your name, a fake site url or your GitHub profile and a short description of why you're using the API
- Copy the API key from the Developer Dashboard
- Go to
src/environments/environment.ts
and paste the API key underrawg.api_key
The API offers 20,000 requests a month, so you should not run out of requests or run into any rate limiting.
The full API documentation is found at https://api.rawg.io/docs/
This project was generated with Angular CLI version 15.2.11.
Run ng serve
for a dev server. Navigate to http://localhost:4200/
. The application will automatically reload if you change any of the source files.
Run ng generate component component-name
to generate a new component. You can also use ng generate directive|pipe|service|class|guard|interface|enum|module
.
Run ng build
to build the project. The build artifacts will be stored in the dist/
directory.
Run ng test
to execute the unit tests via Karma.
Run ng e2e
to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities.
To get more help on the Angular CLI use ng help
or go check out the Angular CLI Overview and Command Reference page.