Esempio n. 1
0
def test_delete_controller_wrong_user(flask_app, auth_user, es_create, willorders_ws_db_session):
    prod_list = es_create("products", 3)
    user_slug = uuid_to_slug(uuid4())
    obj = OrderFactory.create(user_slug=user_slug)
    willorders_ws_db_session.commit()

    slug = obj.uuid_slug
    prod_id_list = [p.meta["id"] for p in prod_list]

    amount = 1
    for es_id in prod_id_list:
        product = ProductFactory.create(es_id=es_id)
        OrderProductFactory.create(order=obj, product=product, amount=amount)
        amount += 1

    willorders_ws_db_session.commit()

    with flask_app.test_client(user=auth_user) as client:
        response = client.delete(
            "api/order/delete/%s" % slug
        )

    data = json.loads(response.data)
    assert data["error"] == {}
    assert response.status_code == 404
Esempio n. 2
0
def test_delete_controller(flask_app, auth_user, es_create, willorders_ws_db_session):
    prod_list = es_create("products", 5)
    user_slug = auth_user.uuid_slug
    obj = OrderFactory.create(user_slug=user_slug)
    willorders_ws_db_session.commit()

    slug = obj.uuid_slug
    prod_id_list = [p.meta["id"] for p in prod_list]

    for es_id in prod_id_list:
        product = ProductFactory.create(es_id=es_id)
        OrderProductFactory.create(order=obj, product=product, amount=2)

    willorders_ws_db_session.commit()

    assert len(willorders_ws_db_session.query(Order).all()) == 1
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 5

    with flask_app.test_client(user=auth_user) as client:
        response = client.delete(
            "api/order/delete/%s" % slug
        )

    data = json.loads(response.data)
    assert data == {}
    assert response.status_code == 200
    assert len(willorders_ws_db_session.query(Order).all()) == 0
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 0

    with flask_app.test_client(user=auth_user) as client:
        response = client.delete(
            "api/order/delete/%s" % slug
        )

    data = json.loads(response.data)
    assert data["error"] == {}
    assert response.status_code == 404
    assert len(willorders_ws_db_session.query(Order).all()) == 0
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 0
Esempio n. 3
0
def test_select_by_slug_controller(flask_app, auth_user, es_create,
                                   willorders_ws_db_session):
    prod_list = es_create("products", 5)
    user_slug = auth_user.uuid_slug
    obj = OrderFactory.create(user_slug=user_slug)
    willorders_ws_db_session.commit()

    slug = obj.uuid_slug
    prod_id_list = [p.meta["id"] for p in prod_list]

    amount = 1
    for es_id in prod_id_list:
        product = ProductFactory.create(es_id=es_id)
        OrderProductFactory.create(order=obj, product=product, amount=amount)
        amount += 1

    willorders_ws_db_session.commit()

    with flask_app.test_client(user=auth_user) as client:
        response = client.get("api/order/%s" % slug)

    data = json.loads(response.data)
    OrderSchema().load(data)
    assert response.status_code == 200
    assert data["slug"] == slug
    assert data["product_types"] == len(prod_list)
    assert data["items_amount"] == ((1 + len(prod_list)) * len(prod_list)) / 2
    assert len(data["products"]) == len(prod_list)

    for item in [item.to_dict() for item in obj.items]:
        product = next(p for p in data["products"]
                       if p["id"] == item["item_id"])
        assert product["amount"] == item["amount"]

    with flask_app.test_client(user=auth_user) as client:
        response = client.get("api/order/WILLrogerPEREIRAslugBR")

    data = json.loads(response.data)
    assert data["error"] == {}
    assert response.status_code == 404
Esempio n. 4
0
def test_delete(domain_url, auth_user, auth_session, es_create, willorders_ws_db_session):
    prod_list = es_create("products", 5)
    user_slug = auth_user.uuid_slug
    obj = OrderFactory.create(user_slug=user_slug)
    willorders_ws_db_session.commit()

    slug = obj.uuid_slug
    prod_id_list = [p.meta["id"] for p in prod_list]

    for es_id in prod_id_list:
        product = ProductFactory.create(es_id=es_id)
        OrderProductFactory.create(order=obj, product=product, amount=2)

    willorders_ws_db_session.commit()

    assert len(willorders_ws_db_session.query(Order).all()) == 1
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 5

    response = auth_session.delete(
        domain_url + "/api/order/delete/%s" % slug
    )

    data = response.json()
    assert data == {}
    assert response.status_code == 200
    assert len(willorders_ws_db_session.query(Order).all()) == 0
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 0

    response = auth_session.delete(
        domain_url + "/api/order/delete/%s" % slug
    )

    data = response.json()
    assert data["error"] == {}
    assert response.status_code == 404
    assert len(willorders_ws_db_session.query(Order).all()) == 0
    assert len(willorders_ws_db_session.query(Product).all()) == 5
    assert len(willorders_ws_db_session.query(OrderProduct).all()) == 0
Esempio n. 5
0
def test_select_by_slug_wrong_user(domain_url, auth_session, es_create,
                                   willorders_ws_db_session):
    prod_list = es_create("products", 3)
    user_slug = uuid_to_slug(uuid4())
    obj = OrderFactory.create(user_slug=user_slug)
    willorders_ws_db_session.commit()

    slug = obj.uuid_slug
    prod_id_list = [p.meta["id"] for p in prod_list]

    amount = 1
    for es_id in prod_id_list:
        product = ProductFactory.create(es_id=es_id)
        OrderProductFactory.create(order=obj, product=product, amount=amount)
        amount += 1

    willorders_ws_db_session.commit()

    response = auth_session.get(domain_url + "/api/order/%s" % slug)

    data = response.json()
    assert data["error"] == {}
    assert response.status_code == 404