前言:引擎組件的介面測試不光是程式測試人員使用,而且也是產品負責人員需要用到的功能,因為在每一步流轉過程中,就會完整模擬實際用戶發生的場景,也就容易排查具體是程式問題還是業務問題,從而快速定位問題,及時解決問題。WebTest測試工具集就是一個統一的交流測試平臺,其帶來的好處是壓縮了不同類型的引擎用 ...
前言:引擎組件的介面測試不光是程式測試人員使用,而且也是產品負責人員需要用到的功能,因為在每一步流轉過程中,就會完整模擬實際用戶發生的場景,也就容易排查具體是程式問題還是業務問題,從而快速定位問題,及時解決問題。WebTest測試工具集就是一個統一的交流測試平臺,其帶來的好處是壓縮了不同類型的引擎用戶交流問題的成本,同時也節約了程式開發和測試人員的工作成本。
1. 測試介紹
用戶交互測試也是一種必不可少的測試過程,而且在交互過程中,可以跟蹤和調試程式,真實系統的流轉是需要用戶身份的不斷切換,但是不妨通過身份模擬來減少切換環節,通過對流程引擎介面的內部改造,證實是可以實現這一思路的。
如下圖所示,一個集成測試的用戶界面,左側是流程定義記錄,右側上半部分是待辦任務列表,下半部分是辦結任務列表。功能介面主要是流程的啟動、流轉、退回和返送。功能測試人員通過選擇流程定義記錄,隨時就能進行流程實例的啟動、流轉、退回和返送操作,不用重覆的身份切換。
2. 功能說明
2.1 流程核心流轉功能
2.1.1 啟動
介面名稱:StartProcess(),啟動流程後,右側的任務列表就會出現新的任務記錄,作為用戶待辦。
2.1.2 流轉
介面名稱:RunProcess(), 流轉運行介面,負責流程的流轉,會出現步驟人員選擇界面,由人工交互確定下一步的辦理步驟,然後確定向下流轉。其中在需要條件變數數值的情況下。可以加入名稱-數值格式的文本,用於步驟列表重新載入。界面如下:
2.1.3 退回
介面名稱:SendBackProcess(),退回到上一步的辦理步驟,讓上一步人員重新辦理。同時,也會彈出上一步的人員辦理列表,方便當前操作用戶知道上一步的步驟和人員信息。
2.1.4 撤銷
介面名稱:WithdrawProcess(),撤銷是由上一步步驟的完成人員發起,它的用途也是把當前步驟退回到上一步去。跟退回介面本質是一樣的,兩者的區別是發起的位置不同,退回是當前運行節點的辦理人發起,而撤銷是上一步已經完成的辦理人員發起。
2.1.5 返送
介面名稱:ResendProcess(),退回後的任務被上一步的完成人員辦理完成後,需要重新發送,而且是僅僅需要發送給原來的退回節點位置就可以。在這種情況下就可以使用返送介面,而不是流轉介面。返送操作只能在退回節點上發起,這是它跟流轉介面的區別。
2.1.6 修訂
介面名稱:ReviseProcess()
1) 會簽修訂
在會簽時候,通常選擇了辦理人員後,會發現需要增加或者減少辦理人員列表。因為會簽節點是多實例節點,增加人員或者減少人員意味著活動實例數目的變化,所以需要單獨開發一個新的介面來實現這樣的功能。
比如當前會簽節點是“辦事員錄入”,對於經理A下發了辦事員D和辦事員E進行會簽,但是經理A認為並行會簽需要變更D和E,這個時候就可以調用會簽修訂功能,選擇新的辦理用戶列表。
2) 並行多實例修訂
如上圖所示,當節點“經理分配”節點退回到“業務分配”節點後,業務分配需要重新指定新的“經理分配”,這個時候就需要調用修訂介面,完成並行分支多實例的創建。假如上圖中的“A”退回,重新選擇經理分配後,可能就是B、C和新並行實例M(此處僅僅是標識,在K之後)。
2.1.7 駁回
介面名稱:RejectProcess(),流程駁回是指流程運行過程中,直接打回給流程發起人的節點位置。
2.1.8 關閉
介面名稱:CloseProcess(),流程辦結是指流程在運行過程中,由於外來因素或者決策需要,而提前直接結束流程,流程狀態正常結束。
2.2 流程數據功能
2.2.1 流程進度圖
流程流轉過程中,需要實時查看流程流轉位置,如果是已經辦理完成,則用紅色標記,如果目前處於待辦階段,則用綠色標記,如下圖所示:
2.2.2 流程變數
流程變數是為了顯示流轉過程中的流程交互數據,其中有兩種類型區分,流程變數和活動變數,這些數據的寫入是用戶根據業務數據的變化,並且是需要引擎交互控制用到為目的的。比如:活動節點完成時,需要調用外部事件,而外部事件的參數和數值來源,就需要通過流程變數來進行存儲。其次,流程分支判斷時候的條件參數,在流程過程中也可以存入到流程變數表中,以便流程關聯人員或者業務人員查看。這些是流程交互的核心變數數據,可以做一個統一的關聯界面來查看或維護。
2.2.3 清除運行實例
測試進行時候,有些情況下如果發生異常,需要重新進行測試,就可以把當前正在運行的流程實例進行刪除。刪除操作時,同時也會把流程實例所有的關聯數據進行刪除,包括以下的數據:活動實例,轉移實例,任務數據和流程變數表。
3. 總結
Slickflow.WebTest 測試工具的開發,加速了引擎組件的集成,降低了開發人員的學習周期,而且可以根據引擎服務介面做出統一的封裝,有助於客戶方項目或產品的二次開發,今後,引擎增加的功能也會呈現在這裡,測試工具最終會作為一個完成的產品使用。
體驗地址:http://demo.slickflow.com/sfw2/