成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Web端PHP代碼函數覆蓋率測試解決方案

開發 后端
只不過沒被覆蓋的話,一定是不完整的。所以這個方案最大的意義在于能夠發現測試中一些遺漏的代碼,找到一部分問題。其實,它也可以幫助新來的員工理解整個項目代碼結構,我們可以清晰的知道,自己的每一次瀏覽器請求,到底在運行服務器上的哪些代碼。

1. 關于代碼覆蓋率

衡量代碼覆蓋率有很多種層次,比如行覆蓋率,函數/方法覆蓋率,類覆蓋率,分支覆蓋率等等。代碼覆蓋率也是衡量測試質量的一個重要標準,對于黑盒測 試來說,如果你不確定自己的測試用例是否真正跑過了系統里面的每一行代碼,在測試的完整性上總要打些折扣。因此,業界幾乎對各種編程語言都有自己的一套代 碼覆蓋率解決方案。世界上最美的語言PHP當然也不例外。PHPUnit和Spike PHPCoverage提供了一套基于xdebug的代碼覆蓋率測試方案。在本文中,我將針對自己碰到的特定業務場景,講述一下自己進行PHP代碼函數覆 蓋率測試的解決方案。

2. 業務背景

假設我們在線開發了一個網站,交給業務測試的同事去進行功能測試。那他們是怎么測試的呢?通常情況下,無非是開發人員把網站部署好了,然后測試人員 把網上所有功能都試用一遍,包括一些異常使用情況。對于業務測試來說,只要我把所有的功能點都測了,把所有異常使用情況也測到了,那就完成了。但是對于開 發來說,我比較好奇的是,你是否把我寫的所有代碼都跑到了?會不會存在一些代碼,只有在很特殊的情況下才能觸發,而你從來沒有測到過這些情況?這時,可能 就需要代碼覆蓋率來出馬了。 

其實我首先想到了xdebug來測試覆蓋率,只需要兩三個函數即可,如下:

xdebug_start_code_coverage(); //開始收集代碼行覆蓋情況

xdebug_get_code_coverage(); //獲取截至目前所跑過的代碼文件名和行號

xdebug_stop_code_coverage(); //停止收集代碼行覆蓋情況

xdebug提供的接口可以用于測試行覆蓋率,這是否能滿足要求呢?其實,行覆蓋率顆粒度有點細,實際項目中,開發人員可能會對代碼進行微調。比 如,這次測試,你跑過了A.php文件的第10行,但是我有一天對A.php進行了微調,在A.php第9行和第10行之間又加了兩行代碼。于是,原來的 第10行變為了第12行,而xdebug的行覆蓋信息只記錄了行號……這樣之前的數據豈不是不準確了么。。。考慮再三,我覺得函數覆蓋是個不錯的顆粒度。 在相對成熟的項目中,很少有大規模函數變動的情況。不過問題是,xdebug并沒有提供函數覆蓋的接口。

于是,我們現在碰到的場景是:

【1】希望測到某次測試中所覆蓋的所有函數列表,知道這個項目總共有多少個函數,計算一下覆蓋率是否足夠高。

【2】測試完成之后,要生成一份覆蓋率報告,將代碼的覆蓋情況可視化。

【3】完整測試的流程如下:

其中插樁的意思是在測試執行之前的一些準備工作。

3. 函數覆蓋率解決方案

(1)原理

xdebug天生提供了對行覆蓋率的支持,我們要自己計算出函數覆蓋率。函數覆蓋率需要兩點數據,一個是哪些函數被執行,一個是文件中總共有多少個函數。

文件中總共的函數量,由于我們不可能把所有函數都執行一遍,因此這部分只能通過代碼靜態掃描來實現。如果是在C++或者Java中,可能就需要詞法 分析工具了,然而在最美的語言PHP面前,我們完全不需要那么復雜。從PHP4.3開始,PHP Zend Engine中內置了tokenizer功能,幫助開發者做源碼詞法分析。我們只需要找到PHP中定義函數時所對應的詞法規律,就可以輕松得到指定PHP 文件中的全部函數了。

