Skip to content
This repository has been archived by the owner on Jan 10, 2022. It is now read-only.

SnappyGifts/coding-challenge-1

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Coding Challenge

Requirements

Design an API endpoint that provides autocomplete suggestions for large cities. The suggestions should be restricted to cities in the USA and Canada with a population above 5000 people.

  • the endpoint is exposed at /suggestions
  • the partial (or complete) search term is passed as a query string parameter q
  • the caller's location can optionally be supplied via query string parameters latitude and longitude to help improve relative scores
  • the endpoint returns a JSON response with an array of scored suggested matches
    • the suggestions are sorted by descending score
    • each suggestion has a score between 0 and 1 (inclusive) indicating confidence in the suggestion (1 is most confident)
    • each suggestion has a name which can be used to disambiguate between similarly named locations
    • each suggestion has a latitude and longitude
  • all functional tests should pass (additional tests may be implemented as necessary).
  • feel free to add more features if you like!

Sample responses

These responses are meant to provide guidance. The exact values can vary based on the data source and scoring algorithm.

Near match

GET /suggestions?q=Londo&latitude=43.70011&longitude=-79.4163
{
  "suggestions": [
    {
      "name": "London, ON, Canada",
      "latitude": "42.98339",
      "longitude": "-81.23304",
      "score": 0.9
    },
    {
      "name": "London, OH, USA",
      "latitude": "39.88645",
      "longitude": "-83.44825",
      "score": 0.5
    },
    {
      "name": "London, KY, USA",
      "latitude": "37.12898",
      "longitude": "-84.08326",
      "score": 0.5
    },
    {
      "name": "Londontowne, MD, USA",
      "latitude": "38.93345",
      "longitude": "-76.54941",
      "score": 0.3
    }
  ]
}

No match

GET /suggestions?q=SomeRandomCity
{
  "suggestions": []
}

Non-functional

  • All code should be written in Javascript
  • Challenge is submitted as a PRIVATE repository
  • Documentation and maintainability is a plus
  • Open source (NPM packages) usage is allowed and recommended
  • Do NOT use database (Redis, Elastic, Mongo, etc.) of any kind as part of the solution.

Dataset

You can find the necessary dataset along with its description and documentation in the data directory.

Evaluation

We will use the following criteria to evaluate your solution:

  • Capacity to follow instructions
  • Developer Experience (how easy it is to run your solution locally, how clear your documentation is, etc)
  • Solution correctness
  • Performance
  • Tests
  • Code style and cleanliness
  • Attention to detail
  • Ability to make sensible assumptions

It is ok to ask us questions!

We know that the time for this project is limited and it is hard to create a "perfect" solution, so we will consider that along with your experience when evaluating the submission.

Getting Started

Prerequisites

You are going to need:

  • Git
  • Node.js

Setting up your environment

  1. Begin by forking this repo and cloning your fork. GitHub has apps for Mac and Windows that make this easier.

  2. Install Node.js.

Setting up the project

In the project directory run:

npm install

The project uses serverless framework (https://www.serverless.com/framework/docs/)

Running the tests

The test suite can be run with:

npm run test

Starting the application

To start a local server run:

npm run start

it should produce an output similar to:

[HTTP] | server ready: http://localhost:3000
[GET]  | http://localhost:3000/dev/suggestions 

Submitting your challenge

Share your forked PRIVATE repository with us (instructions will be given separately)

Good luck!

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published