如何測試代碼重構

一、前言

我最近做的主要工作是重構我們系統的核心功能。做過代碼重構的同學都知道,代碼重構很多時候是個費力不討好的事情。因為代碼重構是在不修改軟件功能的情況下,對軟件內部進行調整優化。

不修改功能便意味著從業務角度講,這項工作不會帶來什么收益。因為這一點,代碼重構工作通常難以得到充分的資源投入。而且,代碼重構工作不同于普通的代碼開發,代碼重構往往需要投入核心的高水平的研發人員,所以會占用更多的研發資源。

另一方面,代碼重構不僅不會給業務帶來收益,一不小心往往還會帶來很大的風險,尤其是對關鍵的代碼、核心的代碼重構。因此,大領導出于業務和研發資源等方面的考慮,通常對代碼重構都持有非常謹慎的保留態度。

但從研發工作角度講,代碼重構往往是必要的。具體到我所在的項目,最近做過調查,團隊中已有近90%的研發同學表示自己項目中的代碼有明顯的難以理解、難以修改的問題。更有同學表示因為經常接觸爛代碼,自己以忍無可忍,每天的工作就是打補丁,毫無成就感可言。

另外,通過代碼檢查工具,發現代碼在圈復雜度、重復率方面有嚴重的問題,具體的數據就不展示。所以,從直觀感受和量化指標上,都說明我們的代碼急需重構。

所以,從研發工作角度看,代碼重構的必要性往往是存在的。而從業務層面看,領導往往是不喜歡(至少是不主動支持)代碼重構的。

那如何協調這個矛盾呢?

其實代碼重構的實施主要存在兩大問題:一是研發資源的問題;二是重構質量的問題。第一個問題不在本文的范圍內,談談第二個問題。質量問題說白了就是代碼重構之后功能還是否正確。如果代碼重構只能功能不正常了,那代碼再漂亮也沒用。如果能保證代碼重構之后不出錯,那領導自然就會少很多顧慮,代碼重構工作也更容易實行。

接下來就談談如何更好地測試重構之后的代碼。

二、測試方案

任何軟件開發都離不開測試,代碼重構更是如此,而且代碼重構往往會帶來更多的回歸測試工作量。假如有充分的測試用例和完善的自動化測試保證,那大量的回歸測試往往不是難題。但開發、產品、測試換了一茬又一茬,早期的需求已被埋入塵土;早期工作方式簡單粗獷,代碼都沒寫好,有何談自動化測試。所以,充分的測試用例和完善的自動化測試很多時候是不存在的。

那怎么辦?在時間緊,任務重的情況下,怎么能在短時間內將這些測試工作準備好?

方法一:對比測試

測試用例,簡單說,就是給定一個場景(輸入),驗證在這個場景下軟件的行為(輸出)。所以定義測試用例就需要定義測試時的輸入輸出和驗證規則。

但在代碼重構中,因為軟件的功能并未增加,因此也就沒有增加新的測試用例。并且,重構前的老系統本身就提供了大量的測試用例。為什么這么說,因為重構之后的新系統的各項業務行為只要和老系統保持一致,那就可以說是正確的。

所以,對于代碼重構工作,測試用例的編寫就被大大簡化:只需定義輸入,無需定義輸出,將老系統的輸出作為輸出即可。同時,驗證規則也簡化了很多,各項數據通常只需和老系統保持一致,少數的不能完全一致的數據,只需驗證其滿足一定規則即可。

具體方法:

定義測試用例輸入,分別調用新(重構后的系統)、老系統。用老系統的結果校驗新系統,從而降低測試的工作量,提高測試效率。

方法二:導流測試

方法一可以幫助簡化對測試結果的驗證,但是測試輸入還是要想辦法豐富起來,否則漏掉一個場景就有可能放過一個 bug。

對于老功能,需求早已丟失,當年設計開發它的人也已不在,那如何為這樣的確實需求的功能設計測試用例。有一個方法是直接使用線上的請求測試。

具體方法:

通過使用 Nginx 的 ngx_http_mirror_module 模塊(或其它技術,如 tcpcopy),復制一份線上的請求,然后將這份復制的真實請求導向部署了重構版本應用的服務器。然后再通過方法一介紹的對比測試方式,比較線上應用和重構后應用的輸出結果(返回值、數據庫記錄等等),從而驗證代碼重構的正確與否。

但是這種測試方法有一定的局限性。簡單來說,這種方式適合測試讀接口,不太適合或者說是難以測試寫接口。因為測試請求來自線上,如果被測服務器同樣部署在線上環境,那寫接口就會對用戶造成應用。如果被測服務器部署在測試環境,需要在測試環境完整同步一份線上數據,這需要相當的基礎測試設施的支持。

三、總結

上面介紹了在面對代碼重構時的一些測試方法,希望能幫助大家安全順利的上線代碼重構,讓項目的代碼質量越來越好。

上面介紹的方法解決的問題范圍是有限的,我工作接觸到的問題也有限。所以歡迎大家能針對這個問題提出自己的意見和方案。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,546評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,570評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,505評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,017評論 1 313
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,786評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,219評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,287評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,438評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,971評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,796評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,995評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,540評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,230評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,918評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,697評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374