Giter VIP home page Giter VIP logo

prueba-store's Introduction

PRUEBA DE DESARROLLADOR BACK

Proyecto desarrollado con laravel 8

Estructura de datos

Para la realización de esta prueba se definieron 3 tablas:

  • products:

En esta tabla se encuentran los productos existentes dentro de la tienda, y donde se agregarán los nuevos productos. La estructura es la siguente

Columns:

     id -> int UN AI PK 
     SKU -> varchar(255) 
     name -> varchar(255) 
     description -> varchar(255) -> La descripción es opcional
     photo -> text  -> se debe guardar una imagen en base 64
     price -> double(8,2)   -> indica el total del producto incluido el iva
     iva -> enum('0','10','19')
  • bills:

En esta tabla se almacenan las facturas generadas.La estructura de esta es:

Columns:

 id -> int UN AI PK 
client -> varchar(255) 
phone -> varchar(255) 
email -> varchar(255) 
subtotal -> double(8,2) 
IVA -> double(8,2) 
total -> double(8,2) 
created_at -> timestamp 
updated_at -> timestamp
  • bill_product:

En esta tabla se relacionan los productos que contiene cada factura generada con su respectiva cantidad. Se presenta la estructura

Columns:

    id -> bigint UN AI PK 
    quantity -> int 
    bill_id -> int UN 
    product_id -> int UN 
    created_at -> timestamp 
    updated_at -> timestamp

Creación de datos:

Dentro del proyecto se adjunta la colección de postman de ejemplo para guardar los datos y poder consultarlos a través de los endpoints.

  • Creación de producto:

    Como se habia mencionado antes, la photo se debe enviar en formato string para almacenar en base64 directamente en la db. El valor del iba se debe enviar en formato string, los valores permitidos son solo 0,10,19 que representa el porcentaje de iba.
    {
    "name":"producto 1",
    "SKU":"aqw123",
    "price":50000,
    "iva":"19",
    "description":"producto de prueba 3",
    "photo":""
}
  • Creación de factura:

    Para la creacion de la factura se debe tener en cuenta de enviar los valores relacionados anteriormente en la estructura, además de un arreglo de productos relacionando su id y la cantidad de cada producto. A continuación se muestra un ejempo (hay que asegurarse que los prodcutos que se envien deben estár previamente registrados sino el endpoint responderá error).
    {
        "client":"cliente1",
        "phone":"+574123",
        "email":"[email protected]",
        "products":[
            {
                "quantity":3,
                "product_id":2
            },
            {
                "quantity":1,
                "product_id":3
            }
        ]
    }

Base de datos:

PAra el proyecto se utilizó una base de datos mysql, se adjunta el script de docker para generar una base de datos rapidamente, con la configuración necesaria para funcionar sobre el proyecto:

docker run --name mysql -p 4306:3306 -e MYSQL_USER=admin -e MYSQL_PASSWORD=123456789 -e MYSQL_ROOT_PASSWORD=admin1234 -e MYSQL_DATABASE=productstore -d mysql 

Adicionamente se adjunta dentro de el proyecto el dump de la base de datos, con datos de prueba generados para las pruebas en la carpeta DumpDB.


Respuesta preguntas parte 2.

  • Si se requiere manejar inventario en el ejemplo anterior, explique como lo haría:

    Se agregaría una columna en la tabla products donde indique la cantidad de productos que existen en el inventario, y cada vez que se genere una nueva factura se descuenta la cantidad de cada producto seleccionado, de dicha columna.

  • Si se requiere crear un reporte de ventas en el ejemplo anterior, explique cómo lo haría:

    Se pueden crear filtros por fechas, productos, total, entre otros , para que el usuario pueda cruzar la info y sacarle el mayor valor a los reportes, además que se podrían generar en archivos por ejemplo excel, para que se le puedan realizar posteriores analisis por parte del usuario.

  • Si se requiere enviar estas facturas de venta 1 vez al día a un sistema externo usando un webservice SOAP en formato txt, explique cómo lo haría.

    Se puede crear un job de cron, y configurarlo para que se ejecute una vez al dia, en el cual se consuma el servicio del webservice externo para asi enviar el archivo.

    Cron es una buena opción gracias a que permite definir con bastante detalle el momento en que se debe ejecutar, y esto puede ser muy util para cuando los servidores y procesos cuentan con alta transaccionalidad poder elegir un momento u hora donde la carga de estos servidores sea poca.

prueba-store's People

Contributors

eduuardp avatar

Stargazers

Alejandro Jesus del Campillo Jaime avatar

Watchers

James Cloos avatar  avatar

Forkers

informaticacba

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.