Skip to content

Commit

Permalink
[#552] DOCS: how to add chrome extension
Browse files Browse the repository at this point in the history
  • Loading branch information
roman-isakov committed Aug 2, 2024
1 parent f7b9a70 commit 57da7ca
Show file tree
Hide file tree
Showing 2 changed files with 99 additions and 0 deletions.
98 changes: 98 additions & 0 deletions docs/faq/adding-chrome-extension-howto.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
# How to add Chrome extension in Selene?


### An example how to remove ads in Chrome with [uBlock Origin extension](https://chromewebstore.google.com/detail/ublock-origin/cjpalhdlnbpafiamejdnhcphjbkeiagm) by installing `.crx` file

**Preliminary steps**
1. Download and store extension. (Example: by using [crxextractor](https://crxextractor.com/))

**Example project structure**
```
📦my-project
┣ 📂my_project
┃ ┣ 📜__init__.py
┃ ┗ 📂resources
┃ ┣ 📜__init__.py
┃ ┗ 📂chrome_extensions
┃ ┗ 📜uBlock-Origin.ctx
┣ 📂tests
┃ ┣ 📜test_ublock.py
┃ ┗ 📜conftest.py
┣ 📜readme.md
┣ 📜.gitignore
┣ 📜poetry.lock
┗ 📜pyproject.toml
```

**Code description**

`my_project / resources / __init__.py`: help function
```python
from pathlib import Path

path = Path(__file__).resolve().parent
```


`conftest.py`: install extension and navigate into it's settings.
```python
import pytest
from selene import browser, have, Element, be
from selene.core.locator import Locator
from selenium import webdriver

from my_project import resources



@pytest.fixture(autouse=True)
def browser_with_ublock():
ublock_path = resources.path / 'chrome_extensions/uBlock-Origin.crx'
ublock_id = 'cjpalhdlnbpafiamejdnhcphjbkeiagm' # it's a unique constant for uBlock Origin
options = webdriver.ChromeOptions()
options.add_extension(ublock_path)
browser.config.driver_options = options

browser.open('chrome://extensions/')
js = f"return document.querySelector('body > extensions-manager')\
.shadowRoot.querySelector('#items-list')\
.shadowRoot.querySelector('#{ublock_id}')\
.shadowRoot.querySelector('#card')"
card = Element(
Locator(
'ublock extension card',
lambda: browser.execute_script(js)
),
browser.config)
# Specific behaviour for uBlock extension. Initially it is enabled, then disabled, then enabled again.
# You might want to increase timeout.
card.should(have.css_class('disabled')).should(have.css_class('enabled'))

browser.open(
f"chrome-extension://{ublock_id}/dashboard.html#about.html"
)
browser.switch_to.frame(browser.element('iframe')())
browser.element('#aboutNameVer').should(be.visible).should(
have.text("uBlock Origin")
)

return browser
```

`tests / test_ublock.py`

```python
from selene import browser, have


def test_verify_noads_rules_are_applied():
# Act
browser.open('https://d3ward.github.io/toolz/adblock')
browser.element('#close-icon').with_(click_by_js=True).click() # close modal
browser.element('#dlg_changelog').element('button').with_(
click_by_js=True).click()

# Assert
browser.element('#adb_test_r').should(have.text('0 not blocked'))

```
1 change: 1 addition & 0 deletions mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ nav:
- How to work with iFrames: faq/iframes-howto.md
- How to work with Shadow DOM: faq/shadow-dom-howto.md
- How to use custom profile: faq/custom-user-profile-howto.md
- How to add Chrome extension: faq/adding-chrome-extension-howto.md
- How to extend Selene [TBD]: faq/extending-selene-howto.md
# - Use Cases:
# - Stub Title 1: use-cases/path-to-some-example.md
Expand Down

0 comments on commit 57da7ca

Please sign in to comment.