推薦一款最強(qiáng) Python 自動(dòng)化神器!不用寫一行代碼!

此文章來源于官方公眾號(hào):「測(cè)試開發(fā)技術(shù)」
版權(quán)聲明:允許轉(zhuǎn)載,但轉(zhuǎn)載必須保留原鏈接;請(qǐng)勿用作商業(yè)或者非法用途

image

搞過自動(dòng)化測(cè)試的小伙伴,相信都知道,在Web自動(dòng)化測(cè)試中,有一款自動(dòng)化測(cè)試神器工具: selenium。結(jié)合標(biāo)準(zhǔn)的WebDriver API來編寫Python自動(dòng)化腳本,可以實(shí)現(xiàn)解放雙手,讓腳本代替人工在Web瀏覽器上完成指定的操作。

雖然selenium有完備的文檔,但也需要一定的學(xué)習(xí)成本,對(duì)于一個(gè)純小白來講還是有些門檻的。

最近,微軟開源了一個(gè)非常強(qiáng)大的自動(dòng)化項(xiàng)目叫「playwright-python」,項(xiàng)目地址:

https://github.com/microsoft/playwright-python

它支持主流的瀏覽器,包含:ChromeFirefox、Safari、Microsoft Edge 等,同時(shí)支持以無頭模式、有頭模式運(yùn)行,并提供了同步、異步的 API,可以結(jié)合 Pytest 測(cè)試框架使用,并且支持瀏覽器端的自動(dòng)化腳本錄制。

而對(duì)于Python愛好者來說,還有一個(gè)更大的福利,這個(gè)項(xiàng)目是針對(duì)Python語言的純自動(dòng)化工具,可以做到,連一行代碼都不用寫,就能實(shí)現(xiàn)自動(dòng)化功能。聽起來,簡直太碉堡了!

image

可能你會(huì)覺得有點(diǎn)不可思議,真的不用寫一行代碼嗎?但它真的就是這么厲害。下面我們一起看下這個(gè)神器。

1. Playwright介紹

Playwright是一個(gè)強(qiáng)大的Python庫,僅用一個(gè)API即可自動(dòng)執(zhí)行ChromiumFirefox、WebKit等主流瀏覽器自動(dòng)化操作,并同時(shí)支持以無頭模式、有頭模式運(yùn)行。

Playwright提供的自動(dòng)化技術(shù)是綠色的、功能強(qiáng)大、可靠且快速,支持Linux、Mac以及Windows操作系統(tǒng)。

image

官網(wǎng):

https://playwright.dev/
image

從官網(wǎng)上來看,官方給Playwright定位是一款真正意義上的Web端到端測(cè)試工具。

2. Playwright使用

2.1 安裝

Playwright功能強(qiáng)大,但它的安裝步驟,非常簡單,只需要 2 步:

第 1 步,安裝 playwright-python 依賴庫 (需要注意的是,playwright庫需要依賴Python3.7+以上)

# 安裝依賴庫

?  ~ pip3 install playwright
Looking in indexes: https://pypi.douban.com/simple
Collecting playwright
  Downloading https://pypi.doubanio.com/packages/08/f0/9f937ccff3221685d4a8bd406649c85855b9b6a2fafe75920b02151b48e0/playwright-0.162.2-py3-none-macosx_10_13_x86_64.whl (58.2 MB)
     |████████████████████████████████| 58.2 MB 1.6 MB/s
Collecting greenlet==1.0a1
  Downloading https://pypi.doubanio.com/packages/aa/74/6e93515873829a8d894863bbae1d709405bdd50d66fdf239480cc9db0598/greenlet-1.0a1-cp38-cp38-macosx_10_9_x86_64.whl (86 kB)
     |████████████████████████████████| 86 kB 6.9 MB/s
Collecting typing-extensions
  Downloading https://pypi.doubanio.com/packages/60/7a/e881b5abb54db0e6e671ab088d079c57ce54e8a01a3ca443f561ccadb37e/typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)
Collecting pyee>=8.0.1
  Downloading https://pypi.doubanio.com/packages/0d/0a/933b3931107e1da186963fd9bb9bceb9a613cff034cb0fb3b0c61003f357/pyee-8.1.0-py2.py3-none-any.whl (12 kB)
Installing collected packages: greenlet, typing-extensions, pyee, playwright
Successfully installed greenlet-1.0a1 playwright-0.162.2 pyee-8.1.0 typing-extensions-3.7.4.3

可以在https://pypi.org/project/playwright/查看它的依賴版本信息。

第 2 步,安裝主流的瀏覽器驅(qū)動(dòng)

這樣,會(huì)將 Chromeium、Firefox、Webkit 瀏覽器驅(qū)動(dòng)下載到本地

# 安裝瀏覽器驅(qū)動(dòng)(安裝過程稍微有點(diǎn)慢,請(qǐng)耐心等待)
?  ~ python3 -m playwright install
Downloading chromium v827102 - 121.3 Mb [====================] 100% 0.0s
chromium v827102 downloaded to /Users/xxx/Library/Caches/ms-playwright/chromium-827102
Downloading firefox v1205 - 74.1 Mb [                    ] 1% 37767.9s

3.如果想查看Playwright支持的功能, 可以直接在命令行輸入:

?  ~ python3 -m playwright help
Usage: index [options] [command]

Options:
  -V, --version                          output the version number
  -b, --browser <browserType>            browser to use, one of cr, chromium, ff, firefox, wk,
                                         webkit (default: "chromium")
  --color-scheme <scheme>                emulate preferred color scheme, "light" or "dark"
  --device <deviceName>                  emulate device, for example  "iPhone 11"
  --geolocation <coordinates>            specify geolocation coordinates, for example
                                         "37.819722,-122.478611"
  --lang <language>                      specify language / locale, for example "en-GB"
  --proxy-server <proxy>                 specify proxy server, for example "http://myproxy:3128" or
                                         "socks5://myproxy:8080"
  --timezone <time zone>                 time zone to emulate, for example "Europe/Rome"
  --timeout <timeout>                    timeout for Playwright actions in milliseconds (default:
                                         "10000")
  --user-agent <ua string>               specify user agent string
  --viewport-size <size>                 specify browser viewport size in pixels, for example "1280,
                                         720"
  -h, --help                             display help for command

Commands:
  open [url]                             open page in browser specified via -b, --browser
  cr [url]                               open page in Chromium
  ff [url]                               open page in Firefox
  wk [url]                               open page in WebKit
  codegen [options] [url]                open page and generate code for user actions
  screenshot [options] <url> <filename>  capture a page screenshot
  pdf [options] <url> <filename>         save page as pdf
  install                                Ensure browsers necessary for this version of Playwright
                                         are installed
  help [command]                         display help for command

從命令行幫助信息中可以看出,Playwright支持的功能相當(dāng)豐富!

3. 實(shí)操演示

開篇就提到,使用Playwright無需寫一行代碼,我們只需手動(dòng)操作瀏覽器,它會(huì)錄制我們的操作,然后自動(dòng)生成代碼腳本。

3.1 錄制腳本

我們先查看錄制腳本的命令說明

?  ~ python3 -m playwright codegen --help
Usage: index codegen [options] [url]

open page and generate code for user actions

Options:
  -o, --output <file name>  saves the generated script to a file
  --target <language>       language to use, one of javascript, python, python-async, csharp (default: "python")
  -h, --help                display help for command

Examples:

  $ codegen
  $ codegen --target=python
  $ -b webkit codegen https://example.com

其中

  • python -m playwright codegen 錄制腳本

  • --help 幫助文檔

  • -o 生成自動(dòng)化腳本的目錄

  • --target 腳本語言,包含 JS 和 Python,分別對(duì)應(yīng)值為:python 和 javascript

  • -b 指定瀏覽器驅(qū)動(dòng)

比如,我要在baidu.com搜索,用chromium驅(qū)動(dòng),將結(jié)果保存為mikezhou.py的python文件。

# 我們通過下面命令打開 Chrome 瀏覽器開始錄制腳本
# 指定生成語言為:Python(默認(rèn)Python,可選)
# 保存的文件名:mikezhou.py(可選)
# 瀏覽器驅(qū)動(dòng):webkit(默認(rèn)webkit,可選)
# 最后跟著要打開的目標(biāo)網(wǎng)站(默認(rèn)僅僅是打開瀏覽器,可選)
python3 -m playwright codegen --target python -o 'mikezhou.py' -b chromium https://www.baidu.com

命令行輸入后會(huì)自動(dòng)打開瀏覽器,然后可以看見在瀏覽器上的一舉一動(dòng)都會(huì)被自動(dòng)翻譯成代碼,如下所示:

image
image

最后,自動(dòng)化腳本會(huì)自動(dòng)生成,保存到文件中mikezhou.py, 且上述所有的人工操作,都會(huì)被自動(dòng)轉(zhuǎn)化成代碼:

from playwright import sync_playwright

def run(playwright):
    browser = playwright.chromium.launch(headless=False)
    context = browser.newContext()

    # Open new page
    page = context.newPage()

    # Go to https://www.baidu.com/
    page.goto("https://www.baidu.com/")

    # Click input[name="wd"]
    page.click("input[name=\"wd\"]")

    # Fill input[name="wd"]
    page.fill("input[name=\"wd\"]", "禾目大")

    # Press CapsLock
    page.press("input[name=\"wd\"]", "CapsLock")

    # Fill input[name="wd"]
    page.fill("input[name=\"wd\"]", "自動(dòng)化測(cè)試實(shí)戰(zhàn)寶典 ")

    # Press Enter
    page.press("input[name=\"wd\"]", "Enter")
    # assert page.url() == "https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95%E5%AE%9E%E6%88%98%E5%AE%9D%E5%85%B8%20&fenlei=256&rsv_pq=af40e9aa00012d5a&rsv_t=c659gpz2%2Fjri1SAoIXdT9gP%2BmrqufXzRtMSSAL0n0fv7GSoLF5vaiNVPA3U&rqlang=cn&rsv_enter=1&rsv_dl=tb&rsv_sug3=38&rsv_sug1=22&rsv_sug7=100&rsv_sug2=0&rsv_btype=i&inputT=8034&rsv_sug4=9153"

    # Close page
    page.close()

    # ---------------------
    context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)

