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

搞過自動(dòng)化測試的小伙伴,相信都知道,在Web自動(dòng)化測試中,有一款自動(dòng)化測試神器工具: selenium。結(jié)合標(biāo)準(zhǔn)的WebDriver API來編寫Python自動(dòng)化腳本,可以實(shí)現(xiàn)解放雙手,讓腳本代替人工在Web瀏覽器上完成指定的操作。
雖然selenium有完備的文檔,但也需要一定的學(xué)習(xí)成本,對于一個(gè)純小白來講還是有些門檻的。
最近,微軟開源了一個(gè)非常強(qiáng)大的自動(dòng)化項(xiàng)目叫playwright-python,項(xiàng)目地址:
https://github.com/microsoft/playwright-python
它支持主流的瀏覽器,包含:Chrome、Firefox、Safari、Microsoft Edge 等,同時(shí)支持以無頭模式、有頭模式運(yùn)行,并提供了同步、異步的 API,可以結(jié)合 Pytest 測試框架使用,并且支持瀏覽器端的自動(dòng)化腳本錄制。
而對于Python愛好者來說,還有一個(gè)更大的福利,這個(gè)項(xiàng)目是針對Python語言的純自動(dòng)化工具,可以做到,連一行代碼都不用寫,就能實(shí)現(xiàn)自動(dòng)化功能。聽起來,簡直太碉堡了!

可能你會(huì)覺得有點(diǎn)不可思議,真的不用寫一行代碼嗎?但它真的就是這么厲害。下面我們一起看下這個(gè)神器。
1. Playwright介紹
Playwright是一個(gè)強(qiáng)大的Python庫,僅用一個(gè)API即可自動(dòng)執(zhí)行Chromium、Firefox、WebKit等主流瀏覽器自動(dòng)化操作,并同時(shí)支持以無頭模式、有頭模式運(yùn)行。
Playwright提供的自動(dòng)化技術(shù)是綠色的、功能強(qiáng)大、可靠且快速,支持Linux、Mac以及Windows操作系統(tǒng)。

官網(wǎng):
https://playwright.dev/

從官網(wǎng)的解釋,官方給Playwright定位是一款真正意義上的Web端到端測試工具。
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)慢,請耐心等待)
???~?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?????????????browser?to?use,?one?of?cr,?chromium,?ff,?firefox,?wk,
?????????????????????????????????????????webkit?(default:?"chromium")
??--color-scheme?????????????????emulate?preferred?color?scheme,?"light"?or?"dark"
??--device???????????????????emulate?device,?for?example??"iPhone?11"
??--geolocation?????????????specify?geolocation?coordinates,?for?example
?????????????????????????????????????????"37.819722,-122.478611"
??--lang???????????????????????specify?language?/?locale,?for?example?"en-GB"
??--proxy-server??????????????????specify?proxy?server,?for?example?"http://myproxy:3128"?or
?????????????????????????????????????????"socks5://myproxy:8080"
??--timezone? 從命令行幫助信息中可以看出,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???saves?the?generated?script?to?a?file
??--target????????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,分別對應(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)翻譯成代碼,如下所示:


最后,自動(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)化測試實(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)核打開瀏覽器,然后百度一下,接著對在搜索界面截圖,最后關(guān)閉瀏覽器
from?time?import?sleep
from?playwright?import?sync_playwright
#?注意:默認(rèn)是無頭模式
with?sync_playwright()?as?p:
????#?分別對應(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)化測試實(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)化測試實(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. 小結(jié)
playwright相比已有的自動(dòng)化測試框架來說,具有有很多優(yōu)勢,比如:
跨瀏覽器,支持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)目去解鎖!
推薦閱讀:
