91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何提高嵌入式軟件測試準確性

要長高 ? 來源:網(wǎng)絡(luò)整理 ? 作者:網(wǎng)絡(luò)整理 ? 2023-09-29 06:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

嵌入式開發(fā)人員測試他們的軟件時,有多種力量在起作用。由于對更大的計算工作負載、更廣泛的連接以及改進的安全性的需求,系統(tǒng)的復(fù)雜性不斷增加,這使得開發(fā)人員更難根據(jù)需求驗證代碼。隨著發(fā)布時間的縮短,測試團隊努力使傳統(tǒng)的測試方法適應(yīng)更大的復(fù)雜性和規(guī)模。

需要一種新的測試方法,團隊正在尋求數(shù)學(xué)上證明的代碼正確性,以顯著提高對其應(yīng)用程序的信心。要了解當今的產(chǎn)品目標與傳統(tǒng)測試方法之間的差距,考慮復(fù)雜性如何影響測試會有所幫助:

覆蓋。隨著軟件復(fù)雜性的增長,創(chuàng)建涵蓋足夠級別的代碼庫(包括函數(shù)、語句、路徑、決策和條件)的測試變得越來越困難。

規(guī)模。無論測試范圍(特性、組件、庫或功能)如何,單元越多,測試它們所需的時間和資源就越多。

速度。傳統(tǒng)的測試開發(fā)和執(zhí)行實踐無法跟上發(fā)布時間表的步伐,不可避免地迫使在測試覆蓋率和時間之間進行權(quán)衡。

長期以來,人們一直認為接近 100% 的代碼覆蓋率是不可能的,因為這樣的目標極難實現(xiàn)且運行成本高昂。單元測試、滲透測試、動態(tài)分析 – 所有傳統(tǒng)技術(shù)都需要大量的時間和資源來執(zhí)行,并導(dǎo)致對系統(tǒng)中錯誤和漏洞的不完整視圖。

隨著軟件技術(shù)和計算能力的最新進步,這種信念現(xiàn)在已成為一個被證明的神話。學(xué)術(shù)和行業(yè)研究人員已經(jīng)開發(fā)出數(shù)學(xué)上嚴格的技術(shù),稱為形式化方法,可實現(xiàn)高達 100% 的代碼覆蓋率并保證系統(tǒng)的正確性 - 現(xiàn)在可供企業(yè)就緒平臺中的安全和安保關(guān)鍵型開發(fā)團隊使用。

了解基于正式方法的測試工具

在紙面上,形式化方法明確證明代碼沒有錯誤和安全漏洞等問題。這些方法使用嚴格指定的數(shù)學(xué)模型,根據(jù)精確定義的規(guī)范驗證軟件的屬性和行為。換句話說,形式化方法可以找到代碼中出現(xiàn)的所有問題。

在實踐中,任何開發(fā)人員都可以使用且負擔得起基于企業(yè)級正式方法的測試工具。它們被稱為詳盡的靜態(tài)分析工具,經(jīng)過精心設(shè)計和驗證,可將正式方法的強大功能集成到安全和安保關(guān)鍵型開發(fā)團隊的現(xiàn)有驗證和確認流程中。

與傳統(tǒng)的測試和靜態(tài)分析方法相比,這些工具有幾個優(yōu)點:

高達 100% 的應(yīng)用程序覆蓋率,涵蓋所有可能的功能、語句、路徑、決策和條件。

高達 100% 的輸入覆蓋率,涵蓋被測單元范圍內(nèi)的所有可能值。

數(shù)學(xué)保證代碼中沒有未定義的行為(錯誤和漏洞),導(dǎo)致部署中零問題。

零漏報,因此開發(fā)人員可以增強發(fā)現(xiàn)所有問題的信心。

誤報率低至零,這意味著開發(fā)人員花在追逐并非真正問題上的時間更少。

顯著縮短測試時間,提高資源消耗效率。

圖 1 說明了差異。傳統(tǒng)的測試方法通常是測試用例開發(fā)和算法設(shè)計的“最大努力”嘗試,受到人力和項目進度的限制。這會導(dǎo)致測試每次運行執(zhí)行一個代碼分支,并限制團隊在給定測試階段可以覆蓋的內(nèi)容。以正式方法為后盾的詳盡靜態(tài)分析可在單次測試運行中并行分析所有分支,將覆蓋率提高到 100%,并顯著縮短測試時間。

wKgZomUFaXqAECEkAAGaYDz7HdM881.png

