Source code for tests.system.put_cars_negaive_test

#!/path/to/interpreter

"""
Flask App REST API testing: PUT
"""

#  Created by Egor Kostan.
#  GitHub: https://github.com/ikostan
#  LinkedIn: https://www.linkedin.com/in/egor-kostan/

import allure
import requests
from tests.system.base_test import BaseTestCase
from api.cars_app import USER_LIST


[docs]@allure.epic('Simple Flask App') @allure.parent_suite('REST API') @allure.suite("System Tests") @allure.sub_suite("Negative Tests") @allure.feature("PUT") @allure.story('Cars') class PutCarNegativeTestCase(BaseTestCase): """ Simple Flask App Negative Test: PUT call > cars """
[docs] def setUp(self) -> None: self.put_url = '/cars/update/Vento' self.original = {"name": "Vento", "brand": "Volkswagen", "price_range": "7-10 lacs", "car_type": "sedan"} self.updated1 = {'name': 'Vento', 'brand': 'Ford', 'price_range': '2-3 lacs', 'car_type': 'sedan'} self.updated2 = {'name': 'Vento', 'brand': 'Ford', 'price_range': '3-5 lacs', 'car_type': 'convertible'}
[docs] def test_put_update_car_admin_wrong_credentials(self): """ Update car properties using wrong admin user credentials. :return: """ allure.dynamic.title("Update car using wrong admin user credentials") allure.dynamic.severity(allure.severity_level.BLOCKER) with allure.step("Verify user permissions"): username = USER_LIST[0]['name'] password = USER_LIST[1]['password'] self.assertEqual("admin", USER_LIST[0]['perm']) with allure.step("Send PUT request"): response = requests.put(self.URL + self.put_url, json=self.updated1, auth=(username, password)) with allure.step("Verify status code"): self.assertEqual(401, response.status_code) with allure.step("Verify error message"): self.assertEqual("Authenticate with proper credentials", response.json()["message"])
[docs] def test_put_update_car_non_admin_wrong_credentials(self): """ Update car properties using wrong non admin user credentials. :return: """ allure.dynamic.title("Update car using wrong non admin user credentials") allure.dynamic.severity(allure.severity_level.BLOCKER) with allure.step("Verify user permissions"): username = USER_LIST[1]['name'] password = USER_LIST[3]['password'] self.assertEqual("non_admin", USER_LIST[1]['perm']) with allure.step("Send PUT request"): response = requests.put(self.URL + self.put_url, json=self.updated2, auth=(username, password)) with allure.step("Verify status code"): self.assertEqual(401, response.status_code) with allure.step("Verify error message"): self.assertEqual("Authenticate with proper credentials", response.json()["message"])