Skip to content

Take home project used during our interview process for backend developer roles.

Notifications You must be signed in to change notification settings

system76/takehome_web_be

Repository files navigation

Take-Home Test for Backend Engineer Role

Thank you for your interest in applying to the Backend Engineer role at System76! Your mission—should you choose to accept it—is outlined in Assignment.

Why a take-home test?

In-person coding interviews can be stressful, and can hide some people's full potential. A take-home test gives you the chance showcase your talent by working in your own space, and on your own time.

We understand you may have time constraints, so we've made this as simple as possible to evaluate the skill and tech stack you will be using in your day-to-day here at System76.

Assignment

Your mission will be to build a web API that can be used to query some information about Products.

Write your code, using Ecto to model the data, and store it in a local Postgres database. Then, utilize Phoenix to build a web API to query the models. A basic API design for this assignment would simply return all of the available products, and make them filterable by one or more categories: e.g. laptop, desktop, server. You may choose to improve and refine this design—and we encourage you to do so! This will give us an opportunity to see how you approach the design of an API you know you and your team members will be using in the future.

If you are running out of time, you can outline below in the Notes section how you would have done things differently if given more time.

Setup Instructions

We use asdf to manage dependencies. This is a Phoenix 1.6.0 project, using Postgres for the database.

To start your Phoenix server:

  • Install asdf to install Erlang and Elixir with asdf install. You can skip this step and use your OS preferred package manager or any other way you prefer.
  • Install dependencies with mix deps.get
  • Create and migrate your database with mix ecto.setup
  • Start Phoenix endpoint with mix phx.server or from inside IEx with iex -S mix phx.server

You can now visit localhost:4000 from your browser to see the app running.

Alternatively, you can run both the database and the app itself in a Docker environment using Docker compose:

docker-compose build
docker compose up

Evaluation Criteria

We will use this project as the basis for evaluating your skill as a developer as it relates to our tech stack and our team.

While we'll be gathering as much data as we can from your implementation, our evaluation will focus on these core concepts:

  • Solution Integrity: Is your solution complete and functional?
  • Design: What choices did you make in regards to functionality, readability, maintainability, extendability, and did you make appropriate use of language/framework features?
  • Testability: Have you considered how you'd test your code?
  • Documentation: Have you provided context for decisions and assumptions that you've made?

Notes

Your Notes

TODO: Please leave us any notes about your experience with this challenge here.

Time Spent

TODO: Give us a rough estimate of the time you spent working on the test. If you spent time learning in order to do this project please feel free to let us know that too. This makes sure that we are evaluating your work fairly and in context. It also gives us the opportunity to learn and adjust our process if needed.

Assumptions

TODO: Did you find yourself needing to make assumptions to complete this? If so, what were they, and how did they impact your design/code?

Production Readiness

TODO: Provide us with some notes about what you would do next if you had more time. Are there additional features that you would want to add? Specific improvements to the code you would make? Any additional testing or documentation?

About

Take home project used during our interview process for backend developer roles.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published