圖 1:傳統(tǒng)測試方法(左)和聲音靜態(tài)分析(右)之間的代碼路徑比較。訪問的段以橙色顯示;未訪問的段為黑色。

詳盡的靜態(tài)分析可以為開發(fā)人員提供一種強大的方法來管理軟件復(fù)雜性,從而極大地改變他們對軟件復(fù)雜性的看法。

詳盡的靜態(tài)分析如何提供幫助

傳統(tǒng)測試方法的一個限制是它們的狀態(tài)空間覆蓋,即數(shù)據(jù)值和輸入、控制和數(shù)據(jù)流的不同組合的數(shù)量以及它們可以覆蓋的輸出路徑的固有限制。例如,傳統(tǒng)的測試方法通常會在給定預(yù)期輸入的情況下測試預(yù)期輸出的函數(shù)。一些靜態(tài)分析工具對此進行了擴展,以涵蓋更廣泛的輸入和輸出。但由于測試設(shè)計、實現(xiàn)和計劃約束,這些工具無法測試所有可能的行為。

下面的代碼示例演示了一個遞增數(shù)組中的單元格值的 C 函數(shù)。

wKgZomUFaYaABxU-AACd4QQ_ViE564.png

典型的單元測試將根據(jù)函數(shù)的要求進行驗證,檢查函數(shù)是否遞增了輸出數(shù)組中的單元格值,并根據(jù)結(jié)果報告通過或失敗。此測試不一定會檢查數(shù)組索引 *p 是否由于系統(tǒng)中意外或不希望的副作用而導(dǎo)致越界內(nèi)存訪問 - 就像本代碼示例中由于 while 循環(huán)中指定的不正確條件而發(fā)生的那樣。

盡管存在緩沖區(qū)溢出,但針對要求的傳統(tǒng)測試將在調(diào)用函數(shù)后驗證數(shù)組是否為 {2, 4, 6, 8},并且始終通過,如以下控制臺輸出所示:

wKgZomUFaZKAeuHTAAAxWLTZK18407.png

除非測試設(shè)計者考慮越界數(shù)組訪問的可能性,否則永遠不會識別此緩沖區(qū)溢出。

這些類型的細微缺陷可能導(dǎo)致內(nèi)存損壞,從而導(dǎo)致潛在的錯誤、崩潰或應(yīng)用程序漏洞 - 傳統(tǒng)測試方法不可見,但可以通過詳盡的靜態(tài)分析工具發(fā)現(xiàn),如圖 2 所示。該工具檢測到數(shù)組開頭后有 16 個字節(jié)的寫入:緩沖區(qū)溢出。

wKgaomUFaaGAE-gbAAFz56nQnWw103.png

圖 2:在 TrustInSoft 詳盡靜態(tài)分析工具中查找結(jié)果的屏幕截圖。

這種內(nèi)存損壞可以通過更詳細的測試用例來揭示,其中越界寫入條件會影響變量名稱的值,即使它不參與測試的函數(shù),如以下控制臺輸出所示:

wKgaomUFaayAOSBRAACLWVfo0OQ187.png

但是,開發(fā)團隊很少實現(xiàn)此級別的測試深度,尤其是當代碼比此示例更復(fù)雜時。

硬件感知在靜態(tài)分析中的重要性

更 高級 的 詳盡 靜態(tài) 分析 工具 為 驗證 和 確認 活動 帶來 硬件 感知, 從而 實現(xiàn) 更 準確 和 高效 的 測試 覆蓋率。硬件感知的重要性怎么強調(diào)都不為過,因為編譯器實現(xiàn)、硬件架構(gòu)和內(nèi)存對齊的差異可能導(dǎo)致測試條件和代碼行為大不相同。例如:

在 64 位目標上,long 通常為 64 位,int 通常為 32 位。

在 32 位目標上,long 和 int 通常都是 32 位。

這些硬件差異會影響測試條件、輸入和路徑,如以下代碼示例所示:

wKgZomUFabqAJcEPAAAmq-4jkM8754.png

如果沒有硬件感知,測試或分析方法將無法確定最后一條語句是否導(dǎo)致整數(shù)溢出(32 位目標)或不導(dǎo)致整數(shù)溢出(64 位目標)。在某些情況下,測試將執(zhí)行比必要的更多的運行,以涵蓋硬件支持范圍之外的條件。在其他情況下,測試可能只是錯過潛在的溢出。硬件感知靜態(tài)分析在 100% 覆蓋率和實現(xiàn)覆蓋率所需的最少測試用例數(shù)量之間提供了完美的平衡。

