日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

代碼的黑盒測試(下)|?庫接口測試Library Interface Testing

北匯信息POLELINK ? 2022-08-04 14:37 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

書接上回:代碼的黑盒測試(上)|目標(biāo)文件測試Object File Testing,我們首先介紹了編譯的基本過程——預(yù)處理(Prepressing)、編譯(compile)、匯編(Assembly)和鏈接(Linking),然后著重介紹了代碼黑盒測試的第一種方法——VectorCAST/C++的目標(biāo)文件的測試方法,解決了在無可用源代碼的情況下,對其相應(yīng)目標(biāo)文件的測試。

其實(shí)一個(gè)代碼工程除了開發(fā)人員手寫代碼外,還包含了很多庫文件,甚至有的庫文件或是經(jīng)過開發(fā)人員修改或是直接由開發(fā)人員編寫的。那么對于這些文件又該如何測試呢?請看如下分解!

一、庫接口測試

(一)庫文件

這里的“庫”,就是庫文件,一般是指編譯好的二進(jìn)制文件,用于在鏈接階段與目標(biāo)文件一起生成可執(zhí)行文件,或者運(yùn)行可執(zhí)行文件的時(shí)候被加載,以便調(diào)用庫文件中的某段代碼。

與可執(zhí)行文件不同的是,庫文件無法直接執(zhí)行。直觀上來看,庫文件的源代碼中沒有main函數(shù),而只是一些函數(shù)模塊的定義和實(shí)現(xiàn),沒有運(yùn)行的入口主函數(shù),無法直接執(zhí)行。

(二)靜態(tài)庫與動(dòng)態(tài)庫

庫文件可分為靜態(tài)庫和動(dòng)態(tài)庫。它們區(qū)別主要體現(xiàn)在程序的鏈接階段——靜態(tài)庫的代碼是在編譯過程中被載入程序中的,這就說明,只要程序編譯完成,程序就不受靜態(tài)庫的影響;動(dòng)態(tài)庫的代碼在編譯的時(shí)候并沒有被編譯進(jìn)入程序中,只是在程序運(yùn)行時(shí)根據(jù)程序需要?jiǎng)討B(tài)的加載到內(nèi)存中。

(三)相關(guān)文件的一些擴(kuò)展名

  1. win32平臺(tái)下,靜態(tài)庫通常后綴為.lib,動(dòng)態(tài)庫為.dll。
  2. Linux平臺(tái)下,靜態(tài)庫通常后綴為.a,動(dòng)態(tài)庫為.so。

從本質(zhì)上來說,由同一段程序編譯出來的靜態(tài)庫和動(dòng)態(tài)庫,在功能上是沒有區(qū)別的;不同之處僅僅在于其名字上,也就是“靜態(tài)”和“動(dòng)態(tài)”。開發(fā)人員只需要將.h/.hpp頭文件和.lib/.so文件提交給其他開發(fā)人員,他們就可以直接使用.lib/.so文件中定義的函數(shù)了。靜態(tài)庫和動(dòng)態(tài)庫的具體使用由開發(fā)人員決定。

(四)庫接口測試

庫接口測試允許客戶在沒有可用源代碼的情況下,對現(xiàn)有庫文件創(chuàng)建測試。在測試時(shí),可以將第三方庫或者被修改的第三方庫作為一個(gè)對象庫文件和API定義(頭文件)??梢詾锳PI創(chuàng)建測試用例,來驗(yàn)證應(yīng)用程序庫函數(shù)的正確性,而無需訪問源代碼。

在代碼開發(fā)中,通常會(huì)將一些常用的函數(shù)封裝成一個(gè)庫,提供接口給其它程序文件調(diào)用,省去重復(fù)寫該函數(shù)接口。當(dāng)使用該函數(shù)時(shí),只需要直接將所需要的文件鏈接到程序中即可,大大提高了開發(fā)效率。依照這個(gè)原理,我們也可以針對一些代碼程序根據(jù)測試需要,將某些源代碼編譯生成相應(yīng)的靜態(tài)庫文件或動(dòng)態(tài)庫文件,以完成代碼功能測試。

二、利用VectorCAST/C++進(jìn)行庫接口測試

對于如何使用VectorCAST/C++進(jìn)行靜態(tài)庫或者動(dòng)態(tài)庫的單元測試,下面我們?nèi)允褂蒙掀恼轮械狞c(diǎn)餐服務(wù)程序(采用GCC編譯鏈),來具體說明。

(一)點(diǎn)餐服務(wù)程序的結(jié)構(gòu)內(nèi)容及說明

poYBAGLrOgiASp3RAAB36SL_x2w424.png

poYBAGLrOhCAF5n2AACE58UQyqM954.png