tokenizer定義的接口也十分簡單:

array token_get_all (string $source)

該函數進行文件解析,將php源代碼拆成由token組成的數組。

string token_name (int $token)

將整數形式的token轉變為字符串形式。類似于C語言中的strerror函數。有了tokenizer,自己再根據php函數定義的規律和格式設計一個有限狀態機,即可完成全量函數的解析。這部分代碼,本人寫了個比較簡陋的,把它單獨拿出來,僅供大家參考:PHPFunctionParser

求函數覆蓋率的另外一個難點在于獲取被執行的函數列表。這地方讓我們走了一些彎路。一開始一個最簡單的辦法,我們既然通過xdebug拿到被執的 行,可以通過行號來反推此行屬于哪一個函數。然而每一次的請求獲取的行號信息量是非常大的,如果一個求情執行了1000行,那就要進行1000次判斷,效 率上會比較差。調研了一番之后,發現xdebug提供了function trace的功能,可以把一次請求中的函數調用關系獲取到,只不過拿到了函數名字,卻沒辦法得到它所在的文件。于是,再次調研一番,發現了 Reflection,給定方法名和類名,可以反推出來它在哪個文件中定義。于是我們使用function trace把函數調用關系暫存在一個臨時文件中,然后通過文件解析,拿到執行的函數名(如果是類方法,則是“類名::函數名”的形式),再通過 reflection機制反推出定義這個函數的文件即可。再次體會到了世界上最美語言的強大之處。

(2)插樁

為了降低使用門檻,我們盡可能少地改變PHP源代碼為好。xdebug收集信息的原理是分別調用 xdebug_start_code_coverage和xdebug_stop_code_coverage來控制覆蓋率信息收集的開始和結束,因此不 可避免地要改變源代碼。此處我們的解決辦法是,將xdebug_stop_code_coverage通過 register_shutdown_function注冊為php程序結束前必須要跑的一段程序(類似C語言的atexit函數),將其封裝到一個文件 中,然后在源代碼***行require這個文件即可。如果你的PHP框架是CodeIgniter這種所有請求都有一個統一入口index.php的框 架,那就只需要改變這一個文件即可,對源代碼只有一行的改動!實際上,目前基本上所有的PHP框架,都是以一個index.php文件作為所有請求的入 口。

我們對源代碼的改動只有入口文件index.php的***行加入了一句話:

<?php require_once "/file/path/to/phpcoverage.php"; ?>

而phpcoverage.php核心代碼邏輯大致如下:

(3)信息存儲

我們的函數覆蓋率測試有了思路,使用xdebug的function trace獲取一次請求中所有函數的調用關系,得到執行過的所有函數,輸出到文件中,通過文件解析和reflection獲得被執行的函數名和該函數所在文件。將這些信息存入數據庫或文件即可。

之前試用Spike的時候,我們發現這些信息以xml格式存入文件,數據冗余度很高,導致幾個測試下來,文件已經非常大了。這顯然不是我們想看到的。因此在數據存儲的時候,我們直接將數據做json格式的序列化,字符串形式存在文件中,大大減少了文件大小。與此同時,我們再通過請求來源的IP和日期作為分隔,分別存儲不同的文件。這樣,來自每個機器每天的請求數據都能一目了然,向著“精準”的方向又邁進了一步,可以對測試人員的每個請求做精確的監控。下圖是我們在業務實踐中搜集的部分數據文件截圖:

這樣,來自任何一個IP的每一次Web請求,它所覆蓋的行和函數信息,都會被記錄到文件中。對于一般的項目測試中,也就只有幾個測試人員在使用,所以不需要考慮一些性能問題。

4. 報告生成