另一個關(guān)鍵的硬件差異是字節(jié)序,如以下代碼示例所示:

wKgaomUFacSAZgLhAAAtRKXa_UY950.png

根據(jù)底層硬件的字節(jié)序,變量 c 將設(shè)置為 0xBE(大端序)或0xEF(小端序)——這是測試執(zhí)行的關(guān)鍵區(qū)別。

這種微妙的差異可能會導(dǎo)致災(zāi)難性的結(jié)果。請考慮將以下語句添加到上述代碼示例中的情況:

wKgZomUFac-AL1FUAAAPwzZfS8w732.png

在大端系統(tǒng)上,此語句將導(dǎo)致除以零條件,并可能導(dǎo)致應(yīng)用程序崩潰或其他不良行為。在小端系統(tǒng)上,此語句是有效的。了解這些差異的測試方法可以得出更準確的結(jié)果。

包含硬件感知的詳盡靜態(tài)分析工具還具有以下優(yōu)點:

開發(fā)人員可以運行硬件感知分析,而無需將物理目標連接到主機。

目標測試可以在開發(fā)生命周期的早期運行,甚至在物理硬件可用之前。

開發(fā)團隊可以提高測試能力并降低成本,因為不需要每個主機和開發(fā)人員都使用物理硬件。

詳盡靜態(tài)分析的未來

優(yōu)先考慮詳盡靜態(tài)分析的嵌入式開發(fā)團隊(代碼覆蓋率高達 100%,準確性遠高于傳統(tǒng)測試)將從其測試投資中獲得最高價值。那些現(xiàn)在能夠加入的開發(fā)人員將能夠更好地提供更高質(zhì)量的代碼,并隨著時間的推移提高測試效率。

從長遠來看,從這種嚴格的測試中獲得的結(jié)果和知識將導(dǎo)致“零問題”保證。這些原則將在開發(fā)過程的早期帶來更強的可測試性,以支持安全和安保關(guān)鍵型產(chǎn)品要求和設(shè)計,并顯著降低現(xiàn)場軟件故障和漏洞的可能性。

