From 38841cb309283b2194f77b2ada12a6a00535ef61 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Sun, 15 Feb 2026 19:05:36 +0500 Subject: [PATCH 01/20] =?UTF-8?q?=D0=9F=D0=B5=D1=80=D0=B2=D1=8B=D0=B9=20?= =?UTF-8?q?=D0=BA=D0=BE=D0=BC=D0=BC=D0=B8=D1=82.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 1 + __pycache__/bun.cpython-311.pyc | Bin 0 -> 1168 bytes __pycache__/burger.cpython-311.pyc | Bin 0 -> 3571 bytes __pycache__/ingredient.cpython-311.pyc | Bin 0 -> 1489 bytes __pycache__/ingredient_types.cpython-311.pyc | Bin 0 -> 428 bytes __pycache__/praktikum.cpython-311.pyc | Bin 0 -> 1665 bytes database.py | 6 +++--- praktikum.py | 8 ++++---- 8 files changed, 8 insertions(+), 7 deletions(-) create mode 100644 __pycache__/bun.cpython-311.pyc create mode 100644 __pycache__/burger.cpython-311.pyc create mode 100644 __pycache__/ingredient.cpython-311.pyc create mode 100644 __pycache__/ingredient_types.cpython-311.pyc create mode 100644 __pycache__/praktikum.cpython-311.pyc diff --git a/README.md b/README.md index 272081708..bbfbb8186 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,4 @@ +## Начинаем 2026.02.15 ## Задание 1: Юнит-тесты ### Автотесты для проверки программы, которая помогает заказать бургер в Stellar Burgers diff --git a/__pycache__/bun.cpython-311.pyc b/__pycache__/bun.cpython-311.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a707f566c9b2a72ae114f271d63ddfa454387dce GIT binary patch literal 1168 zcmb7COKTHR6h8AxCb1927TUTAy2_^DLWCkNL~z%I!A%GZX=WmkJnEf9Xz8M~rFK!M zg-W{++^NM)t=5*diGShFuFOjC4@9aPSAOSCl9s9q?=ata+U#sh- zmm1MG4!X`f=%)$tGSfbT`g<4 zx@WqEXBAD?Tr#sU*YeDw?#AH9;al+I@NL%yYa%r6HL8sbuq0Dh@|A4KPjXKl1*<9f zAy|}0vK2g+hw>nW{86x`vcbIkDEELn3!wH_-4GRze=< zLjQ-sLhgQPx?HQ=%uO|_*WViy@CdH`67c83sZq9!OnD0Gp-LUL7F(h^C+E%7bFz<$yxd^sqjc(m&6U;@3 zY1Y`*EzXYp6QY*5n@M~t)zt{M#+s{6f7y4Uk?)F8 zdIaWedYci2wJ7lIz;^)O4tz}S01IPIaAd}uGR&Fh1VSPzH2NvMO~0ed^cK6I(y!TB zHb=ju%Rra*xEnrNm#ORwz0Ju;*x>}z zg@TdS>mED+GM@(>X&0H`^5FH0x8SiIK)@R%3fR_^9aUvVCBl@Xtt4r^yZ*_U zyl%YXbFBe4YVx}_D-3TiTi|Bb&E@xQ1bmZeJ4R+g(G$dE;$Rg~lT8^#;$b8;2|~eq-+u2hkTRG`OWT$IAa4Z;YJeMJ|(vIx0F+ zVY-lz+yq2COzs!j3s0e&hOuT$ws@E{$sdM8){{V*!Wh1~*G@iLOFmysKL3l%k}ulH z7nyR%Ru0j6cL58UMsdc>`(Ba&=;K*C2h9DTbs6?ugP+@Up(GP>8tU&v1Gj_ZwFgg& zP?O@_@%C#dL7ANvE^M0>;NOKf_B*Npz_8?<@Dvni!OTn=ZeF=KIO`p^6Iu8d)uRHL&M>(867!^>@Vf+Ki86IQ=1VnDT9~eG?FMvzZl+XfY z8lkM9?v|!YMSSMG25>_tTALqk|C3X}Vrgmq6JS~3{z3^mJQD5N~py>5Hx#uNo>}sD;11sOKW}zAZf#6rQoh%Xlf~_;+QCj!|K0+S`yXa zQpgoWN}*RUk%wR*k_fx`tzeGk(>XW2P5fu(NLJBw_(Jhi!Eog4^xKBXGusKAn9k(A z$HWPl#-x!c6wQ`0aN1Cp%>v;HBwe~9*s zczyeUa%jCW-Vm@f-Vm@hHZP2wAEOVw{-snoQtR7S?c2xtp0WF$Vd{{r4%O5bs_F|& z9kJCB*aZETRBiOt>gcO%G-Z#bTp3Un)$FK7d0$mx3mxY>X!md>@P$%S2de4-QwMEz z5JYZg%6?nfPnG>E^}U0Y&MQ5i_psgpyLW(g!`4Bj?6sA>RN1>4+q`h<{Heum7VEWR zy;SMtWjmILrs>m@nr3zYP$oW;<|ZUqV`di+ zN6O@j=2o0;$EkcgJDo1_NSTPRxf{q=gkQ=ZdJ|KT6J)Gkfy_1j)9U|-HQhRd%3%r1O<8b)om!nXUj)msjp(8w6B@K(n~_+D2iVamb}rO`DidGcP&1( zMqp?r@vyve5l+HzPvSa`u8t)_P7tygKUDA`bJ`1L`pshI&6(UD`26DFI-TpX^$!{s zZI0U@99+lpU*$PBZu`xBuz=rCRu0ITBnZL^>8Ad^O14vfUm;2A?`y$?0N%8czfkt~ JT^6`G{{gd?hu8oB literal 0 HcmV?d00001 diff --git a/__pycache__/ingredient.cpython-311.pyc b/__pycache__/ingredient.cpython-311.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a9760683a401f686502b1f5232a4564e260be71b GIT binary patch literal 1489 zcmbVL&1(}u6rcS{H`|sfiP8_0gHwC?6-xXUtb-YOQ(lRT$X%dM{J4;xI%^y*$!4P({`TWK&DeB z^=FH2sOM8TH#CYolXlbX(O{Qx5E{IVDirGT$s?)7?tT-E*lxFf7pVGNlch+NVqY2#J z2#5u85FcID*P;jUL8;CSgR)lPX}~cFBi!{%JfH5A4@ShYS!V!1v&bXR%{56l#!e`* z2OA2F%Uf6MAtHQ-bg^Nu<*8U3{F6_CmLjlO#dtoz3>4hyI z1sC=LrT1Ofq{kKP80ze*@Tg%jP|t;Z7n?6Oa=Cf>_;~ucg9U-wHh@eA(z`Bf;JU>M zR)32fs>V-~`4)S8d`fiefHI0lR%S(209uE=;(v3GCWEK&OB_wH-*e0X^Iwb74NvOZ$M{ z*>$lg#wD{LCqLIPCNnR+C^aQBHLoPTq_QBjSg)Y+7l%!5eoARhs$CH%%t4`BtPCVR kFf%eTeqdr@Wck1VBDfeN6)rG{-jGthz#tAmMI1nN0Od%q_5c6? literal 0 HcmV?d00001 diff --git a/__pycache__/praktikum.cpython-311.pyc b/__pycache__/praktikum.cpython-311.pyc new file mode 100644 index 0000000000000000000000000000000000000000..34c33fe5d53c27c4d5535530e980e6a90f6a44b3 GIT binary patch literal 1665 zcmb_b&1(}u6rasbHp!+{ikOnPniQ+BNLvI?A|67hilT@JB?Q8zyOgE7X_(y&V5d?dxNG~FYMMeJtVKxL3_9Tdh+ybQsJ^5x$casPnif`Y}{N}wk@4b0%=GFMP zh=6{6eWHKB2z_UZJqq=~jsf5qQjy9T$mH@I$8g99nS7r2FmGTpoDX{#8-f|hM?4%h zqGl`~11#J_c~Oh2k!8;-84Dpz+yuW{d(jYBMQ?b&9P2Wv%(?iAZrL#N*=iXkAzLL& z8UYl|DYjBlEDf-Dsk}rqRoBY)qVEj=oCopn@0@{{&ydXp%Hha&kj?D+G@|2bXk)Ju zdnVpIViy9t0WX2+h#g3q6a|m{YedPeC@oH#ayZC+W!u#44 z{^u@X;5a^11vRt@b>H%9@6{mU8w>yyk56}sOScgBUcFv-(`L1 zvZi%ehr6s1U8ayl!jdOU;2uy`72QxuhE^<9%a(gMSnK`;wcMzs*?$ZUD5_cvRPI4@ zWmOv#Ob~5U6s{1xY`gI#a6+_2O|RH8cB5+lHMl~_dm%3NQiuoMEsN!!0oq*vuz0p` z)6$4lfJam!1-eeR=@&sPhwsOnGrlOb05eUJGZeb{09sNj7Jx{$z)i3S}C?P#rSYN2m_XISV zZYO4%i5Vv`*GkOQb09h~)1J;Yr?bvEPcab z8z-AM**LYKyqI;c+`=-&a_2wEy|`_hYT{JmbVG4)riC*UXZmufiKWJM2d7&&O>r8I z6&4?!Y>QG;lpOI`OFZW5Kn=VD#XxSfSY+iX7O%=PdU;96;mq~Un3$hX$pp4(R1dCS~axu!3+G z%-_% Date: Sun, 22 Feb 2026 08:02:09 +0500 Subject: [PATCH 02/20] Second commit --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index bbfbb8186..f0ba02934 100644 --- a/README.md +++ b/README.md @@ -23,3 +23,4 @@ **Запуск автотестов и создание HTML-отчета о покрытии** > `$ pytest --cov=praktikum --cov-report=html` +# 2026.02.22 Воскресенье. From bbd147d7d7da8ef9f0226031e4646dc51e659f9a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Sun, 22 Feb 2026 10:04:18 +0500 Subject: [PATCH 03/20] Third commit --- __pycache__/burger.cpython-311.pyc | Bin 3571 -> 3544 bytes __pycache__/database.cpython-311.pyc | Bin 0 -> 2687 bytes burger.py | 4 ++-- 3 files changed, 2 insertions(+), 2 deletions(-) create mode 100644 __pycache__/database.cpython-311.pyc diff --git a/__pycache__/burger.cpython-311.pyc b/__pycache__/burger.cpython-311.pyc index d7dac2d0915a18c19a0b16f3c322575ae85e98c3..aeb4ddb955af42e14543da057de304f586dc2828 100644 GIT binary patch delta 88 zcmew?eM6dWIWI340}xpB&dU7Ax{*(Um%j)kP{aZvgn-240A3YF)5)d0s!GBa7*Nm+ N2E_}gX!0Ija{#Io7Ha?i delta 115 zcmca1{aKoCIWI340}wpOo0!SUwvkVQSL+sUK~Z9MNoICwu3l1UUJ(mW`j!YnEHf{? lC^aQBHLql{DX$8n`Q#{GRVCRA3@GRZgZ2efG{8EoS9X! z^dSwY6bz^!Ls^3@!_G7;jy%qzHok6OTCtPeK_cBR=+VaItsen&Kcn%>nPDbBccS0u0E+dMri^*O(-zv zm-G(3>0S0ND=_IgUG?Va2K|xV1b$7Szt9cEn*-?<-2lsKxa$_kw_(>$O1SYZz3YAK zUFi=U=C}wILNVZ3Fx#hrE})+Db_U@H-*`FKz|)P$ z8wV#nkw1Zmhw4viE}jGMMQ9%pZ+tgeh&?R$noMF4JLL1mZkeD%^o=18|Cetl!$bAm zTF(zj9CA+f`ffSoob2`8`na4B1W&hZtQ?=T^xS*OWU26wK-}f{htsBOgz^@XW6*k- zWcET?mE+SzS8?=G&L}6GV#!u=wxQ?CExBpaGHZrF&Xruta05)tLJ{`bK@6y)PZ`iE zL~!KGPG>WYVLMr9IFojk zeooh*ncRV{v7V)$(jUS$vkt9i9t^i({fMr4pJeIR&}}y8D*f4;&kmV0Rx$r#mh7~x z{+ZbTYnoXwT}>+=-|c4oyQ(%g*BJ*4bEwjN;;Oh9uk;OE6@A?G0Jkp2@8hm}xa+I- zFWy;s!Ati0$$k$H_;`TgfyxuvFRTb&ve!@cdbrQWeH8bBe>mkn?!Je+zf1gn>ebCt zTaKrsd?n@Kw2#vir{RpIJ-zgN%2U$5lJ;=M#~F$<`#1H`x6+=H@s*5+Cwx3X@kH}! zgPUi!a-K5oE8`wc`8Y*!s@c)t=DEk8Hn=&m4>ll&xecjBfovOY$u2bXcy{Hi6Kx*@ zveeLbQ&1RVJ)F%fb~}(-eb^nq21oP{bkou&Ekk3qR_=_hv(fM@`;N6gxYVQVi?bAW z*_|N%cM$f|upM9=hh-m(j{0ePioN{Y0ciHv6>#OW00}|)N4qKR4pEKuBv^?S^t_>I zK|<5=MN)zgwV+kg-Y@CajwPmPq?pq*`zZ#B<*)Xxo?%@0xLDlRQRp;Gn9cqjgaiZQ z6oJe|e^s8Ba1}9vk4PD=iuO>2lakBga_ZZ76#?5!WKL3+-Ia6x$(NW(c_gV}VK7*f zvO7D&GQzM20$gDjK#-_sDU2gHR##~7iQ&}SMlGc0!9hLDfAGt-l)Yk~1Ouxs=L(Rj qz;Rp!b<)Q90JYP`SwSag Date: Sun, 22 Feb 2026 10:17:31 +0500 Subject: [PATCH 04/20] Fourth commit --- .gitignore | 209 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 209 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..5f048d09b --- /dev/null +++ b/.gitignore @@ -0,0 +1,209 @@ +# Byte-compiled / optimized / DLL files +__pycache__/ +*.py[codz] +*$py.class + +# C extensions +*.so + +# Distribution / packaging +.Python +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +.eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +wheels/ +share/python-wheels/ +*.egg-info/ +.installed.cfg +*.egg +MANIFEST + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.nox/ +.coverage +.coverage.* +.cache +nosetests.xml +coverage.xml +*.cover +*.py.cover +.hypothesis/ +.pytest_cache/ +cover/ + +# Translations +*.mo +*.pot + +# Django stuff: +*.log +local_settings.py +db.sqlite3 +db.sqlite3-journal + +# Flask stuff: +instance/ +.webassets-cache + +# Scrapy stuff: +.scrapy + +# Sphinx documentation +docs/_build/ + +# PyBuilder +.pybuilder/ +target/ + +# Jupyter Notebook +.ipynb_checkpoints + +# IPython +profile_default/ +ipython_config.py + +# pyenv +# For a library or package, you might want to ignore these files since the code is +# intended to run in multiple environments; otherwise, check them in: +# .python-version + +# pipenv +# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. +# However, in case of collaboration, if having platform-specific dependencies or dependencies +# having no cross-platform support, pipenv may install dependencies that don't work, or not +# install all needed dependencies. +#Pipfile.lock + +# UV +# Similar to Pipfile.lock, it is generally recommended to include uv.lock in version control. +# This is especially recommended for binary packages to ensure reproducibility, and is more +# commonly ignored for libraries. +#uv.lock + +# poetry +# Similar to Pipfile.lock, it is generally recommended to include poetry.lock in version control. +# This is especially recommended for binary packages to ensure reproducibility, and is more +# commonly ignored for libraries. +# https://python-poetry.org/docs/basic-usage/#commit-your-poetrylock-file-to-version-control +#poetry.lock +#poetry.toml + +# pdm +# Similar to Pipfile.lock, it is generally recommended to include pdm.lock in version control. +# pdm recommends including project-wide configuration in pdm.toml, but excluding .pdm-python. +# https://pdm-project.org/en/latest/usage/project/#working-with-version-control +#pdm.lock +#pdm.toml +.pdm-python +.pdm-build/ + +# pixi +# Similar to Pipfile.lock, it is generally recommended to include pixi.lock in version control. +#pixi.lock +# Pixi creates a virtual environment in the .pixi directory, just like venv module creates one +# in the .venv directory. It is recommended not to include this directory in version control. +.pixi + +# PEP 582; used by e.g. github.com/David-OConnor/pyflow and github.com/pdm-project/pdm +__pypackages__/ + +# Celery stuff +celerybeat-schedule +celerybeat.pid + +# SageMath parsed files +*.sage.py + +# Environments +.env +.envrc +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Spyder project settings +.spyderproject +.spyproject + +# Rope project settings +.ropeproject + +# mkdocs documentation +/site + +# mypy +.mypy_cache/ +.dmypy.json +dmypy.json + +# Pyre type checker +.pyre/ + +# pytype static type analyzer +.pytype/ + +# Cython debug symbols +cython_debug/ + +# PyCharm +# JetBrains specific template is maintained in a separate JetBrains.gitignore that can +# be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore +# and can be added to the global gitignore or merged into this file. For a more nuclear +# option (not recommended) you can uncomment the following to ignore the entire idea folder. +#.idea/ + +# Abstra +# Abstra is an AI-powered process automation framework. +# Ignore directories containing user credentials, local state, and settings. +# Learn more at https://abstra.io/docs +.abstra/ + +# Visual Studio Code +# Visual Studio Code specific template is maintained in a separate VisualStudioCode.gitignore +# that can be found at https://github.com/github/gitignore/blob/main/Global/VisualStudioCode.gitignore +# and can be added to the global gitignore or merged into this file. However, if you prefer, +# you could uncomment the following to ignore the entire vscode folder +# .vscode/ + +# Ruff stuff: +.ruff_cache/ + +# PyPI configuration file +.pypirc + +# Cursor +# Cursor is an AI-powered code editor. `.cursorignore` specifies files/directories to +# exclude from AI features like autocomplete and code analysis. Recommended for sensitive data +# refer to https://docs.cursor.com/context/ignore-files +.cursorignore +.cursorindexingignore + +# Marimo +marimo/_static/ +marimo/_lsp/ +__marimo__/ + +.vscode \ No newline at end of file From b37a657ec3bb64e1f194344e331ca4aa104a963e Mon Sep 17 00:00:00 2001 From: ababramov06-art Date: Sun, 22 Feb 2026 10:23:03 +0500 Subject: [PATCH 05/20] Delete __pycache__ directory --- __pycache__/bun.cpython-311.pyc | Bin 1168 -> 0 bytes __pycache__/burger.cpython-311.pyc | Bin 3544 -> 0 bytes __pycache__/database.cpython-311.pyc | Bin 2687 -> 0 bytes __pycache__/ingredient.cpython-311.pyc | Bin 1489 -> 0 bytes __pycache__/ingredient_types.cpython-311.pyc | Bin 428 -> 0 bytes __pycache__/praktikum.cpython-311.pyc | Bin 1665 -> 0 bytes 6 files changed, 0 insertions(+), 0 deletions(-) delete mode 100644 __pycache__/bun.cpython-311.pyc delete mode 100644 __pycache__/burger.cpython-311.pyc delete mode 100644 __pycache__/database.cpython-311.pyc delete mode 100644 __pycache__/ingredient.cpython-311.pyc delete mode 100644 __pycache__/ingredient_types.cpython-311.pyc delete mode 100644 __pycache__/praktikum.cpython-311.pyc diff --git a/__pycache__/bun.cpython-311.pyc b/__pycache__/bun.cpython-311.pyc deleted file mode 100644 index a707f566c9b2a72ae114f271d63ddfa454387dce..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1168 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 diff --git a/__pycache__/praktikum.cpython-311.pyc b/__pycache__/praktikum.cpython-311.pyc deleted file mode 100644 index 34c33fe5d53c27c4d5535530e980e6a90f6a44b3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1665 zcmb_b&1(}u6rasbHp!+{ikOnPniQ+BNLvI?A|67hilT@JB?Q8zyOgE7X_(y&V5d?dxNG~FYMMeJtVKxL3_9Tdh+ybQsJ^5x$casPnif`Y}{N}wk@4b0%=GFMP zh=6{6eWHKB2z_UZJqq=~jsf5qQjy9T$mH@I$8g99nS7r2FmGTpoDX{#8-f|hM?4%h zqGl`~11#J_c~Oh2k!8;-84Dpz+yuW{d(jYBMQ?b&9P2Wv%(?iAZrL#N*=iXkAzLL& z8UYl|DYjBlEDf-Dsk}rqRoBY)qVEj=oCopn@0@{{&ydXp%Hha&kj?D+G@|2bXk)Ju zdnVpIViy9t0WX2+h#g3q6a|m{YedPeC@oH#ayZC+W!u#44 z{^u@X;5a^11vRt@b>H%9@6{mU8w>yyk56}sOScgBUcFv-(`L1 zvZi%ehr6s1U8ayl!jdOU;2uy`72QxuhE^<9%a(gMSnK`;wcMzs*?$ZUD5_cvRPI4@ zWmOv#Ob~5U6s{1xY`gI#a6+_2O|RH8cB5+lHMl~_dm%3NQiuoMEsN!!0oq*vuz0p` z)6$4lfJam!1-eeR=@&sPhwsOnGrlOb05eUJGZeb{09sNj7Jx{$z)i3S}C?P#rSYN2m_XISV zZYO4%i5Vv`*GkOQb09h~)1J;Yr?bvEPcab z8z-AM**LYKyqI;c+`=-&a_2wEy|`_hYT{JmbVG4)riC*UXZmufiKWJM2d7&&O>r8I z6&4?!Y>QG;lpOI`OFZW5Kn=VD#XxSfSY+iX7O%=PdU;96;mq~Un3$hX$pp4(R1dCS~axu!3+G z%-_% Date: Mon, 23 Feb 2026 11:21:32 +0500 Subject: [PATCH 06/20] =?UTF-8?q?=D0=9D=D0=B0=D1=87=D0=B8=D0=BD=D0=B0?= =?UTF-8?q?=D0=B5=D0=BC.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 210 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 210 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..22ae658c2 --- /dev/null +++ b/.gitignore @@ -0,0 +1,210 @@ +# Byte-compiled / optimized / DLL files +__pycache__/ +*.py[codz] +*$py.class + +# C extensions +*.so + +# Distribution / packaging +.Python +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +.eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +wheels/ +share/python-wheels/ +*.egg-info/ +.installed.cfg +*.egg +MANIFEST + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.nox/ +.coverage +.coverage.* +.cache +nosetests.xml +coverage.xml +*.cover +*.py.cover +.hypothesis/ +.pytest_cache/ +cover/ + +# Translations +*.mo +*.pot + +# Django stuff: +*.log +local_settings.py +db.sqlite3 +db.sqlite3-journal + +# Flask stuff: +instance/ +.webassets-cache + +# Scrapy stuff: +.scrapy + +# Sphinx documentation +docs/_build/ + +# PyBuilder +.pybuilder/ +target/ + +# Jupyter Notebook +.ipynb_checkpoints + +# IPython +profile_default/ +ipython_config.py + +# pyenv +# For a library or package, you might want to ignore these files since the code is +# intended to run in multiple environments; otherwise, check them in: +# .python-version + +# pipenv +# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. +# However, in case of collaboration, if having platform-specific dependencies or dependencies +# having no cross-platform support, pipenv may install dependencies that don't work, or not +# install all needed dependencies. +#Pipfile.lock + +# UV +# Similar to Pipfile.lock, it is generally recommended to include uv.lock in version control. +# This is especially recommended for binary packages to ensure reproducibility, and is more +# commonly ignored for libraries. +#uv.lock + +# poetry +# Similar to Pipfile.lock, it is generally recommended to include poetry.lock in version control. +# This is especially recommended for binary packages to ensure reproducibility, and is more +# commonly ignored for libraries. +# https://python-poetry.org/docs/basic-usage/#commit-your-poetrylock-file-to-version-control +#poetry.lock +#poetry.toml + +# pdm +# Similar to Pipfile.lock, it is generally recommended to include pdm.lock in version control. +# pdm recommends including project-wide configuration in pdm.toml, but excluding .pdm-python. +# https://pdm-project.org/en/latest/usage/project/#working-with-version-control +#pdm.lock +#pdm.toml +.pdm-python +.pdm-build/ + +# pixi +# Similar to Pipfile.lock, it is generally recommended to include pixi.lock in version control. +#pixi.lock +# Pixi creates a virtual environment in the .pixi directory, just like venv module creates one +# in the .venv directory. It is recommended not to include this directory in version control. +.pixi + +# PEP 582; used by e.g. github.com/David-OConnor/pyflow and github.com/pdm-project/pdm +__pypackages__/ + +# Celery stuff +celerybeat-schedule +celerybeat.pid + +# SageMath parsed files +*.sage.py + +# Environments +.env +.envrc +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Spyder project settings +.spyderproject +.spyproject + +# Rope project settings +.ropeproject + +# mkdocs documentation +/site + +# mypy +.mypy_cache/ +.dmypy.json +dmypy.json + +# Pyre type checker +.pyre/ + +# pytype static type analyzer +.pytype/ + +# Cython debug symbols +cython_debug/ + +# PyCharm +# JetBrains specific template is maintained in a separate JetBrains.gitignore that can +# be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore +# and can be added to the global gitignore or merged into this file. For a more nuclear +# option (not recommended) you can uncomment the following to ignore the entire idea folder. +#.idea/ + +# Abstra +# Abstra is an AI-powered process automation framework. +# Ignore directories containing user credentials, local state, and settings. +# Learn more at https://abstra.io/docs +.abstra/ + +# Visual Studio Code +# Visual Studio Code specific template is maintained in a separate VisualStudioCode.gitignore +# that can be found at https://github.com/github/gitignore/blob/main/Global/VisualStudioCode.gitignore +# and can be added to the global gitignore or merged into this file. However, if you prefer, +# you could uncomment the following to ignore the entire vscode folder +# .vscode/ + +# Ruff stuff: +.ruff_cache/ + +# PyPI configuration file +.pypirc + +# Cursor +# Cursor is an AI-powered code editor. `.cursorignore` specifies files/directories to +# exclude from AI features like autocomplete and code analysis. Recommended for sensitive data +# refer to https://docs.cursor.com/context/ignore-files +.cursorignore +.cursorindexingignore + +# Marimo +marimo/_static/ +marimo/_lsp/ +__marimo__/ + +.vscode +.venv \ No newline at end of file From 7de255fd2c4d4c7a43a33abdf4a6f11f1899b3ec Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Mon, 23 Feb 2026 11:49:22 +0500 Subject: [PATCH 07/20] =?UTF-8?q?=D0=9D=D0=B0=D1=87=D0=B8=D0=BD=D0=B0?= =?UTF-8?q?=D1=8E.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 5f048d09b..22ae658c2 100644 --- a/.gitignore +++ b/.gitignore @@ -206,4 +206,5 @@ marimo/_static/ marimo/_lsp/ __marimo__/ -.vscode \ No newline at end of file +.vscode +.venv \ No newline at end of file From 82720df44d57f0a5e50cf34ab18f4b2e79e224a2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Mon, 23 Feb 2026 16:27:08 +0500 Subject: [PATCH 08/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B4=D0=BB=D0=BB?= =?UTF-8?q?=D0=B6=D0=B0=D1=8E.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Tests/test_bun.py | 0 Tests/test_burger.py | 0 Tests/test_datanase.py | 0 Tests/test_ingredient.py | 0 4 files changed, 0 insertions(+), 0 deletions(-) create mode 100644 Tests/test_bun.py create mode 100644 Tests/test_burger.py create mode 100644 Tests/test_datanase.py create mode 100644 Tests/test_ingredient.py diff --git a/Tests/test_bun.py b/Tests/test_bun.py new file mode 100644 index 000000000..e69de29bb diff --git a/Tests/test_burger.py b/Tests/test_burger.py new file mode 100644 index 000000000..e69de29bb diff --git a/Tests/test_datanase.py b/Tests/test_datanase.py new file mode 100644 index 000000000..e69de29bb diff --git a/Tests/test_ingredient.py b/Tests/test_ingredient.py new file mode 100644 index 000000000..e69de29bb From af9c81b19812b60582ba82d1eb1879f84103f1c0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Mon, 23 Feb 2026 16:51:30 +0500 Subject: [PATCH 09/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B4=D0=BE=D0=BB?= =?UTF-8?q?=D0=B6=D0=B0=D1=8E.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Tests/test_bun.py | 0 Tests/test_datanase.py | 0 Tests/test_ingredient.py | 0 3 files changed, 0 insertions(+), 0 deletions(-) delete mode 100644 Tests/test_bun.py delete mode 100644 Tests/test_datanase.py delete mode 100644 Tests/test_ingredient.py diff --git a/Tests/test_bun.py b/Tests/test_bun.py deleted file mode 100644 index e69de29bb..000000000 diff --git a/Tests/test_datanase.py b/Tests/test_datanase.py deleted file mode 100644 index e69de29bb..000000000 diff --git a/Tests/test_ingredient.py b/Tests/test_ingredient.py deleted file mode 100644 index e69de29bb..000000000 From dfa1b275aecf9cb1883ea3685a90f8eb27969cad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Wed, 25 Feb 2026 19:23:15 +0500 Subject: [PATCH 10/20] =?UTF-8?q?=D0=97=D0=B0=D0=BA=D0=B0=D0=BD=D1=87?= =?UTF-8?q?=D0=B8=D0=B2=D0=B0=D1=8E.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 10 ++--- __init__.py => Tests/__init__.py | 0 Tests/test_burger.py | 69 ++++++++++++++++++++++++++++++++ conftest.py | 61 ++++++++++++++++++++++++++++ data.py | 49 +++++++++++++++++++++++ requirements.txt | 54 +++++++++++++++++++++++++ 6 files changed, 238 insertions(+), 5 deletions(-) rename __init__.py => Tests/__init__.py (100%) create mode 100644 conftest.py create mode 100644 data.py create mode 100644 requirements.txt diff --git a/README.md b/README.md index f0ba02934..e45852366 100644 --- a/README.md +++ b/README.md @@ -1,18 +1,18 @@ ## Начинаем 2026.02.15 ## Задание 1: Юнит-тесты -### Автотесты для проверки программы, которая помогает заказать бургер в Stellar Burgers +### Автотесты для проверки класса бургер в Stellar Burgers ### Реализованные сценарии -Созданы юнит-тесты, покрывающие классы `Bun`, `Burger`, `Ingredient`, `Database` +Созданы юнит-тесты, покрывающие класс `Burger`. Процент покрытия 100% (отчет: `htmlcov/index.html`) ### Структура проекта - `praktikum` - пакет, содержащий код программы -- `tests` - пакет, содержащий тесты, разделенные по классам. Например, `bun_test.py`, `burger_test.py` и т.д. +- `tests` - пакет, содержащий тесты `burger_test.py` ### Запуск автотестов @@ -22,5 +22,5 @@ **Запуск автотестов и создание HTML-отчета о покрытии** -> `$ pytest --cov=praktikum --cov-report=html` -# 2026.02.22 Воскресенье. +> `$ pytest --cov=burger --cov-report=html tests/` +## 2026.02.22 Воскресенье. diff --git a/__init__.py b/Tests/__init__.py similarity index 100% rename from __init__.py rename to Tests/__init__.py diff --git a/Tests/test_burger.py b/Tests/test_burger.py index e69de29bb..831429d5d 100644 --- a/Tests/test_burger.py +++ b/Tests/test_burger.py @@ -0,0 +1,69 @@ +from burger import Burger +from conftest import * +import pytest + +class TestBurger: + #Проверка работы метода set_buns, добавляющего булочку в бургер. + def test_set_buns_success(self, mock_bun): + burger = Burger() + burger.set_buns(mock_bun) + assert burger.bun == mock_bun + + #Проверка работы метода add_ingredient, добавляющего ингредиенты в бургер + #С помощью параметризации выполняем три теста: проверяем по очереди добавление соуса и двух разных начинок. + @pytest.mark.parametrize('ingredients, added_ingredient', [ + [Data1.sauce_name, Data1.sauce_name], + [Data1.filling_name, Data1.filling_name], + [Data2.filling_name, Data2.filling_name] + ] + ) + def test_add_ingredient_success(self, ingredients, added_ingredient): + burger = Burger() + burger.add_ingredient(ingredients) + assert burger.ingredients == [added_ingredient] and len(burger.ingredients) == 1 + + #Проверка работы метода remove_ingredient, удаляющего ингредиент из бургера. + #С помощью параметризации выполняем два теста: проверяем по очереди удаление соуса и начинки. + @pytest.mark.parametrize('ingredients, removed_ingredient', [ + [Data1.sauce_name, Data1.sauce_name], + [Data2.filling_name, Data2.filling_name] + ] + ) + def test_remove_ingredient_success(self, ingredients, removed_ingredient, mock_filling): + burger = Burger() + burger.add_ingredient(mock_filling) + burger.add_ingredient(ingredients) + burger.remove_ingredient(1) + assert removed_ingredient not in burger.ingredients and mock_filling in burger.ingredients + + #Проверка работы метода move_ingredient, перемещающего ингредиенты в бургере. + def test_move_ingredient_success(self, mock_sauce, mock_filling): + burger = Burger() + burger.add_ingredient(mock_sauce) + burger.add_ingredient(mock_filling) + burger.move_ingredient(0, 1) + assert len(burger.ingredients) == 2 + assert burger.ingredients[0] == mock_filling and burger.ingredients[1] == mock_sauce + + #Проверка работы метода get_price, высчитывающего конечную стоимость бургера. + def test_get_price_burger_success(self, mock_bun_2, mock_sauce_2, mock_filling_2): + burger = Burger() + burger.set_buns(mock_bun_2) + burger.add_ingredient(mock_sauce_2) + burger.add_ingredient(mock_filling_2) + assert burger.get_price() == Data2.burger_final_cost + + #Проверка работы метода get_receipt, получающего рецепт собранного бургера и его стоимость. + def test_get_receipt_success(self, mock_bun, mock_sauce, mock_filling, mock_filling_2): + burger = Burger() + burger.set_buns(mock_bun) + burger.add_ingredient(mock_sauce) + burger.add_ingredient(mock_filling) + burger.add_ingredient(mock_filling_2) + assert burger.get_receipt() == ('(==== Флюоресцентная булка R2-D3 ====)\n' + '= sauce Соус традиционный галактический =\n' + '= filling Мясо бессмертных моллюсков Protostomia =\n' + '= filling Сыр с астероидной плесенью =\n' + '(==== Флюоресцентная булка R2-D3 ====)\n' + '\n' + f'Price: {burger.get_price()}') \ No newline at end of file diff --git a/conftest.py b/conftest.py new file mode 100644 index 000000000..6abd89b27 --- /dev/null +++ b/conftest.py @@ -0,0 +1,61 @@ +from database import Database +from unittest.mock import Mock +from data import Data1, Data2 +import pytest + + +@pytest.fixture +def mock_bun(): + mock_for_bun = Mock() + mock_for_bun.get_name.return_value = Data1.bun_name + mock_for_bun.get_price.return_value = Data1.bun_price + return mock_for_bun + + +@pytest.fixture +def mock_bun_2(): + mock_for_bun_2 = Mock() + mock_for_bun_2.get_name.return_value = Data2.bun_name + mock_for_bun_2.get_price.return_value = Data2.bun_price + return mock_for_bun_2 + + +@pytest.fixture +def mock_sauce(): + mock_for_sauce = Mock() + mock_for_sauce.get_name.return_value = Data1.sauce_name + mock_for_sauce.get_price.return_value = Data1.sauce_price + mock_for_sauce.get_type.return_value = Data1.sauce_type + return mock_for_sauce + + +@pytest.fixture +def mock_sauce_2(): + mock_for_sauce_2 = Mock() + mock_for_sauce_2.get_name.return_value = Data2.sauce_name + mock_for_sauce_2.get_price.return_value = Data2.sauce_price + mock_for_sauce_2.get_type.return_value = Data2.sauce_type + return mock_for_sauce_2 + + +@pytest.fixture +def mock_filling(): + mock_for_filling = Mock() + mock_for_filling.get_name.return_value = Data1.filling_name + mock_for_filling.get_price.return_value = Data1.filling_price + mock_for_filling.get_type.return_value = Data1.filling_type + return mock_for_filling + + +@pytest.fixture +def mock_filling_2(): + mock_for_filling_2 = Mock() + mock_for_filling_2.get_name.return_value = Data2.filling_name + mock_for_filling_2.get_price.return_value = Data2.filling_price + mock_for_filling_2.get_type.return_value = Data2.filling_type + return mock_for_filling_2 + + +@pytest.fixture +def db(): + return Database() \ No newline at end of file diff --git a/data.py b/data.py new file mode 100644 index 000000000..d795b6ba3 --- /dev/null +++ b/data.py @@ -0,0 +1,49 @@ +from ingredient_types import INGREDIENT_TYPE_SAUCE, INGREDIENT_TYPE_FILLING + + +class Data1: + bun_name = 'Флюоресцентная булка R2-D3' + bun_price = 988 + + sauce_type = INGREDIENT_TYPE_SAUCE + sauce_name = 'Соус традиционный галактический' + sauce_price = 15 + + filling_type = INGREDIENT_TYPE_FILLING + filling_name = 'Мясо бессмертных моллюсков Protostomia' + filling_price = 1350 + + burger_final_cost = bun_price * 2 + sauce_price + filling_price + + +class Data2: + bun_name = 'Краторная булка N-200i' + bun_price = 1255 + + sauce_type = INGREDIENT_TYPE_SAUCE + sauce_name = 'Соус с шипами Антарианского плоскоходца' + sauce_price = 88 + + filling_type = INGREDIENT_TYPE_FILLING + filling_name = 'Сыр с астероидной плесенью' + filling_price = 4142 + + burger_final_cost = bun_price * 2 + sauce_price + filling_price + + +class TestDataBase: + test_data_base_buns = [ + [0, 'black bun', 100], + [1, 'white bun', 200], + [2, 'red bun', 300] + ] + + test_data_base_ingredients = [ + [0, INGREDIENT_TYPE_SAUCE, 'hot sauce', 100], + [1, INGREDIENT_TYPE_SAUCE, 'sour cream', 200], + [2, INGREDIENT_TYPE_SAUCE, 'chili sauce', 300], + [3, INGREDIENT_TYPE_FILLING, 'cutlet', 100], + [4, INGREDIENT_TYPE_FILLING, 'dinosaur', 200], + [5, INGREDIENT_TYPE_FILLING, 'sausage', 300] + + ] \ No newline at end of file diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 000000000..8aab4dd58 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,54 @@ +asttokens==3.0.0 +attrs==25.4.0 +certifi==2025.11.12 +cffi==2.0.0 +colorama==0.4.6 +comm==0.2.3 +coverage==7.12.0 +debugpy==1.8.17 +decorator==5.2.1 +executing==2.2.1 +Faker==39.0.0 +h11==0.16.0 +idna==3.11 +iniconfig==2.3.0 +ipykernel==6.30.1 +ipython==9.6.0 +ipython_pygments_lexers==1.1.1 +jedi==0.19.2 +jupyter_client==8.6.3 +jupyter_core==5.8.1 +matplotlib-inline==0.1.7 +nest-asyncio==1.6.0 +outcome==1.3.0.post0 +packaging==25.0 +parso==0.8.5 +platformdirs==4.4.0 +pluggy==1.6.0 +prompt_toolkit==3.0.52 +psutil==7.1.0 +pure_eval==0.2.3 +pycparser==2.23 +Pygments==2.19.2 +PySocks==1.7.1 +pytest==9.0.1 +pytest-cov==7.0.0 +pyTesy==0.0.3 +python-dateutil==2.9.0.post0 +pywin32==311 +pyzmq==27.1.0 +selenium==4.39.0 +six==1.17.0 +sniffio==1.3.1 +sortedcontainers==2.4.0 +stack-data==0.6.3 +tornado==6.5.2 +traitlets==5.14.3 +trio==0.32.0 +trio-websocket==0.12.2 +typing_extensions==4.15.0 +tzdata==2025.3 +urllib3==2.6.2 +wcwidth==0.2.14 +websocket-client==1.9.0 +wsproto==1.3.2 From 56580d52542054639c68fc90fc4f26102ff9cb21 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Wed, 25 Feb 2026 19:28:28 +0500 Subject: [PATCH 11/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B1=D1=83=D1=8E=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=BA=D0=B0=D0=BD=D1=87=D0=B8=D0=B2=D0=B0=D0=B0?= =?UTF-8?q?=D1=82=D1=8C.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .coverage | Bin 0 -> 53248 bytes .gitignore | 3 --- 2 files changed, 3 deletions(-) create mode 100644 .coverage diff --git a/.coverage b/.coverage new file mode 100644 index 0000000000000000000000000000000000000000..55f4dc5127416c3a97f37632ad542c9dcc21b149 GIT binary patch literal 53248 zcmeI)&2QUe90zba>5?T)<)Uedx@zikL0z>pBO20R9H4BKn3x2E4KXPqbCM^mA+|Hy z>DmK=l!?I!4xA7Yr*T6Z({1o_j-dq$gTdTMEl*S`9O>oDC6d$|Q8x zmrY)?=oqb99Izb4=e?TMq*#I6pd>n;Wt-lP_(1NIq5yGjf!q$%0ZK$#8xDsMC*tTU z!jmoONv9!wRf-c$w&EY@yHSVmW=9TdJVeGj?{(@461UWMF}-rugRsad#2Oa zlzvH={Teo0D(7~fYU{c7slXL&%ZaM#_*P)Kj*#23(G6ttzzUWaE!hZfxHgp5HLlP# z6*JCjNM{iFfS7UcIC6^$=eP;$AR=c?k)tv@UAs=??|1DEHx9*683*pTnB(FGZd}>N zZkq$za!}uq=1j=BMOCb>V_omce&d(KAZ975hU1n5SAu%Lv$L7vi$`>gdZpaa*sG~4Xt!@Q=ednJr=2U`VdOXmC8waG4PPMmjVW|wF-gfJweJ$!SzN7&{b3qcU z)pZ&?RD7;O!`+gexgpE(Sv4(8yCYH8spK-n^`&uLr{4u?mHuwNw~)ye7Z>&2T-1%? z){399BV8zI$pfa*VMi%_fZW9H_3 zDk}14=}6zENuTfOks|YvL6KjVJF8n}n`V=aX?ZkcX%1E^fZ%{llLDJ{w;M$LmtRKR zlh>X>c~t^~*NHuaT8VT@osOgOp$4 z3w+(Uuh9(~1Rwwb2tWV=5P$##AOHafKmYDrd&B)em+mNN*Q-G5+F|qKmY;|fB*y_009U<00Izz00br^Fsskxa>u^z{q^(rwywVazpokhCzKnK zg#ZK~009U<00Izz00bZa0SG`~ngTQQF+lYFzcxS3Vjyn_KmY;|fB*y_009U<00Izz z00bs2z~BGl`hU{ONFM?afB*y_009U<00Izz00bZ~T><|8e_a1hw+)ax1Rwwb2tWV= R5P$##AOHafKw#1W{{zj6o(cc} literal 0 HcmV?d00001 diff --git a/.gitignore b/.gitignore index 22ae658c2..38f1b7483 100644 --- a/.gitignore +++ b/.gitignore @@ -37,11 +37,8 @@ pip-log.txt pip-delete-this-directory.txt # Unit test / coverage reports -htmlcov/ .tox/ .nox/ -.coverage -.coverage.* .cache nosetests.xml coverage.xml From c9e803b399e1d617e32300e11ca2c7b4435dc05a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Wed, 25 Feb 2026 19:31:51 +0500 Subject: [PATCH 12/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B1=D1=83=D1=8E=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=BA=D0=B0=D0=BD=D1=87=D0=B8=D0=B2=D0=B0=D1=82?= =?UTF-8?q?=D1=8C..?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/.gitignore b/.gitignore index 38f1b7483..afee54c8d 100644 --- a/.gitignore +++ b/.gitignore @@ -36,18 +36,6 @@ MANIFEST pip-log.txt pip-delete-this-directory.txt -# Unit test / coverage reports -.tox/ -.nox/ -.cache -nosetests.xml -coverage.xml -*.cover -*.py.cover -.hypothesis/ -.pytest_cache/ -cover/ - # Translations *.mo *.pot From 07028c61b5a56bb8f90a21efd6a0b8bb960ea7fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Wed, 25 Feb 2026 19:52:53 +0500 Subject: [PATCH 13/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B1=D1=83=D1=8E=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=BA=D0=B0=D0=BD=D1=87=D0=B8=D0=B2=D0=B0=D1=82?= =?UTF-8?q?=D1=8C...?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 106 ----------------------------------------------------- README.md | 6 +-- 2 files changed, 2 insertions(+), 110 deletions(-) diff --git a/.gitignore b/.gitignore index afee54c8d..cff536f20 100644 --- a/.gitignore +++ b/.gitignore @@ -1,10 +1,5 @@ # Byte-compiled / optimized / DLL files __pycache__/ -*.py[codz] -*$py.class - -# C extensions -*.so # Distribution / packaging .Python @@ -59,46 +54,8 @@ docs/_build/ # PyBuilder .pybuilder/ target/ - -# Jupyter Notebook -.ipynb_checkpoints - -# IPython profile_default/ ipython_config.py - -# pyenv -# For a library or package, you might want to ignore these files since the code is -# intended to run in multiple environments; otherwise, check them in: -# .python-version - -# pipenv -# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. -# However, in case of collaboration, if having platform-specific dependencies or dependencies -# having no cross-platform support, pipenv may install dependencies that don't work, or not -# install all needed dependencies. -#Pipfile.lock - -# UV -# Similar to Pipfile.lock, it is generally recommended to include uv.lock in version control. -# This is especially recommended for binary packages to ensure reproducibility, and is more -# commonly ignored for libraries. -#uv.lock - -# poetry -# Similar to Pipfile.lock, it is generally recommended to include poetry.lock in version control. -# This is especially recommended for binary packages to ensure reproducibility, and is more -# commonly ignored for libraries. -# https://python-poetry.org/docs/basic-usage/#commit-your-poetrylock-file-to-version-control -#poetry.lock -#poetry.toml - -# pdm -# Similar to Pipfile.lock, it is generally recommended to include pdm.lock in version control. -# pdm recommends including project-wide configuration in pdm.toml, but excluding .pdm-python. -# https://pdm-project.org/en/latest/usage/project/#working-with-version-control -#pdm.lock -#pdm.toml .pdm-python .pdm-build/ @@ -128,68 +85,5 @@ venv/ ENV/ env.bak/ venv.bak/ - -# Spyder project settings -.spyderproject -.spyproject - -# Rope project settings -.ropeproject - -# mkdocs documentation -/site - -# mypy -.mypy_cache/ -.dmypy.json -dmypy.json - -# Pyre type checker -.pyre/ - -# pytype static type analyzer -.pytype/ - -# Cython debug symbols -cython_debug/ - -# PyCharm -# JetBrains specific template is maintained in a separate JetBrains.gitignore that can -# be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore -# and can be added to the global gitignore or merged into this file. For a more nuclear -# option (not recommended) you can uncomment the following to ignore the entire idea folder. -#.idea/ - -# Abstra -# Abstra is an AI-powered process automation framework. -# Ignore directories containing user credentials, local state, and settings. -# Learn more at https://abstra.io/docs -.abstra/ - -# Visual Studio Code -# Visual Studio Code specific template is maintained in a separate VisualStudioCode.gitignore -# that can be found at https://github.com/github/gitignore/blob/main/Global/VisualStudioCode.gitignore -# and can be added to the global gitignore or merged into this file. However, if you prefer, -# you could uncomment the following to ignore the entire vscode folder -# .vscode/ - -# Ruff stuff: -.ruff_cache/ - -# PyPI configuration file -.pypirc - -# Cursor -# Cursor is an AI-powered code editor. `.cursorignore` specifies files/directories to -# exclude from AI features like autocomplete and code analysis. Recommended for sensitive data -# refer to https://docs.cursor.com/context/ignore-files -.cursorignore -.cursorindexingignore - -# Marimo -marimo/_static/ -marimo/_lsp/ -__marimo__/ - .vscode .venv \ No newline at end of file diff --git a/README.md b/README.md index e45852366..39a801e06 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,6 @@ -## Начинаем 2026.02.15 ## Задание 1: Юнит-тесты -### Автотесты для проверки класса бургер в Stellar Burgers +### Автотесты для проверки класса Burger в Stellar Burgers ### Реализованные сценарии @@ -11,7 +10,6 @@ ### Структура проекта -- `praktikum` - пакет, содержащий код программы - `tests` - пакет, содержащий тесты `burger_test.py` ### Запуск автотестов @@ -23,4 +21,4 @@ **Запуск автотестов и создание HTML-отчета о покрытии** > `$ pytest --cov=burger --cov-report=html tests/` -## 2026.02.22 Воскресенье. + From 22c82c93bd8880524600c6e142b2be841495acdd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Wed, 25 Feb 2026 19:59:46 +0500 Subject: [PATCH 14/20] =?UTF-8?q?=D0=9F=D1=80=D0=BE=D0=B1=D1=83=D1=8E=20?= =?UTF-8?q?=D0=B7=D0=B0=D0=BA=D0=B0=D0=BD=D1=87=D0=B8=D0=B2=D0=B0=D1=82?= =?UTF-8?q?=D1=8C....?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index cff536f20..cd2ebeb5f 100644 --- a/.gitignore +++ b/.gitignore @@ -1,5 +1,6 @@ # Byte-compiled / optimized / DLL files __pycache__/ +.pytest_cache # Distribution / packaging .Python From e40000415661f6dd8bc129363527a9f39c4f4250 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Thu, 26 Feb 2026 06:20:44 +0500 Subject: [PATCH 15/20] =?UTF-8?q?=D0=97=D0=B0=D0=BA=D0=B0=D0=BD=D1=87?= =?UTF-8?q?=D0=B8=D0=B2=D0=B0=D1=8E....?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 28 ++-------------------------- 1 file changed, 2 insertions(+), 26 deletions(-) diff --git a/.gitignore b/.gitignore index cd2ebeb5f..fef994e38 100644 --- a/.gitignore +++ b/.gitignore @@ -1,40 +1,16 @@ # Byte-compiled / optimized / DLL files __pycache__/ .pytest_cache - +.coverage # Distribution / packaging .Python -build/ -develop-eggs/ -dist/ -downloads/ -eggs/ -.eggs/ -lib/ -lib64/ -parts/ -sdist/ -var/ -wheels/ -share/python-wheels/ -*.egg-info/ -.installed.cfg -*.egg -MANIFEST - -# PyInstaller -# Usually these files are written by a python script from a template -# before PyInstaller builds the exe, so as to inject date/other infos into it. -*.manifest -*.spec # Installer logs pip-log.txt pip-delete-this-directory.txt # Translations -*.mo -*.pot + # Django stuff: *.log From e8ca073eacd3f5526bec6705f37989d9b350b34e Mon Sep 17 00:00:00 2001 From: ababramov06-art Date: Thu, 26 Feb 2026 06:25:20 +0500 Subject: [PATCH 16/20] Delete .coverage --- .coverage | Bin 53248 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 .coverage diff --git a/.coverage b/.coverage deleted file mode 100644 index 55f4dc5127416c3a97f37632ad542c9dcc21b149..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 53248 zcmeI)&2QUe90zba>5?T)<)Uedx@zikL0z>pBO20R9H4BKn3x2E4KXPqbCM^mA+|Hy z>DmK=l!?I!4xA7Yr*T6Z({1o_j-dq$gTdTMEl*S`9O>oDC6d$|Q8x zmrY)?=oqb99Izb4=e?TMq*#I6pd>n;Wt-lP_(1NIq5yGjf!q$%0ZK$#8xDsMC*tTU z!jmoONv9!wRf-c$w&EY@yHSVmW=9TdJVeGj?{(@461UWMF}-rugRsad#2Oa zlzvH={Teo0D(7~fYU{c7slXL&%ZaM#_*P)Kj*#23(G6ttzzUWaE!hZfxHgp5HLlP# z6*JCjNM{iFfS7UcIC6^$=eP;$AR=c?k)tv@UAs=??|1DEHx9*683*pTnB(FGZd}>N zZkq$za!}uq=1j=BMOCb>V_omce&d(KAZ975hU1n5SAu%Lv$L7vi$`>gdZpaa*sG~4Xt!@Q=ednJr=2U`VdOXmC8waG4PPMmjVW|wF-gfJweJ$!SzN7&{b3qcU z)pZ&?RD7;O!`+gexgpE(Sv4(8yCYH8spK-n^`&uLr{4u?mHuwNw~)ye7Z>&2T-1%? z){399BV8zI$pfa*VMi%_fZW9H_3 zDk}14=}6zENuTfOks|YvL6KjVJF8n}n`V=aX?ZkcX%1E^fZ%{llLDJ{w;M$LmtRKR zlh>X>c~t^~*NHuaT8VT@osOgOp$4 z3w+(Uuh9(~1Rwwb2tWV=5P$##AOHafKmYDrd&B)em+mNN*Q-G5+F|qKmY;|fB*y_009U<00Izz00br^Fsskxa>u^z{q^(rwywVazpokhCzKnK zg#ZK~009U<00Izz00bZa0SG`~ngTQQF+lYFzcxS3Vjyn_KmY;|fB*y_009U<00Izz z00bs2z~BGl`hU{ONFM?afB*y_009U<00Izz00bZ~T><|8e_a1hw+)ax1Rwwb2tWV= R5P$##AOHafKw#1W{{zj6o(cc} From c4a74c418ab6b4bfb8164f833ad4091e081fc292 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Thu, 26 Feb 2026 18:44:36 +0500 Subject: [PATCH 17/20] =?UTF-8?q?=D0=97=D0=B0=D0=BA=D0=B0=D0=BD=D1=87?= =?UTF-8?q?=D0=B8=D0=B2=D0=B0=D1=8E.....?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 50 -------------------------------------------------- 1 file changed, 50 deletions(-) diff --git a/.gitignore b/.gitignore index fef994e38..fbab4280d 100644 --- a/.gitignore +++ b/.gitignore @@ -2,56 +2,6 @@ __pycache__/ .pytest_cache .coverage -# Distribution / packaging -.Python - -# Installer logs -pip-log.txt -pip-delete-this-directory.txt - -# Translations - - -# Django stuff: -*.log -local_settings.py -db.sqlite3 -db.sqlite3-journal - -# Flask stuff: -instance/ -.webassets-cache - -# Scrapy stuff: -.scrapy - -# Sphinx documentation -docs/_build/ - -# PyBuilder -.pybuilder/ -target/ -profile_default/ -ipython_config.py -.pdm-python -.pdm-build/ - -# pixi -# Similar to Pipfile.lock, it is generally recommended to include pixi.lock in version control. -#pixi.lock -# Pixi creates a virtual environment in the .pixi directory, just like venv module creates one -# in the .venv directory. It is recommended not to include this directory in version control. -.pixi - -# PEP 582; used by e.g. github.com/David-OConnor/pyflow and github.com/pdm-project/pdm -__pypackages__/ - -# Celery stuff -celerybeat-schedule -celerybeat.pid - -# SageMath parsed files -*.sage.py # Environments .env From 23391abac8e09c31cec863c321e2887c99b8a3fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Thu, 26 Feb 2026 19:00:29 +0500 Subject: [PATCH 18/20] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=20=D0=BE=D1=82=D1=87=D1=91=D1=82=20=D0=BF=D0=BE?= =?UTF-8?q?=D0=BA=D1=80=D1=8B=D1=82=D0=B8=D1=8F.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- htmlcov/.gitignore | 2 + htmlcov/burger_py.html | 145 ++++++ htmlcov/class_index.html | 131 +++++ htmlcov/coverage_html_cb_188fc9a4.js | 735 +++++++++++++++++++++++++++ htmlcov/favicon_32_cb_c827f16f.png | Bin 0 -> 1732 bytes htmlcov/function_index.html | 191 +++++++ htmlcov/index.html | 117 +++++ htmlcov/keybd_closed_cb_900cfef5.png | Bin 0 -> 9004 bytes htmlcov/status.json | 1 + htmlcov/style_cb_5c747636.css | 389 ++++++++++++++ 10 files changed, 1711 insertions(+) create mode 100644 htmlcov/.gitignore create mode 100644 htmlcov/burger_py.html create mode 100644 htmlcov/class_index.html create mode 100644 htmlcov/coverage_html_cb_188fc9a4.js create mode 100644 htmlcov/favicon_32_cb_c827f16f.png create mode 100644 htmlcov/function_index.html create mode 100644 htmlcov/index.html create mode 100644 htmlcov/keybd_closed_cb_900cfef5.png create mode 100644 htmlcov/status.json create mode 100644 htmlcov/style_cb_5c747636.css diff --git a/htmlcov/.gitignore b/htmlcov/.gitignore new file mode 100644 index 000000000..ccccf1423 --- /dev/null +++ b/htmlcov/.gitignore @@ -0,0 +1,2 @@ +# Created by coverage.py +* diff --git a/htmlcov/burger_py.html b/htmlcov/burger_py.html new file mode 100644 index 000000000..76a40ec05 --- /dev/null +++ b/htmlcov/burger_py.html @@ -0,0 +1,145 @@ + + + + + Coverage for burger.py: 100% + + + + + +
+
+

