?一、項目背景
大眾博客系統采用前后端分離的方法來實現,同時使用了數據庫來存儲相關的數據,同時將其部署到云服務器上。前端主要有四個頁面構成:登錄頁、列表頁、詳情頁以及編輯頁,以上模擬實現了最簡單的大眾博客系統。其結合后端實現了以下的主要功能:登錄、編輯博客、注銷、刪除博客、以及強制登錄等功能。
但是該項目沒有設計用戶注冊功能,只能提前在數據庫中存儲用戶信息后經過校驗登錄;并且用戶頭像不能自己設定,在進行前端頁面的書寫過程中已經將頭像的圖片寫為靜態了;而用戶信息中的文章數以及分類數也沒有在后端中具體實現,直接在前端頁面中寫為了靜態的。
該個人博客系統可以實現個人用戶簡單的博客記錄,時間、標題、內容以及發布者等都可以進行詳細地查看。
二、項目功能
一功能介紹
該大眾博客系統主要實現了以下幾個功能:登錄,寫博客以及用戶管理等功能。
登錄功能:用戶名以及密碼已經在后端寫入了數據庫,沒有實現賬戶注冊功能,即:用戶名以及密碼是已經存在的。登錄成功后就會跳轉到列表頁面。在右上角存在主頁和寫博客兩個按鈕,但是在未登錄情況下按下均只會跳轉到登錄頁面。
列表頁面:可以在列表頁查看有限數量的博客簡介,其包括博客標題、發布時間以及內容概要。在左側可以看到登錄的用戶以及文章數、分類數等的模塊。在右上角有主頁、寫博客和注銷三個功能:主頁即列表頁,寫博客即博客編輯頁,注銷即注銷用戶,回到登錄頁面。
詳情頁面:在列表頁面點擊“查看全文”按鈕就會跳轉到詳情頁,此時就可以看到該篇博客的完整內容。在右上角同樣有主頁、寫博客、刪除和注銷四個功能:刪除即刪除該篇博客,刪除之后就會跳轉到列表頁面,該篇博客就被成功刪除。
寫博客:在登錄之后的任意界面點擊“寫博客”之后就會進入博客編輯頁面,此時就可以進行博客的編寫,點擊“發布文章”后就可以成功發布文章,此時就會跳轉到列表頁。
二相關源碼
@Order(3)@Testvoid EditBlog() throws InterruptedException {EdgeOptions options = new EdgeOptions();options.addArguments("--remote-allow-origins=*");EdgeDriver driver = new EdgeDriver(options);driver.get("http://62.234.43.231:7551/blog_add.html");driver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);driver.findElement(By.xpath(" body > div.nav > a:nth-child(5)")).click();//輸入框輸入標題((JavascriptExecutor)driver).executeScript("document.getElementById(\"title\").value=\"自動化測試\"");sleep(3000);driver.findElement(By.cssSelector("body > div.blog-edit-container > div.title > button")).click();sleep(3000);//獲取urlString cur_url = driver.getCurrentUrl();Assertions.assertEquals("http://62.234.43.231:7551/blog_list.html",cur_url);
三、測試計劃操作
一功能測試
1測試用例:
實際執行測試的部分操作步驟/截圖
1正常登錄:
2寫博客測試
3發布成功并查看詳情頁
4博客用戶管理進行查詢
5博客用戶管理進行添加
6博客用戶管理進行刪除
6博客用戶管理進行修改
二?自動化測試
代碼編寫
根據腦圖進行測試用例的編寫:每個頁面一個測試類,然后再各個測試類中進行測試用例的編寫。
注意公共屬性需要單獨放一個類,方便進行代碼復用。
使用測試套件便于運行以及修改。
創建啟動以及現場截圖就是會頻繁進行復用,所以單獨創建一個類進行存儲。
注意添加隱式等待,為了確保頁面正確加載顯示。
1. 添加相關依賴pom.xml
<dependencies>
<!-- ? ? ? ?添加selenium依賴--><dependency><groupId>org.seleniumhq.selenium</groupId><artifactId>selenium-java</artifactId><version>4.0.0</version></dependency><!-- ? ? ? ?保存屏幕截圖需要用到的包--><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.6</version></dependency><!-- ? ? ? ?添加junit5依賴--><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>5.8.2</version><scope>test</scope></dependency><dependency><groupId>org.junit.platform</groupId><artifactId>junit-platform-suite</artifactId><version>1.8.2</version><scope>test</scope></dependency></dependencies>29
2. 新建包并在包下創建測試類以及公共類
以下是所建立的是common公共包和Tests測試包:
1)公共類AutoTestUtils
創建驅動、保存現場截圖
注意:在保存現場截圖的時候命名是按時間來進行文件夾的劃分,然后圖片的名稱要體現出測試類的類名,方便進行問題的追溯。
注意文件名的動態獲取,注意時間格式的設置。
注意:可以在創建驅動的時候修改默認的有頭模式or無頭模式
2)登錄頁面測試BlogLoginTest
① 創建驅動,并打開頁面
② 測試頁面是否正常打開
③ 測試正常登錄:多參數測試
④ 測試異常登錄:用戶名/密碼錯誤的情況(此處不測null)
⑤ 注意測試的順序,使用Order注解指定,否則可能會因為執行順序不對導致測試失敗
⑥ 注意清空內容后才能再次輸入用戶名以及密碼
3)列表頁測試BlogListTest
① 測試博客列表頁是否可以正常打開
② 測試列表頁的“查看全文”按鈕是否可以正常跳轉
③ 測試未登錄的直接鏈接是否會跳轉到登錄頁面,順便測試了“注銷”按鈕
④ 同樣注意執行順序
4)編輯頁測試BlogEditTest
① 測試編輯頁是否可以正確打開
② 測試博客是否可以正常發布:元素齊全 or 部分元素
③ 測試“寫博客”按鈕是否可以正常使用
④ 執行順序
5)詳情頁測試BlogDetailTest
① 測試詳情頁的正確打開:有blogId和沒有blogId兩種情況
② 測試“刪除”按鈕是否可用,注意比較的是時間,因為標題可能會存在為空的情況
③ 執行順序
④ 一定要注意導航回到列表頁的操作
6)驅動釋放DriverQuiteTest
因為驅動的測試是要在最后一個測試類完成之后進行釋放的,如果是使用@AfterAll注解,那么每次修改測試類的時候都會需要挪動驅動釋放的位置,所以直接新建一個類作為驅動釋放,此時只需要在測試套件中放到最后就行。
7)測試套件runSuite
測試套件的運行,使用的是以測試類作為執行順序的方式
三 性能測試
使用loadrunner進行簡單性能測試:針對登錄、編寫并發布博客以及刪除博客、注銷等功能進行簡單的性能測試。
然后在實現的過程中,插入集合點以及事務等,并通過設置來實現用戶的并發操作。
錄制腳本
登錄測試
通過開發者工具查看請求發送的格式,以此來進行性能測試腳本的編寫。發現:用戶名以及密碼是使用form表單的形式來進行發送的。因為用戶名以及密碼可以有多個,所以可以進行參數化。
添加事務以及集合點、檢查點:注意檢查點一般放在請求之前。
設置迭代次數:為了能夠更好地遍歷到所有的參數,一定要進行保存。
參數化
檢查點:一定注意函數只放在要檢查的URL前面,不要隨便再往前面放置。(即:只放在需求之前)相關源碼
Action()
{web_custom_request("crx_game_2.html", "URL=http://browser.360.cn/se/config/crx_game_2.html", "Method=GET", "Resource=0", "RecContentType=text/html", "Referer=", "Snapshot=t4.inf", "Mode=HTML", EXTRARES, "Url=http://62.234.43.231:7551/css/conmmon.css", "Referer=http://62.234.43.231:7551/login.html", ENDITEM, "Url=http://62.234.43.231:7551/css/login.css", "Referer=http://62.234.43.231:7551/login.html", ENDITEM, "Url=http://62.234.43.231:7551/js/jquery.min.js", "Referer=http://62.234.43.231:7551/login.html", ENDITEM, "Url=http://62.234.43.231:7551/img/logo2.jpg", "Referer=http://62.234.43.231:7551/login.html", ENDITEM, "Url=http://62.234.43.231:7551/img/cat.jpg", "Referer=http://62.234.43.231:7551/css/conmmon.css", ENDITEM, "Url=http://62.234.43.231:7551/login.html", "Referer=http://62.234.43.231:7551/login.html", ENDITEM, "Url=http://cseupdate.360safe.com/safe/safe.cab", "Referer=", ENDITEM, "Url=http://cseupdate.360safe.com/formal/360chrome.cab?ver=13.5.2044.0&mid=4f3c60c60fbd8d385ef600e811f8f6f5&guid=4f3c60c60fbd8d385ef600e811f8f6f5&pid=360CE&db=1&sbox=0&ceip=1&usei=0&usei9=0&usew=0&skin=&safe=0&setc=&to=4", "Referer=", ENDITEM, LAST);//集合點lr_rendezvous("Rendezvous");//事務lr_start_transaction("login_transaction");lr_think_time(9);web_submit_data("info", "Action=http://cloud.browser.360.cn/site/info", "Method=POST", "EncType=multipart/form-data", "RecContentType=text/plain", "Referer=", "Snapshot=t5.inf", "Mode=HTML", ITEMDATA, "Name=rn", "Value=814537", ENDITEM, "Name=sitedata", "Value=631302071d050b051a0100190a02050f0b020b081b176e", ENDITEM, LAST);//檢查點
web_reg_find("Text=admin",LAST);web_submit_data("login", "Action=http://62.234.43.231:7551/user/login", "Method=POST", "RecContentType=application/json", "Referer=http://62.234.43.231:7551/login.html", "Snapshot=t6.inf", "Mode=HTML", ITEMDATA, "Name=username", "Value={username}", ENDITEM, "Name=password", "Value={password}", ENDITEM, LAST);web_submit_data("info_2", "Action=http://cloud.browser.360.cn/site/info", "Method=POST", "EncType=multipart/form-data", "RecContentType=text/plain", "Referer=", "Snapshot=t7.inf", "Mode=HTML", ITEMDATA, "Name=rn", "Value=680672", ENDITEM, "Name=sitedata", "Value=6d1a0104001c061600180608070808061865535a645942404517126b", ENDITEM, LAST);web_url("myblog_list.html", "URL=http://62.234.43.231:7551/myblog_list.html", "Resource=0", "RecContentType=text/html", "Referer=http://62.234.43.231:7551/login.html", "Snapshot=t8.inf", "Mode=HTML", LAST);web_submit_data("info_3", "Action=http://cloud.browser.360.cn/site/info", "Method=POST", "EncType=multipart/form-data", "RecContentType=text/plain", "Referer=", "Snapshot=t9.inf", "Mode=HTML", ITEMDATA, "Name=rn", "Value=501298", ENDITEM, "Name=sitedata", "Value=6e12000b0b160406091c0c0e1b010b030900051f46575b4c5a4543411b65", ENDITEM, LAST);web_submit_data("info_4", "Action=http://cloud.browser.360.cn/site/info", "Method=POST", "EncType=multipart/form-data", "RecContentType=text/plain", "Referer=", "Snapshot=t10.inf", "Mode=HTML", ITEMDATA, "Name=rn", "Value=859621", ENDITEM, "Name=sitedata", "Value=6317080f001f090301180707160403070209081a5a515b1c5a5c571945545456565b571f48591b6b", ENDITEM, LAST);web_custom_request("mylist", "URL=http://62.234.43.231:7551/art/mylist", "Method=POST", "Resource=0", "RecContentType=application/json", "Referer=http://62.234.43.231:7551/myblog_list.html", "Snapshot=t11.inf", "Mode=HTML", "EncType=", LAST);web_custom_request("showinfo", "URL=http://62.234.43.231:7551/user/showinfo", "Method=POST", "Resource=0", "RecContentType=application/json", "Referer=http://62.234.43.231:7551/myblog_list.html", "Snapshot=t12.inf", "Mode=HTML", "EncType=", LAST);lr_end_transaction("login_transaction",LR_AUTO);return 0;
}
腳本測試通過
同時測試2個用戶并顯示日志
設置并發數量進行性能測試,并導出測試報告以及圖表
1)設置2個虛擬用戶,防止電腦崩潰
2)在Controller中設置場景
3)開始進行運行,性能測試開始(運行中+結束截圖)
4)在Analysis中查看性能報告以及報表
① 報告
② 點擊率和吞吐量分析圖
③ 事務響應量
5)分析系統資源
① 剩余的物理內存近80%,即使用了近40%的內存,對于簡單的登錄功能來說還是較高的內存使用,還有內存優化的空間。
② 當點擊率較大時CPU使用也是達到了一個較高的點,CPU利用率較高。
③ 總之,該性能還有優化的空間。