diff --git a/.coverage b/.coverage new file mode 100644 index 000000000..64e7feaa0 Binary files /dev/null and b/.coverage differ diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..17c68def0 --- /dev/null +++ b/.gitignore @@ -0,0 +1,3 @@ +.idea +.venv +__pycache__ \ No newline at end of file diff --git a/allure_results/0190a364-8fd7-4279-8356-a2a6961435b6-result.json b/allure_results/0190a364-8fd7-4279-8356-a2a6961435b6-result.json new file mode 100644 index 000000000..ab8827528 --- /dev/null +++ b/allure_results/0190a364-8fd7-4279-8356-a2a6961435b6-result.json @@ -0,0 +1 @@ +{"name": "Проверка начального состояния атрибута bun", "status": "passed", "description": "Проверяем что начальное состояние атрибута bun равняется None", "start": 1769972811494, "stop": 1769972811495, "uuid": "096e1973-b0d0-4357-8349-4604908d8013", "historyId": "ea1508e5456b7d90acd8fb6464b97361", "testCaseId": "ea1508e5456b7d90acd8fb6464b97361", "fullName": "tests.test_burger.TestBurger#test_bun_initial_state", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/030aa4bb-218d-4350-9f17-a232a53c9a7b-container.json b/allure_results/030aa4bb-218d-4350-9f17-a232a53c9a7b-container.json new file mode 100644 index 000000000..52fc2280e --- /dev/null +++ b/allure_results/030aa4bb-218d-4350-9f17-a232a53c9a7b-container.json @@ -0,0 +1 @@ +{"uuid": "378a2757-05f0-4118-ad8d-1461bfb4cc77", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811613, "stop": 1769972811613}], "start": 1769972811613, "stop": 1769972811615} \ No newline at end of file diff --git a/allure_results/074621ad-4525-420c-9509-fc94b97ab606-result.json b/allure_results/074621ad-4525-420c-9509-fc94b97ab606-result.json new file mode 100644 index 000000000..7c02460a4 --- /dev/null +++ b/allure_results/074621ad-4525-420c-9509-fc94b97ab606-result.json @@ -0,0 +1 @@ +{"name": "Проверка начального состояния атрибута ingredients", "status": "passed", "description": "Проверяем что начальное состояние атрибута ingredients равняется пустому списку", "start": 1769972811500, "stop": 1769972811501, "uuid": "dd25ee07-c605-4d9c-8739-50aa40f31df6", "historyId": "8c010eed90e0bdbb72754aa1bffdb7c7", "testCaseId": "8c010eed90e0bdbb72754aa1bffdb7c7", "fullName": "tests.test_burger.TestBurger#test_ingredients_initial_state", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/07f2f1da-42d6-4bad-bc1c-fd4852e8012f-container.json b/allure_results/07f2f1da-42d6-4bad-bc1c-fd4852e8012f-container.json new file mode 100644 index 000000000..26fa3e888 --- /dev/null +++ b/allure_results/07f2f1da-42d6-4bad-bc1c-fd4852e8012f-container.json @@ -0,0 +1 @@ +{"uuid": "f32b100e-8b84-4c1f-be50-f319c64bb0a2", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811588, "stop": 1769972811588}], "start": 1769972811588, "stop": 1769972811591} \ No newline at end of file diff --git a/allure_results/09a53d1f-389e-4899-a315-bd330870101b-result.json b/allure_results/09a53d1f-389e-4899-a315-bd330870101b-result.json new file mode 100644 index 000000000..ecc25bddf --- /dev/null +++ b/allure_results/09a53d1f-389e-4899-a315-bd330870101b-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода add_ingredient", "status": "passed", "description": "Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients", "parameters": [{"name": "mock_ingredients", "value": "[]"}, {"name": "expected_len", "value": "1"}], "start": 1769972811517, "stop": 1769972811518, "uuid": "6fbdbb86-e080-4c5c-9391-e77f72ac8397", "historyId": "6ac19aa76f28d12490671a680f559e3f", "testCaseId": "30496d62bf692687f1cd0f5be1a8a3a1", "fullName": "tests.test_burger.TestBurger#test_add_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/1a71a702-1b3c-49c4-a618-f1409a77ae6f-container.json b/allure_results/1a71a702-1b3c-49c4-a618-f1409a77ae6f-container.json new file mode 100644 index 000000000..70fc54d3a --- /dev/null +++ b/allure_results/1a71a702-1b3c-49c4-a618-f1409a77ae6f-container.json @@ -0,0 +1 @@ +{"uuid": "c0f9a046-62a7-41f4-8aa2-1403cb0eaaf7", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811607, "stop": 1769972811607}], "start": 1769972811607, "stop": 1769972811609} \ No newline at end of file diff --git a/allure_results/1cc6a018-3aa2-4c29-ae20-558da5c44119-container.json b/allure_results/1cc6a018-3aa2-4c29-ae20-558da5c44119-container.json new file mode 100644 index 000000000..5fc1831a5 --- /dev/null +++ b/allure_results/1cc6a018-3aa2-4c29-ae20-558da5c44119-container.json @@ -0,0 +1 @@ +{"uuid": "1cb78068-afc4-41de-b228-7e1db00b3348", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811601, "stop": 1769972811601}], "start": 1769972811601, "stop": 1769972811602} \ No newline at end of file diff --git a/allure_results/20a1e461-c89b-404b-9576-f192a692f0d8-container.json b/allure_results/20a1e461-c89b-404b-9576-f192a692f0d8-container.json new file mode 100644 index 000000000..75054490d --- /dev/null +++ b/allure_results/20a1e461-c89b-404b-9576-f192a692f0d8-container.json @@ -0,0 +1 @@ +{"uuid": "1b28ed46-ccf5-4912-b0c0-5997f175bfb9", "befores": [{"name": "expected_price", "status": "passed", "start": 1769972811588, "stop": 1769972811588}], "start": 1769972811588, "stop": 1769972811590} \ No newline at end of file diff --git a/allure_results/23d49498-f241-4ee0-89a4-af214cdb5ea2-result.json b/allure_results/23d49498-f241-4ee0-89a4-af214cdb5ea2-result.json new file mode 100644 index 000000000..3818ab39f --- /dev/null +++ b/allure_results/23d49498-f241-4ee0-89a4-af214cdb5ea2-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода add_ingredient", "status": "passed", "description": "Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients", "parameters": [{"name": "mock_ingredients", "value": "[, ]"}, {"name": "expected_len", "value": "2"}], "start": 1769972811529, "stop": 1769972811529, "uuid": "1cf2c56f-a4d0-4374-b895-4b1528a86642", "historyId": "bdbfe6511484e0d807ef7030e2b53828", "testCaseId": "30496d62bf692687f1cd0f5be1a8a3a1", "fullName": "tests.test_burger.TestBurger#test_add_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/267bfc8a-0f2e-439b-964a-a07ed3165db1-result.json b/allure_results/267bfc8a-0f2e-439b-964a-a07ed3165db1-result.json new file mode 100644 index 000000000..d49dde00a --- /dev/null +++ b/allure_results/267bfc8a-0f2e-439b-964a-a07ed3165db1-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_price", "status": "passed", "description": "Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "bun", "value": ""}, {"name": "ingredients", "value": "[, , ]"}, {"name": "expected_price", "value": "1000"}], "start": 1769972811595, "stop": 1769972811596, "uuid": "c8f43581-59fb-49d6-9e5c-d125845af0fd", "historyId": "5f70b24cf97d623bcd9898dfc4a3d948", "testCaseId": "9bc48baa4883de12242efddc23bca86a", "fullName": "tests.test_burger.TestBurger#test_get_price", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/30945e9a-1453-441b-981f-8135ca14aaae-container.json b/allure_results/30945e9a-1453-441b-981f-8135ca14aaae-container.json new file mode 100644 index 000000000..8a0dba3b1 --- /dev/null +++ b/allure_results/30945e9a-1453-441b-981f-8135ca14aaae-container.json @@ -0,0 +1 @@ +{"uuid": "a58f2ec5-fb10-4a60-9419-e46411676c05", "befores": [{"name": "mock_ingredients", "status": "passed", "start": 1769972811539, "stop": 1769972811539}], "start": 1769972811539, "stop": 1769972811542} \ No newline at end of file diff --git a/allure_results/323833b3-1128-4279-b7d0-5b01ad47ef0d-result.json b/allure_results/323833b3-1128-4279-b7d0-5b01ad47ef0d-result.json new file mode 100644 index 000000000..9e0207a97 --- /dev/null +++ b/allure_results/323833b3-1128-4279-b7d0-5b01ad47ef0d-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_price", "status": "passed", "description": "Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "bun", "value": ""}, {"name": "ingredients", "value": "[, ]"}, {"name": "expected_price", "value": "800"}], "start": 1769972811589, "stop": 1769972811589, "uuid": "988db18e-0bcc-4ca7-932f-ac2c2288792a", "historyId": "5b81d86c2cb468f96646ec3bfe1b342e", "testCaseId": "9bc48baa4883de12242efddc23bca86a", "fullName": "tests.test_burger.TestBurger#test_get_price", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/39244ea5-8d4a-4f83-afb3-1c635a5e5c76-container.json b/allure_results/39244ea5-8d4a-4f83-afb3-1c635a5e5c76-container.json new file mode 100644 index 000000000..ccedfaeb3 --- /dev/null +++ b/allure_results/39244ea5-8d4a-4f83-afb3-1c635a5e5c76-container.json @@ -0,0 +1 @@ +{"uuid": "98c72be1-c35d-46f0-b069-19768a247758", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811619, "stop": 1769972811619}], "start": 1769972811619, "stop": 1769972811622} \ No newline at end of file diff --git a/allure_results/3ae36b28-bbaa-4444-b319-767bb6c6b393-result.json b/allure_results/3ae36b28-bbaa-4444-b319-767bb6c6b393-result.json new file mode 100644 index 000000000..e0f93b290 --- /dev/null +++ b/allure_results/3ae36b28-bbaa-4444-b319-767bb6c6b393-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_price", "status": "passed", "description": "Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "bun", "value": ""}, {"name": "ingredients", "value": "[, ]"}, {"name": "expected_price", "value": "800"}], "start": 1769972811582, "stop": 1769972811583, "uuid": "8c69ea07-1685-4076-9087-16a57cdb9536", "historyId": "71aa865c68229a582788f6579d889eef", "testCaseId": "9bc48baa4883de12242efddc23bca86a", "fullName": "tests.test_burger.TestBurger#test_get_price", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/3de63cff-4ee3-4e95-8972-0a09ba82fec8-container.json b/allure_results/3de63cff-4ee3-4e95-8972-0a09ba82fec8-container.json new file mode 100644 index 000000000..08d94caa6 --- /dev/null +++ b/allure_results/3de63cff-4ee3-4e95-8972-0a09ba82fec8-container.json @@ -0,0 +1 @@ +{"uuid": "16fd7181-cb0b-4fdc-bf83-73d6897479d4", "children": ["813be3ea-e848-4d59-95ed-e3802e4e0dc9"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811619, "stop": 1769972811619}], "start": 1769972811619, "stop": 1769972811623} \ No newline at end of file diff --git a/allure_results/41b2a876-fb80-43aa-9470-5640ad39a5d1-container.json b/allure_results/41b2a876-fb80-43aa-9470-5640ad39a5d1-container.json new file mode 100644 index 000000000..ffd95a32f --- /dev/null +++ b/allure_results/41b2a876-fb80-43aa-9470-5640ad39a5d1-container.json @@ -0,0 +1 @@ +{"uuid": "fdfabaf0-3f4d-44a6-b17e-e462c5aa01d4", "children": ["86a5b3e9-4354-48bb-bffa-df41ea98d6e2"], "befores": [{"name": "mock_sauce", "status": "passed", "start": 1769972811545, "stop": 1769972811545}], "start": 1769972811545, "stop": 1769972811548} \ No newline at end of file diff --git a/allure_results/4e9384ce-8bb2-481f-8af1-fd2dd0244063-container.json b/allure_results/4e9384ce-8bb2-481f-8af1-fd2dd0244063-container.json new file mode 100644 index 000000000..dfac5ed50 --- /dev/null +++ b/allure_results/4e9384ce-8bb2-481f-8af1-fd2dd0244063-container.json @@ -0,0 +1 @@ +{"uuid": "2a812d52-ffc4-4bd9-a85f-95127d4d7b36", "children": ["47b84c62-a890-4f88-9cce-8b355bd1e29c"], "befores": [{"name": "mock_filling", "status": "passed", "start": 1769972811558, "stop": 1769972811558}], "start": 1769972811558, "stop": 1769972811561} \ No newline at end of file diff --git a/allure_results/4f1112b1-9550-4cfe-89ff-843cdb745bca-result.json b/allure_results/4f1112b1-9550-4cfe-89ff-843cdb745bca-result.json new file mode 100644 index 000000000..65f35dd28 --- /dev/null +++ b/allure_results/4f1112b1-9550-4cfe-89ff-843cdb745bca-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода add_ingredient", "status": "passed", "description": "Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients", "parameters": [{"name": "mock_ingredients", "value": "[, , ]"}, {"name": "expected_len", "value": "3"}], "start": 1769972811540, "stop": 1769972811541, "uuid": "56edb4ce-836c-4257-9ad4-994edc615191", "historyId": "a7098e5a43f611d5095878087858b19a", "testCaseId": "30496d62bf692687f1cd0f5be1a8a3a1", "fullName": "tests.test_burger.TestBurger#test_add_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/50f720f7-76a9-459e-926e-7a8e5d6e2df7-container.json b/allure_results/50f720f7-76a9-459e-926e-7a8e5d6e2df7-container.json new file mode 100644 index 000000000..8f8489a18 --- /dev/null +++ b/allure_results/50f720f7-76a9-459e-926e-7a8e5d6e2df7-container.json @@ -0,0 +1 @@ +{"uuid": "fba13b2f-97a9-4356-87fa-7fd2a1c6814e", "befores": [{"name": "expected_len", "status": "passed", "start": 1769972811528, "stop": 1769972811528}], "start": 1769972811528, "stop": 1769972811530} \ No newline at end of file diff --git a/allure_results/53f6c08f-0682-4f6c-a158-f2fb7570e1c4-container.json b/allure_results/53f6c08f-0682-4f6c-a158-f2fb7570e1c4-container.json new file mode 100644 index 000000000..1470b4637 --- /dev/null +++ b/allure_results/53f6c08f-0682-4f6c-a158-f2fb7570e1c4-container.json @@ -0,0 +1 @@ +{"uuid": "ffa05d44-0124-4360-ac2c-0426d624f3ed", "befores": [{"name": "expected_len", "status": "passed", "start": 1769972811534, "stop": 1769972811534}], "start": 1769972811534, "stop": 1769972811535} \ No newline at end of file diff --git a/allure_results/5ab5f8d4-1556-49d2-bf04-5a0f89f1ab26-container.json b/allure_results/5ab5f8d4-1556-49d2-bf04-5a0f89f1ab26-container.json new file mode 100644 index 000000000..0725789b5 --- /dev/null +++ b/allure_results/5ab5f8d4-1556-49d2-bf04-5a0f89f1ab26-container.json @@ -0,0 +1 @@ +{"uuid": "2ac32ba7-eaf7-4ab0-9113-ca5593962453", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811626, "stop": 1769972811626}], "start": 1769972811626, "stop": 1769972811628} \ No newline at end of file diff --git a/allure_results/5cd4ab1d-2cd1-451b-9835-f74c70b1df03-container.json b/allure_results/5cd4ab1d-2cd1-451b-9835-f74c70b1df03-container.json new file mode 100644 index 000000000..60c809837 --- /dev/null +++ b/allure_results/5cd4ab1d-2cd1-451b-9835-f74c70b1df03-container.json @@ -0,0 +1 @@ +{"uuid": "d4d605b1-820c-44c5-a15c-d8e1f2fe2137", "befores": [{"name": "mock_ingredients", "status": "passed", "start": 1769972811522, "stop": 1769972811522}], "start": 1769972811522, "stop": 1769972811524} \ No newline at end of file diff --git a/allure_results/60b4a5cd-317d-4e0b-9e2c-ce8ebdce0718-container.json b/allure_results/60b4a5cd-317d-4e0b-9e2c-ce8ebdce0718-container.json new file mode 100644 index 000000000..c017f1081 --- /dev/null +++ b/allure_results/60b4a5cd-317d-4e0b-9e2c-ce8ebdce0718-container.json @@ -0,0 +1 @@ +{"uuid": "aa9ba739-0ef7-43c7-a966-75f0a7b03bee", "befores": [{"name": "bun", "status": "passed", "start": 1769972811594, "stop": 1769972811594}], "start": 1769972811594, "stop": 1769972811598} \ No newline at end of file diff --git a/allure_results/60bf518c-c681-4c22-af8d-d49b163a9e0f-result.json b/allure_results/60bf518c-c681-4c22-af8d-d49b163a9e0f-result.json new file mode 100644 index 000000000..3855128b5 --- /dev/null +++ b/allure_results/60bf518c-c681-4c22-af8d-d49b163a9e0f-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_receipt", "status": "passed", "description": "Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "ingredients", "value": "[]"}], "start": 1769972811608, "stop": 1769972811608, "uuid": "a5678730-9ffd-4911-b7b9-cdd8812a9f4c", "historyId": "99c458a99b2aaa8270f055f603d84a5b", "testCaseId": "5bf52d3a38b900560c9be02b6a5d981c", "fullName": "tests.test_burger.TestBurger#test_get_receipt", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/6233a07c-f69e-40c4-9193-6d5dbcb8ab90-result.json b/allure_results/6233a07c-f69e-40c4-9193-6d5dbcb8ab90-result.json new file mode 100644 index 000000000..9c669d200 --- /dev/null +++ b/allure_results/6233a07c-f69e-40c4-9193-6d5dbcb8ab90-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_receipt", "status": "passed", "description": "Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "ingredients", "value": "[, , ]"}], "start": 1769972811626, "stop": 1769972811627, "uuid": "da8a6ead-91f2-4791-b389-466c37341302", "historyId": "bf70a98fdcf72667ec6c94dd327810c9", "testCaseId": "5bf52d3a38b900560c9be02b6a5d981c", "fullName": "tests.test_burger.TestBurger#test_get_receipt", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/6685c17f-4ec2-4e83-9340-11f324a86d8f-container.json b/allure_results/6685c17f-4ec2-4e83-9340-11f324a86d8f-container.json new file mode 100644 index 000000000..bd1feb43a --- /dev/null +++ b/allure_results/6685c17f-4ec2-4e83-9340-11f324a86d8f-container.json @@ -0,0 +1 @@ +{"uuid": "26968d0d-3129-416f-8463-fe8d2bc0b1e1", "befores": [{"name": "bun", "status": "passed", "start": 1769972811575, "stop": 1769972811575}], "start": 1769972811575, "stop": 1769972811578} \ No newline at end of file diff --git a/allure_results/6703d0e5-176c-486d-bb2a-b8d2899e8e0e-container.json b/allure_results/6703d0e5-176c-486d-bb2a-b8d2899e8e0e-container.json new file mode 100644 index 000000000..9a63b1d11 --- /dev/null +++ b/allure_results/6703d0e5-176c-486d-bb2a-b8d2899e8e0e-container.json @@ -0,0 +1 @@ +{"uuid": "db3c6f03-9613-4f5b-b229-53ec0cacef2e", "befores": [{"name": "expected_price", "status": "passed", "start": 1769972811568, "stop": 1769972811568}], "start": 1769972811568, "stop": 1769972811570} \ No newline at end of file diff --git a/allure_results/679e2274-eaf6-456c-aeb2-6e55f6606696-container.json b/allure_results/679e2274-eaf6-456c-aeb2-6e55f6606696-container.json new file mode 100644 index 000000000..09e735f6c --- /dev/null +++ b/allure_results/679e2274-eaf6-456c-aeb2-6e55f6606696-container.json @@ -0,0 +1 @@ +{"uuid": "5bec7e87-0cb7-47c4-a621-8dcc61571d07", "children": ["86a5b3e9-4354-48bb-bffa-df41ea98d6e2"], "befores": [{"name": "mock_filling", "status": "passed", "start": 1769972811546, "stop": 1769972811546}], "start": 1769972811546, "stop": 1769972811547} \ No newline at end of file diff --git a/allure_results/6879b6ad-9961-402a-aa45-8fd051db5278-container.json b/allure_results/6879b6ad-9961-402a-aa45-8fd051db5278-container.json new file mode 100644 index 000000000..0060cc581 --- /dev/null +++ b/allure_results/6879b6ad-9961-402a-aa45-8fd051db5278-container.json @@ -0,0 +1 @@ +{"uuid": "0a4959c8-5e13-495e-ac7a-2ef26fe5f82d", "befores": [{"name": "expected_price", "status": "passed", "start": 1769972811575, "stop": 1769972811575}], "start": 1769972811575, "stop": 1769972811577} \ No newline at end of file diff --git a/allure_results/68af57cd-fc5a-4fa4-8ea9-2ae2c6f22d57-container.json b/allure_results/68af57cd-fc5a-4fa4-8ea9-2ae2c6f22d57-container.json new file mode 100644 index 000000000..e0d1f6aa4 --- /dev/null +++ b/allure_results/68af57cd-fc5a-4fa4-8ea9-2ae2c6f22d57-container.json @@ -0,0 +1 @@ +{"uuid": "d36a08c9-753f-4335-aac4-e0dffcf566db", "befores": [{"name": "expected_len", "status": "passed", "start": 1769972811522, "stop": 1769972811522}], "start": 1769972811522, "stop": 1769972811523} \ No newline at end of file diff --git a/allure_results/6f850193-7840-4c3d-bbd8-f9472cc94838-container.json b/allure_results/6f850193-7840-4c3d-bbd8-f9472cc94838-container.json new file mode 100644 index 000000000..1677d06ff --- /dev/null +++ b/allure_results/6f850193-7840-4c3d-bbd8-f9472cc94838-container.json @@ -0,0 +1 @@ +{"uuid": "2f34a439-f74f-4523-baec-88ea1f410a7a", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811582, "stop": 1769972811582}], "start": 1769972811582, "stop": 1769972811584} \ No newline at end of file diff --git a/allure_results/736e7798-f4a4-4e28-bf24-4b518f881d75-container.json b/allure_results/736e7798-f4a4-4e28-bf24-4b518f881d75-container.json new file mode 100644 index 000000000..7498c9136 --- /dev/null +++ b/allure_results/736e7798-f4a4-4e28-bf24-4b518f881d75-container.json @@ -0,0 +1 @@ +{"uuid": "590cc725-776b-429c-97fc-55f29cb0c297", "children": ["30d711e7-13cf-4173-83ee-4ad4900e6473"], "befores": [{"name": "mock_sauce", "status": "passed", "start": 1769972811551, "stop": 1769972811551}], "start": 1769972811551, "stop": 1769972811554} \ No newline at end of file diff --git a/allure_results/7478d44a-c1a4-4864-bef9-0d4f4e2cf28b-container.json b/allure_results/7478d44a-c1a4-4864-bef9-0d4f4e2cf28b-container.json new file mode 100644 index 000000000..8189f482c --- /dev/null +++ b/allure_results/7478d44a-c1a4-4864-bef9-0d4f4e2cf28b-container.json @@ -0,0 +1 @@ +{"uuid": "17e6e01c-cc4b-4748-bc13-d18fa59ec1b5", "children": ["d59e55d4-fb76-4094-a6af-f71bfe27f4b6"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811503, "stop": 1769972811504}], "start": 1769972811503, "stop": 1769972811505} \ No newline at end of file diff --git a/allure_results/7a57525a-5147-40a1-bce7-89f6d8a521be-container.json b/allure_results/7a57525a-5147-40a1-bce7-89f6d8a521be-container.json new file mode 100644 index 000000000..1a005167f --- /dev/null +++ b/allure_results/7a57525a-5147-40a1-bce7-89f6d8a521be-container.json @@ -0,0 +1 @@ +{"uuid": "443be059-f653-4df9-bb4f-eb904e452306", "children": ["a5678730-9ffd-4911-b7b9-cdd8812a9f4c"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811607, "stop": 1769972811607}], "start": 1769972811607, "stop": 1769972811610} \ No newline at end of file diff --git a/allure_results/8306f9f7-69c3-4ab7-9e9e-c9c92ecf6e64-result.json b/allure_results/8306f9f7-69c3-4ab7-9e9e-c9c92ecf6e64-result.json new file mode 100644 index 000000000..066d46714 --- /dev/null +++ b/allure_results/8306f9f7-69c3-4ab7-9e9e-c9c92ecf6e64-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода set_buns", "status": "passed", "description": "Проверяем, что метод set_buns корректно устанавливает значение атрибута bun", "start": 1769972811504, "stop": 1769972811505, "uuid": "d59e55d4-fb76-4094-a6af-f71bfe27f4b6", "historyId": "526dbd1ce3838d4db9bb0071580bc3ca", "testCaseId": "526dbd1ce3838d4db9bb0071580bc3ca", "fullName": "tests.test_burger.TestBurger#test_set_buns", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/89bca703-370f-4ea0-a84e-29419e239d9e-container.json b/allure_results/89bca703-370f-4ea0-a84e-29419e239d9e-container.json new file mode 100644 index 000000000..e26451e4a --- /dev/null +++ b/allure_results/89bca703-370f-4ea0-a84e-29419e239d9e-container.json @@ -0,0 +1 @@ +{"uuid": "b28746c8-0950-4346-9818-c0309bb29f69", "children": ["8029a9b3-e5ec-43e5-b1a7-523d1ee83137"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811613, "stop": 1769972811613}], "start": 1769972811613, "stop": 1769972811616} \ No newline at end of file diff --git a/allure_results/8a432eec-dafc-4c66-a396-4d0e478d6736-container.json b/allure_results/8a432eec-dafc-4c66-a396-4d0e478d6736-container.json new file mode 100644 index 000000000..24028b3c7 --- /dev/null +++ b/allure_results/8a432eec-dafc-4c66-a396-4d0e478d6736-container.json @@ -0,0 +1 @@ +{"uuid": "12d4512b-d695-4df2-a263-655f1c0073e4", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811594, "stop": 1769972811594}], "start": 1769972811594, "stop": 1769972811597} \ No newline at end of file diff --git a/allure_results/92f90a35-0df6-44ef-af24-3c5b7a7158d1-container.json b/allure_results/92f90a35-0df6-44ef-af24-3c5b7a7158d1-container.json new file mode 100644 index 000000000..6ea78f325 --- /dev/null +++ b/allure_results/92f90a35-0df6-44ef-af24-3c5b7a7158d1-container.json @@ -0,0 +1 @@ +{"uuid": "8e94f31c-b858-42fe-a299-db4aa167ee28", "befores": [{"name": "bun", "status": "passed", "start": 1769972811587, "stop": 1769972811588}], "start": 1769972811587, "stop": 1769972811591} \ No newline at end of file diff --git a/allure_results/9a4d2c80-bed0-4f7a-bd59-275137e3d9f2-container.json b/allure_results/9a4d2c80-bed0-4f7a-bd59-275137e3d9f2-container.json new file mode 100644 index 000000000..6b19a2a4e --- /dev/null +++ b/allure_results/9a4d2c80-bed0-4f7a-bd59-275137e3d9f2-container.json @@ -0,0 +1 @@ +{"uuid": "246b8d0f-e5c9-4675-9bd1-360e0601f67a", "children": ["da8a6ead-91f2-4791-b389-466c37341302"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811625, "stop": 1769972811626}], "start": 1769972811625, "stop": 1769972811629} \ No newline at end of file diff --git a/allure_results/9aac08f4-6ce0-4034-810f-709deea71b3e-result.json b/allure_results/9aac08f4-6ce0-4034-810f-709deea71b3e-result.json new file mode 100644 index 000000000..5cef8576b --- /dev/null +++ b/allure_results/9aac08f4-6ce0-4034-810f-709deea71b3e-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_receipt", "status": "passed", "description": "Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "ingredients", "value": "[]"}], "start": 1769972811601, "stop": 1769972811602, "uuid": "b8640063-cfcf-4ae4-9a76-720b9ad15be9", "historyId": "7829af9606fda5598341d86615ec342e", "testCaseId": "5bf52d3a38b900560c9be02b6a5d981c", "fullName": "tests.test_burger.TestBurger#test_get_receipt", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/9d7f68fb-c83a-4e13-ba62-e18659e0f6ab-container.json b/allure_results/9d7f68fb-c83a-4e13-ba62-e18659e0f6ab-container.json new file mode 100644 index 000000000..5d98e0769 --- /dev/null +++ b/allure_results/9d7f68fb-c83a-4e13-ba62-e18659e0f6ab-container.json @@ -0,0 +1 @@ +{"uuid": "ec631e36-8170-4aeb-9f0b-208d1f7ad07c", "children": ["30d711e7-13cf-4173-83ee-4ad4900e6473"], "befores": [{"name": "mock_filling", "status": "passed", "start": 1769972811551, "stop": 1769972811552}], "start": 1769972811551, "stop": 1769972811553} \ No newline at end of file diff --git a/allure_results/9fbd438c-450b-4486-aed5-34254de41b3d-container.json b/allure_results/9fbd438c-450b-4486-aed5-34254de41b3d-container.json new file mode 100644 index 000000000..571e764a6 --- /dev/null +++ b/allure_results/9fbd438c-450b-4486-aed5-34254de41b3d-container.json @@ -0,0 +1 @@ +{"uuid": "425cb080-17de-41e3-9ef2-6c57037861eb", "befores": [{"name": "bun", "status": "passed", "start": 1769972811568, "stop": 1769972811568}], "start": 1769972811568, "stop": 1769972811571} \ No newline at end of file diff --git a/allure_results/a0e9eafa-4bbe-4d34-9a5e-da9bd0c67519-result.json b/allure_results/a0e9eafa-4bbe-4d34-9a5e-da9bd0c67519-result.json new file mode 100644 index 000000000..65c3fc7dc --- /dev/null +++ b/allure_results/a0e9eafa-4bbe-4d34-9a5e-da9bd0c67519-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода remove_ingredient: удаление двух ингредиентов", "status": "passed", "description": "Проверяем, что метод remove_ingredient корректно удаляет 2 ингредиента из атрибута ingredients", "start": 1769972811552, "stop": 1769972811552, "uuid": "30d711e7-13cf-4173-83ee-4ad4900e6473", "historyId": "a32698614c66b67705e85aa7602e4288", "testCaseId": "a32698614c66b67705e85aa7602e4288", "fullName": "tests.test_burger.TestBurger#test_remove_two_ingredients", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/a1f25e6f-0c3d-4673-85f8-83ac5efc54c4-container.json b/allure_results/a1f25e6f-0c3d-4673-85f8-83ac5efc54c4-container.json new file mode 100644 index 000000000..c1f503e7f --- /dev/null +++ b/allure_results/a1f25e6f-0c3d-4673-85f8-83ac5efc54c4-container.json @@ -0,0 +1 @@ +{"uuid": "4d4f8b5b-3141-49d2-ae28-09fb3fca9d28", "children": ["b8640063-cfcf-4ae4-9a76-720b9ad15be9"], "befores": [{"name": "mock_bun", "status": "passed", "start": 1769972811600, "stop": 1769972811600}], "start": 1769972811600, "stop": 1769972811603} \ No newline at end of file diff --git a/allure_results/a7d2bd4f-fe89-4338-af78-8a173b9bb172-container.json b/allure_results/a7d2bd4f-fe89-4338-af78-8a173b9bb172-container.json new file mode 100644 index 000000000..615e43247 --- /dev/null +++ b/allure_results/a7d2bd4f-fe89-4338-af78-8a173b9bb172-container.json @@ -0,0 +1 @@ +{"uuid": "6a7ad10c-c609-4e4c-bbb1-d0bb42e57064", "befores": [{"name": "expected_len", "status": "passed", "start": 1769972811539, "stop": 1769972811539}], "start": 1769972811539, "stop": 1769972811541} \ No newline at end of file diff --git a/allure_results/b37d4789-798e-401a-a86a-a0dc51350a5a-result.json b/allure_results/b37d4789-798e-401a-a86a-a0dc51350a5a-result.json new file mode 100644 index 000000000..98390b03d --- /dev/null +++ b/allure_results/b37d4789-798e-401a-a86a-a0dc51350a5a-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода add_ingredient", "status": "passed", "description": "Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients", "parameters": [{"name": "mock_ingredients", "value": "[, ]"}, {"name": "expected_len", "value": "2"}], "start": 1769972811534, "stop": 1769972811535, "uuid": "82a7ca89-26ce-483c-8ce9-e349c5879aa1", "historyId": "cf37e3b0c28fa1ea7c362b15a980cfcf", "testCaseId": "30496d62bf692687f1cd0f5be1a8a3a1", "fullName": "tests.test_burger.TestBurger#test_add_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/b63cf63c-22d3-4d72-82a4-4fd1b3cccb98-container.json b/allure_results/b63cf63c-22d3-4d72-82a4-4fd1b3cccb98-container.json new file mode 100644 index 000000000..00819cc1d --- /dev/null +++ b/allure_results/b63cf63c-22d3-4d72-82a4-4fd1b3cccb98-container.json @@ -0,0 +1 @@ +{"uuid": "78aacd62-9410-46fa-9fc8-ea5e1bbb8957", "befores": [{"name": "expected_price", "status": "passed", "start": 1769972811582, "stop": 1769972811582}], "start": 1769972811582, "stop": 1769972811583} \ No newline at end of file diff --git a/allure_results/b73227ce-1aeb-4ad5-a920-8fd9ea60550d-result.json b/allure_results/b73227ce-1aeb-4ad5-a920-8fd9ea60550d-result.json new file mode 100644 index 000000000..df7a34299 --- /dev/null +++ b/allure_results/b73227ce-1aeb-4ad5-a920-8fd9ea60550d-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_price", "status": "passed", "description": "Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "bun", "value": ""}, {"name": "ingredients", "value": "[]"}, {"name": "expected_price", "value": "500"}], "start": 1769972811569, "stop": 1769972811569, "uuid": "c83d2963-39d8-4ab1-b715-021233baaf5a", "historyId": "d3162efeea243464135d4b142aeb3f26", "testCaseId": "9bc48baa4883de12242efddc23bca86a", "fullName": "tests.test_burger.TestBurger#test_get_price", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/be9942ea-3f7b-44a0-aeca-0737f169e193-container.json b/allure_results/be9942ea-3f7b-44a0-aeca-0737f169e193-container.json new file mode 100644 index 000000000..1156ad430 --- /dev/null +++ b/allure_results/be9942ea-3f7b-44a0-aeca-0737f169e193-container.json @@ -0,0 +1 @@ +{"uuid": "ac498cd8-2f94-4815-8f66-8af2391b44fb", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811568, "stop": 1769972811568}], "start": 1769972811568, "stop": 1769972811571} \ No newline at end of file diff --git a/allure_results/c556cfb5-2064-4524-8fde-8cb680591413-container.json b/allure_results/c556cfb5-2064-4524-8fde-8cb680591413-container.json new file mode 100644 index 000000000..9c52347b8 --- /dev/null +++ b/allure_results/c556cfb5-2064-4524-8fde-8cb680591413-container.json @@ -0,0 +1 @@ +{"uuid": "cb506e6c-b026-4115-a49a-d52c27d12ed0", "befores": [{"name": "bun", "status": "passed", "start": 1769972811581, "stop": 1769972811581}], "start": 1769972811581, "stop": 1769972811585} \ No newline at end of file diff --git a/allure_results/c684ab1c-a402-4fd9-89ff-ecab9daefdf2-result.json b/allure_results/c684ab1c-a402-4fd9-89ff-ecab9daefdf2-result.json new file mode 100644 index 000000000..1ab0ec2b5 --- /dev/null +++ b/allure_results/c684ab1c-a402-4fd9-89ff-ecab9daefdf2-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_price", "status": "passed", "description": "Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "bun", "value": ""}, {"name": "ingredients", "value": "[]"}, {"name": "expected_price", "value": "500"}], "start": 1769972811576, "stop": 1769972811577, "uuid": "043aed41-a8b6-46c8-809c-1c5bd8e560ba", "historyId": "ae13170c0f0bee3f35f845d8714d3e8f", "testCaseId": "9bc48baa4883de12242efddc23bca86a", "fullName": "tests.test_burger.TestBurger#test_get_price", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/d497cced-3849-4f6a-b50a-19f264c48612-result.json b/allure_results/d497cced-3849-4f6a-b50a-19f264c48612-result.json new file mode 100644 index 000000000..f602bf61a --- /dev/null +++ b/allure_results/d497cced-3849-4f6a-b50a-19f264c48612-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_receipt", "status": "passed", "description": "Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "ingredients", "value": "[, ]"}], "start": 1769972811614, "stop": 1769972811614, "uuid": "8029a9b3-e5ec-43e5-b1a7-523d1ee83137", "historyId": "eb290b52dc8babc99f7fffd77086fb54", "testCaseId": "5bf52d3a38b900560c9be02b6a5d981c", "fullName": "tests.test_burger.TestBurger#test_get_receipt", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/d6df134d-e926-4987-a490-794379a4f0a4-container.json b/allure_results/d6df134d-e926-4987-a490-794379a4f0a4-container.json new file mode 100644 index 000000000..bc45fd246 --- /dev/null +++ b/allure_results/d6df134d-e926-4987-a490-794379a4f0a4-container.json @@ -0,0 +1 @@ +{"uuid": "69b6efb0-84ed-421e-8718-88e0aab7fe61", "children": ["096e1973-b0d0-4357-8349-4604908d8013", "dd25ee07-c605-4d9c-8739-50aa40f31df6", "d59e55d4-fb76-4094-a6af-f71bfe27f4b6", "6fbdbb86-e080-4c5c-9391-e77f72ac8397", "bc832e3f-2354-4698-bab4-1b6754c0900e", "1cf2c56f-a4d0-4374-b895-4b1528a86642", "82a7ca89-26ce-483c-8ce9-e349c5879aa1", "56edb4ce-836c-4257-9ad4-994edc615191", "86a5b3e9-4354-48bb-bffa-df41ea98d6e2", "30d711e7-13cf-4173-83ee-4ad4900e6473", "47b84c62-a890-4f88-9cce-8b355bd1e29c", "c83d2963-39d8-4ab1-b715-021233baaf5a", "043aed41-a8b6-46c8-809c-1c5bd8e560ba", "8c69ea07-1685-4076-9087-16a57cdb9536", "988db18e-0bcc-4ca7-932f-ac2c2288792a", "c8f43581-59fb-49d6-9e5c-d125845af0fd", "b8640063-cfcf-4ae4-9a76-720b9ad15be9", "a5678730-9ffd-4911-b7b9-cdd8812a9f4c", "8029a9b3-e5ec-43e5-b1a7-523d1ee83137", "813be3ea-e848-4d59-95ed-e3802e4e0dc9", "da8a6ead-91f2-4791-b389-466c37341302"], "befores": [{"name": "_session_faker", "status": "passed", "start": 1769972811368, "stop": 1769972811492}], "start": 1769972811368, "stop": 1769972811629} \ No newline at end of file diff --git a/allure_results/d78f917a-7919-4cf2-8d42-99e0ab63981a-container.json b/allure_results/d78f917a-7919-4cf2-8d42-99e0ab63981a-container.json new file mode 100644 index 000000000..2d73617e9 --- /dev/null +++ b/allure_results/d78f917a-7919-4cf2-8d42-99e0ab63981a-container.json @@ -0,0 +1 @@ +{"uuid": "abb8fbbd-cf04-4488-8c3c-e25772dc7ec9", "befores": [{"name": "expected_len", "status": "passed", "start": 1769972811509, "stop": 1769972811510}], "start": 1769972811509, "stop": 1769972811518} \ No newline at end of file diff --git a/allure_results/dda127b5-a10b-4cc9-8ccb-93f4e8af720b-container.json b/allure_results/dda127b5-a10b-4cc9-8ccb-93f4e8af720b-container.json new file mode 100644 index 000000000..df6a9b908 --- /dev/null +++ b/allure_results/dda127b5-a10b-4cc9-8ccb-93f4e8af720b-container.json @@ -0,0 +1 @@ +{"uuid": "dffd8651-a454-450e-8ce1-5bea58ecd85f", "befores": [{"name": "mock_ingredients", "status": "passed", "start": 1769972811509, "stop": 1769972811509}], "start": 1769972811509, "stop": 1769972811519} \ No newline at end of file diff --git a/allure_results/e19ae352-b3ec-4c27-a26e-f7ccad1ebf24-container.json b/allure_results/e19ae352-b3ec-4c27-a26e-f7ccad1ebf24-container.json new file mode 100644 index 000000000..4ed205bca --- /dev/null +++ b/allure_results/e19ae352-b3ec-4c27-a26e-f7ccad1ebf24-container.json @@ -0,0 +1 @@ +{"uuid": "67000f15-1f25-4397-afc5-306b652faf16", "befores": [{"name": "ingredients", "status": "passed", "start": 1769972811575, "stop": 1769972811575}], "start": 1769972811575, "stop": 1769972811578} \ No newline at end of file diff --git a/allure_results/e28aee11-9b0f-4dac-a238-20518b69aebf-result.json b/allure_results/e28aee11-9b0f-4dac-a238-20518b69aebf-result.json new file mode 100644 index 000000000..ad70dbe08 --- /dev/null +++ b/allure_results/e28aee11-9b0f-4dac-a238-20518b69aebf-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода move_ingredient", "status": "passed", "description": "Проверить, что метод move_ingredient корректно меняет порядок ингредиентов", "start": 1769972811560, "stop": 1769972811560, "uuid": "47b84c62-a890-4f88-9cce-8b355bd1e29c", "historyId": "d9e6d7bb097dfe246d776c6c756f7737", "testCaseId": "d9e6d7bb097dfe246d776c6c756f7737", "fullName": "tests.test_burger.TestBurger#test_move_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/e590fbb1-e6a8-4877-8630-c274c9cadec8-result.json b/allure_results/e590fbb1-e6a8-4877-8630-c274c9cadec8-result.json new file mode 100644 index 000000000..affa1c0d7 --- /dev/null +++ b/allure_results/e590fbb1-e6a8-4877-8630-c274c9cadec8-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода get_receipt", "status": "passed", "description": "Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов", "parameters": [{"name": "ingredients", "value": "[, ]"}], "start": 1769972811620, "stop": 1769972811621, "uuid": "813be3ea-e848-4d59-95ed-e3802e4e0dc9", "historyId": "5e8cf452954d0ee7d603e475f8104f10", "testCaseId": "5bf52d3a38b900560c9be02b6a5d981c", "fullName": "tests.test_burger.TestBurger#test_get_receipt", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/eaedea99-8316-4b4d-bf9d-a32174893919-container.json b/allure_results/eaedea99-8316-4b4d-bf9d-a32174893919-container.json new file mode 100644 index 000000000..bf0153571 --- /dev/null +++ b/allure_results/eaedea99-8316-4b4d-bf9d-a32174893919-container.json @@ -0,0 +1 @@ +{"uuid": "277cf484-e4c2-462c-83ee-7d5e3fd78664", "befores": [{"name": "mock_ingredients", "status": "passed", "start": 1769972811528, "stop": 1769972811528}], "start": 1769972811528, "stop": 1769972811531} \ No newline at end of file diff --git a/allure_results/eca9f124-d081-48d5-901d-ec9cf4992c06-container.json b/allure_results/eca9f124-d081-48d5-901d-ec9cf4992c06-container.json new file mode 100644 index 000000000..5217a4f84 --- /dev/null +++ b/allure_results/eca9f124-d081-48d5-901d-ec9cf4992c06-container.json @@ -0,0 +1 @@ +{"uuid": "2b3f05dd-ea1e-4c54-a6b8-93d603115e79", "children": ["47b84c62-a890-4f88-9cce-8b355bd1e29c"], "befores": [{"name": "mock_sauce", "status": "passed", "start": 1769972811557, "stop": 1769972811558}], "start": 1769972811557, "stop": 1769972811562} \ No newline at end of file diff --git a/allure_results/ee29deb6-179d-498c-b6d6-28dec8fa994e-container.json b/allure_results/ee29deb6-179d-498c-b6d6-28dec8fa994e-container.json new file mode 100644 index 000000000..2dc6d593c --- /dev/null +++ b/allure_results/ee29deb6-179d-498c-b6d6-28dec8fa994e-container.json @@ -0,0 +1 @@ +{"uuid": "cfd76035-1316-40e6-9488-f70d5eaa1bbd", "befores": [{"name": "expected_price", "status": "passed", "start": 1769972811594, "stop": 1769972811595}], "start": 1769972811594, "stop": 1769972811596} \ No newline at end of file diff --git a/allure_results/eeac5d12-8e2a-499c-90d8-dacea7a21239-result.json b/allure_results/eeac5d12-8e2a-499c-90d8-dacea7a21239-result.json new file mode 100644 index 000000000..ad52d3262 --- /dev/null +++ b/allure_results/eeac5d12-8e2a-499c-90d8-dacea7a21239-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода remove_ingredient", "status": "passed", "description": "Проверяем, что метод remove_ingredient корректно удаляет ингредиент из атрибута ingredients", "start": 1769972811546, "stop": 1769972811547, "uuid": "86a5b3e9-4354-48bb-bffa-df41ea98d6e2", "historyId": "5ed087b1751066e2ba56e83cb206e0c3", "testCaseId": "5ed087b1751066e2ba56e83cb206e0c3", "fullName": "tests.test_burger.TestBurger#test_remove_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/allure_results/f665e1d5-d167-4c81-b4c1-50e7ae1d428c-container.json b/allure_results/f665e1d5-d167-4c81-b4c1-50e7ae1d428c-container.json new file mode 100644 index 000000000..186312a68 --- /dev/null +++ b/allure_results/f665e1d5-d167-4c81-b4c1-50e7ae1d428c-container.json @@ -0,0 +1 @@ +{"uuid": "ccb8cfd7-f5ee-40ce-8a6b-65d8b9c39ff6", "befores": [{"name": "mock_ingredients", "status": "passed", "start": 1769972811534, "stop": 1769972811534}], "start": 1769972811534, "stop": 1769972811536} \ No newline at end of file diff --git a/allure_results/fa15a1a9-beff-4a11-9d2a-222b54980a83-result.json b/allure_results/fa15a1a9-beff-4a11-9d2a-222b54980a83-result.json new file mode 100644 index 000000000..9689eb595 --- /dev/null +++ b/allure_results/fa15a1a9-beff-4a11-9d2a-222b54980a83-result.json @@ -0,0 +1 @@ +{"name": "Проверка метода add_ingredient", "status": "passed", "description": "Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients", "parameters": [{"name": "mock_ingredients", "value": "[]"}, {"name": "expected_len", "value": "1"}], "start": 1769972811523, "stop": 1769972811523, "uuid": "bc832e3f-2354-4698-bab4-1b6754c0900e", "historyId": "1068dd37b692fd28d06d1bbb84a92c82", "testCaseId": "30496d62bf692687f1cd0f5be1a8a3a1", "fullName": "tests.test_burger.TestBurger#test_add_ingredient", "labels": [{"name": "parentSuite", "value": "tests"}, {"name": "suite", "value": "test_burger"}, {"name": "subSuite", "value": "TestBurger"}, {"name": "host", "value": "DESKTOP-E3C2TUR"}, {"name": "thread", "value": "15372-MainThread"}, {"name": "framework", "value": "pytest"}, {"name": "language", "value": "cpython3"}, {"name": "package", "value": "tests.test_burger"}], "titlePath": ["tests", "test_burger.py", "TestBurger"]} \ No newline at end of file diff --git a/conftest.py b/conftest.py new file mode 100644 index 000000000..eb839a8a7 --- /dev/null +++ b/conftest.py @@ -0,0 +1,23 @@ +import pytest +from data import * +from praktikum.ingredient_types import INGREDIENT_TYPE_SAUCE, INGREDIENT_TYPE_FILLING + +@pytest.fixture() +def mock_bun(): + return MockBun.get_mock_bun() + +@pytest.fixture() +def mock_sauce(): + return MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[0]['name'], + AvailableIngredients.sauces[0]['price'] + ) + +@pytest.fixture() +def mock_filling(): + return MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_FILLING, + AvailableIngredients.fillings[0]['name'], + AvailableIngredients.fillings[0]['price'] + ) diff --git a/data.py b/data.py new file mode 100644 index 000000000..f86d23c3b --- /dev/null +++ b/data.py @@ -0,0 +1,130 @@ +from typing import List +from unittest.mock import Mock + +from praktikum.bun import Bun +from praktikum.ingredient import Ingredient +from praktikum.ingredient_types import INGREDIENT_TYPE_SAUCE, INGREDIENT_TYPE_FILLING + +class BunData: + bun_name = 'white bun' + bun_price = 200 + +class AvailableIngredients: + sauces = [ + { + 'name': 'hot sauce', + 'price': 100, + }, + { + 'name': 'sour cream', + 'price': 200, + }, + { + 'name': 'chili sauce', + 'price': 300, + }, + ] + fillings = [ + { + 'name': 'cutlet', + 'price': 100, + }, + { + 'name': 'dinosaur', + 'price': 200, + }, + { + 'name': 'sausage', + 'price': 300, + }, + ] + +class MockBun: + @staticmethod + def get_mock_bun() -> Bun: + bun = Mock() + bun.get_name.return_value = BunData.bun_name + bun.get_price.return_value = BunData.bun_price + return bun + +class MockIngredient: + @staticmethod + def get_mock_ingredient(ingredient_type, ingredient_name, ingredient_price) -> Ingredient: + ingredient = Mock() + ingredient.get_type.return_value = ingredient_type + ingredient.get_name.return_value = ingredient_name + ingredient.get_price.return_value = ingredient_price + return ingredient + +class BurgerReceipt: + @staticmethod + def get_receipt(bun: Bun, ingredients: List[Ingredient]): + price = bun.get_price() * 2 + receipt = f'(==== {bun.get_name()} ====)\n' + for ingredient in ingredients: + receipt += f'= {str(ingredient.get_type()).lower()} {ingredient.get_name()} =\n' + price += ingredient.get_price() + receipt += f'(==== {bun.get_name()} ====)\n\n' + receipt += f'Price: {price}' + return receipt + +class IngredientsCombinations: + only_sauce = [MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[0]['name'], + AvailableIngredients.sauces[0]['price'] + )] + only_filling = [MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_FILLING, + AvailableIngredients.fillings[0]['name'], + AvailableIngredients.fillings[0]['price'] + )] + two_same_sauces = [ + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[1]['name'], + AvailableIngredients.sauces[1]['price'] + ), + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[1]['name'], + AvailableIngredients.sauces[1]['price'] + ) + ] + two_same_fillings = [ + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_FILLING, + AvailableIngredients.fillings[1]['name'], + AvailableIngredients.fillings[1]['price'] + ), + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_FILLING, + AvailableIngredients.fillings[1]['name'], + AvailableIngredients.fillings[1]['price'] + ) + ] + tree_different_ingredients = [ + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[0]['name'], + AvailableIngredients.sauces[0]['price'] + ), + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_SAUCE, + AvailableIngredients.sauces[2]['name'], + AvailableIngredients.sauces[2]['price'] + ), + MockIngredient.get_mock_ingredient( + INGREDIENT_TYPE_FILLING, + AvailableIngredients.fillings[1]['name'], + AvailableIngredients.fillings[1]['price'] + ) + ] + +burgers_variants = [ + (MockBun.get_mock_bun(), IngredientsCombinations.only_sauce, 500), + (MockBun.get_mock_bun(), IngredientsCombinations.only_filling, 500), + (MockBun.get_mock_bun(), IngredientsCombinations.two_same_sauces, 800), + (MockBun.get_mock_bun(), IngredientsCombinations.two_same_fillings, 800), + (MockBun.get_mock_bun(), IngredientsCombinations.tree_different_ingredients, 1000) +] \ No newline at end of file diff --git a/htmlcov/class_index.html b/htmlcov/class_index.html new file mode 100644 index 000000000..8df6123b3 --- /dev/null +++ b/htmlcov/class_index.html @@ -0,0 +1,131 @@ + + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.1, + created at 2026-02-01 22:06 +0300 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Fileclass statementsmissingexcluded coverage
praktikum \ burger.pyBurger 1600 100%
praktikum \ burger.py(no class) 1100 100%
Total  2700 100%
+