+ Coverage for burger.py: + 100% +

+ +

+ 27 statements   + + + +

+

+ « prev     + ^ index     + » next +       + coverage.py v7.13.4, + created at 2026-02-26 18:51 +0500 +

+ +
+
+
+

1from typing import List 

+

2 

+

3from bun import Bun 

+

4from 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/htmlcov/class_index.html b/htmlcov/class_index.html new file mode 100644 index 000000000..3aa4d95fd --- /dev/null +++ b/htmlcov/class_index.html @@ -0,0 +1,131 @@ + + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.4, + created at 2026-02-26 18:51 +0500 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Fileclass statementsmissingexcluded coverage
burger.pyBurger 1600 100%
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 0000000000000000000000000000000000000000..8649f0475d8d20793b2ec431fe25a186a414cf10 GIT binary patch literal 1732 zcmV;#20QtQP)K2KOkBOVxIZChq#W-v7@TU%U6P(wycKT1hUJUToW3ke1U1ONa4 z000000000000000bb)GRa9mqwR9|UWHy;^RUrt?IT__Y0JUcxmBP0(51q1>E00030 z|NrOz)aw7%8sJzM<5^g%z7^qE`}_Ot|JUUG(NUkWzR|7K?Zo%@_v-8G-1N%N=D$;; zw;keH4dGY$`1t4M=HK_s*zm^0#KgqfwWhe3qO_HtvXYvtjgX>;-~C$L`&k>^R)9)7 zdPh2TL^pCnHC#0+_4D)M`p?qp!pq{jO_{8;$fbaflbx`Tn52n|n}8VFRTA1&ugOP< zPd{uvFjz7t*Vot1&d$l-xWCk}s;sQL&#O(Bskh6gqNJv>#iB=ypG1e3K!K4yc7!~M zfj4S*g^zZ7eP$+_Sl07Z646l;%urinP#D8a6TwRtnLIRcI!r4f@bK~9-`~;E(N?Lv zSEst7s;rcxsi~}{Nsytfz@MtUoR*iFc8!#vvx}Umhm4blk(_~MdVD-@dW&>!Nn~ro z_E~-ESVQAj6Wmn;(olz(O&_{U2*pZBc1aYjMh>Dq3z|6`jW`RDHV=t3I6yRKJ~LOX zz_z!!vbVXPqob#=pj3^VMT?x6t(irRmSKsMo1~LLkB&=#j!=M%NP35mfqim$drWb9 zYIb>no_LUwc!r^NkDzs4YHu@=ZHRzrafWDZd1EhEVq=tGX?tK$pIa)DTh#bkvh!J- z?^%@YS!U*0E8$q$_*aOTQ&)Ra64g>ep;BdcQgvlg8qQHrP*E$;P{-m=A*@axn@$bO zO-Y4JzS&EAi%YG}N?cn?YFS7ivPY=EMV6~YH;+Xxu|tefLS|Aza)Cg6us#)=JW!uH zQa?H>d^j+YHCtyjL^LulF*05|F$RG!AX_OHVI&MtA~_@=5_lU|0000rbW%=J06GH4 z^5LD8b8apw8vNh1ua1mF{{Hy)_U`NA;Nacc+sCpuHXa-V{r&yz?c(9#+}oX+NmiRW z+W-IqK1oDDR5;6GfCDCOP5}iL5fK(cB~ET81`MFgF2kGa9AjhSIk~-E-4&*tPPKdiilQJ11k_J082ZS z>@TvivP!5ZFG?t@{t+GpR3XR&@*hA_VE1|Lo8@L@)l*h(Z@=?c-NS$Fk&&61IzUU9 z*nPqBM=OBZ-6ka1SJgGAS-Us5EN)r#dUX%>wQZLa2ytPCtMKp)Ob z*xcu38Z&d5<-NBS)@jRD+*!W*cf-m_wmxDEqBf?czI%3U0J$Xik;lA`jg}VH?(S(V zE!M3;X2B8w0TnnW&6(8;_Uc)WD;Ms6PKP+s(sFgO!}B!^ES~GDt4qLPxwYB)^7)XA zZwo9zDy-B0B+jT6V=!=bo(zs_8{eBA78gT9GH$(DVhz;4VAYwz+bOIdZ-PNb|I&rl z^XG=vFLF)1{&nT2*0vMz#}7^9hXzzf&ZdKlEj{LihP;|;Ywqn35ajP?H?7t|i-Un% z&&kxee@9B{nwgv1+S-~0)E1{ob1^Wn`F2isurqThKK=3%&;`@{0{!D- z&CSj80t;uPu&FaJFtSXKH#ajgGj}=sEad7US6jP0|Db@0j)?(5@sf<7`~a9>s;wCa zm^)spe{uxGFmrJYI9cOh7s$>8Npkt-5EWB1UKc`{W{y5Ce$1+nM9Cr;);=Ju#N^62OSlJMn7omiUgP&ErsYzT~iGxcW aE(`!K@+CXylaC4j0000 + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.4, + created at 2026-02-26 18:51 +0500 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Filefunction statementsmissingexcluded coverage
burger.pyBurger.__init__ 200 100%
burger.pyBurger.set_buns 100 100%
burger.pyBurger.add_ingredient 100 100%
burger.pyBurger.remove_ingredient 100 100%
burger.pyBurger.move_ingredient 100 100%
burger.pyBurger.get_price 400 100%
burger.pyBurger.get_receipt 600 100%
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..4201039c4 --- /dev/null +++ b/htmlcov/index.html @@ -0,0 +1,117 @@ + + + + + Coverage report + + + + + +
+
+

