我的軟考歷程
摘要
2023年2月,我所在的公司做了開發紗線MES系統的決定,該系統為國內紗線工廠提供SAAS服務,旨在提高紗線工廠的智能化和數字化水平。我在該項目中被任命為系統架構設計師,全面掌管該項目的架構設計工作。本文將結合我在該項目中的架構設計工作經驗,詳細介紹如何把單元測試方法應用在項目中。在該項目中,我們采用了多種單元測試方法,包括靜態測試和動態測試。靜態測試在不運行程序的情況下,通過代碼分析、人工走查等方式檢查問題和缺陷。動態測試在運行項目后,通過訪問項目去發現問題點。單元測試提高了項目的穩定性,最終在2023年10月,該系統正式上線并運行至今,系統運行穩定,表現優異,得到了客戶工廠和公司領導的一致贊揚。
項目背景
隨著我國從制造業大國升級為制造業強國以及工廠數字化和智能化的持續推進,我所在的某地某科技公司基于自研的物聯網平臺相繼開發了染整一體化和織布一體化等系統,這些系統上線后,得到了工廠的追捧,也為公司帶來了豐厚的經濟回報。基于此,我司于2023年2月開始研發紗線MES系統,該系統預算730萬,建設工期10個月,涵蓋紗線工廠從清花、梳棉、并條、精梳、粗紗、細紗到絡筒的全流程工序,將為紗線工廠提供全面的生產管理解決方案以及基于數據的智能決策分析能力。該項目為物聯網層次架構,整體分為感知層、網絡層和應用層。其中網絡層為公司已有的物聯網平臺,這次重點建設內容為感知層和應用層,感知層使用Golang語言開發,作為聯網網關部署在工廠側,負責工廠數據的采集和云端指令的下發。應用層為紗線MES系統主體,采用Java語言開發,使用Spring Cloud微服務架構,數據庫使用Mysql,緩存使用Redis,前端框架使用vue.js,日志、監控和鏈路追蹤采用skywalking、prometheus、grafana和ELK,最終通過devops的方式部署在kubernetes集群中。系統上線后,將提供以下:基礎管理、數據接入、工單排產、數字孿生、工資計算、智控中心和數據分析等等功能,通過以上功能,可以全面提升紗線工廠的數字化和智能化水平,使其運營水平和生產效率得到質的提升。
論述內容
由于該項目涉及流程多,處理過程復雜,同時項目參與者眾多,需求變動快。為了提升項目的穩定性,我們采用單元測試方法來保證項目的質量。單元測試分為靜態測試和動態測試,靜態測試是指在不運行程序的情況下,通過人工走查、代碼工具分析等方式去發現程序中的錯誤和問題,從而修正錯誤。動態測試是指在啟動系統的情況下,通過人工驗證功能或者別的驅動方式去讓系統運行起來,讓系統的業務運轉起來,從而發現系統運行中的錯誤和問題,動態測試通常會采用邊界值分析、等價類劃分、因果圖、決策樹、代碼覆蓋等方式實現,為了提高系統的穩定性,我們會對不同級別的功能采用不同的測試方式。除此之外,我們在每次迭代后,都會采用自動化測試的方式去進行回歸測試,通過回歸測試保證業務的連貫性。下面我會詳細論述各種測試方法在本項目中的應用。
一、靜態測試
靜態測試是保證代碼質量的一種重要方式,我們在項目中會采取兩種方式進行靜態測試:一、成員代碼互審會議;二、通過CICD中的自動化代碼分析工具以及Idea中的代碼審核插件。每次迭代中,當代碼要提交測試前,小組就會舉行代碼評審會議,把本次迭代修改的代碼邏輯給大家講述一遍,大家一起去發現代碼中的缺陷和問題,旨在提高代碼的質量和可修改性以及可擴展性。當代碼開發者修改之后,再次提交代碼時,需要經過其他開發者的審核,在這個過程中,審核者要嚴格審查代碼,否則具有同等的責任。除此之外,我們公司統一安裝了Idea中的代碼掃描工具,只要通過掃描才能進行代碼提交,否則該代碼會勒令修改,直到達到掃描標準。當代碼提交后,CICD會自動化再次掃描代碼,并生成報告,防止有問題的代碼進入后續流程。我們公司就是通過這種方式,顯著提高了代碼的質量,在系統運行前就對系統的質量進行了把關。
二、動態測試
動態測試是測試團隊的工作重心,動態測試的主要目標是提升系統的質量,發現系統存在的問題。所以,在項目的需求階段,測試團隊就要參與進來,識別測試需求,進行測試案例設計,經過測試評審之后,當完成系統開發之后,就可以進行動態測試。動態測試的種類很多如等價類劃分、邊界值分析、覆蓋測試、基于因果圖、基于決策樹、基于正交等等方式,我們在設計測試案例時,主要采用了邊界值分析和覆蓋測試,邊界值分析比較容易理解,比如我們在錄入工廠的工序時,1-10的范圍是合法的,測試人員在測試時就要測試邊界值如0、1、2、9、10、11等等,看系統是否正常運行并進行響應。我們在進行覆蓋測試時,首先要決定使用哪種級別的覆蓋級別,覆蓋測試分為:語句覆蓋、條件覆蓋、分支覆蓋、條件分支覆蓋、組合覆蓋、路徑覆蓋等等。其中語句覆蓋最弱,路徑覆蓋最強。我們在選擇覆蓋測試時首先要對系統模塊的重要性做一個分析,因為都選擇路徑覆蓋,成本太高,耗費時間太長,不具備可操作性。所以我們根據重要性的不同采用不同級別的覆蓋測試方式,比如,數據接入模塊是系統的核心,我們在進行動態測試時就要采用路徑覆蓋,確保流程沒有任何問題,避免造成嚴重的故障。又比如,消息通知模塊不在主流程中,它的執行過程對主流程影響不大,并且消息保存再數據庫中,也可以重新發送,所以在測試時就采用條件覆蓋,降低測試級別,保障測試進度。當動態測試進行完成后,測試人員需要生成測試報告,該報告詳細描述測試的全部信息,以便其他人員查看,通過發現的問題,要給對應的負責人提bug,讓其在規定時間內完成。
三、回歸測試
回歸測試是每次迭代的一種重點,當進行一個迭代時,測試人員首先要分析這次迭代對現在系統業務的影響,并把影響模塊和范圍標注出來,形成回歸測試范圍,然后根據回歸范圍進行回歸測試用例的挑選,形成回歸測試用例。當本次迭代完成后,測試人員通過自動化腳本的方式執行回歸測試用例,并生成回歸測試報告。通過回歸測試,可以保證現有改動不會影響老的業務,可以讓業務的持久性和穩定性得到保證。
總結
通過采用了多種單元測試方法,我們保證了系統的開發進度和質量。最終在2023年12月,該項目正式投產并對外提供服務,至今穩定運行,各項功能和性能指標均遠遠超過了客戶的預期,得到了客戶工廠和公司領導的一致贊揚。雖然項目取得了成功,但是也遇到過一些問題,在項目初期,由于產品經理對紗線業務的不熟悉,導致很多功能的調整和返工,這打擊了開發人員的士氣,基于此,我提出兩個解決方式:1、派產品進入工廠一線,與工人交流,熟悉操作流程,徹底摸清紗線業務,保證需求質量;2、開發人員也要學習紗線業務,遇到問題反饋給產品,同時在做設計時,采用靈活的設計模式,為需求的變動留下可操作的空間。我們通過這兩個方法解決了這個問題,保證了項目的進展。通過這次實踐,我不僅學習到了測試相關技術,也鍛煉了自己的架構和管理能力,我意識到只有不斷地學習和實踐才能讓知識融匯于自己的技術體系之中,才能在未來的工作中游刃有余、勇擔大任,為祖國的信息化建設貢獻自己的力量。