/bemobi-test

Primary LanguageCSSApache License 2.0Apache-2.0

Hire.me

Um pequeno projeto para testar suas habilidades como programador.

Instruções Gerais

  1. Clone este repositório
  2. Em seu fork, atenda os casos de usos especificados e se desejar também os bonus points
  3. Envio um e-mail para rh@bemobi.com.br com a seu Nome e endereço do repositorio.

Projeto

O projeto consiste em reproduzir um encurtador de URL's (apenas sua API), simples e com poucas funções, porém com espaço suficiente para mostrar toda a gama de desenho de soluções, escolha de componentes, mapeamento ORM, uso de bibliotecas de terceiros, uso de GIT e criatividade.

O projeto consiste de dois casos de uso:

  1. Shorten URL
  2. Retrieve URL

1 - Shorten URL

Short URL

  1. Usuario chama a API passando a URL que deseja encurtar e um parametro opcional CUSTOM_ALIAS

    1. Caso o CUSTOM_ALIAS já exista, um erro especifico {ERR_CODE: 001, Description:CUSTOM ALIAS ALREADY EXISTS} deve ser retornado.
    2. Toda URL criada sem um CUSTOM_ALIAS deve ser reduzida a um novo alias, você deve sugerir um algoritmo para isto e o porquê.
  2. O Registro é colocado em um repositório (Data Store)

  3. É retornado para o cliente um resultado que contenha a URL encurtada e outros detalhes como

    1. Quanto tempo a operação levou
    2. URL Original

Exemplos (Você não precisa seguir este formato):

  • Chamada sem CUSTOM_ALIAS
PUT http://shortener/create?url=http://www.bemobi.com.br

{
   "alias": "XYhakR",
   "url": "http://shortener/u/XYhakR",
   "statistics": {
       "time_taken": "10ms",
   }
}
  • Chamada com CUSTOM_ALIAS
PUT http://shortener/create?url=http://www.bemobi.com.br&CUSTOM_ALIAS=bemobi

{
   "alias": "bemobi",
   "url": "http://shortener/u/bemobi",
   "statistics": {
       "time_taken": "12ms",
   }
}
  • Chamada com CUSTOM_ALIAS que já existe
PUT http://shortener/create?url=http://www.github.com&CUSTOM_ALIAS=bemobi

{
   "alias": "bemobi",
   "err_code": "001",
   "description": "CUSTOM ALIAS ALREADY EXISTS"
}

2 - Retrieve URL

Retrieve URL

  1. Usuario chama a API passando a URL que deseja acessar
    1. Caso a URL não exista, um erro especifico {ERR_CODE: 002, Description:SHORTENED URL NOT FOUND} deve ser retornado.
  2. O Registro é lido de um repositório (Data Store)
  3. Esta tupla ou registro é mapeado para uma entidade de seu projeto
  4. É retornado para o cliente um resultado que contenha a URL final, a qual ele deve ser redirecionado automaticamente

Stack Tecnológico

Não há requerimentos específicos para linguagens, somos poliglotas. Utilize a linguagem que você se sente mais confortável.

Bonus Points

  1. Crie testcases para todas as funcionalidades criadas
  2. Crie um endpoint que mostre as dez URL's mais acessadas
  3. Crie um client para chamar sua API
  4. Faça um diagrama de sequencia da implementação feita nos casos de uso (Dica, use o https://www.websequencediagrams.com/)
  5. Monte um deploy da sua solução utilizando containers