編輯:黃飛

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4381

    瀏覽量

    64904
  • 嵌入式軟件
    +關(guān)注

    關(guān)注

    4

    文章

    245

    瀏覽量

    27339
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70758
  • 軟件測試
    +關(guān)注

    關(guān)注

    2

    文章

    239

    瀏覽量

    19229
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    淺析嵌入式系統(tǒng)軟件的可靠測試難點

    `目前,嵌入式軟件的可靠評價主要依賴測試,因為嵌入式軟件的開發(fā)環(huán)境和
    發(fā)表于 08-02 10:05

    合同智能審核軟件-提高審查效率和準確性

    審查的準確性。使用軟件能夠提高審查速度在提高合同審查的速度方面,靈玖合同智能審核軟件設(shè)定了豐富的合同審核范圍:1.審查合同格式是否規(guī)范:檢查
    發(fā)表于 09-05 17:22

    如何對嵌入式軟件進行可靠測試

    摘 要 本文針對目前嵌入式軟件設(shè)計可靠測試用例的手段主要依靠手工分析,沿用傳統(tǒng)的軟件測試用例設(shè)
    發(fā)表于 10-27 06:10

    嵌入式軟件可靠測試方法是什么

    本文原文鏈接如下:https://www.jianshu.com/p/f6f5c3cd3fab目前,嵌入式軟件的可靠評價主要依賴測試,因為嵌入式
    發(fā)表于 12-21 07:09

    如何提高嵌入式軟件單元測試效率

    在本指南中,您將學(xué)習如何通過在更短的時間內(nèi)運行更多的測試來增加您的單元測試吞吐量。 這種效率的提高來自于使用虛擬平臺而不是物理硬件作為開發(fā)平臺。 本指南對任何開發(fā)或運行嵌入式
    發(fā)表于 08-28 06:31

    如何提高投標報價編制的準確性

        施工企業(yè)要在激烈的市場競爭中戰(zhàn)勝對手,贏得工程項目,投標報價的準確性是關(guān)鍵。下面結(jié)合多年工作的實際,談一下如何提高投標報價編制的準確性。
    發(fā)表于 01-08 15:36 ?13次下載

    基于CodeTEST的嵌入式軟件測試技術(shù)

    嵌入式軟件測試有助于提高嵌入式軟件質(zhì)量和可靠。因此
    發(fā)表于 01-17 15:53 ?41次下載

    嵌入式Linux軟件測試框架的研究

    嵌入式Linux 軟件是最難測試的一類軟件。在測試過程中通過使用有效的測試框架,可以顯著
    發(fā)表于 06-07 17:14 ?29次下載

    嵌入式軟件測試參考書籍

    嵌入式軟件測試的幾本參考書籍:1、《嵌入式軟件測試》;2、《
    發(fā)表于 10-20 12:06 ?51次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>測試</b>參考書籍

    嵌入式軟件怎樣測試,如何對嵌入式軟件進行可靠測試

    摘 要 本文針對目前嵌入式軟件設(shè)計可靠測試用例的手段主要依靠手工分析,沿用傳統(tǒng)的軟件測試用例設(shè)
    發(fā)表于 10-20 15:21 ?8次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>怎樣<b class='flag-5'>測試</b>,如何對<b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>進行可靠<b class='flag-5'>性</b><b class='flag-5'>測試</b>

    嵌入式軟件測試研究意義,嵌入式軟件測試的研究

    摘要:嵌入式系統(tǒng)在人類生活中發(fā)揮著重要的作用,包括飛行控制器這樣的控制系統(tǒng),以及洗衣機這樣的家用電器。日前,嵌入式系統(tǒng)中軟件的比重越來越大,也越來越復(fù)雜,保證嵌入式
    發(fā)表于 10-20 17:20 ?17次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>測試</b>研究意義,<b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>測試</b>的研究

    測試嵌入式軟件測試VS一般軟件測試

    嵌入式軟件測試的復(fù)雜多樣3.3 嵌入式軟件測試中對實時
    發(fā)表于 10-21 13:06 ?31次下載
    【<b class='flag-5'>測試</b>】<b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>測試</b>VS一般<b class='flag-5'>軟件</b><b class='flag-5'>測試</b>

    幾款常見的嵌入式軟件測試工具

    說起嵌入式軟件測試,我們先快速了解一下嵌入式軟件自身的特點。嵌入式
    的頭像 發(fā)表于 02-14 15:50 ?7859次閱讀
    幾款常見的<b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b><b class='flag-5'>測試</b>工具

    影響電源紋波測試準確性的因素

    電源紋波測試是評估電源質(zhì)量的重要手段之一,它能夠反映出電源在輸出電壓中的波動情況。然而,測試過程中的多種因素都可能對測試結(jié)果的準確性產(chǎn)生影響。本文將從多個方面分析影響電源紋波
    的頭像 發(fā)表于 08-02 09:42 ?1193次閱讀

    如何提高OTDR測試準確性

    OTDR(光時域反射儀)是光纜線路故障定位和光纖特性測量的重要工具,提高OTDR測試準確性對于確保光纜線路的穩(wěn)定運行至關(guān)重要。以下是一些提高OTDR
    的頭像 發(fā)表于 12-31 09:25 ?1079次閱讀
    主站蜘蛛池模板: 在线免费看影视网站 | 永久免费看的啪啪网站 | 国产在线小视频 | 高清毛片一区二区三区 | 欧美色综合高清免费 | yy6080理aa级伦大片一级 | 天天干天天操天天碰 | 国产网站在线 | 夜夜福利 | 日本黄段视频 | 久久精品国产免费中文 | 女人张开腿等男人桶免费视频 | 一区二区三区亚洲 | 高清不卡日本v在线二区 | 四虎最新入口 | 五月婷婷久久综合 | 人人澡人人人人夜夜爽 | 不良视频在线观看 | 国产精品资源在线观看网站 | 6080yy午夜不卡一二三区 | 让她爽的喷水叫爽乱 | 天天爽天天爽天天片a久久网 | 婷婷丁香激情五月 | 亚州色图欧美色图 | 国内精品久久久久久影院老狼 | 亚洲网站在线观看 | 国产成人综合久久 | 国产jzjzjz免费大全视频 | 欧美色图网站 | 国产男靠女免费视频网站 | 91大神精品长腿在线观看网站 | ts人妖在线观看 | 综合婷婷丁香 | 特级毛片免费视频播放 | 黄色美女网址 | 同性同男小说肉黄 | 久久影院午夜伦手机不四虎卡 | 欧美视频图片 | 日韩成人一级 | 五月sese| 欧美成人午夜 |