+ No items found using the specified filter. +

+
+ + + diff --git a/htmlcov/coverage_html_cb_188fc9a4.js b/htmlcov/coverage_html_cb_188fc9a4.js new file mode 100644 index 000000000..6f871742c --- /dev/null +++ b/htmlcov/coverage_html_cb_188fc9a4.js @@ -0,0 +1,735 @@ +// Licensed under the Apache License: http://www.apache.org/licenses/LICENSE-2.0 +// For details: https://github.com/coveragepy/coveragepy/blob/main/NOTICE.txt + +// Coverage.py HTML report browser code. +/*jslint browser: true, sloppy: true, vars: true, plusplus: true, maxerr: 50, indent: 4 */ +/*global coverage: true, document, window, $ */ + +coverage = {}; + +// General helpers +function debounce(callback, wait) { + let timeoutId = null; + return function(...args) { + clearTimeout(timeoutId); + timeoutId = setTimeout(() => { + callback.apply(this, args); + }, wait); + }; +}; + +function checkVisible(element) { + const rect = element.getBoundingClientRect(); + const viewBottom = Math.max(document.documentElement.clientHeight, window.innerHeight); + const viewTop = 30; + return !(rect.bottom < viewTop || rect.top >= viewBottom); +} + +function on_click(sel, fn) { + const elt = document.querySelector(sel); + if (elt) { + elt.addEventListener("click", fn); + } +} + +// Helpers for table sorting +function getCellValue(row, column = 0) { + const cell = row.cells[column] // nosemgrep: eslint.detect-object-injection + if (cell.childElementCount == 1) { + var child = cell.firstElementChild; + if (child.tagName === "A") { + child = child.firstElementChild; + } + if (child instanceof HTMLDataElement && child.value) { + return child.value; + } + } + return cell.innerText || cell.textContent; +} + +function rowComparator(rowA, rowB, column = 0) { + let valueA = getCellValue(rowA, column); + let valueB = getCellValue(rowB, column); + if (!isNaN(valueA) && !isNaN(valueB)) { + return valueA - valueB; + } + return valueA.localeCompare(valueB, undefined, {numeric: true}); +} + +function sortColumn(th) { + // Get the current sorting direction of the selected header, + // clear state on other headers and then set the new sorting direction. + const currentSortOrder = th.getAttribute("aria-sort"); + [...th.parentElement.cells].forEach(header => header.setAttribute("aria-sort", "none")); + var direction; + if (currentSortOrder === "none") { + direction = th.dataset.defaultSortOrder || "ascending"; + } + else if (currentSortOrder === "ascending") { + direction = "descending"; + } + else { + direction = "ascending"; + } + th.setAttribute("aria-sort", direction); + + const column = [...th.parentElement.cells].indexOf(th) + + // Sort all rows and afterwards append them in order to move them in the DOM. + Array.from(th.closest("table").querySelectorAll("tbody tr")) + .sort((rowA, rowB) => rowComparator(rowA, rowB, column) * (direction === "ascending" ? 1 : -1)) + .forEach(tr => tr.parentElement.appendChild(tr)); + + // Save the sort order for next time. + if (th.id !== "region") { + let th_id = "file"; // Sort by file if we don't have a column id + let current_direction = direction; + const stored_list = localStorage.getItem(coverage.INDEX_SORT_STORAGE); + if (stored_list) { + ({th_id, direction} = JSON.parse(stored_list)) + } + localStorage.setItem(coverage.INDEX_SORT_STORAGE, JSON.stringify({ + "th_id": th.id, + "direction": current_direction + })); + if (th.id !== th_id || document.getElementById("region")) { + // Sort column has changed, unset sorting by function or class. + localStorage.setItem(coverage.SORTED_BY_REGION, JSON.stringify({ + "by_region": false, + "region_direction": current_direction + })); + } + } + else { + // Sort column has changed to by function or class, remember that. + localStorage.setItem(coverage.SORTED_BY_REGION, JSON.stringify({ + "by_region": true, + "region_direction": direction + })); + } +} + +// Find all the elements with data-shortcut attribute, and use them to assign a shortcut key. +coverage.assign_shortkeys = function () { + document.querySelectorAll("[data-shortcut]").forEach(element => { + document.addEventListener("keypress", event => { + if (event.target.tagName.toLowerCase() === "input") { + return; // ignore keypress from search filter + } + if (event.key === element.dataset.shortcut) { + element.click(); + } + }); + }); +}; + +// Create the events for the filter box. +coverage.wire_up_filter = function () { + // Populate the filter and hide100 inputs if there are saved values for them. + const saved_filter_value = localStorage.getItem(coverage.FILTER_STORAGE); + if (saved_filter_value) { + document.getElementById("filter").value = saved_filter_value; + } + const saved_hide100_value = localStorage.getItem(coverage.HIDE100_STORAGE); + if (saved_hide100_value) { + document.getElementById("hide100").checked = JSON.parse(saved_hide100_value); + } + + // Cache elements. + const table = document.querySelector("table.index"); + const table_body_rows = table.querySelectorAll("tbody tr"); + const no_rows = document.getElementById("no_rows"); + + const footer = table.tFoot.rows[0]; + const ratio_columns = Array.from(footer.cells).map(cell => Boolean(cell.dataset.ratio)); + + // Observe filter keyevents. + const filter_handler = (event => { + // Keep running total of each metric, first index contains number of shown rows + const totals = ratio_columns.map( + is_ratio => is_ratio ? {"numer": 0, "denom": 0} : 0 + ); + + var text = document.getElementById("filter").value; + // Store filter value + localStorage.setItem(coverage.FILTER_STORAGE, text); + const casefold = (text === text.toLowerCase()); + const hide100 = document.getElementById("hide100").checked; + // Store hide value. + localStorage.setItem(coverage.HIDE100_STORAGE, JSON.stringify(hide100)); + + // Hide / show elements. + table_body_rows.forEach(row => { + var show = false; + // Check the text filter. + for (let column = 0; column < totals.length; column++) { + cell = row.cells[column]; + if (cell.classList.contains("name")) { + var celltext = cell.textContent; + if (casefold) { + celltext = celltext.toLowerCase(); + } + if (celltext.includes(text)) { + show = true; + } + } + } + + // Check the "hide covered" filter. + if (show && hide100) { + const [numer, denom] = row.cells[row.cells.length - 1].dataset.ratio.split(" "); + show = (numer !== denom); + } + + if (!show) { + // hide + row.classList.add("hidden"); + return; + } + + // show + row.classList.remove("hidden"); + totals[0]++; + + for (let column = 0; column < totals.length; column++) { + // Accumulate dynamic totals + cell = row.cells[column] // nosemgrep: eslint.detect-object-injection + if (cell.matches(".name, .spacer")) { + continue; + } + if (ratio_columns[column] && cell.dataset.ratio) { + // Column stores a ratio + const [numer, denom] = cell.dataset.ratio.split(" "); + totals[column]["numer"] += parseInt(numer, 10); // nosemgrep: eslint.detect-object-injection + totals[column]["denom"] += parseInt(denom, 10); // nosemgrep: eslint.detect-object-injection + } + else { + totals[column] += parseInt(cell.textContent, 10); // nosemgrep: eslint.detect-object-injection + } + } + }); + + // Show placeholder if no rows will be displayed. + if (!totals[0]) { + // Show placeholder, hide table. + no_rows.style.display = "block"; + table.style.display = "none"; + return; + } + + // Hide placeholder, show table. + no_rows.style.display = null; + table.style.display = null; + + // Calculate new dynamic sum values based on visible rows. + for (let column = 0; column < totals.length; column++) { + // Get footer cell element. + const cell = footer.cells[column]; // nosemgrep: eslint.detect-object-injection + if (cell.matches(".name, .spacer")) { + continue; + } + + // Set value into dynamic footer cell element. + if (ratio_columns[column]) { + // Percentage column uses the numerator and denominator, + // and adapts to the number of decimal places. + const match = /\.([0-9]+)/.exec(cell.textContent); + const places = match ? match[1].length : 0; + const { numer, denom } = totals[column]; // nosemgrep: eslint.detect-object-injection + cell.dataset.ratio = `${numer} ${denom}`; + // Check denom to prevent NaN if filtered files contain no statements + cell.textContent = denom + ? `${(numer * 100 / denom).toFixed(places)}%` + : `${(100).toFixed(places)}%`; + } + else { + cell.textContent = totals[column]; // nosemgrep: eslint.detect-object-injection + } + } + }); + + document.getElementById("filter").addEventListener("input", debounce(filter_handler)); + document.getElementById("hide100").addEventListener("input", debounce(filter_handler)); + + // Trigger change event on setup, to force filter on page refresh + // (filter value may still be present). + document.getElementById("filter").dispatchEvent(new Event("input")); + document.getElementById("hide100").dispatchEvent(new Event("input")); +}; +coverage.FILTER_STORAGE = "COVERAGE_FILTER_VALUE"; +coverage.HIDE100_STORAGE = "COVERAGE_HIDE100_VALUE"; + +// Set up the click-to-sort columns. +coverage.wire_up_sorting = function () { + document.querySelectorAll("[data-sortable] th[aria-sort]").forEach( + th => th.addEventListener("click", e => sortColumn(e.target)) + ); + + // Look for a localStorage item containing previous sort settings: + let th_id = "file", direction = "ascending"; + const stored_list = localStorage.getItem(coverage.INDEX_SORT_STORAGE); + if (stored_list) { + ({th_id, direction} = JSON.parse(stored_list)); + } + let by_region = false, region_direction = "ascending"; + const sorted_by_region = localStorage.getItem(coverage.SORTED_BY_REGION); + if (sorted_by_region) { + ({ + by_region, + region_direction + } = JSON.parse(sorted_by_region)); + } + + const region_id = "region"; + if (by_region && document.getElementById(region_id)) { + direction = region_direction; + } + // If we are in a page that has a column with id of "region", sort on + // it if the last sort was by function or class. + let th; + if (document.getElementById(region_id)) { + th = document.getElementById(by_region ? region_id : th_id); + } + else { + th = document.getElementById(th_id); + } + th.setAttribute("aria-sort", direction === "ascending" ? "descending" : "ascending"); + th.click() +}; + +coverage.INDEX_SORT_STORAGE = "COVERAGE_INDEX_SORT_2"; +coverage.SORTED_BY_REGION = "COVERAGE_SORT_REGION"; + +// Loaded on index.html +coverage.index_ready = function () { + coverage.assign_shortkeys(); + coverage.wire_up_filter(); + coverage.wire_up_sorting(); + + on_click(".button_prev_file", coverage.to_prev_file); + on_click(".button_next_file", coverage.to_next_file); + + on_click(".button_show_hide_help", coverage.show_hide_help); +}; + +// -- pyfile stuff -- + +coverage.LINE_FILTERS_STORAGE = "COVERAGE_LINE_FILTERS"; + +coverage.pyfile_ready = function () { + // If we're directed to a particular line number, highlight the line. + var frag = location.hash; + if (frag.length > 2 && frag[1] === "t") { + document.querySelector(frag).closest(".n").classList.add("highlight"); + coverage.set_sel(parseInt(frag.substr(2), 10)); + } + else { + coverage.set_sel(0); + } + + on_click(".button_toggle_run", coverage.toggle_lines); + on_click(".button_toggle_mis", coverage.toggle_lines); + on_click(".button_toggle_exc", coverage.toggle_lines); + on_click(".button_toggle_par", coverage.toggle_lines); + + on_click(".button_next_chunk", coverage.to_next_chunk_nicely); + on_click(".button_prev_chunk", coverage.to_prev_chunk_nicely); + on_click(".button_top_of_page", coverage.to_top); + on_click(".button_first_chunk", coverage.to_first_chunk); + + on_click(".button_prev_file", coverage.to_prev_file); + on_click(".button_next_file", coverage.to_next_file); + on_click(".button_to_index", coverage.to_index); + + on_click(".button_show_hide_help", coverage.show_hide_help); + + coverage.filters = undefined; + try { + coverage.filters = localStorage.getItem(coverage.LINE_FILTERS_STORAGE); + } catch(err) {} + + if (coverage.filters) { + coverage.filters = JSON.parse(coverage.filters); + } + else { + coverage.filters = {run: false, exc: true, mis: true, par: true}; + } + + for (cls in coverage.filters) { + coverage.set_line_visibilty(cls, coverage.filters[cls]); // nosemgrep: eslint.detect-object-injection + } + + coverage.assign_shortkeys(); + coverage.init_scroll_markers(); + coverage.wire_up_sticky_header(); + + document.querySelectorAll("[id^=ctxs]").forEach( + cbox => cbox.addEventListener("click", coverage.expand_contexts) + ); + + // Rebuild scroll markers when the window height changes. + window.addEventListener("resize", coverage.build_scroll_markers); +}; + +coverage.toggle_lines = function (event) { + const btn = event.target.closest("button"); + const category = btn.value + const show = !btn.classList.contains("show_" + category); + coverage.set_line_visibilty(category, show); + coverage.build_scroll_markers(); + coverage.filters[category] = show; + try { + localStorage.setItem(coverage.LINE_FILTERS_STORAGE, JSON.stringify(coverage.filters)); + } catch(err) {} +}; + +coverage.set_line_visibilty = function (category, should_show) { + const cls = "show_" + category; + const btn = document.querySelector(".button_toggle_" + category); + if (btn) { + if (should_show) { + document.querySelectorAll("#source ." + category).forEach(e => e.classList.add(cls)); + btn.classList.add(cls); + } + else { + document.querySelectorAll("#source ." + category).forEach(e => e.classList.remove(cls)); + btn.classList.remove(cls); + } + } +}; + +// Return the nth line div. +coverage.line_elt = function (n) { + return document.getElementById("t" + n)?.closest("p"); +}; + +// Set the selection. b and e are line numbers. +coverage.set_sel = function (b, e) { + // The first line selected. + coverage.sel_begin = b; + // The next line not selected. + coverage.sel_end = (e === undefined) ? b+1 : e; +}; + +coverage.to_top = function () { + coverage.set_sel(0, 1); + coverage.scroll_window(0); +}; + +coverage.to_first_chunk = function () { + coverage.set_sel(0, 1); + coverage.to_next_chunk(); +}; + +coverage.to_prev_file = function () { + window.location = document.getElementById("prevFileLink").href; +} + +coverage.to_next_file = function () { + window.location = document.getElementById("nextFileLink").href; +} + +coverage.to_index = function () { + location.href = document.getElementById("indexLink").href; +} + +coverage.show_hide_help = function () { + const helpCheck = document.getElementById("help_panel_state") + helpCheck.checked = !helpCheck.checked; +} + +// Return a string indicating what kind of chunk this line belongs to, +// or null if not a chunk. +coverage.chunk_indicator = function (line_elt) { + const classes = line_elt?.className; + if (!classes) { + return null; + } + const match = classes.match(/\bshow_\w+\b/); + if (!match) { + return null; + } + return match[0]; +}; + +coverage.to_next_chunk = function () { + const c = coverage; + + // Find the start of the next colored chunk. + var probe = c.sel_end; + var chunk_indicator, probe_line; + while (true) { + probe_line = c.line_elt(probe); + if (!probe_line) { + return; + } + chunk_indicator = c.chunk_indicator(probe_line); + if (chunk_indicator) { + break; + } + probe++; + } + + // There's a next chunk, `probe` points to it. + var begin = probe; + + // Find the end of this chunk. + var next_indicator = chunk_indicator; + while (next_indicator === chunk_indicator) { + probe++; + probe_line = c.line_elt(probe); + next_indicator = c.chunk_indicator(probe_line); + } + c.set_sel(begin, probe); + c.show_selection(); +}; + +coverage.to_prev_chunk = function () { + const c = coverage; + + // Find the end of the prev colored chunk. + var probe = c.sel_begin-1; + var probe_line = c.line_elt(probe); + if (!probe_line) { + return; + } + var chunk_indicator = c.chunk_indicator(probe_line); + while (probe > 1 && !chunk_indicator) { + probe--; + probe_line = c.line_elt(probe); + if (!probe_line) { + return; + } + chunk_indicator = c.chunk_indicator(probe_line); + } + + // There's a prev chunk, `probe` points to its last line. + var end = probe+1; + + // Find the beginning of this chunk. + var prev_indicator = chunk_indicator; + while (prev_indicator === chunk_indicator) { + probe--; + if (probe <= 0) { + return; + } + probe_line = c.line_elt(probe); + prev_indicator = c.chunk_indicator(probe_line); + } + c.set_sel(probe+1, end); + c.show_selection(); +}; + +// Returns 0, 1, or 2: how many of the two ends of the selection are on +// the screen right now? +coverage.selection_ends_on_screen = function () { + if (coverage.sel_begin === 0) { + return 0; + } + + const begin = coverage.line_elt(coverage.sel_begin); + const end = coverage.line_elt(coverage.sel_end-1); + + return ( + (checkVisible(begin) ? 1 : 0) + + (checkVisible(end) ? 1 : 0) + ); +}; + +coverage.to_next_chunk_nicely = function () { + if (coverage.selection_ends_on_screen() === 0) { + // The selection is entirely off the screen: + // Set the top line on the screen as selection. + + // This will select the top-left of the viewport + // As this is most likely the span with the line number we take the parent + const line = document.elementFromPoint(0, 0).parentElement; + if (line.parentElement !== document.getElementById("source")) { + // The element is not a source line but the header or similar + coverage.select_line_or_chunk(1); + } + else { + // We extract the line number from the id + coverage.select_line_or_chunk(parseInt(line.id.substring(1), 10)); + } + } + coverage.to_next_chunk(); +}; + +coverage.to_prev_chunk_nicely = function () { + if (coverage.selection_ends_on_screen() === 0) { + // The selection is entirely off the screen: + // Set the lowest line on the screen as selection. + + // This will select the bottom-left of the viewport + // As this is most likely the span with the line number we take the parent + const line = document.elementFromPoint(document.documentElement.clientHeight-1, 0).parentElement; + if (line.parentElement !== document.getElementById("source")) { + // The element is not a source line but the header or similar + coverage.select_line_or_chunk(coverage.lines_len); + } + else { + // We extract the line number from the id + coverage.select_line_or_chunk(parseInt(line.id.substring(1), 10)); + } + } + coverage.to_prev_chunk(); +}; + +// Select line number lineno, or if it is in a colored chunk, select the +// entire chunk +coverage.select_line_or_chunk = function (lineno) { + var c = coverage; + var probe_line = c.line_elt(lineno); + if (!probe_line) { + return; + } + var the_indicator = c.chunk_indicator(probe_line); + if (the_indicator) { + // The line is in a highlighted chunk. + // Search backward for the first line. + var probe = lineno; + var indicator = the_indicator; + while (probe > 0 && indicator === the_indicator) { + probe--; + probe_line = c.line_elt(probe); + if (!probe_line) { + break; + } + indicator = c.chunk_indicator(probe_line); + } + var begin = probe + 1; + + // Search forward for the last line. + probe = lineno; + indicator = the_indicator; + while (indicator === the_indicator) { + probe++; + probe_line = c.line_elt(probe); + indicator = c.chunk_indicator(probe_line); + } + + coverage.set_sel(begin, probe); + } + else { + coverage.set_sel(lineno); + } +}; + +coverage.show_selection = function () { + // Highlight the lines in the chunk + document.querySelectorAll("#source .highlight").forEach(e => e.classList.remove("highlight")); + for (let probe = coverage.sel_begin; probe < coverage.sel_end; probe++) { + coverage.line_elt(probe).querySelector(".n").classList.add("highlight"); + } + + coverage.scroll_to_selection(); +}; + +coverage.scroll_to_selection = function () { + // Scroll the page if the chunk isn't fully visible. + if (coverage.selection_ends_on_screen() < 2) { + const element = coverage.line_elt(coverage.sel_begin); + coverage.scroll_window(element.offsetTop - 60); + } +}; + +coverage.scroll_window = function (to_pos) { + window.scroll({top: to_pos, behavior: "smooth"}); +}; + +coverage.init_scroll_markers = function () { + // Init some variables + coverage.lines_len = document.querySelectorAll("#source > p").length; + + // Build html + coverage.build_scroll_markers(); +}; + +coverage.build_scroll_markers = function () { + const temp_scroll_marker = document.getElementById("scroll_marker") + if (temp_scroll_marker) temp_scroll_marker.remove(); + // Don't build markers if the window has no scroll bar. + if (document.body.scrollHeight <= window.innerHeight) { + return; + } + + const marker_scale = window.innerHeight / document.body.scrollHeight; + const line_height = Math.min(Math.max(3, window.innerHeight / coverage.lines_len), 10); + + let previous_line = -99, last_mark, last_top; + + const scroll_marker = document.createElement("div"); + scroll_marker.id = "scroll_marker"; + document.getElementById("source").querySelectorAll( + "p.show_run, p.show_mis, p.show_exc, p.show_exc, p.show_par" + ).forEach(element => { + const line_top = Math.floor(element.offsetTop * marker_scale); + const line_number = parseInt(element.querySelector(".n a").id.substr(1)); + + if (line_number === previous_line + 1) { + // If this solid missed block just make previous mark higher. + last_mark.style.height = `${line_top + line_height - last_top}px`; + } + else { + // Add colored line in scroll_marker block. + last_mark = document.createElement("div"); + last_mark.id = `m${line_number}`; + last_mark.classList.add("marker"); + last_mark.style.height = `${line_height}px`; + last_mark.style.top = `${line_top}px`; + scroll_marker.append(last_mark); + last_top = line_top; + } + + previous_line = line_number; + }); + + // Append last to prevent layout calculation + document.body.append(scroll_marker); +}; + +coverage.wire_up_sticky_header = function () { + const header = document.querySelector("header"); + const header_bottom = ( + header.querySelector(".content h2").getBoundingClientRect().top - + header.getBoundingClientRect().top + ); + + function updateHeader() { + if (window.scrollY > header_bottom) { + header.classList.add("sticky"); + } + else { + header.classList.remove("sticky"); + } + } + + window.addEventListener("scroll", updateHeader); + updateHeader(); +}; + +coverage.expand_contexts = function (e) { + var ctxs = e.target.parentNode.querySelector(".ctxs"); + + if (!ctxs.classList.contains("expanded")) { + var ctxs_text = ctxs.textContent; + var width = Number(ctxs_text[0]); + ctxs.textContent = ""; + for (var i = 1; i < ctxs_text.length; i += width) { + key = ctxs_text.substring(i, i + width).trim(); + ctxs.appendChild(document.createTextNode(contexts[key])); + ctxs.appendChild(document.createElement("br")); + } + ctxs.classList.add("expanded"); + } +}; + +document.addEventListener("DOMContentLoaded", () => { + if (document.body.classList.contains("indexfile")) { + coverage.index_ready(); + } + else { + coverage.pyfile_ready(); + } +}); diff --git a/htmlcov/favicon_32_cb_c827f16f.png b/htmlcov/favicon_32_cb_c827f16f.png new file mode 100644 index 000000000..8649f0475 Binary files /dev/null and b/htmlcov/favicon_32_cb_c827f16f.png differ diff --git a/htmlcov/function_index.html b/htmlcov/function_index.html new file mode 100644 index 000000000..7a07568f7 --- /dev/null +++ b/htmlcov/function_index.html @@ -0,0 +1,191 @@ + + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.1, + created at 2026-02-01 22:06 +0300 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Filefunction statementsmissingexcluded coverage
praktikum \ burger.pyBurger.__init__ 200 100%
praktikum \ burger.pyBurger.set_buns 100 100%
praktikum \ burger.pyBurger.add_ingredient 100 100%
praktikum \ burger.pyBurger.remove_ingredient 100 100%
praktikum \ burger.pyBurger.move_ingredient 100 100%
praktikum \ burger.pyBurger.get_price 400 100%
praktikum \ burger.pyBurger.get_receipt 600 100%
praktikum \ burger.py(no function) 1100 100%
Total  2700 100%
+