圖 1點(diǎn)餐服務(wù)程序的結(jié)構(gòu)內(nèi)容及說明

(二)利用VectorCAST/C++進(jìn)行靜態(tài)庫接口測試

1、靜態(tài)庫文件的生成

對于這個(gè)點(diǎn)餐主程序manager_driver.c,我們可以將manager.c和database.c分別作為一個(gè)調(diào)用的庫文件來使用,也可以一起作為一個(gè)調(diào)用的庫文件來使用。本例中,將manager.c和database.c一起作為一個(gè)調(diào)用的庫文件來使用。

使用一個(gè)BAT腳本生成靜態(tài)庫文件,腳本內(nèi)容如下:

set path=%VECTORCAST_DIR%\mingw\bin;%PATH%

gcc -c manager.c

gcc -c database.c

ar rcs manager_driver.lib manager.o database.o

說明:無論靜態(tài)庫,還是動(dòng)態(tài)庫,都是在*.o目標(biāo)文件基礎(chǔ)上生成的。

2、環(huán)境構(gòu)建基本過程

VectorCAST環(huán)境構(gòu)建的基本過程在代碼的黑盒測試(上)|目標(biāo)文件測試Object File Testing有詳細(xì)說明,這里不再贅述,對于不同的以及需要注意的地方,有如下說明:

本例中,我們是利用manager.c和database.c一起生成靜態(tài)庫文件manager_driver.lib的,所以在構(gòu)建測試環(huán)境的第3步需要選擇“庫接口測試方法”并在“Link Options”添加該文件及所在路徑,如圖2所示。同時(shí)在構(gòu)建測試環(huán)境的第6步添加需要的頭文件,有manager.h和database.h,如圖3所示。

pYYBAGLrOi-AB43LAAGSTnfVKnk986.png

圖2選擇添加靜態(tài)庫文件manager_driver.lib

poYBAGLrOjWAdYEGAADByjzH0Gc062.png

圖3選擇添加頭文件manager.h或database.h

3、測試用例編寫與執(zhí)行

按照上述說明成功構(gòu)建測試環(huán)境。編寫測試用例及執(zhí)行測試用例,結(jié)果如下圖4所示。

poYBAGLrOlSAEjWuAABhkE54dEQ448.png

pYYBAGLrOl2AQHHJAAEKsv_XNSM597.png

圖4測試用例編寫與執(zhí)行

細(xì)心的小伙伴可以注意到上圖左邊部分只有顯示了執(zhí)行狀態(tài)圖標(biāo),因?yàn)槲覀儾捎玫脑摲N測試屬于黑盒測試方法,所以我們在構(gòu)建環(huán)境的第4步,沒有勾選“Whitebox”前面的復(fù)選框,自然也沒有結(jié)構(gòu)覆蓋度圖標(biāo)。

(三)利用VectorCAST/C++進(jìn)行動(dòng)態(tài)庫接口測試

1、動(dòng)態(tài)庫文件的生成

與靜態(tài)庫文件生成類似,將manager.c和database.c一起作為一個(gè)調(diào)用的動(dòng)態(tài)庫文件來使用。

使用一個(gè)BAT腳本生成動(dòng)態(tài)庫文件,腳本內(nèi)容如下:

set path=%VECTORCAST_DIR%\mingw\bin;%PATH%

gcc -c -fPIC manager.c -o manager_dyn.o

gcc -c -fPIC database.c -o database_dyn.o

gcc manager_dyn.o database_dyn.o -shared -o libmanager_drive.dll

2、環(huán)境構(gòu)建基本過程

動(dòng)態(tài)庫接口測試與靜態(tài)庫接口測試基本一致,不同的地方如下說明:

此例中,我們?nèi)岳胢anager.c和database.c一起生成動(dòng)態(tài)庫文件manager_driver.dll,所以在構(gòu)建測試環(huán)境的第3步選擇“庫接口測試方法”并在“Link Options”添加該動(dòng)態(tài)庫dll文件,如圖5所示。后面的操作與靜態(tài)庫接口測試一致,故不在贅述。

poYBAGLrOoWAQ7btAAEuGA59J2E457.png

圖5選擇添加動(dòng)態(tài)庫文件manager_driver.dll

三、總結(jié)

本文提供了代碼黑盒測試的第二種方法——庫接口測試,可以利用工具為API創(chuàng)建測試用例,來驗(yàn)證應(yīng)用程序庫函數(shù)的正確性,而無需訪問源代碼,感興趣的同學(xué)可以嘗試下。

