溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Playwright怎么使用

發(fā)布時間:2021-12-13 09:06:38 來源:億速云 閱讀:372 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“Playwright怎么使用”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Playwright怎么使用”吧!

    Playwright是由微軟公司2020年初發(fā)布的新一代自動化測試工具,相較于目前最常用的Selenium,它僅用一個API即可自動執(zhí)行Chromium、Firefox、WebKit等主流瀏覽器自動化操作。作為針對 Python 語言純自動化的工具,在回歸測試中可更快的實(shí)現(xiàn)自動化。

    1. 為什么選擇Playwright

    1.1 Playwright的優(yōu)勢

    (1) Selenium需要通過WebDriver操作瀏覽器;Playwright通過開發(fā)者工具與瀏覽器交互,安裝簡潔,不需要安裝各種Driver。

    (2) Playwright幾乎支持所有語言,且不依賴于各種Driver,通過調(diào)用內(nèi)置瀏覽器所以啟動速度更快。

    (3) Selenium基于HTTP協(xié)議(單向通訊),Playwright基于Websocket(雙向通訊)可自動獲取瀏覽器實(shí)際情況。

    (4) Playwright為自動等待。

    • 等待元素出現(xiàn)(定位元素時,自動等待30s,等待時間可以自定義,單位毫秒)

    • 等待事件發(fā)生

    1.2 已知局限性

    (1) Playwright不支持舊版Microsoft Edge或IE11。支持新的Microsoft Edge(在Chromium上);所以對瀏覽器版本有硬性要求的項(xiàng)目不適用。

    (2) 需要SSL證書進(jìn)行訪問的網(wǎng)站可能無法錄制,該過程需要單獨(dú)定位編寫。

    (3) 移動端測試是通過桌面瀏覽器來模擬移動設(shè)備(相當(dāng)于自帶模擬器),無法控制真機(jī)。

    2. Playwright使用

    2.1 安裝

    (1)安裝Playwright依賴庫(Playwright支持Async\Await語法,故需要Python3.7+)

    pip install playwright

    (2)安裝Chromium、Firefox、WebKit等瀏覽器的驅(qū)動文件(內(nèi)置瀏覽器)

    python -m playwright install

    2.2 自動錄制

    (1)命令行鍵入 --help 看到所有可后接選項(xiàng)

    python -m playwright codegen --help

    (2)從起始頁為xingzheai.cn開始錄制

    python -m playwright codegen https://xingzheai.cn/

    (3)打開xingzheai.cn,用Chromium驅(qū)動,將結(jié)果保存為my.py的python文件

    python -m playwright codegen --target python -o 'my.py' -b chromium https://xingzheai.cn/

     -target:規(guī)定生成腳本的語言,有JS和Python兩種,默認(rèn)為Python
    -b:指定瀏覽器驅(qū)動
    -o:將錄制的腳本保存到一個文件

    2.3 定制化編寫

    (1)元素定位

    • 選擇單個元素:querySelector(engine=body)

    • 選擇多個元素:querySelectorAll(engine=body)

    • 選擇單個元素,并且自動等待:waitForSelector(engine=body)

    By的8種定位方式,實(shí)際為4種

    • id、name、tag name、class name(java和pythona將該4種都?xì)w為CSS)

    • xpath、link text、partial link text、css selector

    W3C標(biāo)準(zhǔn)規(guī)定的webDriver協(xié)議為5種定位方式

    • CSS、Link text、Partial link text、Tag name、XPath

    Playwright將選擇器匯總為3種

    • CSS、XPATH(支持邏輯表達(dá)式和函數(shù))、TEXT

    (2)選擇器規(guī)則

    • CSS: ID選擇器、類選擇器、元素選擇器、屬性選擇器、通配選擇器、層次選擇器。

    • XPath: XML路徑語言,通過“路徑標(biāo)識符”,導(dǎo)航XML文檔的,在類XML種(HTML)也可以使用。

    • Text: 結(jié)構(gòu)化內(nèi)容(html,xml,json)使用模糊匹配(忽略大小寫,忽略前后空格,搜索子字符串)及精確匹配、非結(jié)構(gòu)化內(nèi)容使用正則匹配。

    (3)元素常用操作

    • 下拉選擇框:selectOpion、value、labei、index

    • 文件上傳:setInputFiles、單個文件、多個文件、拖放上傳

    • 鼠標(biāo)點(diǎn)擊:click、dbclick

    • 鼠標(biāo)拖動:down、up

    • 鼠標(biāo)移動:move

    • 觸摸屏幕:tag

    • 鍵盤按鍵:press

    • 截屏、錄屏:screenshot、recordVideo

    2.4 網(wǎng)絡(luò)攔截(Mock接口),示例如下:

    page = context.newPage()
    def Whether_intercept() -> bool:
        return True  #進(jìn)行攔截
    # return False #不進(jìn)行攔截
    
    def handler(route:Route):
        print(route.request.url)
        #正常訪問
        # route.continue_()
        #拒絕訪問
        # route.abort("網(wǎng)絡(luò)攔截")
        # 重定向到非目標(biāo)地址
        route.fulfill(
            status=302,
            headers={
                'Location' : "https://xingzheai.cn/"
            }
        )
    page.route(Whether_intercept,handler)

    2.5 同步執(zhí)行,示例如下:

    #依次打開三個瀏覽器,前往行者官網(wǎng),截圖后退出。
    from playwright import sync_playwright with sync_playwright() as p:
        for browser_type in [p.chromium, p.firefox, p.webkit]:
             # 指定為有頭模式,Ture為無頭模式
            browser = browser_type.launch(headless=False)
            page = browser.newPage()
            page.goto('https://xingzheai.cn/')
            # 等待頁面加載完全后截圖
            page.waitForSelector("text=智能內(nèi)容審核")
            page.screenshot(path=f'example-{browser_type.name}.png')
            browser.close()

    2.6 異步執(zhí)行,示例如下:

    #同時進(jìn)行三個瀏覽器操作
    import asyncio
    from playwright import async_playwright
    async def main():
     async with async_playwright() as p:
         for browser_type in [p.chromium, p.firefox, p.webkit]:
              browser = await browser_type.launch()
             page = await browser.newPage()
             await page.goto('https://xingzheai.cn/')
              await page.waitForSelector("text=智能內(nèi)容審核")
              await page.screenshot(path=f'example-{browser_type.name}.png')
              await browser.close()
             asyncio.get_event_loop().run_until_complete(main())

    2.7 Pytest結(jié)合,示例如下:

    安裝:pip install pytest-playwright

    def test_playwright(page):
        page.goto("https://xingzheai.cn/")
        with page.expect_popup() as popup_info:         
     page.click('text="智能內(nèi)容審核"')         
        assert "智能內(nèi)容審核" == element.textContent()

    2.8 移動端操作,示例如下:

    目前支持模擬機(jī)型較少, 參照:仿真設(shè)備列表

    from time import sleep
    from playwright import sync_playwright  
    with sync_playwright() as p:
        GalaxyS5 = p.devices['Galaxy S5']
        browser = p.chromium.launch(headless=False)
        context = browser.newContext(**GalaxyS5)
        page = context.newPage()
        page.goto('https://xingzheai.cn/')
        page.click('text="智能內(nèi)容審核"')
        # 截圖
        # page.screenshot(path='colosseum-GalaxyS5.png')
        sleep(10)
        browser.close()

    感謝各位的閱讀,以上就是“Playwright怎么使用”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Playwright怎么使用這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

    向AI問一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI