嵌入式系統(tǒng)TDD策略

目標硬件的瓶頸

目標硬件

產(chǎn)品代碼最終運行的硬件載體

目標硬件的瓶頸

軟件只能在目標硬件上運行灭抑,將面臨一些瓶頸:

  • 硬件就緒后于軟件開發(fā)玲献,推遲了軟件測試;
  • 目標硬件本身需要調(diào)試驗證,疊加軟件的調(diào)試驗證很泊,調(diào)試驗證困難度增加努咐;
  • 系統(tǒng)的構(gòu)建和上傳普遍漫長

那如何解決硬件瓶頸問題呢苦蒿?

  • 傳統(tǒng)手段:開發(fā)板
    可以解決項目早期硬件未到位及部分調(diào)試驗證問題,但未解決系統(tǒng)構(gòu)建上傳漫長等問題渗稍;
  • 更為有效的手段:雙目標開發(fā)

雙目標開發(fā)

  • 雙目標:目標硬件佩迟、開發(fā)系統(tǒng)
    • 代碼從第一天就設(shè)計成至少在兩個平臺上運行

雙目標好處:

  • 硬件就緒之前就能測試代碼
  • 避免硬件和軟件同時調(diào)試
  • 幫助設(shè)計
    • 更關(guān)注軟硬件的邊界,軟硬件解耦
  • 快速移植到新硬件竿屹,自動化單元測試驗證

雙目標測試的風(fēng)險:

  • 編譯特性报强、語言特性不同
  • 基本數(shù)據(jù)類型可能不同
  • 字節(jié)序及數(shù)據(jù)結(jié)構(gòu)對齊可能不同

如何降低雙目標測試風(fēng)險?

開發(fā)系統(tǒng)盡量選用與目標硬件相同的編譯拱燃、語言秉溉、數(shù)據(jù)類型、字節(jié)序及對齊等

嵌入式的TDD循環(huán)

  • 平臺1: TDD微循環(huán)
    • 寫通用軟件
    • 隔離硬件和軟件
    • 頻繁運行
  • 平臺2: 目標編譯器兼容性檢查
    • 每次采用新的語言特性時編譯
    • 這可以提醒你一些移植性問題,比如有些頭文件沒有召嘶、不兼容的或者缺失的語言特性父晶。
  • 平臺3: 評估板上運行單元測試
    • 一直保持在評估板上運行的能力
    • 前期可用于評估在目標硬件上的效果
    • 后期可用于排除目標硬件可疑行為
  • 平臺4:在目標硬件上運行單元測試
    • 若內(nèi)存不能一次性裝入所有測試,可以分割成多組測試套件弄跌,分批裝入測試
  • 平臺5: 在目標硬件上運行驗收測試
    • 手工測試不能完全被自動化的依賴于硬件的代碼

雙目標的不兼容性

如何處理與平臺相關(guān)的不兼容性甲喝?

  • 共用接口、獨立實現(xiàn)(共用頭文件铛只、分平臺獨立目錄及源文件)
  • 每個平臺有一個目錄保存與平臺相關(guān)的代碼
  • 利用編譯器和鏈接器

和硬件一起測試

和硬件一起的測試應(yīng)該自動化
3種可能的硬件測試:

  • 自動化硬件測試
  • 部分自動化硬件測試
    • 有效地最小化依賴于硬件的代碼埠胖,并手工測試
  • 利用外部設(shè)備的自動化硬件測試
    外部設(shè)備對目標系統(tǒng)進行一些輸入,測試目標硬件的輸出是否符合預(yù)期淳玩。
    比如LED硬件亮滅可能需要人工的半自動化測試押袍,若有外部工具可以對其LED控制,并有相應(yīng)LED效果的捕獲手段即可完成全自動化的測試凯肋。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谊惭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子侮东,更是在濱河造成了極大的恐慌圈盔,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悄雅,死亡現(xiàn)場離奇詭異驱敲,居然都是意外死亡,警方通過查閱死者的電腦和手機宽闲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門众眨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人容诬,你說我怎么就攤上這事娩梨。” “怎么了览徒?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵狈定,是天一觀的道長。 經(jīng)常有香客問我习蓬,道長纽什,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任躲叼,我火速辦了婚禮芦缰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘枫慷。我一直安慰自己让蕾,他們只是感情好浪规,可當我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著涕俗,像睡著了一般罗丰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上再姑,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天萌抵,我揣著相機與錄音,去河邊找鬼元镀。 笑死绍填,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的栖疑。 我是一名探鬼主播讨永,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼遇革!你這毒婦竟也來了卿闹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤萝快,失蹤者是張志新(化名)和其女友劉穎锻霎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體揪漩,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡旋恼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了奄容。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冰更。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖昂勒,靈堂內(nèi)的尸體忽然破棺而出蜀细,到底是詐尸還是另有隱情,我是刑警寧澤叁怪,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布审葬,位于F島的核電站,受9級特大地震影響奕谭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜痴荐,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一血柳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧生兆,春花似錦难捌、人聲如沸膝宁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽员淫。三九已至,卻和暖如春击敌,著一層夾襖步出監(jiān)牢的瞬間介返,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工沃斤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留圣蝎,地道東北人。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓衡瓶,卻偏偏與公主長得像徘公,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子哮针,可洞房花燭夜當晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容