VectorCAST/C++作為Vector公司的代碼動(dòng)態(tài)測試工具,支持自動(dòng)生成測試用例,提供完善的覆蓋度信息,還可以與Git/SVN/Jekins等工具集成等等;后續(xù)也會(huì)為大家?guī)砀嗷赩ectorCAST/C++的動(dòng)態(tài)測試相關(guān)內(nèi)容;同時(shí)也歡迎垂詢和溝通,共同探討測試相關(guān)問題。

北匯信息作為Vector中國的合作伙伴,始終專注于汽車電子領(lǐng)域的新技術(shù)和新產(chǎn)品,為整車廠和零部件企業(yè)提供完整的研發(fā)、測試解決方案,為工程師在汽車領(lǐng)域提供“趁手裝備“!

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

    關(guān)注

    9

    文章

    6429

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    PROFINET-RT使用 ETS 進(jìn)行一致性測試

    指示器看起來像綠色勾號(hào),則一致性測試已準(zhǔn)備就緒。請選擇必要的測試用例并按開始按鈕。 謹(jǐn)慎:根據(jù)ETS HW手冊,運(yùn)行4小時(shí)后,接口時(shí)鐘可以跳轉(zhuǎn)。因此,ETS 應(yīng)在 4 小時(shí)過去之前重
    發(fā)表于 04-23 12:51

    醫(yī)療電子設(shè)備測試 | 人機(jī)交互 + 傳感器接口 + 執(zhí)行控制 協(xié)同測試方案

    醫(yī)療電子設(shè)備測試 | 人機(jī)交互 + 傳感器接口 + 執(zhí)行控制 協(xié)同測試方案
    的頭像 發(fā)表于 03-27 13:46 ?237次閱讀
    醫(yī)療電子設(shè)備<b class='flag-5'>測試</b> | 人機(jī)交互 + 傳感器<b class='flag-5'>接口</b> + 執(zhí)行控制 協(xié)同<b class='flag-5'>測試</b>方案

    PCB板焊點(diǎn)高低溫環(huán)境強(qiáng)度測試|推拉力測試機(jī)選型指南+實(shí)測演示

    在汽車電子、工控設(shè)備及消費(fèi)電子領(lǐng)域,PCB焊點(diǎn)的機(jī)械強(qiáng)度直接決定了產(chǎn)品在振動(dòng)、沖擊及熱循環(huán)工況的服役壽命,焊點(diǎn)推力測試是量化焊接質(zhì)量的核心手段。本文我們將基于科準(zhǔn)測控Beta-S100推拉力測試
    的頭像 發(fā)表于 03-06 11:07 ?224次閱讀
    PCB板焊點(diǎn)高低溫環(huán)境<b class='flag-5'>下</b>強(qiáng)度<b class='flag-5'>測試</b>|推拉力<b class='flag-5'>測試</b>機(jī)選型指南+實(shí)測演示

    Labview接口interface)的工作過程

    UI actor, 用來做數(shù)據(jù)和狀態(tài)顯示 3、創(chuàng)建一個(gè)random Actor,用來產(chǎn)生隨機(jī)數(shù)據(jù)。 4、創(chuàng)建一個(gè).Livb,在庫中,創(chuàng)建一個(gè)接口對象interface。 注:接口對象
    發(fā)表于 02-03 11:07

    代碼ATE測試系統(tǒng),輕松完成LED電源模塊的自動(dòng)化測試

    一、案例概述 零代碼ATE測試系統(tǒng)賦能湖南某電子科技公司,針對其 LED 電源研發(fā)測試階段 “手動(dòng)測試效率低、方案調(diào)整不靈活、數(shù)據(jù)分析需求迫切” 的核心問題,提供定制化自動(dòng)化
    的頭像 發(fā)表于 12-22 19:50 ?506次閱讀
    零<b class='flag-5'>代碼</b>ATE<b class='flag-5'>測試</b>系統(tǒng),輕松完成LED電源模塊的自動(dòng)化<b class='flag-5'>測試</b>

    創(chuàng)建一個(gè)Library工程

    -&gt; Empty Project,工具鏈選擇RISC-V Cross GCC,具本如下圖 創(chuàng)建一個(gè)Library工程工程 將Library文件放入工程中,并點(diǎn)擊工程,右鍵 在設(shè)置
    發(fā)表于 10-20 09:30

    淘寶商品的API接口測試

    前兩天我們簡單的說了一些現(xiàn)有的幾大電商平臺(tái),現(xiàn)在我們來介紹API接口測試操作。 使用說明: 首先需要開放平臺(tái)注冊賬號(hào)并創(chuàng)建應(yīng)用,獲取 App Key 和 App Secret 將代碼
    的頭像 發(fā)表于 10-08 09:22 ?544次閱讀

    嵌入式軟件測試與專業(yè)測試工具的必要性深度解析

    。專業(yè)工具通過虛擬化硬件接口(如GPIO、CAN總線),允許開發(fā)者在早期驗(yàn)證代碼邏輯,實(shí)現(xiàn)軟硬件并行開發(fā)。例如,硬件在環(huán)(HIL)測試通過FPGA模擬硬件時(shí)序,盡管設(shè)備成本較高,但能顯著提高
    發(fā)表于 09-28 17:42

    測試小白3分鐘上手,零代碼自動(dòng)化測試平臺(tái),15分鐘搭建自動(dòng)化測試方案

    還在為不懂代碼、搭建測試方案耗時(shí)久而發(fā)愁?ATECLOUD 零代碼自動(dòng)化測試平臺(tái),專為自動(dòng)化測試量身打造,小白3 分鐘就能輕松上手,15 分
    的頭像 發(fā)表于 09-22 17:52 ?1052次閱讀
    <b class='flag-5'>測試</b>小白3分鐘上手,零<b class='flag-5'>代碼</b>自動(dòng)化<b class='flag-5'>測試</b>平臺(tái),15分鐘搭建自動(dòng)化<b class='flag-5'>測試</b>方案

    Simulink模型測試典型問題分享-接口定義不完整

    典型測試問題分享-接口定義不完整 問題描述: ?計(jì)算模塊未定義數(shù)值范圍,存在越界風(fēng)險(xiǎn)。 ?信號(hào)未規(guī)定精度和誤差范圍,導(dǎo)致背靠背測試未通過。
    的頭像 發(fā)表于 09-22 15:40 ?1248次閱讀
    Simulink模型<b class='flag-5'>測試</b>典型問題分享-<b class='flag-5'>接口</b>定義不完整

    邊聊安全 | 軟件單元測試的設(shè)計(jì)方法

    上海磐時(shí)PANSHI“磐時(shí),做汽車企業(yè)的安全智”軟件單元測試的設(shè)計(jì)方法寫在前面:軟件單元測試的設(shè)計(jì)是一個(gè)系統(tǒng)化的過程,旨在驗(yàn)證代碼的最小可測試
    的頭像 發(fā)表于 09-05 16:18 ?9806次閱讀
    邊聊安全 | 軟件單元<b class='flag-5'>測試</b>的設(shè)計(jì)方法

    芯片硬件測試用例

    用例是項(xiàng)目開始的關(guān)鍵,利用白盒和黑盒覆蓋,保證產(chǎn)品質(zhì)量。根據(jù)芯片功能,目標(biāo)市場,進(jìn)行測試立項(xiàng):依據(jù)BRD/MRD/PRD;計(jì)劃:測試需求分析、人力資源時(shí)間線;測試用例設(shè)
    的頭像 發(fā)表于 09-05 10:04 ?1223次閱讀
    芯片硬件<b class='flag-5'>測試</b>用例

    LambdaTest推出全球首個(gè)AI智能體測試平臺(tái)

    領(lǐng)先的AI原生測試平臺(tái)LambdaTest已推出其智能體對智能體測試(Agent-to-Agent Testing)平臺(tái)的封閉測試版。這是全球首個(gè)專為驗(yàn)證與評估AI智能體而設(shè)計(jì)的平臺(tái)。
    的頭像 發(fā)表于 08-26 17:37 ?1192次閱讀

    Green Testing Lab聯(lián)合CSM開展電池溫度測試

    ,奧地利的Green Testing Lab聯(lián)合CSM,在此類極端工況開展電池溫度測試,致力于在開發(fā)早期提出改進(jìn)措施,有效降低潛在安全風(fēng)險(xiǎn)。
    的頭像 發(fā)表于 08-26 11:46 ?1103次閱讀

    “System Level EOS Testing Method”可以翻譯為: “系統(tǒng)級電性過應(yīng)力測試方法”

    “System Level EOS Testing Method”可以翻譯為: “系統(tǒng)級電性過應(yīng)力測試方法”
    的頭像 發(fā)表于 05-05 15:55 ?1123次閱讀
    “System Level EOS <b class='flag-5'>Testing</b> Method”可以翻譯為: “系統(tǒng)級電性過應(yīng)力<b class='flag-5'>測試</b>方法”
    灌阳县| 循化| 孟津县| 苏州市| 夏河县| 湖南省| 普宁市| 东阳市| 紫云| 山西省| 丹阳市| 余江县| 昌邑市| 汽车| 宜良县| 竹山县| 库伦旗| 离岛区| 华蓥市| 东至县| 容城县| 陵川县| 手游| 唐海县| 博乐市| 调兵山市| 宣武区| 双鸭山市| 靖远县| 临安市| 涟源市| 乳源| 丰县| 大悟县| 开鲁县| 临高县| 丹巴县| 兴国县| 临澧县| 武安市| 天峻县|