項目背景
最近有一個超級表格的項目測試,支持多人實時協作編輯表格。項目選用了WebSocket這種基於 TCP 的全雙工通訊協議,它可以實現服務端和客戶端之間的主動數據推送,具有資源佔用少、實時性高等特點,消息推送模式包括:單對單、單對多(全體廣播)。
我們的項目使用WebSocket協議提交、廣播增量數據,並廣播提示其他用戶拉取全量數據以達到同步的目的。

在性能測試中需要模擬多個用戶協同編輯一個文檔的場景,選用Jmeter作為測試工具。
Jmeter插件
在Jmeter中測試WebSocket協議介面,需要先安裝WebSocket插件和依賴包;
需添加的插件為:
jmeter-websocket-samplers-1.2.1.jar
依賴包:jetty-http
jetty-io
jetty-util
websocket-api
websocket-client
websocket-common
把插件放到Jmeter的libext,依賴包放到Jmeter的lib目錄,打開Jmeter即可看到WebSocket相關的取樣器。

這幾種取樣器的作用如下表所示:

常用的取樣器是WebSocket Open Connection和WebSocket request-response Sampler,前者用來建立連接不發送數據,後者建立連接並發送data或者只發data。
創建腳本
在編寫腳本前先通過瀏覽器查看建立連接的過程,首先打開一個文檔時通過HTTP升級機制,使用HTTP的Upgrade和Connection協議頭的方式將連接升級為WebSocket。

返回的狀態碼為101則說明WebSocket連接建立成功,協議已經變為了WebSocket,如下圖所示,瀏覽器先後發送三個數據幀,包括CONNECT建立連接、SUBSCRIBE訂閱文檔、SEND類型為CLIENT_READY消息,客戶端收到的數據包括服務端返回的響應和每25s一個的心跳幀。

後續通過WebSocket協議提交、廣播、拉取各種類型的增量數據。
了解了這些之後就可以開始在測試場景中添加和配置WebSocket的sampler編寫腳本。
1.右鍵單擊測試計劃,選擇添加->線程->線程組,將一個線程組添加到測試計劃。
2.在線程組添加WebSocket request-response Sampler建立連接,選擇建立新連接,並發送請求數據如下:

說明:
(1)Connection:有兩個選項,第一項是使用已有連接,就是上一個WebSocket請求所建立的連接通道,選擇後Server URL全置灰只讀不可操作。第二項是新建連接通道。
(2)Server URL:可以發送ws協議和加密的WebSocket,即wss協議。Server Name Or IP處填寫WebSocket伺服器的地址,Port和Path依照實際填寫即可。
(3)Request data:支持文本(包括JSON)和Binary二進位數據的發送,可以將瀏覽器中查看到的數據根據需求參數化之後填寫。默認請求響應的超時時間為6S,超過這個時間報錯。
因為要通過收到返回包含CONNECTED字樣的報文來判斷是否發送後續的消息。需要把收到的服務端返回的其他數據幀過濾掉,再用斷言進行判斷。
右鍵單擊WebSocket request-response Sampler添加->配置元件->WebSocket Text Frame Filter,配置條件過濾掉不需要的數據幀,如心跳幀等。

右鍵添加->斷言->響應斷言,添加斷言對建立連接的響應幀進行判斷。

第一個建立連接的請求成功後,後續WebSocket request-response Sampler的連接類型選擇使用已存在的連接,下面的Server URL全置灰只讀不可操作。

添加後續的SUBSCRIBE訂閱文檔,通過固定請求數據中的文檔id可以使所有用戶打開同一個文檔,添加SEND類型為CLIENT_READY消息請求後,就完成了基本的打開文檔建立連接的操作,之後可以添加循環控制器並用類似的方法添加發送編輯文檔的請求。
運行腳本
腳本完成之後配置線程組的線程數,循環次數或執行時間,即可模擬並發用戶同時編輯文檔,添加結果樹、聚合報告等監聽器後可以查看測試的運行情況:

從瀏覽器也可以驗證收到了其他並發用戶廣播的數據。

除了多用戶協同編輯用一個文檔的場景,性能測試的過程中還覆蓋了協同用戶保存同一文檔、不同文檔同時保存等場景,確保測試場景的充分性。
原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/268433.html
微信掃一掃
支付寶掃一掃