Coverage report: + 100% +

+ +
+ +
+ + +
+
+

+ Files + Functions + Classes +

+

+ coverage.py v7.13.4, + created at 2026-02-26 18:51 +0500 +

+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
File statementsmissingexcluded coverage
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 0000000000000000000000000000000000000000..ba119c47df81ed2bbd27a06988abf700139c4f99 GIT binary patch literal 9004 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 literal 0 HcmV?d00001 diff --git a/htmlcov/status.json b/htmlcov/status.json new file mode 100644 index 000000000..d52c6e598 --- /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.4","globals":"4c49438f61bd68a5103040270fd254a9","files":{"burger_py":{"hash":"3aa785a6a395b20a3fbb21efda800bee","index":{"url":"burger_py.html","file":"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; } } From 28059ae06e25a060ea4ce2953d63f3520d13c92f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Thu, 5 Mar 2026 18:41:15 +0500 Subject: [PATCH 19/20] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=BE=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B0=20=D0=B2=20gitignore=20.vscode?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index fbab4280d..adbe36c55 100644 --- a/.gitignore +++ b/.gitignore @@ -13,4 +13,6 @@ ENV/ env.bak/ venv.bak/ .vscode -.venv \ No newline at end of file +.venv + +.vscode \ No newline at end of file From 975b912d8eb7c0c8523fd6a3307d616f41e212a3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BB=D0=B5=D0=BA=D1=81=D0=B0=D0=BD=D0=B4=D1=80=20?= =?UTF-8?q?=D0=90=D0=B1=D1=80=D0=B0=D0=BC=D0=BE=D0=B2?= Date: Fri, 6 Mar 2026 19:10:43 +0500 Subject: [PATCH 20/20] =?UTF-8?q?=D0=94=D0=BE=D1=80=D0=B0=D0=B1=D0=BE?= =?UTF-8?q?=D1=82=D0=BA=D0=B0.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Tests/test_burger.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Tests/test_burger.py b/Tests/test_burger.py index 831429d5d..b041a4171 100644 --- a/Tests/test_burger.py +++ b/Tests/test_burger.py @@ -20,8 +20,8 @@ def test_set_buns_success(self, mock_bun): def test_add_ingredient_success(self, ingredients, added_ingredient): burger = Burger() burger.add_ingredient(ingredients) - assert burger.ingredients == [added_ingredient] and len(burger.ingredients) == 1 - + assert burger.ingredients == [added_ingredient] + #Проверка работы метода remove_ingredient, удаляющего ингредиент из бургера. #С помощью параметризации выполняем два теста: проверяем по очереди удаление соуса и начинки. @pytest.mark.parametrize('ingredients, removed_ingredient', [