當(dāng)前位置:首頁 > 嵌入式 > 嵌入式硬件

為了確保程序運行一切正常,我們重新運行整個分析過程。首先,我們開啟運行時內(nèi)存監(jiān)測并運行應(yīng)用程序,一切表現(xiàn)正常。然后我們開啟內(nèi)存監(jiān)測并運行單元測試,一個任務(wù)被報告出來:


  我們的單元測試檢測到reportSensorFailure()函數(shù)的行為已經(jīng)發(fā)生了改變。這是由于我們已經(jīng)對finalize()函數(shù)進行了修改——為了糾正之前報告的一個問題所做的修改。此處報告的任務(wù)是為了讓我們注意此修改,并提示我們應(yīng)該對測試用例進行相應(yīng)的審查,并且確定是否應(yīng)該對代碼或者測試用例進行相應(yīng)的修改,以表示這種新的行為實際上是我們所預(yù)期的行為。在檢查完代碼之后,我們發(fā)現(xiàn)后者(修改)是正確的并且應(yīng)該更新斷言的正確條件。

  /* CPPtest_TEST_CASE_BEGIN test_reportSensorFailure */

  /* CPPTEST_TEST_CASE_CONTEXT void reportSensorFailure(void) */

  void sensor_tests_test_reportSensorFailure()

  {

  /* Pre-condition initialization */

  /* Initializing global variable messages */

  {

  messages = 0 ;

  }

  {

  /* Tested function call */

  reportSensorFailure();

  /* Post-condition check */

  CPPTEST_ASSERT(0 == ( messages ));

  }

  }

  /* CPPTEST_TEST_CASE_END test_reportSensorFailure */

  作為最終的確認,我們需要獨立地運行整個程序——在IDE中關(guān)閉掉運行時內(nèi)存監(jiān)測來對程序進行構(gòu)建。結(jié)果顯示一切如我們所預(yù)期一樣運行。

  總結(jié)

  作為全文的結(jié)尾,讓我們一起對上述各個步驟進行一個鳥瞰式的總結(jié)。

  首先,我們開發(fā)的程序并未如我么所預(yù)期那樣運行,我們不得不在兩種解決方法中選擇一種來查找程序中的錯誤:通過運行調(diào)試器或者使用自動錯誤檢測技術(shù)。

  如果我們使用調(diào)試器運行代碼來查找錯誤,我們將會看到一些很奇怪的現(xiàn)象:程序中的一些變量總是被賦予了相同的值?;谶@種現(xiàn)象我們不得不通過排除法來查找問題的原因——即在應(yīng)該使用比較運算符的地方我們錯誤地使用了賦值運算符。而靜態(tài)代碼分析則能為我們自動地檢查出該邏輯錯誤。運行時內(nèi)存分析是不可能檢查出這種錯誤的,因為這種錯誤與內(nèi)存無關(guān)。數(shù)據(jù)流分析也很有可能找不到這類錯誤因為數(shù)據(jù)流分析僅僅是通過這些路徑而不會驗證這些條件的正確性。

  當(dāng)我們解決了這個問題后,程序可以運行了,但是仍然還有內(nèi)存相關(guān)的問題。內(nèi)存相關(guān)的問題是很難被調(diào)試器發(fā)現(xiàn)的;當(dāng)用戶使用調(diào)試器調(diào)試程序時,用戶并不知道內(nèi)存的實際大小。但是自動錯誤檢查工具能夠做到這點。因此,為了查找這些內(nèi)存問題,我們將整個程序進行插裝,并使用運行時內(nèi)存分析工具來運行程序。這樣我們就能知道到底是那一片內(nèi)存發(fā)生了寫溢出錯誤。

  盡管如此,在審查覆蓋率分析結(jié)果的時候,我們注意到在目標(biāo)板上測試的時候,并不是全部代碼都被覆蓋到了。通過自動化的工具得到這樣的覆蓋率信息是簡單的,因為工具會自動地

  跟蹤覆蓋率,但是,如果我們是通過調(diào)試器,就不得不判斷哪一部分程序經(jīng)過了驗證。而這通常只能依靠我們?nèi)斯び涗浀姆绞絹韺崿F(xiàn)。

  當(dāng)工具提醒我們一些代碼未被覆蓋到時,我們決定改變單元測試來額外地增加我們測試執(zhí)行的覆蓋率。這就揭示了程序中另外一些問題。在目標(biāo)系統(tǒng)的正常測試中,覆蓋所有函數(shù)也許是不可能完成的任務(wù),因為其中一些函數(shù)可能是硬件的失敗處理函數(shù)或僅在某些小概率的特定情況下才會被調(diào)用的函數(shù)。而對這些函數(shù)的測試對于一些注重安全性的程序而言又是至關(guān)重要的。試想在飛機上用來處理速度傳感器問題的程序中存在著代碼錯誤:我們會有系統(tǒng)崩潰的危險,而不是導(dǎo)致某個設(shè)備為非工作狀態(tài)。因此,通過創(chuàng)建單元測試用例來覆蓋這類型的執(zhí)行路徑往往是對其進行有效測試的唯一方法。

  接下來,我們修復(fù)了工具檢查到的所有問題,同時通過驗證相應(yīng)的結(jié)果創(chuàng)建了一個回歸測試用例(作為報告的任務(wù)之一引導(dǎo)我們完成)。然后我們運行數(shù)據(jù)流分析來覆蓋在目標(biāo)系統(tǒng)上即便使用單元測試也未執(zhí)行到的路徑。在此之前,我們幾乎已經(jīng)達到了100%的代碼行覆蓋率,但是我們的路徑覆蓋率卻未達到這個水平。BugDetective幫我們發(fā)現(xiàn)了這些方面的一些潛在問題。這些問題可能并沒有實際發(fā)生或者有可能永遠不會發(fā)生。也許在實際運行時,這些問題僅僅會在當(dāng)其條件滿足的情況下才會出現(xiàn),并且在現(xiàn)實生活中,這些條件可能永遠不可能滿足。盡管如此,我們不能保證隨著代碼的升級,應(yīng)用程序不會執(zhí)行到這些路徑。

  安全起見,我們?nèi)匀恍薷牧怂鶊蟾娴膯栴}以排除任何可能影響它的實際應(yīng)用執(zhí)行的風(fēng)險。在修改代碼的同時,我們同時也引入了回歸測試,當(dāng)我們再次運行單元測試時立即被檢測到。在所有的自動化錯誤檢測方法中,回歸測試是唯一能夠幫助我們檢查到代碼是否發(fā)生了功能性的改變的方法,并且能驗證出對代碼進行的修改是否引入了功能性的錯誤以及不可預(yù)知的副作用。最后,我們修改了回歸測試套件,并重新測試代碼,發(fā)現(xiàn)一切運行正常。

  正如讀者所見,我們使用的一切測試方法——基于模式的靜態(tài)代碼分析、內(nèi)存分析、單元測試、數(shù)據(jù)流分析以及回歸測試——并不是相互競爭的關(guān)系,恰好相反,它們是一種互補的關(guān)系。將上述工具結(jié)合使用,它們就是一套具有強大作用的工具集,并為嵌入式C語言程序/軟件提供一個無可比擬的自動化錯誤檢測解決方案。

  總而言之,通過自動地查找很多關(guān)于內(nèi)存和其它編碼的缺陷,我們成功地讓程序運行起來了。盡管如此,值得注意的是,最危險的缺陷卻是實際的功能性錯誤:例如程序并未如所指定的要求運行。而不幸的是,這些錯誤往往是非常難以被發(fā)現(xiàn)的。

  查找這類缺陷的最好的一個方式就是通過同行代碼審查來實現(xiàn)。即另指派至少一人來檢查代碼并且審查代碼與需求內(nèi)容的一致性,這樣用戶就能對實際程序是否會如預(yù)期那樣運行有一個很好的*估。

  另外一個十分有用的策略是圍繞代碼創(chuàng)建一個回歸測試套件,這能幫助用戶快捷地驗證代碼與規(guī)范的一致性。在本文所描述的示例情景中,單元測試被用來強制執(zhí)行應(yīng)用程序級的運行時內(nèi)存監(jiān)測所未覆蓋到的代碼:它能覆蓋到當(dāng)前程序的功能性,在此之后,我們對代碼做了一些修改,它能提醒我們代碼出現(xiàn)的相應(yīng)的功能性問題。事實上,這種單元測試用例應(yīng)該被更早地創(chuàng)建起來:理想情況下,當(dāng)用戶在實現(xiàn)程序的功能時就應(yīng)該被創(chuàng)建起來。這樣,用戶就能得到更高的覆蓋率并同時構(gòu)建起一個更強壯的“安全網(wǎng)”來捕捉關(guān)鍵的功能性改變。

  Parasoft的C++test能幫助用戶完成這兩個任務(wù):從自動化到管理同行代碼審查流程,以及幫助團隊創(chuàng)建,持續(xù)地運行并維護一個高效的回歸測試套件。

  關(guān)于Parasoft C++test

  Parasoft C++test是一個經(jīng)廣泛的最佳實踐證明能提升軟件開發(fā)團隊開發(fā)效率以及軟件質(zhì)量的自動化集成解決方案。C++test能進行諸如編碼策略增強、靜態(tài)代碼分析、運行時內(nèi)存監(jiān)測、自動同行代碼審查以及單元和組件測試,從而為軟件開發(fā)團隊提供一種更加實用的方法來確保其C以及C++程序能如所預(yù)期那樣工作。C++test可以用于在通用開發(fā)IDE下的桌面平臺中,以及在回歸測試時通過命令行以批處理模式的方式運行。同時,C++test還集成了Parasoft的報告系統(tǒng),該系統(tǒng)能提供具有細分能力的基于Web 的儀表板,這使得開發(fā)團隊根據(jù)C++test的測試結(jié)果和其他的一些關(guān)鍵進程指標(biāo)來更加方便地跟蹤項目的狀態(tài)和趨勢。

  通過在宿主機上進行大量的測試以及在目標(biāo)系統(tǒng)中進行的平滑的驗證,C++test能夠幫助軟件開發(fā)團隊減少花在嵌入式系統(tǒng)開發(fā)中的時間、精力以及成本。隨著代碼在宿主機上的構(gòu)建,C++test的自動化框架使得開發(fā)者能在目標(biāo)硬件系統(tǒng)尚未準(zhǔn)備好的情況下就開始測試以提升代碼質(zhì)量。這大大地縮短了花在目標(biāo)系統(tǒng)上測試的時間。早期在宿主機上構(gòu)建的測試套件可以被重用來在仿真器或真實的目標(biāo)板上驗證程序的功能性。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