在做移动端页面测试时可以利用Chrome mobile emulation 辅助完成页面的适配问题,但是目前手机市场上的型号居多我们也没有办法通过人工的模式一一的去适配,所以这里考虑到通过自动化的模式来模拟,下面介绍两种方式通过selenium调用Chrome mobile emulation来完成自动化测试。(电脑浏览器伪装成手机浏览器)
import time
from selenium import webdriver
mobileEmulation = {'deviceName': 'iPhone 6'}
options = webdriver.ChromeOptions()
options.add_experimental_option('mobileEmulation', mobileEmulation)
driver = webdriver.Chrome(chrome_options=options)
driver.get('http://www.baidu.com')
time.sleep(3)
driver.close()
附录:
deviceName列表
mobile_emulation = {
"deviceName": "Apple iPhone 3GS",
"deviceName": "Apple iPhone 4",
"deviceName": "Apple iPhone 5",
"deviceName": "Apple iPhone 6",
"deviceName": "Apple iPhone 6 Plus",
"deviceName": "BlackBerry Z10",
"deviceName": "BlackBerry Z30",
"deviceName": "Google Nexus 4",
"deviceName": "Google Nexus 5",
"deviceName": "Google Nexus S",
"deviceName": "HTC Evo, Touch HD, Desire HD, Desire",
"deviceName": "HTC One X, EVO LTE",
"deviceName": "HTC Sensation, Evo 3D",
"deviceName": "LG Optimus 2X, Optimus 3D, Optimus Black",
"deviceName": "LG Optimus G",
"deviceName": "LG Optimus LTE, Optimus 4X HD" ,
"deviceName": "LG Optimus One",
"deviceName": "Motorola Defy, Droid, Droid X, Milestone",
"deviceName": "Motorola Droid 3, Droid 4, Droid Razr, Atrix 4G, Atrix 2",
"deviceName": "Motorola Droid Razr HD",
"deviceName": "Nokia C5, C6, C7, N97, N8, X7",
"deviceName": "Nokia Lumia 7X0, Lumia 8XX, Lumia 900, N800, N810, N900",
"deviceName": "Samsung Galaxy Note 3",
"deviceName": "Samsung Galaxy Note II",
"deviceName": "Samsung Galaxy Note",
"deviceName": "Samsung Galaxy S III, Galaxy Nexus",
"deviceName": "Samsung Galaxy S, S II, W",
"deviceName": "Samsung Galaxy S4",
"deviceName": "Sony Xperia S, Ion",
"deviceName": "Sony Xperia Sola, U",
"deviceName": "Sony Xperia Z, Z1",
"deviceName": "Amazon Kindle Fire HDX 7″",
"deviceName": "Amazon Kindle Fire HDX 8.9″",
"deviceName": "Amazon Kindle Fire (First Generation)",
"deviceName": "Apple iPad 1 / 2 / iPad Mini",
"deviceName": "Apple iPad 3 / 4",
"deviceName": "BlackBerry PlayBook",
"deviceName": "Google Nexus 10",
"deviceName": "Google Nexus 7 2",
"deviceName": "Google Nexus 7",
"deviceName": "Motorola Xoom, Xyboard",
"deviceName": "Samsung Galaxy Tab 7.7, 8.9, 10.1",
"deviceName": "Samsung Galaxy Tab",
"deviceName": "Notebook with touch",
"deviceName": "iPhone 6"
}
import time
from selenium import webdriver
WIDTH = 320 # 宽度
HEIGHT = 640 # 高度
PIXEL_RATIO = 3.0 # 分辨率
mobileEmulation = {"deviceMetrics": {"width": WIDTH, "height": HEIGHT, "pixelRatio": PIXEL_RATIO}}
options = webdriver.ChromeOptions()
options.add_experimental_option('mobileEmulation', mobileEmulation)
driver = webdriver.Chrome(chrome_options=options)
driver.get('http://m.baidu.com')
time.sleep(3)
driver.close()
上面这种方法直接指定了宽度、高度、分辨率以及ua标识,全部可以自定义。
你也可以配合 driver.set_window_size(width,height) 来将浏览器窗口设置为相同大小,这样看起来更舒服一些。
现在,你可以用chrome来模拟手机浏览器测试手机网页了。用touch_actions来模拟手指操作吧!