+ No items found using the specified filter. +

+
+ + + diff --git a/htmlcov/index.html b/htmlcov/index.html new file mode 100644 index 000000000..06e91ede3 --- /dev/null +++ b/htmlcov/index.html @@ -0,0 +1,117 @@ + + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.1, + created at 2026-02-01 22:06 +0300 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
File statementsmissingexcluded coverage
praktikum \ burger.py 2700 100%
Total 2700 100%
+

+ No items found using the specified filter. +

+
+ + + diff --git a/htmlcov/keybd_closed_cb_900cfef5.png b/htmlcov/keybd_closed_cb_900cfef5.png new file mode 100644 index 000000000..ba119c47d Binary files /dev/null and b/htmlcov/keybd_closed_cb_900cfef5.png differ diff --git a/htmlcov/status.json b/htmlcov/status.json new file mode 100644 index 000000000..0081fdfbe --- /dev/null +++ b/htmlcov/status.json @@ -0,0 +1 @@ +{"note":"This file is an internal implementation detail to speed up HTML report generation. Its format can change at any time. You might be looking for the JSON report: https://coverage.rtfd.io/cmd.html#cmd-json","format":5,"version":"7.13.1","globals":"1563e62c381713d2c5de62b4dad6874c","files":{"z_c68eb0c7512457e4_burger_py":{"hash":"80129eeb12a5b5f10eef6d82eef1ca17","index":{"url":"z_c68eb0c7512457e4_burger_py.html","file":"praktikum\\burger.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":27,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}}}} \ No newline at end of file diff --git a/htmlcov/style_cb_5c747636.css b/htmlcov/style_cb_5c747636.css new file mode 100644 index 000000000..5e304ce5f --- /dev/null +++ b/htmlcov/style_cb_5c747636.css @@ -0,0 +1,389 @@ +@charset "UTF-8"; +/* Licensed under the Apache License: http://www.apache.org/licenses/LICENSE-2.0 */ +/* For details: https://github.com/coveragepy/coveragepy/blob/main/NOTICE.txt */ +/* Don't edit this .css file. Edit the .scss file instead! */ +html, body, h1, h2, h3, p, table, td, th { margin: 0; padding: 0; border: 0; font-weight: inherit; font-style: inherit; font-size: 100%; font-family: inherit; vertical-align: baseline; } + +body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; font-size: 1em; background: #fff; color: #000; } + +@media (prefers-color-scheme: dark) { body { background: #1e1e1e; } } + +@media (prefers-color-scheme: dark) { body { color: #eee; } } + +html > body { font-size: 16px; } + +a:active, a:focus { outline: 2px dashed #007acc; } + +p { font-size: .875em; line-height: 1.4em; } + +table { border-collapse: collapse; } + +td { vertical-align: top; } + +table tr.hidden { display: none !important; } + +p#no_rows { display: none; font-size: 1.15em; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; } + +a.nav { text-decoration: none; color: inherit; } + +a.nav:hover { text-decoration: underline; color: inherit; } + +.hidden { display: none; } + +header { background: #f8f8f8; width: 100%; z-index: 2; border-bottom: 1px solid #ccc; } + +@media (prefers-color-scheme: dark) { header { background: black; } } + +@media (prefers-color-scheme: dark) { header { border-color: #333; } } + +header .content { padding: 1rem 3.5rem; } + +header h2 { margin-top: .5em; font-size: 1em; } + +header h2 a.button { font-family: inherit; font-size: inherit; border: 1px solid; border-radius: .2em; background: #eee; color: inherit; text-decoration: none; padding: .1em .5em; margin: 1px calc(.1em + 1px); cursor: pointer; border-color: #ccc; } + +@media (prefers-color-scheme: dark) { header h2 a.button { background: #333; } } + +@media (prefers-color-scheme: dark) { header h2 a.button { border-color: #444; } } + +header h2 a.button.current { border: 2px solid; background: #fff; border-color: #999; cursor: default; } + +@media (prefers-color-scheme: dark) { header h2 a.button.current { background: #1e1e1e; } } + +@media (prefers-color-scheme: dark) { header h2 a.button.current { border-color: #777; } } + +header p.text { margin: .5em 0 -.5em; color: #666; font-style: italic; } + +@media (prefers-color-scheme: dark) { header p.text { color: #aaa; } } + +header.sticky { position: fixed; left: 0; right: 0; height: 2.5em; } + +header.sticky .text { display: none; } + +header.sticky h1, header.sticky h2 { font-size: 1em; margin-top: 0; display: inline-block; } + +header.sticky .content { padding: 0.5rem 3.5rem; } + +header.sticky .content p { font-size: 1em; } + +header.sticky ~ #source { padding-top: 6.5em; } + +main { position: relative; z-index: 1; } + +footer { margin: 1rem 3.5rem; } + +footer .content { padding: 0; color: #666; font-style: italic; } + +@media (prefers-color-scheme: dark) { footer .content { color: #aaa; } } + +#index { margin: 1rem 0 0 3.5rem; } + +h1 { font-size: 1.25em; display: inline-block; } + +#filter_container { float: right; margin: 0 2em 0 0; line-height: 1.66em; } + +#filter_container #filter { width: 10em; padding: 0.2em 0.5em; border: 2px solid #ccc; background: #fff; color: #000; } + +@media (prefers-color-scheme: dark) { #filter_container #filter { border-color: #444; } } + +@media (prefers-color-scheme: dark) { #filter_container #filter { background: #1e1e1e; } } + +@media (prefers-color-scheme: dark) { #filter_container #filter { color: #eee; } } + +#filter_container #filter:focus { border-color: #007acc; } + +#filter_container :disabled ~ label { color: #ccc; } + +@media (prefers-color-scheme: dark) { #filter_container :disabled ~ label { color: #444; } } + +#filter_container label { font-size: .875em; color: #666; } + +@media (prefers-color-scheme: dark) { #filter_container label { color: #aaa; } } + +header button { font-family: inherit; font-size: inherit; border: 1px solid; border-radius: .2em; background: #eee; color: inherit; text-decoration: none; padding: .1em .5em; margin: 1px calc(.1em + 1px); cursor: pointer; border-color: #ccc; } + +@media (prefers-color-scheme: dark) { header button { background: #333; } } + +@media (prefers-color-scheme: dark) { header button { border-color: #444; } } + +header button:active, header button:focus { outline: 2px dashed #007acc; } + +header button.run { background: #eeffee; } + +@media (prefers-color-scheme: dark) { header button.run { background: #373d29; } } + +header button.run.show_run { background: #dfd; border: 2px solid #00dd00; margin: 0 .1em; } + +@media (prefers-color-scheme: dark) { header button.run.show_run { background: #373d29; } } + +header button.mis { background: #ffeeee; } + +@media (prefers-color-scheme: dark) { header button.mis { background: #4b1818; } } + +header button.mis.show_mis { background: #fdd; border: 2px solid #ff0000; margin: 0 .1em; } + +@media (prefers-color-scheme: dark) { header button.mis.show_mis { background: #4b1818; } } + +header button.exc { background: #f7f7f7; } + +@media (prefers-color-scheme: dark) { header button.exc { background: #333; } } + +header button.exc.show_exc { background: #eee; border: 2px solid #808080; margin: 0 .1em; } + +@media (prefers-color-scheme: dark) { header button.exc.show_exc { background: #333; } } + +header button.par { background: #ffffd5; } + +@media (prefers-color-scheme: dark) { header button.par { background: #650; } } + +header button.par.show_par { background: #ffa; border: 2px solid #bbbb00; margin: 0 .1em; } + +@media (prefers-color-scheme: dark) { header button.par.show_par { background: #650; } } + +#help_panel, #source p .annotate.long { display: none; position: absolute; z-index: 999; background: #ffffcc; border: 1px solid #888; border-radius: .2em; color: #333; padding: .25em .5em; } + +#source p .annotate.long { white-space: normal; float: right; top: 1.75em; right: 1em; height: auto; } + +#help_panel_wrapper { float: right; position: relative; } + +#keyboard_icon { margin: 5px; } + +#help_panel_state { display: none; } + +#help_panel { top: 25px; right: 0; padding: .75em; border: 1px solid #883; color: #333; } + +#help_panel .keyhelp p { margin-top: .75em; } + +#help_panel .legend { font-style: italic; margin-bottom: 1em; } + +.indexfile #help_panel { width: 25em; } + +.pyfile #help_panel { width: 18em; } + +#help_panel_state:checked ~ #help_panel { display: block; } + +kbd { border: 1px solid black; border-color: #888 #333 #333 #888; padding: .1em .35em; font-family: SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-weight: bold; background: #eee; border-radius: 3px; } + +#source { padding: 1em 0 1em 3.5rem; font-family: SFMono-Regular, Menlo, Monaco, Consolas, monospace; } + +#source p { position: relative; white-space: pre; } + +#source p * { box-sizing: border-box; } + +#source p .n { float: left; text-align: right; width: 3.5rem; box-sizing: border-box; margin-left: -3.5rem; padding-right: 1em; color: #999; user-select: none; } + +@media (prefers-color-scheme: dark) { #source p .n { color: #777; } } + +#source p .n.highlight { background: #ffdd00; } + +#source p .n a { scroll-margin-top: 6em; text-decoration: none; color: #999; } + +@media (prefers-color-scheme: dark) { #source p .n a { color: #777; } } + +#source p .n a:hover { text-decoration: underline; color: #999; } + +@media (prefers-color-scheme: dark) { #source p .n a:hover { color: #777; } } + +#source p .t { display: inline-block; width: 100%; box-sizing: border-box; margin-left: -.5em; padding-left: 0.3em; border-left: 0.2em solid #fff; } + +@media (prefers-color-scheme: dark) { #source p .t { border-color: #1e1e1e; } } + +#source p .t:hover { background: #f2f2f2; } + +@media (prefers-color-scheme: dark) { #source p .t:hover { background: #282828; } } + +#source p .t:hover ~ .r .annotate.long { display: block; } + +#source p .t .com { color: #008000; font-style: italic; line-height: 1px; } + +@media (prefers-color-scheme: dark) { #source p .t .com { color: #6a9955; } } + +#source p .t .key { font-weight: bold; line-height: 1px; } + +#source p .t .str, #source p .t .fst { color: #0451a5; } + +@media (prefers-color-scheme: dark) { #source p .t .str, #source p .t .fst { color: #9cdcfe; } } + +#source p.mis .t { border-left: 0.2em solid #ff0000; } + +#source p.mis.show_mis .t { background: #fdd; } + +@media (prefers-color-scheme: dark) { #source p.mis.show_mis .t { background: #4b1818; } } + +#source p.mis.show_mis .t:hover { background: #f2d2d2; } + +@media (prefers-color-scheme: dark) { #source p.mis.show_mis .t:hover { background: #532323; } } + +#source p.mis.mis2 .t { border-left: 0.2em dotted #ff0000; } + +#source p.mis.mis2.show_mis .t { background: #ffeeee; } + +@media (prefers-color-scheme: dark) { #source p.mis.mis2.show_mis .t { background: #351b1b; } } + +#source p.mis.mis2.show_mis .t:hover { background: #f2d2d2; } + +@media (prefers-color-scheme: dark) { #source p.mis.mis2.show_mis .t:hover { background: #532323; } } + +#source p.run .t { border-left: 0.2em solid #00dd00; } + +#source p.run.show_run .t { background: #dfd; } + +@media (prefers-color-scheme: dark) { #source p.run.show_run .t { background: #373d29; } } + +#source p.run.show_run .t:hover { background: #d2f2d2; } + +@media (prefers-color-scheme: dark) { #source p.run.show_run .t:hover { background: #404633; } } + +#source p.run.run2 .t { border-left: 0.2em dotted #00dd00; } + +#source p.run.run2.show_run .t { background: #eeffee; } + +@media (prefers-color-scheme: dark) { #source p.run.run2.show_run .t { background: #2b2e24; } } + +#source p.run.run2.show_run .t:hover { background: #d2f2d2; } + +@media (prefers-color-scheme: dark) { #source p.run.run2.show_run .t:hover { background: #404633; } } + +#source p.exc .t { border-left: 0.2em solid #808080; } + +#source p.exc.show_exc .t { background: #eee; } + +@media (prefers-color-scheme: dark) { #source p.exc.show_exc .t { background: #333; } } + +#source p.exc.show_exc .t:hover { background: #e2e2e2; } + +@media (prefers-color-scheme: dark) { #source p.exc.show_exc .t:hover { background: #3c3c3c; } } + +#source p.exc.exc2 .t { border-left: 0.2em dotted #808080; } + +#source p.exc.exc2.show_exc .t { background: #f7f7f7; } + +@media (prefers-color-scheme: dark) { #source p.exc.exc2.show_exc .t { background: #292929; } } + +#source p.exc.exc2.show_exc .t:hover { background: #e2e2e2; } + +@media (prefers-color-scheme: dark) { #source p.exc.exc2.show_exc .t:hover { background: #3c3c3c; } } + +#source p.par .t { border-left: 0.2em solid #bbbb00; } + +#source p.par.show_par .t { background: #ffa; } + +@media (prefers-color-scheme: dark) { #source p.par.show_par .t { background: #650; } } + +#source p.par.show_par .t:hover { background: #f2f2a2; } + +@media (prefers-color-scheme: dark) { #source p.par.show_par .t:hover { background: #6d5d0c; } } + +#source p.par.par2 .t { border-left: 0.2em dotted #bbbb00; } + +#source p.par.par2.show_par .t { background: #ffffd5; } + +@media (prefers-color-scheme: dark) { #source p.par.par2.show_par .t { background: #423a0f; } } + +#source p.par.par2.show_par .t:hover { background: #f2f2a2; } + +@media (prefers-color-scheme: dark) { #source p.par.par2.show_par .t:hover { background: #6d5d0c; } } + +#source p .r { position: absolute; top: 0; right: 2.5em; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; } + +#source p .annotate { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; color: #666; padding-right: .5em; } + +@media (prefers-color-scheme: dark) { #source p .annotate { color: #ddd; } } + +#source p .annotate.short:hover ~ .long { display: block; } + +#source p .annotate.long { width: 30em; right: 2.5em; } + +#source p input { display: none; } + +#source p input ~ .r label.ctx { cursor: pointer; border-radius: .25em; } + +#source p input ~ .r label.ctx::before { content: "▶ "; } + +#source p input ~ .r label.ctx:hover { background: #e8f4ff; color: #666; } + +@media (prefers-color-scheme: dark) { #source p input ~ .r label.ctx:hover { background: #0f3a42; } } + +@media (prefers-color-scheme: dark) { #source p input ~ .r label.ctx:hover { color: #aaa; } } + +#source p input:checked ~ .r label.ctx { background: #d0e8ff; color: #666; border-radius: .75em .75em 0 0; padding: 0 .5em; margin: -.25em 0; } + +@media (prefers-color-scheme: dark) { #source p input:checked ~ .r label.ctx { background: #056; } } + +@media (prefers-color-scheme: dark) { #source p input:checked ~ .r label.ctx { color: #aaa; } } + +#source p input:checked ~ .r label.ctx::before { content: "▼ "; } + +#source p input:checked ~ .ctxs { padding: .25em .5em; overflow-y: scroll; max-height: 10.5em; } + +#source p label.ctx { color: #999; display: inline-block; padding: 0 .5em; font-size: .8333em; } + +@media (prefers-color-scheme: dark) { #source p label.ctx { color: #777; } } + +#source p .ctxs { display: block; max-height: 0; overflow-y: hidden; transition: all .2s; padding: 0 .5em; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; white-space: nowrap; background: #d0e8ff; border-radius: .25em; margin-right: 1.75em; text-align: right; } + +@media (prefers-color-scheme: dark) { #source p .ctxs { background: #056; } } + +#index { font-family: SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 0.875em; } + +#index table.index { margin-left: -.5em; } + +#index td, #index th { text-align: right; vertical-align: baseline; padding: .25em .5em; border-bottom: 1px solid #eee; } + +@media (prefers-color-scheme: dark) { #index td, #index th { border-color: #333; } } + +#index td.name, #index th.name { text-align: left; width: auto; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; min-width: 15em; } + +#index td.left, #index th.left { text-align: left; } + +#index td.spacer, #index th.spacer { border: none; padding: 0; } + +#index td.spacer:hover, #index th.spacer:hover { background: inherit; } + +#index th { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; font-style: italic; color: #333; border-color: #ccc; cursor: pointer; } + +@media (prefers-color-scheme: dark) { #index th { color: #ddd; } } + +@media (prefers-color-scheme: dark) { #index th { border-color: #444; } } + +#index th:hover { background: #eee; } + +@media (prefers-color-scheme: dark) { #index th:hover { background: #333; } } + +#index th .arrows { color: #666; font-size: 85%; font-family: sans-serif; font-style: normal; pointer-events: none; } + +#index th[aria-sort="ascending"], #index th[aria-sort="descending"] { white-space: nowrap; background: #eee; padding-left: .5em; } + +@media (prefers-color-scheme: dark) { #index th[aria-sort="ascending"], #index th[aria-sort="descending"] { background: #333; } } + +#index th[aria-sort="ascending"] .arrows::after { content: " ▲"; } + +#index th[aria-sort="descending"] .arrows::after { content: " ▼"; } + +#index tr.grouphead th { cursor: default; font-style: normal; border-color: #999; } + +@media (prefers-color-scheme: dark) { #index tr.grouphead th { border-color: #777; } } + +#index td.name { font-size: 1.15em; } + +#index td.name a { text-decoration: none; color: inherit; } + +#index td.name .no-noun { font-style: italic; } + +#index tr.total td, #index tr.total_dynamic td { font-weight: bold; border-bottom: none; } + +#index tr.region:hover { background: #eee; } + +@media (prefers-color-scheme: dark) { #index tr.region:hover { background: #333; } } + +#index tr.region:hover td.name { text-decoration: underline; color: inherit; } + +#scroll_marker { position: fixed; z-index: 3; right: 0; top: 0; width: 16px; height: 100%; background: #fff; border-left: 1px solid #eee; will-change: transform; } + +@media (prefers-color-scheme: dark) { #scroll_marker { background: #1e1e1e; } } + +@media (prefers-color-scheme: dark) { #scroll_marker { border-color: #333; } } + +#scroll_marker .marker { background: #ccc; position: absolute; min-height: 3px; width: 100%; } + +@media (prefers-color-scheme: dark) { #scroll_marker .marker { background: #444; } } diff --git a/htmlcov/z_c68eb0c7512457e4_burger_py.html b/htmlcov/z_c68eb0c7512457e4_burger_py.html new file mode 100644 index 000000000..7c0825d7e --- /dev/null +++ b/htmlcov/z_c68eb0c7512457e4_burger_py.html @@ -0,0 +1,145 @@ + + + + + Coverage for praktikum\burger.py: 100% + + + + + +
+
+

