CSCI-GA-2820-FA24-003 / wishlists

NYU DevOps Wishlists Service Fall 2024
Apache License 2.0
0 stars 2 forks source link

Wishlists Service

Build Status codecov License made-with-python

This repository contains the Wishlists microservice. Refer to the following sections for the RESTful routes for wishlists and items.

Endpoint              Methods  Rule
----------------      -------  -------------------------------------------
index                  GET      /

list_wishlists         GET      /wishlists
create_wishlists       POST     /wishlists
read_wishlists         GET      /wishlists/<wishlist_id>
update_wishlists       PUT      /wishlists/<wishlist_id>
delete_wishlists       DELETE   /wishlists/<wishlist_id>

list_items             GET      /wishlists/<int:wishlist_id>/items
create_items           POST     /wishlists/<wishlist_id>/items
read_items             GET      /wishlists/<wishlist_id>/items/<item_id>
update_item            PUT      /wishlists/<wishlist_id>/items/<item_id>
delete_items           DELETE   /wishlists/<wishlist_id>/items/<item_id>

The test cases have 97% test coverage and can be run with pytest (or make test)

Contents

The project contains the following:

.gitignore          - this will ignore vagrant and other metadata files
.flaskenv           - Environment variables to configure Flask
.gitattributes      - File to gix Windows CRLF issues
.devcontainers/     - Folder with support for VSCode Remote Containers
dot-env-example     - copy to .env to use environment variables
pyproject.toml      - Poetry list of Python libraries required by your code

service/                   - service python package
├── __init__.py            - package initializer
├── config.py              - configuration parameters
├── models.py              - module with business models
├── routes.py              - module with service routes
└── common                 - common code package
    ├── cli_commands.py    - Flask command to recreate all tables
    ├── error_handlers.py  - HTTP error handling code
    ├── log_handlers.py    - logging setup code
    └── status.py          - HTTP status constants

tests/                     - test cases package
├── __init__.py            - package initializer
├── factories.py           - Factory for testing with fake objects
├── test_cli_commands.py   - test suite for the CLI
├── test_models.py         - test suite for business models
└── test_routes.py         - test suite for service routes

License

Copyright (c) 2016, 2024 John Rofrano. All rights reserved.

Licensed under the Apache License. See LICENSE

This repository is part of the New York University (NYU) masters class: CSCI-GA.2820-001 DevOps and Agile Methodologies created and taught by John Rofrano, Adjunct Instructor, NYU Courant Institute, Graduate Division, Computer Science, and NYU Stern School of Business.