Desafio Java Concrete

Desafio técnico para evaluar el conocimiento de los aspirantes a unirse al equipo de Backend.

Contenido

El Desafio

Escenario

Recientemente te has unido a un equipo que esta desarrollando una aplicación mobile para una gran compañía de e-commerce.
Esta aplicación esta dirigida a dispositivos de bajo rendimiento hasta dispositivos con gran poder de procesamiento.
El cliente ya cuenta con un backend establecido que contiene todas las reglas e información de negocio, pero algunos sistemas dependen de tecnologías legadas que pueden ser inestables.
Tu eres responsable de construir la API que integrará con estos servicios y proveerá todas las informaciones que Mobile necesita.
Para las próximas iteraciones, el equipo va a trabajar en la Pantalla de Início y tu debes construir todo(s) los endpoint(s) que se requieran para integrar con los servicios y proveer la información para la pantalla.

APIs

Necesitarás consumir los siguientes servicios:

Features

El equipo Mobile necesita construir una pantalla de inicio que debe mostrar:

  • Carrusel con Top 5 categorias.
  • Carrusel con cupones que no han expirado.
  • Tabla (Grid) con las categorias restantes.
  • Mobile no necesita de todas las imagenes del modelo de subcategorías, solamente la imagen más pequeña. Tu podrías tener que filtrar la respuesta, si tu quieres.

Puntos a Considerar

  • La API de Cupones es inestable y a veces demora en responder. ¿Qué podemos hacer para que este problema no se replique en otras capas? ¿Habrá algún patrón que nos ayude?
  • La API de Categorias responde un modelo complejo de manejar. ¿Qué podríamos hacer para simplificar este modelo y que las integraciones con su aplicación sean más sencillas?

¿Qué nos Gustaría Ver?

Eres libre para implementar la solución de la forma que consideres mejor, pero debes considerar el escenario, objetivo, implicaciones de performance y stack/pool de tecnología propuesta abajo.

  • Nos enfocamos mucho en la calidad de nuestros proyectos y nos gustaría ver alguna estrategia aplicada. Puedes usar, por ejemplo, Pruebas Unitárias.
  • No queremos que la experiencia de usuario se vea afectada por el rendimiento de los servicios;
  • Usted tiene 1 semana para completar el desafio. Si necesitas mas tiempo, no hay problema, puede hablar con nosotros y veremos que podemos hacer :)
  • Documentación de como configurar y ejecutar el proyecto. Puede sobrescribir el README.md para eso.

Deseables

  • Podría ser bueno una documentación de API. Sugerencia: Swagger.
  • Ejecutando con Docker.

Stack/Pool de Tecnologías

  • Java 8 o superiores.
  • Cualquier Framework Web. Sugerencia: Spring Boot.
  • Cualquier API Client. Sugerencia: Feign.
  • De preferencia Gradle como sistema de compilación.
  • Tu eres libre para escoger librerias y frameworks de pruebas que mas te guste. Nuestra sugerencia es: JUnit, Mockito.

Forma de Entrega

Siga los siguientes pasos para implementar y enviar este desafío:

  • Haga un Fork a este repositorio. Puedes mirar esta guía para mayores informaciones: Como hacer fork de un repositorio.
  • Implemente el desafío.
  • Después de completar el desafío, realice un Pull Request a este repositorio, utilizando la interface de Github. Creando un Pull Request.
  • Si es posible, deja tu repositorio publico para hacer la revisión de código más sencilla.

Importante

No intente hacer un PUSH directo a ESTE repositorio!