+ Coverage for praktikum \ burger.py: + 100% +

+ +

+ 27 statements   + + + +

+

+ « prev     + ^ index     + » next +       + coverage.py v7.13.1, + created at 2026-02-01 22:04 +0300 +

+ +
+
+
+

1from typing import List 

+

2 

+

3from praktikum.bun import Bun 

+

4from praktikum.ingredient import Ingredient 

+

5 

+

6 

+

7class Burger: 

+

8 """ 

+

9 Модель бургера. 

+

10 Бургер состоит из булочек и ингредиентов (начинка или соус). 

+

11 Ингредиенты можно перемещать и удалять. 

+

12 Можно распечать чек с информацией о бургере. 

+

13 """ 

+

14 

+

15 def __init__(self): 

+

16 self.bun = None 

+

17 self.ingredients: List[Ingredient] = [] 

+

18 

+

19 def set_buns(self, bun: Bun): 

+

20 self.bun = bun 

+

21 

+

22 def add_ingredient(self, ingredient: Ingredient): 

+

23 self.ingredients.append(ingredient) 

+

24 

+

25 def remove_ingredient(self, index: int): 

+

26 del self.ingredients[index] 

+

27 

+

28 def move_ingredient(self, index: int, new_index: int): 

+

29 self.ingredients.insert(new_index, self.ingredients.pop(index)) 