上面講了生成覆蓋率數據的原理,不過我們至此獲得的只是一份份的數據文件,如何匯總成一份完整的報告呢?這就需要我們自己來寫一段腳本解析剛才生成的數據文件了。我們的做法是借鑒了開源工具spike phpcoverage的模版,并加入自己的代碼邏輯,特別是加入了該工具所不具有的函數覆蓋率統計數據。我們自己測試的web頁面生成的報告如下:

圖中可以看到每個文件的行覆蓋率,函數覆蓋率,還有總的覆蓋率統計數據。如果需要更精確的數據,可以點進文件連接,查看到底覆蓋的是哪些代碼行(藍色為覆蓋,紅色為未覆蓋):

5. 總結

業務測試中做Web測試時,對代碼的覆蓋率是衡量測試質量的重要指標。我們希望通過此方法做到盡量地“精準”,測試執行完后可以精確看到哪一行代碼被執行過,哪一行沒被執行過。分析沒被執行過的原因,從而改進測試用例。使用工具的流程也很簡單,插樁=>測試=>搜集數據=>出報告。并且此解決方案***化地減少了對業務代碼的影響,只需要改一行代碼即可。即便中間出現了問題,也可以快速將代碼恢復為原來的樣子。讓測試放心,讓開發也放心。

不過,***還需要強調的一點是,并不是說覆蓋了所有的代碼,就證明測試已經完整了。只不過沒被覆蓋的話,一定是不完整的。所以這個方案***的意義在于能夠發現測試中一些遺漏的代碼,找到一部分問題。其實,它也可以幫助新來的員工理解整個項目代碼結構,我們可以清晰的知道,自己的每一次瀏覽器請求,到底在運行服務器上的哪些代碼。

責任編輯:王雪燕 來源: 博客園
相關推薦

2015-11-09 17:56:57

WebPHP函數覆蓋

2023-10-27 08:49:00

JCovOpenJDK

2012-04-11 11:21:57

ibmdw

2011-11-01 10:10:48

ScriptCover

2019-09-25 09:20:41

谷歌代碼開發者

2011-04-25 09:49:20

代碼測試

2021-12-25 22:30:27

Chrome DevTJavaScript調試工具

2022-05-31 09:01:18

SwiftApp 項目

2022-08-25 06:27:39

vivoJaCoCo代碼覆蓋率

2023-06-26 19:48:32

2022-03-29 11:32:32

單元測試覆蓋率框架

2022-05-27 12:40:25

前端測試項目

2016-03-13 17:35:18

2022-10-21 15:29:32

5G網絡

2024-11-01 15:05:12

2012-09-21 10:30:56

Linux項目代碼覆蓋率

2024-06-14 12:04:33

2011-06-21 09:01:02

2021-10-15 13:47:19

覆蓋率檢測 istanbul 總代碼的比例

2014-07-17 00:42:18

Android應用測試方案
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品免费在线 | 亚洲精品乱码久久久久久按摩观 | 国产精品日韩欧美 | 成年人在线观看 | 人成在线| 亚洲va欧美va天堂v国产综合 | 婷婷在线视频 | 欧美精品一区二区三区四区 在线 | 97超碰成人| 国产精品国产三级国产aⅴ中文 | 影音先锋久久 | 不卡一二区 | 成人在线中文字幕 | 国产精品久久久久久久久久 | 韩日精品一区 | 国产精品国产三级国产aⅴ中文 | 久久一久久 | 毛片免费在线 | 中国一级特黄真人毛片 | 蜜桃av一区二区三区 | 99精品国产一区二区三区 | 久久久www成人免费精品 | 日韩精品二区 | 九九视频在线观看视频6 | 精品日韩一区二区三区av动图 | 久久综合久久久 | 久久精品青青大伊人av | 精品1区2区 | 男女视频免费 | 天天操夜夜骑 | 91欧美 | www亚洲成人 | 国产精品区一区二 | 日韩在线一区二区三区 | 久久免费香蕉视频 | 精品三级在线观看 | 深爱激情综合 | 毛片区| 欧美日产国产成人免费图片 | 欧美日韩视频在线第一区 | 羞羞视频免费观看 |