嚴格說來,有兩種不同的路徑覆蓋測試,分別為程序路徑覆蓋和程序圖路徑覆蓋。這兩種測試可分別稱為程序的自然執(zhí)行和強迫執(zhí)行。所謂自然執(zhí)行是指測試者(人或計算機)讀入程序中的條件表達式,根據(jù)程序變量的當前值計算該條件表達式的值(真或假),并相應地分支。強迫執(zhí)行是在用程序圖作為程序的抽象模型時產(chǎn)生的一個人為的概念,它可以簡化測試問題。強迫執(zhí)行的含義是,一旦遇到條件表達式,測試者就強迫程序分兩種情況(條件表達式的值為真和為假)執(zhí)行。顯然,強迫執(zhí)行將遍歷程序圖的所有路徑,然而由于各個條件表達式之間存在相互依賴的關系,這些路徑中的某一些在自然執(zhí)行時可能永遠也不會進入。為了使強迫執(zhí)行的概念在實際工作中有用,它簡化測試工具的好處應該超過它使用額外的不可能達到的測試用例所帶來的壞處。在絕大多數(shù)情況下,強迫執(zhí)行的測試數(shù)并不比自然執(zhí)行的測試數(shù)大很多,此外,對強迫執(zhí)行的定義實際上包含了一種技術,能夠縮短在測試含有循環(huán)的程序時所需要的運行時間。程序的大部分執(zhí)行時間通常用于重復執(zhí)行程序中的DO循環(huán),特別是嵌套的循環(huán)。因此必須發(fā)明一種技術,使得每個DO循環(huán)只執(zhí)行一遍。這樣做并不會降低測試的功效,因為經(jīng)驗表明第一次或最后一次執(zhí)行循環(huán)時最容易出錯。
Laemmel教授提出的自動測試每條路徑的技術如下:當編寫程序時每個DO循環(huán)應該寫成一種包含測試變量T和模式變量M的特殊形式,因此:
您可能感興趣的試卷
你可能感興趣的試題
最新試題
()有助于提高程序的可讀性。
某業(yè)務管理信息系統(tǒng)中,采購子系統(tǒng)根據(jù)材料價格、數(shù)量等信息計算采購的金額,并給財務子系統(tǒng)傳低采購金額、shoukuanf和采購日期等信息,則這兩個子系統(tǒng)之間的耦合類型為()耦合。
結構化分析中,使用()建立數(shù)據(jù)模型。
以下關于消息模塊化的敘述中,不正確的是()
()不是軟件工程方法學中結構化方法學的特點。
()不適合大數(shù)據(jù)編程。
變量名MyData屬于()命名規(guī)則。
以下關于軟件開發(fā)相關的敘述中,不正確的是()
世界上第一個程序員是()
在面向對象方法中,對象之間僅通過()相聯(lián)系。