Source code for tests.system.get_cars_negative_test

#!/path/to/interpreter

"""
Flask App REST API testing: GET
"""

#  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("GET") @allure.story('Cars') class GetCarsNegativeTestCase(BaseTestCase): """ Simple Flask App Negative Test: GET call > cars """
[docs] def setUp(self) -> None: """ Test data preparation :return: """ with allure.step("Prepare test data"): self.cars_url = '/cars'
[docs] def test_get_list_of_cars_admin_wrong_credentials(self): """ Get full list of cars using wrong admin user credentials. Wrong password + Correct username. Correct password + Wrong username. :return: """ allure.dynamic.title("Get list of cars 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 GET request with wrong credentials"): response = requests.get(self.URL + self.cars_url, 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_get_list_of_cars_empty_credentials(self): """ Get full list of cars using empty username/password. Empty password + Empty username. :return: """ allure.dynamic.title("Get list of cars empty username/password") allure.dynamic.severity(allure.severity_level.BLOCKER) username = '' password = '' with allure.step("Send GET request with empty username/password"): response = requests.get(self.URL + self.cars_url, 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_get_list_of_cars_non_admin_wrong_credentials(self): """ Get full list of cars using wrong non admin user credentials. Wrong password + Correct username. Correct password + Wrong username. :return: """ allure.dynamic.title("Get list of cars 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 GET request "): response = requests.get(self.URL + self.cars_url, 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_get_list_of_cars_non_admin_sedan_wrong_credentials(self): """ Get full list of cars of type = 'sedan' using wrong non admin user credentials. :return: """ allure.dynamic.title("Get list of cars of type = 'sedan' " "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 GET request with wrong credentials"): response = requests.get(self.URL + self.cars_url + '/filter/sedan', 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_get_list_of_cars_sedan_empty_credentials(self): """ Get full list of cars of type = 'sedan' using empty credentials. :return: """ allure.dynamic.title("Get list of cars of type = 'sedan' " "using empty credentials") allure.dynamic.severity(allure.severity_level.BLOCKER) username = '' password = '' with allure.step("Send GET request with wrong credentials"): response = requests.get(self.URL + self.cars_url + '/filter/sedan', 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_get_list_of_cars_admin_hatchback_wrong_credentials(self): """ Get full list of cars from type = 'hatchback' using wrong admin user credentials. :return: """ allure.dynamic.title("Get list of cars of type = 'hatchback' " "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 GET request"): response = requests.get(self.URL + self.cars_url + '/filter/hatchback', 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_get_car_by_name_non_admin_swift_wrong_credentials(self): """ Get car data by name = 'swift' using wrong non admin user credentials. :return: """ allure.dynamic.title("Get car data by name 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 GET request"): response = requests.get(self.URL + self.cars_url + '/Swift', 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_get_car_by_name_swift_empty_credentials(self): """ Get car data by name = 'swift' using empty user credentials. :return: """ allure.dynamic.title("Get car data by name using " "empty user credentials") allure.dynamic.severity(allure.severity_level.BLOCKER) username = '' password = '' with allure.step("Send GET request"): response = requests.get(self.URL + self.cars_url + '/Swift', 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"])