¡La familia "Jackson" necesita una API estática! Necesitamos construir las estructuras de datos (data structures) y crear un API endpoint para interactuar con él utilizando Hoppscotch (recomendado) o Postman.
Este proyecto viene con los archivos necesarios para comenzar a trabajar de inmediato.
Recomendamos abrir este mismo repositorio usando un entorno de desarrollo como Codespaces (recomendado) o Gitpod. Alternativamente, puedes clonarlo en tu computadora local usando el comando git clone
.
Este es el repositorio que necesitas abrir:
https://github.com/breatheco-de/exercise-family-static-api
-
Instala las dependencias del proyecto
$ pipenv install
. -
Entra dentro del virtual environment
$ pipenv shell
-
Inicia el servidor flask
$ pipenv run start
- Evalúa tu código con el comando
$ pipenv run test
-
Crea el código necesario para desarrollar los API endpoints descritos más adelante.
-
Los únicos dos archivos que tienes que editar son:
src/datastructure.py
: Contiene la estructura de datosFamilyStructure
que se encarga de manejar la familia.src/app.py
: Es el código de tu API, aquí debes agregar los endpoints (rutas) y la lógica de programación.
- Hemos preparado un conjunto de pruebas automatizadas que te darán una idea de si tu código es correcto, ejecuta las pruebas escribiendo
$ pipenv run test
en la línea de comandos (terminal o consola).
Cada miembro de la familia Jackson debe ser un diccionario, equivalente a Objetos literales en JS - y tienen estos valores:
+ id: Int
+ first_name: String
+ last_name: String (Siempre Jackson)
+ age: Int > 0
+ lucky_numbers: List of integers
La estructura de datos family será una clase con la siguiente estructura:
class FamilyStructure:
def __init__(self, last_name):
self.last_name = last_name
self._next_id = 1
self._members = []
# Este método genera un 'id' único al agregar miembros a la lista (no debes modificar esta función)
def _generate_id(self):
generated_id = self._next_id
self._next_id += 1
return generated_id
def add_member(self, member):
## Debes implementar este método
## Agrega un nuevo miembro a la lista de _members
pass
def delete_member(self, id):
## Debes implementar este método
## Recorre la lista y elimina el miembro con el id proporcionado
pass
def get_member(self, id):
## Debes implementar este método
## Recorre la lista y obtén el miembro con el id proporcionado
pass
def get_all_members(self, id):
return self._members
Nota: no olvides inicializar la clase: jackson_family = FamilyStructure('Jackson')
antes de las rutas.
John Jackson
33 Years old
Lucky Numbers: 7, 13, 22
Jane Jackson
35 Years old
Lucky Numbers: 10, 14, 3
Jimmy Jackson
5 Years old
Lucky Numbers: 1
Esta API debe tener 4 endpoints, todos devuelven JSON:
Devuelve todos los miembros de la familia.
GET /members
status_code 200 si se realizó con éxito, 400 si hubo un error por parte del cliente, 500 si el servidor encuentra un error
RESPONSE BODY (content-type: application/json):
[] <!--- Lista de miembros de la familia -->
Devuelve el miembro de la familia para el cual id == member_id
.
GET /member/<int:member_id>
RESPONSE (content_type: application/json):
status_code 200 si se realizó con éxito, 400 si hubo un error por parte del cliente, 500 si el servidor encuentra un error
body: <!--- el objeto json del miembro de la familia -->
{
"id": Int,
"first_name": String,
"age": Int,
"lucky_numbers": List
}
Agrega un nuevo miembro a la estructura de datos de la familia.
POST /member
REQUEST BODY (content_type: application/json):
{
id: Int,
first_name: String,
age: Int,
lucky_numbers: []
}
RESPONSE (content_type: application/json):
status_code 200 si se realizó con éxito, 400 si hubo un error por parte del cliente, 500 si el servidor encuentra un error
Elimina el miembro de la familia para el cual id == member_id
.
DELETE /member/<int:member_id>
RESPONSE (content_type: application/json):
status_code 200 si se realizó con éxito, 400 si hubo un error por parte del cliente, 500 si el servidor encuentra un error
body: {
done: True
}
- Todas las solicitudes y respuestas deben estar en content/type: application/json
- Los códigos de respuesta deben ser
200
para solicitudes exitosas,400
para una solicitud incorrecta o404
para no encontrados. - Este ejercicio no incluye una base de datos, todo se debe hacer en durante el tiempo de ejecución del programa (memoria RAM).
Este y otros proyectos son usados para aprender a programar por parte de los alumnos de 4Geeks Academy Coding Bootcamp realizado por Alejandro Sánchez y muchos otros contribuyentes. Conoce más sobre nuestros Cursos de Programación para convertirte en Full Stack Developer, o nuestro Data Science Bootcamp.