3.2 支持同步

同步的關(guān)鍵字為:sync_playwright

比如,我們依次使用三個(gè)瀏覽器內(nèi)核打開瀏覽器,然后百度一下,接著對(duì)在搜索界面截圖,最后關(guān)閉瀏覽器

from time import sleep
from playwright import sync_playwright

# 注意:默認(rèn)是無頭模式
with sync_playwright() as p:
    # 分別對(duì)應(yīng)三個(gè)瀏覽器驅(qū)動(dòng)
    for browser_type in [p.chromium, p.firefox, p.webkit]:

        # 指定為有頭模式,方便查看
        browser = browser_type.launch(headless=False)
        page = browser.newPage()
        page.goto('http://baidu.com')

        # 執(zhí)行一次搜索操作
        page.fill("input[name=\"wd\"]", "自動(dòng)化測(cè)試實(shí)戰(zhàn)寶典")
        with page.expect_navigation():
            page.press("input[name=\"wd\"]", "Enter")

        # 等待頁面加載完全
        page.waitForSelector("text=搜索工具")
        
        # 截圖
        page.screenshot(path=f'test-{browser_type.name}.png')

        # 休眠3s
        sleep(3)

        # 關(guān)閉瀏覽器
        browser.close()

需要指出的是,playwright-python 內(nèi)置的 API 基本上囊括常見的自動(dòng)化操作

3.3 支持異步

異步步的關(guān)鍵字為:async_playwright,異步操作可結(jié)合asyncio同時(shí)進(jìn)行三個(gè)瀏覽器操作。

import asyncio
from playwright import async_playwright

# 異步執(zhí)行
async def main():
    async with async_playwright() as p:
        for browser_type in [p.chromium, p.firefox, p.webkit]:
            # 指定為有頭模式,方便查看
            browser = await browser_type.launch(headless=False)
            page = await browser.newPage()

            await page.goto('http://baidu.com')

            # 執(zhí)行一次搜索操作
            await page.fill("input[name=\"wd\"]", "自動(dòng)化測(cè)試實(shí)戰(zhàn)寶典")
            await page.press("input[name=\"wd\"]", "Enter")

            # 等待頁面加載完全
            await page.waitForSelector("text=搜索工具")

            # 截圖
            await page.screenshot(path=f'test-{browser_type.name}.png')
            await browser.close()

asyncio.get_event_loop().run_until_complete(main())

3.4 支持移動(dòng)端

更厲害的是,playwright還可支持移動(dòng)端的瀏覽器模擬。下面是官方文檔提供的一段代碼,模擬在給定地理位置上手機(jī)iphone 11 pro上的Safari瀏覽器,首先導(dǎo)航到maps.google.com,然后執(zhí)行定位并截圖。

from playwright import sync_playwright

with sync_playwright() as p:
    iphone_11 = p.devices['iPhone 11 Pro']
    browser = p.webkit.launch(headless=False)
    context = browser.newContext(
        **iphone_11,
        locale='en-US',
        geolocation={ 'longitude': 12.492507, 'latitude': 41.889938 },
        permissions=['geolocation']
    )
    page = context.newPage()
    page.goto('https://maps.google.com')
    page.click('text="Your location"')
    page.screenshot(path='colosseum-iphone.png')
    browser.close()

3. 5 支持Pytest框架

另外,還可以配合pytest插件一起使用,給出一段官網(wǎng)示例:

def test_playwright_is_visible_on_google(page):
    page.goto("https://www.google.com")
    page.type("input[name=q]", "Playwright GitHub")
    page.click("input[type=submit]")
    page.waitForSelector("text=microsoft/Playwright")

當(dāng)然,除了上面列舉出來的特性,還有更多有意思的用法,感興趣的讀者可以自行探索一下。

4. 最后

playwright相比已有的自動(dòng)化測(cè)試框架來說,具有有很多優(yōu)勢(shì),比如:

  • 跨瀏覽器,支持Chromium、Firefox、WebKit
  • 跨操作系統(tǒng),支持Linux、Mac、Windows
  • 可提供錄制生成代碼功能,解放雙手
  • 可用于移動(dòng)端

目前存在的缺點(diǎn)就是生態(tài)和文檔還不是非常完備,比如沒有API中文文檔、沒有較好的教程和示例供學(xué)習(xí)。不過相信,隨著知道的人越來越多,未來會(huì)越來越好。

最后,再說一個(gè)小秘密,Playwright 是一個(gè)跨語言的自動(dòng)化框架,除了支持 Python,也支持Java、JS 等,更加詳細(xì)的功能可以通過官方項(xiàng)目去解鎖!

如果你覺得文章還不錯(cuò),請(qǐng)大家 點(diǎn)贊、分享、留言 下,因?yàn)檫@將是我持續(xù)輸出更多優(yōu)質(zhì)文章的最強(qiáng)動(dòng)力!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容