e-nms_qa_automation/site/components/base_component/index.html

3325 lines
102 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<!doctype html>
<html lang="en" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<link rel="prev" href="../alert_component/">
<link rel="next" href="../card_component/">
<link rel="icon" href="../../assets/images/favicon.png">
<meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.5.21">
<title>BaseComponent - Документация тестов</title>
<link rel="stylesheet" href="../../assets/stylesheets/main.66ac8b77.min.css">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
<style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
<link rel="stylesheet" href="../../assets/_mkdocstrings.css">
<script>__md_scope=new URL("../..",location),__md_hash=e=>[...e].reduce((e,_)=>(e<<5)-e+_.charCodeAt(0),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
</head>
<body dir="ltr">
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
<label class="md-overlay" for="__drawer"></label>
<div data-md-component="skip">
<a href="#basecomponent" class="md-skip">
Skip to content
</a>
</div>
<div data-md-component="announce">
</div>
<header class="md-header md-header--shadow" data-md-component="header">
<nav class="md-header__inner md-grid" aria-label="Header">
<a href="../.." title="Документация тестов" class="md-header__button md-logo" aria-label="Документация тестов" data-md-component="logo">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54Z"/></svg>
</a>
<label class="md-header__button md-icon" for="__drawer">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2Z"/></svg>
</label>
<div class="md-header__title" data-md-component="header-title">
<div class="md-header__ellipsis">
<div class="md-header__topic">
<span class="md-ellipsis">
Документация тестов
</span>
</div>
<div class="md-header__topic" data-md-component="header-topic">
<span class="md-ellipsis">
BaseComponent
</span>
</div>
</div>
</div>
<script>var media,input,key,value,palette=__md_get("__palette");if(palette&&palette.color){"(prefers-color-scheme)"===palette.color.media&&(media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']"),palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent"));for([key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
<label class="md-header__button md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg>
</label>
<div class="md-search" data-md-component="search" role="dialog">
<label class="md-search__overlay" for="__search"></label>
<div class="md-search__inner" role="search">
<form class="md-search__form" name="search">
<input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
<label class="md-search__icon md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5Z"/></svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12Z"/></svg>
</label>
<nav class="md-search__options" aria-label="Search">
<button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41Z"/></svg>
</button>
</nav>
</form>
<div class="md-search__output">
<div class="md-search__scrollwrap" data-md-scrollfix>
<div class="md-search-result" data-md-component="search-result">
<div class="md-search-result__meta">
Initializing search
</div>
<ol class="md-search-result__list" role="presentation"></ol>
</div>
</div>
</div>
</div>
</div>
</nav>
</header>
<div class="md-container" data-md-component="container">
<main class="md-main" data-md-component="main">
<div class="md-main__inner md-grid">
<div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
<label class="md-nav__title" for="__drawer">
<a href="../.." title="Документация тестов" class="md-nav__button md-logo" aria-label="Документация тестов" data-md-component="logo">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54Z"/></svg>
</a>
Документация тестов
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../.." class="md-nav__link">
<span class="md-ellipsis">
Главная
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_2" >
<label class="md-nav__link" for="__nav_2" id="__nav_2_label" tabindex="0">
<span class="md-ellipsis">
Данные и конфигурации
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_2">
<span class="md-nav__icon md-icon"></span>
Данные и конфигурации
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../data/constants/" class="md-nav__link">
<span class="md-ellipsis">
Constants
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../data/environment/" class="md-nav__link">
<span class="md-ellipsis">
Environment
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../data/roles_dict/" class="md-nav__link">
<span class="md-ellipsis">
Roles_dict
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3" >
<label class="md-nav__link" for="__nav_3" id="__nav_3_label" tabindex="0">
<span class="md-ellipsis">
Фикстуры Pytest
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_3_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_3">
<span class="md-nav__icon md-icon"></span>
Фикстуры Pytest
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../fixtures/pages/" class="md-nav__link">
<span class="md-ellipsis">
Browser Fixtures
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--active md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_4" checked>
<label class="md-nav__link" for="__nav_4" id="__nav_4_label" tabindex="0">
<span class="md-ellipsis">
Компоненты UI
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="true">
<label class="md-nav__title" for="__nav_4">
<span class="md-nav__icon md-icon"></span>
Компоненты UI
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../alert_component/" class="md-nav__link">
<span class="md-ellipsis">
AlertComponent
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--active">
<input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
<label class="md-nav__link md-nav__link--active" for="__toc">
<span class="md-ellipsis">
BaseComponent
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<a href="./" class="md-nav__link md-nav__link--active">
<span class="md-ellipsis">
BaseComponent
</span>
</a>
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#components.base_component" class="md-nav__link">
<span class="md-ellipsis">
base_component
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent" class="md-nav__link">
<span class="md-ellipsis">
BaseComponent
</span>
</a>
<nav class="md-nav" aria-label="BaseComponent">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.__init__" class="md-nav__link">
<span class="md-ellipsis">
__init__
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.check_presence" class="md-nav__link">
<span class="md-ellipsis">
check_presence
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.get_locator" class="md-nav__link">
<span class="md-ellipsis">
get_locator
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.is_scrollable_horizontally" class="md-nav__link">
<span class="md-ellipsis">
is_scrollable_horizontally
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.is_scrollable_vertically" class="md-nav__link">
<span class="md-ellipsis">
is_scrollable_vertically
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_down" class="md-nav__link">
<span class="md-ellipsis">
scroll_down
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_left" class="md-nav__link">
<span class="md-ellipsis">
scroll_left
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_right" class="md-nav__link">
<span class="md-ellipsis">
scroll_right
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_up" class="md-nav__link">
<span class="md-ellipsis">
scroll_up
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../card_component/" class="md-nav__link">
<span class="md-ellipsis">
CardComponent
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../confirm_component/" class="md-nav__link">
<span class="md-ellipsis">
ConfirmComponent
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../modal_window_component/" class="md-nav__link">
<span class="md-ellipsis">
ModalWindowComponent
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../navbar_component/" class="md-nav__link">
<span class="md-ellipsis">
NavigationPanelComponent
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../table_component/" class="md-nav__link">
<span class="md-ellipsis">
TableComponent
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../toolbar_component/" class="md-nav__link">
<span class="md-ellipsis">
ToolbarComponent
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_5" >
<label class="md-nav__link" for="__nav_5" id="__nav_5_label" tabindex="0">
<span class="md-ellipsis">
Элементы UI
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_5_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_5">
<span class="md-nav__icon md-icon"></span>
Элементы UI
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../elements/base_element/" class="md-nav__link">
<span class="md-ellipsis">
BaseElement
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/button_element/" class="md-nav__link">
<span class="md-ellipsis">
Button
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/checkbox_element/" class="md-nav__link">
<span class="md-ellipsis">
Checkbox
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/dropdown_list_element/" class="md-nav__link">
<span class="md-ellipsis">
DropdownList
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/text_element/" class="md-nav__link">
<span class="md-ellipsis">
Text
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/text_input_element/" class="md-nav__link">
<span class="md-ellipsis">
TextInput
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../elements/tooltip_button_element/" class="md-nav__link">
<span class="md-ellipsis">
ToolbarButton
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_6" >
<label class="md-nav__link" for="__nav_6" id="__nav_6_label" tabindex="0">
<span class="md-ellipsis">
Локаторы
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_6_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_6">
<span class="md-nav__icon md-icon"></span>
Локаторы
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../locators/confirm_locators/" class="md-nav__link">
<span class="md-ellipsis">
ConfirmLocators
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../locators/event_panel_locators/" class="md-nav__link">
<span class="md-ellipsis">
EventPanelLocators
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../locators/modal_window_locators/" class="md-nav__link">
<span class="md-ellipsis">
ModalWindowLocators
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../locators/navigation_panel_locators/" class="md-nav__link">
<span class="md-ellipsis">
NavigationPanelLocators
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../locators/table_locators/" class="md-nav__link">
<span class="md-ellipsis">
TableLocators
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../locators/toolbar_locators/" class="md-nav__link">
<span class="md-ellipsis">
ToolbarLocators
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_7" >
<label class="md-nav__link" for="__nav_7" id="__nav_7_label" tabindex="0">
<span class="md-ellipsis">
Страницы приложения
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_7_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_7">
<span class="md-nav__icon md-icon"></span>
Страницы приложения
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../pages/base_page/" class="md-nav__link">
<span class="md-ellipsis">
BasePage
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../pages/login_page/" class="md-nav__link">
<span class="md-ellipsis">
LoginPage
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../pages/main_page/" class="md-nav__link">
<span class="md-ellipsis">
MainPage
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../pages/service_status_tab/" class="md-nav__link">
<span class="md-ellipsis">
ServiceStatusTab
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../pages/session_tab.md" class="md-nav__link">
<span class="md-ellipsis">
SessionTab
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../pages/users_tab/" class="md-nav__link">
<span class="md-ellipsis">
UsersTab
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8" >
<label class="md-nav__link" for="__nav_8" id="__nav_8_label" tabindex="0">
<span class="md-ellipsis">
Тесты
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_8_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_8">
<span class="md-nav__icon md-icon"></span>
Тесты
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8_1" >
<label class="md-nav__link" for="__nav_8_1" id="__nav_8_1_label" tabindex="0">
<span class="md-ellipsis">
End-to-End
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_8_1_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_8_1">
<span class="md-nav__icon md-icon"></span>
End-to-End
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../tests/e2e/test_license_tab/" class="md-nav__link">
<span class="md-ellipsis">
TestLicenseTab
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/e2e/test_login/" class="md-nav__link">
<span class="md-ellipsis">
TestLogin
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/e2e/test_session_tab.md" class="md-nav__link">
<span class="md-ellipsis">
TestSessionTab
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/e2e/test_users_tab/" class="md-nav__link">
<span class="md-ellipsis">
TestUsersTab
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/e2e/test_service_status_tab/" class="md-nav__link">
<span class="md-ellipsis">
TestServiceStatusTab
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_8_2" >
<label class="md-nav__link" for="__nav_8_2" id="__nav_8_2_label" tabindex="0">
<span class="md-ellipsis">
Компоненты
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="2" aria-labelledby="__nav_8_2_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_8_2">
<span class="md-nav__icon md-icon"></span>
Компоненты
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../tests/components/test_json_container/" class="md-nav__link">
<span class="md-ellipsis">
TestJsonContainer
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/components/test_navigation_panel/" class="md-nav__link">
<span class="md-ellipsis">
TestNavigationPanel
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/components/test_services_table/" class="md-nav__link">
<span class="md-ellipsis">
TestServiceStatusTable
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tests/components/test_user_modal_window/" class="md-nav__link">
<span class="md-ellipsis">
TestUsersModalWindow
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_9" >
<label class="md-nav__link" for="__nav_9" id="__nav_9_label" tabindex="0">
<span class="md-ellipsis">
Утилиты
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_9_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_9">
<span class="md-nav__icon md-icon"></span>
Утилиты
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../tools/logger/" class="md-nav__link">
<span class="md-ellipsis">
Logging
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../../tools/fix_python_project/" class="md-nav__link">
<span class="md-ellipsis">
Python Project Fixer
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_10" >
<label class="md-nav__link" for="__nav_10" id="__nav_10_label" tabindex="0">
<span class="md-ellipsis">
Инструкции
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_10_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_10">
<span class="md-nav__icon md-icon"></span>
Инструкции
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../../docs/config/mkdocs_guide.md" class="md-nav__link">
<span class="md-ellipsis">
Настройка MkDocs
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#components.base_component" class="md-nav__link">
<span class="md-ellipsis">
base_component
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent" class="md-nav__link">
<span class="md-ellipsis">
BaseComponent
</span>
</a>
<nav class="md-nav" aria-label="BaseComponent">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.__init__" class="md-nav__link">
<span class="md-ellipsis">
__init__
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.check_presence" class="md-nav__link">
<span class="md-ellipsis">
check_presence
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.get_locator" class="md-nav__link">
<span class="md-ellipsis">
get_locator
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.is_scrollable_horizontally" class="md-nav__link">
<span class="md-ellipsis">
is_scrollable_horizontally
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.is_scrollable_vertically" class="md-nav__link">
<span class="md-ellipsis">
is_scrollable_vertically
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_down" class="md-nav__link">
<span class="md-ellipsis">
scroll_down
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_left" class="md-nav__link">
<span class="md-ellipsis">
scroll_left
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_right" class="md-nav__link">
<span class="md-ellipsis">
scroll_right
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#components.base_component.BaseComponent.scroll_up" class="md-nav__link">
<span class="md-ellipsis">
scroll_up
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-content" data-md-component="content">
<article class="md-content__inner md-typeset">
<h1 id="basecomponent">BaseComponent</h1>
<div class="doc doc-object doc-module">
<a id="components.base_component"></a>
<div class="doc doc-contents first">
<p>Базовый модуль для работы с компонентами страницы.</p>
<p>Содержит базовый класс для взаимодействия с элементами страницы через Playwright.</p>
<div class="doc doc-children">
<div class="doc doc-object doc-class">
<h2 id="components.base_component.BaseComponent" class="doc doc-heading">
<code>BaseComponent</code>
</h2>
<div class="doc doc-contents ">
<p>Базовый компонент для работы с элементами страницы.</p>
<p>Предоставляет общие методы для взаимодействия с элементами:
- получение локаторов
- проверка видимости элементов
- работа с прокруткой</p>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal"> 12</span>
<span class="normal"> 13</span>
<span class="normal"> 14</span>
<span class="normal"> 15</span>
<span class="normal"> 16</span>
<span class="normal"> 17</span>
<span class="normal"> 18</span>
<span class="normal"> 19</span>
<span class="normal"> 20</span>
<span class="normal"> 21</span>
<span class="normal"> 22</span>
<span class="normal"> 23</span>
<span class="normal"> 24</span>
<span class="normal"> 25</span>
<span class="normal"> 26</span>
<span class="normal"> 27</span>
<span class="normal"> 28</span>
<span class="normal"> 29</span>
<span class="normal"> 30</span>
<span class="normal"> 31</span>
<span class="normal"> 32</span>
<span class="normal"> 33</span>
<span class="normal"> 34</span>
<span class="normal"> 35</span>
<span class="normal"> 36</span>
<span class="normal"> 37</span>
<span class="normal"> 38</span>
<span class="normal"> 39</span>
<span class="normal"> 40</span>
<span class="normal"> 41</span>
<span class="normal"> 42</span>
<span class="normal"> 43</span>
<span class="normal"> 44</span>
<span class="normal"> 45</span>
<span class="normal"> 46</span>
<span class="normal"> 47</span>
<span class="normal"> 48</span>
<span class="normal"> 49</span>
<span class="normal"> 50</span>
<span class="normal"> 51</span>
<span class="normal"> 52</span>
<span class="normal"> 53</span>
<span class="normal"> 54</span>
<span class="normal"> 55</span>
<span class="normal"> 56</span>
<span class="normal"> 57</span>
<span class="normal"> 58</span>
<span class="normal"> 59</span>
<span class="normal"> 60</span>
<span class="normal"> 61</span>
<span class="normal"> 62</span>
<span class="normal"> 63</span>
<span class="normal"> 64</span>
<span class="normal"> 65</span>
<span class="normal"> 66</span>
<span class="normal"> 67</span>
<span class="normal"> 68</span>
<span class="normal"> 69</span>
<span class="normal"> 70</span>
<span class="normal"> 71</span>
<span class="normal"> 72</span>
<span class="normal"> 73</span>
<span class="normal"> 74</span>
<span class="normal"> 75</span>
<span class="normal"> 76</span>
<span class="normal"> 77</span>
<span class="normal"> 78</span>
<span class="normal"> 79</span>
<span class="normal"> 80</span>
<span class="normal"> 81</span>
<span class="normal"> 82</span>
<span class="normal"> 83</span>
<span class="normal"> 84</span>
<span class="normal"> 85</span>
<span class="normal"> 86</span>
<span class="normal"> 87</span>
<span class="normal"> 88</span>
<span class="normal"> 89</span>
<span class="normal"> 90</span>
<span class="normal"> 91</span>
<span class="normal"> 92</span>
<span class="normal"> 93</span>
<span class="normal"> 94</span>
<span class="normal"> 95</span>
<span class="normal"> 96</span>
<span class="normal"> 97</span>
<span class="normal"> 98</span>
<span class="normal"> 99</span>
<span class="normal">100</span>
<span class="normal">101</span>
<span class="normal">102</span>
<span class="normal">103</span>
<span class="normal">104</span>
<span class="normal">105</span>
<span class="normal">106</span>
<span class="normal">107</span>
<span class="normal">108</span>
<span class="normal">109</span>
<span class="normal">110</span>
<span class="normal">111</span>
<span class="normal">112</span>
<span class="normal">113</span>
<span class="normal">114</span>
<span class="normal">115</span>
<span class="normal">116</span>
<span class="normal">117</span>
<span class="normal">118</span>
<span class="normal">119</span>
<span class="normal">120</span>
<span class="normal">121</span>
<span class="normal">122</span>
<span class="normal">123</span>
<span class="normal">124</span>
<span class="normal">125</span>
<span class="normal">126</span>
<span class="normal">127</span>
<span class="normal">128</span>
<span class="normal">129</span>
<span class="normal">130</span>
<span class="normal">131</span>
<span class="normal">132</span>
<span class="normal">133</span>
<span class="normal">134</span>
<span class="normal">135</span>
<span class="normal">136</span>
<span class="normal">137</span>
<span class="normal">138</span>
<span class="normal">139</span>
<span class="normal">140</span>
<span class="normal">141</span>
<span class="normal">142</span>
<span class="normal">143</span>
<span class="normal">144</span>
<span class="normal">145</span>
<span class="normal">146</span>
<span class="normal">147</span>
<span class="normal">148</span>
<span class="normal">149</span>
<span class="normal">150</span>
<span class="normal">151</span>
<span class="normal">152</span>
<span class="normal">153</span>
<span class="normal">154</span>
<span class="normal">155</span>
<span class="normal">156</span>
<span class="normal">157</span>
<span class="normal">158</span>
<span class="normal">159</span>
<span class="normal">160</span>
<span class="normal">161</span>
<span class="normal">162</span>
<span class="normal">163</span>
<span class="normal">164</span>
<span class="normal">165</span>
<span class="normal">166</span>
<span class="normal">167</span>
<span class="normal">168</span>
<span class="normal">169</span>
<span class="normal">170</span>
<span class="normal">171</span>
<span class="normal">172</span>
<span class="normal">173</span>
<span class="normal">174</span>
<span class="normal">175</span>
<span class="normal">176</span>
<span class="normal">177</span>
<span class="normal">178</span>
<span class="normal">179</span>
<span class="normal">180</span>
<span class="normal">181</span>
<span class="normal">182</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">class</span><span class="w"> </span><span class="nc">BaseComponent</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Базовый компонент для работы с элементами страницы.</span>
<span class="sd"> Предоставляет общие методы для взаимодействия с элементами:</span>
<span class="sd"> - получение локаторов</span>
<span class="sd"> - проверка видимости элементов</span>
<span class="sd"> - работа с прокруткой</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="k">def</span><span class="w"> </span><span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">page</span><span class="p">:</span> <span class="n">Page</span><span class="p">):</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Инициализация базового компонента.</span>
<span class="sd"> Args:</span>
<span class="sd"> page: экземпляр страницы Playwright.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span> <span class="o">=</span> <span class="n">page</span>
<span class="c1"># Действия:</span>
<span class="k">def</span><span class="w"> </span><span class="nf">get_locator</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">Locator</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Получение объекта Locator из строки или существующего Locator.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: строка с CSS/XPath селектором или объект Locator.</span>
<span class="sd"> Returns:</span>
<span class="sd"> Locator: объект для работы с элементом.</span>
<span class="sd"> Raises:</span>
<span class="sd"> TypeError: если передан некорректный тип локатора.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">locator</span><span class="p">,</span> <span class="n">Locator</span><span class="p">):</span>
<span class="k">return</span> <span class="n">locator</span>
<span class="k">elif</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">locator</span><span class="p">,</span> <span class="nb">str</span><span class="p">):</span>
<span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">else</span><span class="p">:</span>
<span class="k">raise</span> <span class="ne">TypeError</span><span class="p">(</span><span class="s2">&quot;locator value should be string type or Locator type&quot;</span><span class="p">)</span>
<span class="c1"># Закомментированный код сохранен без изменений</span>
<span class="c1"># def wait_for_all_elements(self, locator: Locator, timeout=5000):</span>
<span class="c1"># loc = self.get_locator(locator)</span>
<span class="c1"># elements = self.page.locator(loc).all()</span>
<span class="c1">#</span>
<span class="c1"># for element in elements:</span>
<span class="c1"># self.page.locator(loc).wait_for(timeout=timeout)</span>
<span class="c1">#</span>
<span class="c1"># return elements</span>
<span class="c1"># Проверки:</span>
<span class="k">def</span><span class="w"> </span><span class="nf">check_presence</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">,</span> <span class="n">msg</span><span class="p">:</span> <span class="nb">str</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка видимости элемента на странице.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента (строка или объект Locator).</span>
<span class="sd"> msg: сообщение об ошибке при неудачной проверке.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если элемент не виден на странице.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">expect</span><span class="p">(</span><span class="n">loc</span><span class="p">)</span><span class="o">.</span><span class="n">to_be_visible</span><span class="p">(</span><span class="n">visible</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">timeout</span><span class="o">=</span><span class="mi">12000</span><span class="p">),</span> <span class="n">msg</span>
<span class="k">def</span><span class="w"> </span><span class="nf">is_scrollable_vertically</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">bool</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка возможности вертикальной прокрутки элемента.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Returns:</span>
<span class="sd"> bool: True если элемент можно прокрутить вертикально.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">return</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollHeight &gt; el.clientHeight&quot;</span><span class="p">)</span>
<span class="k">def</span><span class="w"> </span><span class="nf">is_scrollable_horizontally</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">bool</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка возможности горизонтальной прокрутки элемента.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Returns:</span>
<span class="sd"> bool: True если элемент можно прокрутить горизонтально.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">return</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth &gt; el.clientWidth&quot;</span><span class="p">)</span>
<span class="c1"># Методы прокрутки:</span>
<span class="k">def</span><span class="w"> </span><span class="nf">scroll_up</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вверх.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTo(0, 0)&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTop&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">==</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll up&quot;</span>
<span class="k">def</span><span class="w"> </span><span class="nf">scroll_down</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вниз.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTo(0, el.scrollHeight)&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTop&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">&gt;</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll down&quot;</span>
<span class="k">def</span><span class="w"> </span><span class="nf">scroll_left</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента влево.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">width</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">scroll_into_view_if_needed</span><span class="p">()</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">mouse</span><span class="o">.</span><span class="n">wheel</span><span class="p">(</span><span class="o">-</span><span class="n">width</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollLeft&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">==</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll left&quot;</span>
<span class="k">def</span><span class="w"> </span><span class="nf">scroll_right</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вправо.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">width</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">scroll_into_view_if_needed</span><span class="p">()</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">mouse</span><span class="o">.</span><span class="n">wheel</span><span class="p">(</span><span class="n">width</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollLeft&quot;</span><span class="p">)</span>
<span class="n">max_scroll_x</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth - el.clientWidth&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">&gt;=</span> <span class="n">max_scroll_x</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll right&quot;</span>
</code></pre></div></td></tr></table></div>
</details>
<div class="doc doc-children">
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.__init__" class="doc doc-heading">
<code class="highlight language-python"><span class="fm">__init__</span><span class="p">(</span><span class="n">page</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Инициализация базового компонента.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>page</code>
</td>
<td>
<code><span title="playwright.sync_api.Page">Page</span></code>
</td>
<td>
<div class="doc-md-description">
<p>экземпляр страницы Playwright.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">21</span>
<span class="normal">22</span>
<span class="normal">23</span>
<span class="normal">24</span>
<span class="normal">25</span>
<span class="normal">26</span>
<span class="normal">27</span>
<span class="normal">28</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">page</span><span class="p">:</span> <span class="n">Page</span><span class="p">):</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Инициализация базового компонента.</span>
<span class="sd"> Args:</span>
<span class="sd"> page: экземпляр страницы Playwright.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span> <span class="o">=</span> <span class="n">page</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.check_presence" class="doc doc-heading">
<code class="highlight language-python"><span class="n">check_presence</span><span class="p">(</span><span class="n">locator</span><span class="p">,</span> <span class="n">msg</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Проверка видимости элемента на странице.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента (строка или объект Locator).</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
<tr class="doc-section-item">
<td>
<code>msg</code>
</td>
<td>
<code><span title="str">str</span></code>
</td>
<td>
<div class="doc-md-description">
<p>сообщение об ошибке при неудачной проверке.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="AssertionError">AssertionError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если элемент не виден на странице.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">62</span>
<span class="normal">63</span>
<span class="normal">64</span>
<span class="normal">65</span>
<span class="normal">66</span>
<span class="normal">67</span>
<span class="normal">68</span>
<span class="normal">69</span>
<span class="normal">70</span>
<span class="normal">71</span>
<span class="normal">72</span>
<span class="normal">73</span>
<span class="normal">74</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">check_presence</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">,</span> <span class="n">msg</span><span class="p">:</span> <span class="nb">str</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка видимости элемента на странице.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента (строка или объект Locator).</span>
<span class="sd"> msg: сообщение об ошибке при неудачной проверке.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если элемент не виден на странице.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">expect</span><span class="p">(</span><span class="n">loc</span><span class="p">)</span><span class="o">.</span><span class="n">to_be_visible</span><span class="p">(</span><span class="n">visible</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">timeout</span><span class="o">=</span><span class="mi">12000</span><span class="p">),</span> <span class="n">msg</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.get_locator" class="doc doc-heading">
<code class="highlight language-python"><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Получение объекта Locator из строки или существующего Locator.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>строка с CSS/XPath селектором или объект Locator.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Returns:</span></p>
<table>
<thead>
<tr>
<th>Name</th> <th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td><code>Locator</code></td> <td>
<code><span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>объект для работы с элементом.</p>
</div>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="TypeError">TypeError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если передан некорректный тип локатора.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">31</span>
<span class="normal">32</span>
<span class="normal">33</span>
<span class="normal">34</span>
<span class="normal">35</span>
<span class="normal">36</span>
<span class="normal">37</span>
<span class="normal">38</span>
<span class="normal">39</span>
<span class="normal">40</span>
<span class="normal">41</span>
<span class="normal">42</span>
<span class="normal">43</span>
<span class="normal">44</span>
<span class="normal">45</span>
<span class="normal">46</span>
<span class="normal">47</span>
<span class="normal">48</span>
<span class="normal">49</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">get_locator</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">Locator</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Получение объекта Locator из строки или существующего Locator.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: строка с CSS/XPath селектором или объект Locator.</span>
<span class="sd"> Returns:</span>
<span class="sd"> Locator: объект для работы с элементом.</span>
<span class="sd"> Raises:</span>
<span class="sd"> TypeError: если передан некорректный тип локатора.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="k">if</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">locator</span><span class="p">,</span> <span class="n">Locator</span><span class="p">):</span>
<span class="k">return</span> <span class="n">locator</span>
<span class="k">elif</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">locator</span><span class="p">,</span> <span class="nb">str</span><span class="p">):</span>
<span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">else</span><span class="p">:</span>
<span class="k">raise</span> <span class="ne">TypeError</span><span class="p">(</span><span class="s2">&quot;locator value should be string type or Locator type&quot;</span><span class="p">)</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.is_scrollable_horizontally" class="doc doc-heading">
<code class="highlight language-python"><span class="n">is_scrollable_horizontally</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Проверка возможности горизонтальной прокрутки элемента.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Returns:</span></p>
<table>
<thead>
<tr>
<th>Name</th> <th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td><code>bool</code></td> <td>
<code><span title="bool">bool</span></code>
</td>
<td>
<div class="doc-md-description">
<p>True если элемент можно прокрутить горизонтально.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal"> 89</span>
<span class="normal"> 90</span>
<span class="normal"> 91</span>
<span class="normal"> 92</span>
<span class="normal"> 93</span>
<span class="normal"> 94</span>
<span class="normal"> 95</span>
<span class="normal"> 96</span>
<span class="normal"> 97</span>
<span class="normal"> 98</span>
<span class="normal"> 99</span>
<span class="normal">100</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">is_scrollable_horizontally</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">bool</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка возможности горизонтальной прокрутки элемента.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Returns:</span>
<span class="sd"> bool: True если элемент можно прокрутить горизонтально.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">return</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth &gt; el.clientWidth&quot;</span><span class="p">)</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.is_scrollable_vertically" class="doc doc-heading">
<code class="highlight language-python"><span class="n">is_scrollable_vertically</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Проверка возможности вертикальной прокрутки элемента.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Returns:</span></p>
<table>
<thead>
<tr>
<th>Name</th> <th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td><code>bool</code></td> <td>
<code><span title="bool">bool</span></code>
</td>
<td>
<div class="doc-md-description">
<p>True если элемент можно прокрутить вертикально.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">76</span>
<span class="normal">77</span>
<span class="normal">78</span>
<span class="normal">79</span>
<span class="normal">80</span>
<span class="normal">81</span>
<span class="normal">82</span>
<span class="normal">83</span>
<span class="normal">84</span>
<span class="normal">85</span>
<span class="normal">86</span>
<span class="normal">87</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">is_scrollable_vertically</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">bool</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Проверка возможности вертикальной прокрутки элемента.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Returns:</span>
<span class="sd"> bool: True если элемент можно прокрутить вертикально.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="k">return</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollHeight &gt; el.clientHeight&quot;</span><span class="p">)</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.scroll_down" class="doc doc-heading">
<code class="highlight language-python"><span class="n">scroll_down</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Прокрутка элемента вниз.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="AssertionError">AssertionError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если прокрутка не выполнена до конца.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">121</span>
<span class="normal">122</span>
<span class="normal">123</span>
<span class="normal">124</span>
<span class="normal">125</span>
<span class="normal">126</span>
<span class="normal">127</span>
<span class="normal">128</span>
<span class="normal">129</span>
<span class="normal">130</span>
<span class="normal">131</span>
<span class="normal">132</span>
<span class="normal">133</span>
<span class="normal">134</span>
<span class="normal">135</span>
<span class="normal">136</span>
<span class="normal">137</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">scroll_down</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вниз.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTo(0, el.scrollHeight)&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTop&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">&gt;</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll down&quot;</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.scroll_left" class="doc doc-heading">
<code class="highlight language-python"><span class="n">scroll_left</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Прокрутка элемента влево.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="AssertionError">AssertionError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если прокрутка не выполнена до конца.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">139</span>
<span class="normal">140</span>
<span class="normal">141</span>
<span class="normal">142</span>
<span class="normal">143</span>
<span class="normal">144</span>
<span class="normal">145</span>
<span class="normal">146</span>
<span class="normal">147</span>
<span class="normal">148</span>
<span class="normal">149</span>
<span class="normal">150</span>
<span class="normal">151</span>
<span class="normal">152</span>
<span class="normal">153</span>
<span class="normal">154</span>
<span class="normal">155</span>
<span class="normal">156</span>
<span class="normal">157</span>
<span class="normal">158</span>
<span class="normal">159</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">scroll_left</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента влево.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">width</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">scroll_into_view_if_needed</span><span class="p">()</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">mouse</span><span class="o">.</span><span class="n">wheel</span><span class="p">(</span><span class="o">-</span><span class="n">width</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollLeft&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">==</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll left&quot;</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.scroll_right" class="doc doc-heading">
<code class="highlight language-python"><span class="n">scroll_right</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Прокрутка элемента вправо.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="AssertionError">AssertionError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если прокрутка не выполнена до конца.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">161</span>
<span class="normal">162</span>
<span class="normal">163</span>
<span class="normal">164</span>
<span class="normal">165</span>
<span class="normal">166</span>
<span class="normal">167</span>
<span class="normal">168</span>
<span class="normal">169</span>
<span class="normal">170</span>
<span class="normal">171</span>
<span class="normal">172</span>
<span class="normal">173</span>
<span class="normal">174</span>
<span class="normal">175</span>
<span class="normal">176</span>
<span class="normal">177</span>
<span class="normal">178</span>
<span class="normal">179</span>
<span class="normal">180</span>
<span class="normal">181</span>
<span class="normal">182</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">scroll_right</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вправо.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">width</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">scroll_into_view_if_needed</span><span class="p">()</span>
<span class="bp">self</span><span class="o">.</span><span class="n">page</span><span class="o">.</span><span class="n">mouse</span><span class="o">.</span><span class="n">wheel</span><span class="p">(</span><span class="n">width</span><span class="p">,</span> <span class="mi">0</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollLeft&quot;</span><span class="p">)</span>
<span class="n">max_scroll_x</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollWidth - el.clientWidth&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">&gt;=</span> <span class="n">max_scroll_x</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll right&quot;</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
<div class="doc doc-object doc-function">
<h3 id="components.base_component.BaseComponent.scroll_up" class="doc doc-heading">
<code class="highlight language-python"><span class="n">scroll_up</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span></code>
</h3>
<div class="doc doc-contents ">
<p>Прокрутка элемента вверх.</p>
<p><span class="doc-section-title">Parameters:</span></p>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Description</th>
<th>Default</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code>locator</code>
</td>
<td>
<code><span title="str">str</span> | <span title="playwright.sync_api.Locator">Locator</span></code>
</td>
<td>
<div class="doc-md-description">
<p>локатор элемента.</p>
</div>
</td>
<td>
<em>required</em>
</td>
</tr>
</tbody>
</table>
<p><span class="doc-section-title">Raises:</span></p>
<table>
<thead>
<tr>
<th>Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr class="doc-section-item">
<td>
<code><span title="AssertionError">AssertionError</span></code>
</td>
<td>
<div class="doc-md-description">
<p>если прокрутка не выполнена до конца.</p>
</div>
</td>
</tr>
</tbody>
</table>
<details class="quote">
<summary>Source code in <code>components\base_component.py</code></summary>
<div class="highlight"><table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><span></span><span class="normal">103</span>
<span class="normal">104</span>
<span class="normal">105</span>
<span class="normal">106</span>
<span class="normal">107</span>
<span class="normal">108</span>
<span class="normal">109</span>
<span class="normal">110</span>
<span class="normal">111</span>
<span class="normal">112</span>
<span class="normal">113</span>
<span class="normal">114</span>
<span class="normal">115</span>
<span class="normal">116</span>
<span class="normal">117</span>
<span class="normal">118</span>
<span class="normal">119</span></pre></div></td><td class="code"><div><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">scroll_up</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">locator</span><span class="p">:</span> <span class="nb">str</span> <span class="o">|</span> <span class="n">Locator</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="kc">None</span><span class="p">:</span>
<span class="w"> </span><span class="sd">&quot;&quot;&quot;Прокрутка элемента вверх.</span>
<span class="sd"> Args:</span>
<span class="sd"> locator: локатор элемента.</span>
<span class="sd"> Raises:</span>
<span class="sd"> AssertionError: если прокрутка не выполнена до конца.</span>
<span class="sd"> &quot;&quot;&quot;</span>
<span class="n">loc</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">get_locator</span><span class="p">(</span><span class="n">locator</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTo(0, 0)&quot;</span><span class="p">)</span>
<span class="n">loc</span><span class="o">.</span><span class="n">wait_for</span><span class="p">(</span><span class="n">timeout</span><span class="o">=</span><span class="mi">2000</span><span class="p">)</span>
<span class="c1"># Проверка позиции прокрутки</span>
<span class="n">scroll_position</span> <span class="o">=</span> <span class="n">loc</span><span class="o">.</span><span class="n">evaluate</span><span class="p">(</span><span class="s2">&quot;el =&gt; el.scrollTop&quot;</span><span class="p">)</span>
<span class="k">assert</span> <span class="n">scroll_position</span> <span class="o">==</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;Invalid postion after scroll up&quot;</span>
</code></pre></div></td></tr></table></div>
</details>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</article>
</div>
<script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
</div>
</main>
<footer class="md-footer">
<div class="md-footer-meta md-typeset">
<div class="md-footer-meta__inner md-grid">
<div class="md-copyright">
Made with
<a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
Material for MkDocs
</a>
</div>
</div>
</div>
</footer>
</div>
<div class="md-dialog" data-md-component="dialog">
<div class="md-dialog__inner md-typeset"></div>
</div>
<script id="__config" type="application/json">{"base": "../..", "features": [], "search": "../../assets/javascripts/workers/search.b8dbb3d2.min.js", "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}}</script>
<script src="../../assets/javascripts/bundle.a7c05c9e.min.js"></script>
</body>
</html>