第一章 自動化測試課程介紹和課程大綱php
一、自動化測試課程介紹css
簡介:講解什麼是自動化測試和課程大綱講解,課程須要的基礎和學後的水平html
python3.7+selenium3前端
pycharmjava
第二章自動化測試相關軟件安裝python
一、自動測試工具selenium介紹linux
簡介:介紹selenium自動化測試工具git
爲何用selenium工具 1 -> 2 -> 3github
一、主流,各大公司都有用,開源免費社區活躍web
二、支持主流瀏覽器 火狐FireFox、谷歌chrome、IE(不建議)
三、支持多個語言,如python、java,js、php等
四、跨平臺:mac、windows、linux等 64位系統
二、自動化測試環境搭建之python3安裝
簡介:使用windwos安裝python3
一、python3安裝
1)官方文檔安裝 下載解壓包
https://www.python.org/downloads/windows/
2)python環境變量安裝
3)pip工具介紹
包管理工具
三、自動化測試環境搭建之selenium3安裝
簡介:使用安裝包安裝selenium3
方法1:cmd環境下,用pip install selenium
方法2:下載selenium安裝包手動安裝 (推薦)
下載地址:https://pypi.org/project/selenium/
在解壓好的目錄下進行安裝 python setup.py install
四、自動化測試工具selenium驗證安裝
簡介:講解自動化測試工具selenium安裝準確性
下載火狐瀏覽器
一、使用selenium打開firefox瀏覽器
須要下載對應的驅動
火狐:https://github.com/mozilla/geckodriver/releases
下載driver、拷貝到瀏覽器安裝路徑、配置環境變量
配置環境變量,須要重啓cmd窗口
from selenium import webdriver
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
五、前端知識講解和工具安裝使用
簡介:講解前端基礎知識和推薦安裝的工具
sublime / cmder / chrome瀏覽器 / firefox瀏覽器
必需要了解的前端基礎知識:
html: 網頁基礎,用於顯示數據
js: 網頁腳本,控制頁面的數據
css: 用於控制文件樣式
xml: 用來傳輸和存儲數據
json: 用來傳輸和存儲數據
http: 網絡請求協議
xpath:
第三章 測試核心理論知識-(工做面試必備)
一、必備知識之軟件開發生命週期
簡介:講解軟件開發的生命週期
一、測試人員須要全程參與
需求調研-》需求分析評審-》軟件架構設計-》編碼-》單元測試-》集成測試-》系統測試-》預發佈系統測試-》上線
測試人員要求開發人員寫單元測試
把控時間點、風險點
接口文檔不完善(更新了需求功能,不及時更新接口文檔)
二、測試相關知識分類講解
簡介: 測試分類講解
黑盒測試(功能測試):功能符合用戶的需求:
白盒測試:知道里面的邏輯,驗證符合用戶的需求
冒煙測試:主功能、主路徑測試
自動化測試: 人工測試轉爲工具自動執行(沒有誰取代誰,有些場景適合自動化測試,有些場景適合手工測試)
性能測試:模擬多種峯值和負載去測試各項性能指標 jmeter、loadrunner
三、自動化測試和手工測試優缺點
簡介:介紹何時須要用到自動化測試和何時用手工測試
一、自動化測試方便,自動驗證功能是否有問題
二、更好的利用自有,節約人力成本
三、覆蓋更全,增長軟件的穩定性
場景:
軟件需求變動少,項目週期長,穩定性要強,環境要隔離獨立(開發一套環境、測試一套環境)
若是整個系統需求變動多,只能抽取部分功能作自動化測試
語言選擇:
python java ruby php
打造本身的惟一性
第四章 自動測試selenium精講實戰
一、selenium基礎實戰之定位網頁元素技巧上集
簡介:講解使用selenium定位網頁元素,
find_element_by_id,find_element_by_name,find_element_by_class_name
一、開啓瀏覽器
browser = webdriver.Firefox();
二、打開網頁
browser.get("http://baidu.com")
使用python判斷是否正確
browser.title 或者 browser.current_url
三、定位元素的8種方法,(!!!!必定要惟一)
id: find_element_by_id() 採用id屬性進行定位
name: find_element_by_name() 定位方式和id定位類似,id、name和class通常在網頁都至少會有其中的一種
class name: find_element_by_class_name() 定位方式和id定位類似,id、name和class通常在網頁都至少會有其中的一種
四、定位到元素後的方法
clear() //清空
send_keys() // 輸入
back() //後退頁面
maximize_window() // 最大化窗口
click() //點擊事件,點擊按鈕,超連接
submit() //提交表單
五、定位到元素後的屬性
tag_name //標籤名
text //文本內容
二、selenium基礎實戰之定位網頁元素技巧下集
簡介:講解使用selenium定位網頁元素,
一、tag name:find_element_by_tag_name() 經過標籤名去定位,用的少,如find_element_by_tag_name("div")
二、link text: find_element_by_link_text() 超連接內容定位,元素內容
如 <a href="#">xxx </a>,則find_element_by_link_text("xxx")
from time import sleep
sleep(5)
三、partial link text:find_element_by_partial_link_text() 超連接內容定位,模糊匹配,和上面相似
比較難下面的兩種,下節課講解
xpath:
css selector
三、selenium實戰定位網頁元素之CSS定位
簡介:講解使用css定位網頁元素
一、css selector:find_element_by_css_selector()
根據CSS屬性定位,通常class是用.標記,id是用#標記,定位方式也會比xpath快
如 find_element_by_css_selector('input[id=\'search\']') // 規則: 元素[屬性=值]
技巧:經過firebug的拷貝css路徑
路徑:審查元素-》右鍵-》複製-》css選擇器
四、selenium實戰定位網頁元素之xpath定位
簡介:講解使用xpath定位網頁元素
一、xpath語法:http://www.w3school.com.cn/xpath/xpath_syntax.asp
注意 : 」//「 是所有的意思,即全文掃描, 」/「 的相鄰的意思, *是全部元素, 」..「是元素的父節點, "."是當前節點
二、xpath :find_element_by_xpath()xpath是XML路徑語言,經過元素的路徑來完成對元素的查找,HTML就是XML的一種實現方式,在FriePath插件裏copy對應的xpath地址
絕對路徑定位:從<html>標籤開始依次往下進行查找
相對路徑:利用元素屬性來進行xpath定位
技巧:經過firebug的拷貝css路徑
8種選擇器注意問題:若是定位元素報錯,緣由以下
一、根據定位取不到
二、多個元素根據下標超出範圍,沒有0,從1開始
解決辦法:換其餘方式定位元素
第五章 selenium實戰之模擬事件處理
一、自動化測試實戰之ActionChains模擬用戶行爲
簡介:講解使用selenium裏面的ActionChains模擬用戶的行爲
需求:
須要模擬鼠標操做才能進行的狀況,好比單擊、雙擊、點擊鼠標右鍵、拖拽
解決:selenium提供了一個類來處理這類事件
selenium.webdriver.common.action_chains.ActionChains(driver)
腳本:
from selenium.webdriver.common.action_chains import ActionChains
執行原理:
調用ActionChains的方法時不會當即執行,會將全部的操做按順序存放在一個隊列裏,當調用perform()方法時,隊列中的事件會依次執行
支持鏈式寫法或者分步寫法
ActionChains(driver).click(ele).perform()
鼠標和鍵盤方法列表:
perform() 執行鏈中的全部動做
click(on_element=None) 單擊鼠標左鍵
context_click(on_element=None) 點擊鼠標右鍵
double_click(on_element=None) 雙擊鼠標左鍵
move_to_element(to_element) 鼠標移動到某個元素
ele.send_keys(keys_to_send) 發送某個詞到當前焦點的元素
========== 不經常使用 ==========
click_and_hold(on_element=None) 點擊鼠標左鍵,不鬆開
release(on_element=None) 在某個元素位置鬆開鼠標左鍵
key_down(value, element=None) 按下某個鍵盤上的鍵
key_up(value, element=None) 鬆開某個鍵
drag_and_drop(source, target) 拖拽到某個元素而後鬆開
drag_and_drop_by_offset(source, xoffset, yoffset) 拖拽到某個座標而後鬆開
move_by_offset(xoffset, yoffset) 鼠標從當前位置移動到某個座標
move_to_element_with_offset(to_element, xoffset, yoffset) 移動到距某個元素(左上角座標)多少距離的位置
send_keys_to_element(element, keys_to_send) 發送某個鍵到指定元素
二、鼠標事件實戰之hover菜單欄彈出
簡介:鼠標事件之菜單欄hover彈出
一、
#引入 ActionChains 類
from selenium.webdriver.common.action_chains import ActionChains
二、move_to_element(to_element) 鼠標移動到某個元素
#對定位到的元素執行鼠標移動到上面的操做
ActionChains(driver).move_to_element(ele1).perform()
三、多知識點綜合實戰之模擬用戶登陸
簡介:講解使用selenium模擬登陸小D課堂,並選擇課程
一、多知識點實戰
二、查找登陸框-》輸入用戶名和密碼-》觸發登陸-》判斷登陸是否成功-》打印結果
四、自動化測試實戰之網頁等待時間
簡介:講解自動化測試的等待時間
一、爲何須要等待時間--》等系統穩定
網頁須要加載對應的資源文件,頁面渲染,窗口處理等等
二、自動化測試經常使用的等待時間
強制等待 : (本身調試代碼看效果)
from time import sleep
sleep(5) # 強制等待5秒再執行下一步,缺點是無論資源是否是完成,都必須等待
隱性等待:
driver.implicitly_wait(10) # 隱性等待,最長等10秒
#設置了一個最長等待時間,若是在規定時間內網頁加載完成,則執行下一步,不然一直等到時間截止,而後執行下一步,弊端就是程序會一直等待整個頁面加載完成,到瀏覽器標籤欄那個加載圈再也不轉
注意:對driver起做用,因此只要設置一次便可,沒有必要處處設置
顯性等待:
WebDriverWait 須要配合 until和until_not,程序每隔N秒檢查一次,若是成功,則執行下一步,不然繼續等待,直到超過設置的最長時間
from selenium.webdriver.support.wait import WebDriverWait
語法:WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
結論: 隱性等待和顯性等待能夠同時用,等待的最長時間取二者之中的較大者