Skip to content

Latest commit

 

History

History
133 lines (99 loc) · 9.28 KB

Readme.md

File metadata and controls

133 lines (99 loc) · 9.28 KB

parcelLab Fullstack Engineer Quest

header img Welcome to the lost Fullstack Engineer Repository. You've probably come a long way - join me around the campfire, make yourself a coffee and take a break - before you start your quest.
Take your time and read this Markdown parchment carefully, it will help you on your mission to become a Fullstack Engineer at parcelLab.

Scenario

At parcelLab we integrate with a variety of online retailers and shipping providers. One of the more common tasks for us is to process those different data sources, analyse and combine them and serve them to one our users in a human readable and convenient way.

In this scenario, you are developer at parcelLab and you are tasked with building a website that displays the orders and their tracking status for a specific user. Therefore you will need to build a frontend that presents this data to the user and a backend that serves the data to the frontend.

Our Expectations

You might be wondering after reading the below scenario, how much effort and time we expect you to invest in this task. We know that you likely have a job, a life, further open job applications and other things that require some of your valuable time. Therefore you should not spend more than 3-4 hours on this task.

Just for you to have a understanding about the scope we expect, here a list for each level you might be applying for:

Junior Developer:

  • your application works without the need of modifications
  • you use Python or Javascript for the task
  • someone looking at the code knows what you tried to accomplish because you stick with the "Clean Code" principles

Midlevel Developer:

  • all of the above plus:
  • functional programming is endorsed
  • the code base is "Clean Code" by the book
  • your Backend is able to handle a bigger number of requests (by e.g. using a proper Database)

Senior Developer:

  • all of the above plus:
  • show us your TDD knowledge
  • follow the SOLID principles

The most important thing to us is to see how you approach the below problem and how you end up designing the backend and frontend for it. The outcome of this task will then be used in the follow-up interview, in which we will review the code with you together and have a more in-depth discussion about your design decisions and their possible issues and improvement possibilities. Most important of all, do not stress it. You can only achieve a certain amount within the mentioned time frame. Your code will likely not be perfect, but as long as it's runnable and is able to support the basic user flow, it will be enough for us to have a technical conversation with you about it.

If anything of the below task is unclear or you struggle with some aspects of it, please do not hesitate to reach out to us. It's very important to us to keep on improving our interview task and experience, so any feedback is highly appreciated.

How to setup your repository

For setting up your project for this challenge there are 2 ways:

  • You can simply fork this repository and add your code in here. Afterwards just createa PR and send us the link.
  • If you do not feel confortable to do this in a public repository, you can just duplicate this repository and send us an invitation to it.

js

Frontend part

The web frontend can be created with any framework you like or no framework at all. Choose what works best for you in this scenario. At parcelLab we're using React, but this isn't a requirement.

The overall user flow of the frontend should be similar to the following:

Screen 1

The user should be able to enter their email address into a form to request a list of all their orders. alt

Screen 2

After submitting the form, the user will be presented with a list of all their orders, the delivery address of that order and the current status of the order. alt

Screen 3

If the user chooses to click on one of the presented orders in the list, they will be presented with a detailed view of the order, including tracking and article information. alt

☝ Above mockups are just an inspiration. The final design and what you want to display to the user is up to you - do not overdo it - we just want to see how you tackle the task and what your coding style is like 😏

Backend part

The data that the frontend is displaying needs to be served by some sort of API. The design of that API is completely up to you. Feel free to decide on the type of API (REST, SOAP, GraphQL, freestyle), endpoints, request and response types. Use what you feel most comfortable with or what you think is best suited for this kind of scenario.

At parcelLab we often need to handle a great amount of unconventional file types that are provided to us by customers and couriers. Unfortunately in this case your API will also need to handle a rather uncommon file format, which needs to be processed so it can be served to the frontend. Again it's your choice how to parse and process the file. For sake of simplicity you do not need to create a database to store the data in, you can choose to read and process straight from the file instead.

Data Sources

☝ Please do not edit the content of the below files. It's up to you, how or what information you want to store in your API, but do read the files as they are without modifying them first.

trackings.csv

The online retailer parcelFashion, has provided us with a CSV that contains order details of their only and most valued customer - our CTO Julian 🙂

If you open the trackings.csv file you will see it contains multiple entries with following properties:

  • orderNo - the order number of one of the orders that Julian submitted
  • tracking_number - the courier tracking number that is used to ship the order to the recipient
  • courier - the name of the courier that fulfils the shipment
  • street - the street and house number of the recipient
  • zip_code - the ZIP / postal code of the recipient
  • city - the city of the recipient
  • destination_country_iso3 - the ISO3 country code of the recipient
  • email - the email address of the recipient
  • articleNo - the online shop's article number of the article that is being shipped to the recipient
  • articleImageUrl - a picture URL of the article
  • quantity - the quantity of the article
  • product_name - the name of the article

checkpoints.csv

In addition to the parcelFashion order information, we've been provided with tracking status updates, so called checkpoints, by the courier of the orders' trackings. Fortunately they are in the same file format as the trackings.csv.

If you open the checkpoints.csv file you will see it contains multiple entries. Each entry represents a checkpoint of the specified tracking. If a tracking number has multiple entries, then this means the courier has had multiple checkpoints for that specific trackings. You can find out which one of the status updates is the most recent one by looking at the specified timestamps.

Each row will contain the following properties:

  • tracking_number - the courier tracking number that identifies a single shipment
  • location - a place name that specifies where the checkpoint occurred
  • timestamp - a UTC timestamp that specifies when the checkpoint occurred
  • status - a short code that describes the checkpoint's status
  • status_text - a more human readable version of the status short code
  • status_detail - a more human readable detailed version of the checkpoint's status

What you will need

For setting up the website / frontend you can just set up a standard React/Vue/Svelte... project with the transpiler of your choice or don't use any framework at all. Choose the tool you like. (Hint - we are fans of functional programming and react hooks 😏)

For the backend you can also use a programming language or framework of your choice. At parcelLab we're mostly using Node.js and Python, but ultimately use what you're most comfortable with.

If you're done with this challenge, simply send us a link to a repository that we can access - or create a PR to this repository.

In the end you should have

  • a website (frontend)
    • that has 3 views
      • email address input form
      • order history view
      • order detail view
    • that fetches data from your backend API
    • that upon entering a known email address of a user will present you with the order history related to that email address and allows you to view order details
  • an API (backend)
    • that parses and processes the provided CSV files' content
    • that serves content to the frontend via created endpoint(s) in a format of your choice

museum

What really makes us happy 😍

  • You provide us with a README.md that explains how we can run your app
  • Your code is well structured, clean and readable
  • You add comments and documentation, if your code isn't self-explanatory
  • You handle any common errors that could occur
  • You use automated tests where appropriate

That is it - everything else is up to you! Happy coding!