+

30 

+

31 def get_price(self) -> float: 

+

32 price = self.bun.get_price() * 2 

+

33 

+

34 for ingredient in self.ingredients: 

+

35 price += ingredient.get_price() 

+

36 

+

37 return price 

+

38 

+

39 def get_receipt(self) -> str: 

+

40 receipt: List[str] = [f'(==== {self.bun.get_name()} ====)'] 

+

41 

+

42 for ingredient in self.ingredients: 

+

43 receipt.append(f'= {str(ingredient.get_type()).lower()} {ingredient.get_name()} =') 

+

44 

+

45 receipt.append(f'(==== {self.bun.get_name()} ====)\n') 

+

46 receipt.append(f'Price: {self.get_price()}') 

+

47 

+

48 return '\n'.join(receipt) 

+
+ + + diff --git a/__init__.py b/praktikum/__init__.py similarity index 100% rename from __init__.py rename to praktikum/__init__.py diff --git a/bun.py b/praktikum/bun.py similarity index 100% rename from bun.py rename to praktikum/bun.py diff --git a/burger.py b/praktikum/burger.py similarity index 100% rename from burger.py rename to praktikum/burger.py diff --git a/database.py b/praktikum/database.py similarity index 100% rename from database.py rename to praktikum/database.py diff --git a/ingredient.py b/praktikum/ingredient.py similarity index 100% rename from ingredient.py rename to praktikum/ingredient.py diff --git a/ingredient_types.py b/praktikum/ingredient_types.py similarity index 100% rename from ingredient_types.py rename to praktikum/ingredient_types.py diff --git a/praktikum.py b/praktikum/praktikum.py similarity index 100% rename from praktikum.py rename to praktikum/praktikum.py diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 000000000..e3e5a50e9 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,4 @@ +pytest~=9.0.2 +pytest-cov~=7.0.0 +allure-pytest~=2.15.3 +allure-python-commons~=2.15.3 \ No newline at end of file diff --git a/tests/test_burger.py b/tests/test_burger.py new file mode 100644 index 000000000..bc4bb4701 --- /dev/null +++ b/tests/test_burger.py @@ -0,0 +1,95 @@ +import allure + +import pytest +from data import * +from praktikum.burger import Burger + + +class TestBurger: + @allure.title('Проверка начального состояния атрибута bun') + @allure.description('Проверяем что начальное состояние атрибута bun равняется None') + def test_bun_initial_state(self): + burger = Burger() + assert burger.bun is None + + @allure.title('Проверка начального состояния атрибута ingredients') + @allure.description('Проверяем что начальное состояние атрибута ingredients равняется пустому списку') + def test_ingredients_initial_state(self): + burger = Burger() + assert burger.ingredients == [] + + @allure.title('Проверка метода set_buns') + @allure.description('Проверяем, что метод set_buns корректно устанавливает значение атрибута bun') + def test_set_buns(self, mock_bun): + burger = Burger() + burger.set_buns(mock_bun) + assert burger.bun == mock_bun + + @allure.title('Проверка метода add_ingredient') + @allure.description('Проверяем, что метод add_ingredient корректно добавляет ингредиент в атрибут ingredients') + @pytest.mark.parametrize('mock_ingredients, expected_len', [ + [IngredientsCombinations.only_sauce, len(IngredientsCombinations.only_sauce)], + [IngredientsCombinations.only_filling, len(IngredientsCombinations.only_filling)], + [IngredientsCombinations.two_same_sauces, len(IngredientsCombinations.two_same_sauces)], + [IngredientsCombinations.two_same_fillings, len(IngredientsCombinations.two_same_fillings)], + [IngredientsCombinations.tree_different_ingredients, len(IngredientsCombinations.tree_different_ingredients)], + ]) + def test_add_ingredient(self, mock_ingredients, expected_len): + burger = Burger() + for ingredient in mock_ingredients: + burger.add_ingredient(ingredient) + assert len(burger.ingredients) == expected_len and burger.ingredients == mock_ingredients + + @allure.title('Проверка метода remove_ingredient') + @allure.description('Проверяем, что метод remove_ingredient корректно удаляет ингредиент из атрибута ingredients') + def test_remove_ingredient(self, mock_sauce, mock_filling): + burger = Burger() + burger.ingredients.append(mock_sauce) + burger.ingredients.append(mock_filling) + burger.remove_ingredient(1) + assert len(burger.ingredients) == 1 and burger.ingredients == [mock_sauce] + + @allure.title('Проверка метода remove_ingredient: удаление двух ингредиентов') + @allure.description('Проверяем, что метод remove_ingredient корректно удаляет 2 ингредиента из атрибута ingredients') + def test_remove_two_ingredients(self, mock_sauce, mock_filling): + burger = Burger() + burger.ingredients.append(mock_sauce) + burger.ingredients.append(mock_filling) + burger.remove_ingredient(0) + burger.remove_ingredient(0) + assert len(burger.ingredients) == 0 and burger.ingredients == [] + + @allure.title('Проверка метода move_ingredient') + @allure.description('Проверить, что метод move_ingredient корректно меняет порядок ингредиентов') + def test_move_ingredient(self, mock_sauce, mock_filling): + burger = Burger() + burger.ingredients.append(mock_sauce) + burger.ingredients.append(mock_filling) + burger.move_ingredient(1, 0) + assert burger.ingredients == [mock_filling, mock_sauce] + + @allure.title('Проверка метода get_price') + @allure.description( + 'Проверяем, что метод get_price корректно возвращает цену бургера в зависимости от передаваемых ингредиентов') + @pytest.mark.parametrize('bun, ingredients, expected_price', burgers_variants) + def test_get_price(self, bun, ingredients, expected_price): + burger = Burger() + burger.bun = bun + burger.ingredients = ingredients + assert burger.get_price() == expected_price + + @allure.title('Проверка метода get_receipt') + @allure.description( + 'Проверяем, что метод get_receipt корректно возвращает чек бургера в зависимости от передаваемых ингредиентов') + @pytest.mark.parametrize('ingredients', [ + IngredientsCombinations.only_sauce, + IngredientsCombinations.only_filling, + IngredientsCombinations.two_same_sauces, + IngredientsCombinations.two_same_fillings, + IngredientsCombinations.tree_different_ingredients, + ]) + def test_get_receipt(self, mock_bun, ingredients): + burger = Burger() + burger.bun = mock_bun + burger.ingredients = ingredients + assert burger.get_receipt() == BurgerReceipt.get_receipt(mock_bun, ingredients) \ No newline at end of file