Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Luis Martinez - PlatziMaster_Backend #45

Open
wants to merge 9 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 0 additions & 38 deletions .github/workflows/e2e.yml

This file was deleted.

68 changes: 13 additions & 55 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,65 +1,23 @@
# Prueba de Backend NodeJS
Crear un CRUD para crear productos conectado a MongoDB.
Visit the app [here](https://immense-everglades-01880.herokuapp.com/), deployed at Heroku.
### Category Model
- [x] name
- [ ] image

### CRUD de categorías
- [x] GET `/api/categories/` Endpoint para retornar la lista de categorías.
- [ ] GET `/api/categories/{id}/` Endpoint para retornar un categoría.
- [x] POST `/api/categories/` Endpoint para crear un categoría.
- [x] PUT `/api/categories/{id}/` Endpoint para modificar un categoría.
- [x] DELETE `/api/categories/{id}/` Endpoint para eliminar un categoría.
- [ ] GET `/api/categories/{id}/products` Endpoint para retornar la lista de productos que pertenecen a una categoría.

### Instalación
```
npm install
```

### Ejecución
```
npm run start
```

## Modelos

### Product
Un Producto debe tener los siguientes atributos:
- name
- price
- description
- categoryId
- image

### Category
Una Categoría debe tener los siguientes atributos:
- name
- image

## Requerimientos

### CRUD de productos
- [ ] GET `/api/products/` Endpoint para retornar la lista de productos.
- [ ] GET `/api/products/{id}/` Endpoint para retornar un producto.
- [ ] POST `/api/products/` Endpoint para crear un producto.
- [ ] PUT `/api/products/{id}/` Endpoint para modificar un producto.
- [ ] DELETE `/api/products/{id}/` Endpoint para eliminar un producto.

### CRUD de categorías
- [ ] GET `/api/categories/` Endpoint para retornar la lista de categorías.
- [ ] GET `/api/categories/{id}/` Endpoint para retornar un categoría.
- [ ] POST `/api/categories/` Endpoint para crear un categoría.
- [ ] PUT `/api/categories/{id}/` Endpoint para modificar un categoría.
- [ ] DELETE `/api/categories/{id}/` Endpoint para eliminar un categoría.
- [ ] GET `/api/categories/{id}/products` Endpoint para retornar la lista de productos que pertenecen a una categoría.

## Instrucciones

1. Utilizando el archivo `.env-example` realiza la configuración para tu archivo `.env`.
2. Proponer una arquitectura la aplicación.
3. Verificar que la conexión de tu aplicación a MongoDBAtlas funcione.
4. Realizar el deploy de tu aplicación.

### Correr pruebas en local
```
npm run test:e2e
npm start
```
1. Debes tener mongoDB en local corriendo para hacer las pruebas.
2. Y poner las variables de ambiente en el archivo `.env`.


## Enviar solución de reto
Debes de crear un "Fork" de este proyecto, revolverlo desde tu cuenta personal.

### Licencia
La licencia [MIT](https://opensource.org/licenses/MIT).
153 changes: 0 additions & 153 deletions e2e/categories.e2e.js

This file was deleted.

6 changes: 0 additions & 6 deletions e2e/jest-e2e.json

This file was deleted.

Loading