作者 | zh小編 | 吃不飽上回系列文章《基于ODX診斷測試開發(fā)(1): ODX數(shù)據(jù)庫剖析》簡單介紹了ODX文件類型及各個文件層級結構,本期我們來詳細介紹下ODX數(shù)據(jù)庫如何解析。
在展開正文之前,先說明一下,此文介紹的解析ODX數(shù)據(jù)庫的目的所在。針對涉及診斷功能類(如DTC等)測試的項目,實現(xiàn)過程大致為兩步:先通過CANoe-CAPL完成通用的診斷功能測試腳本的開發(fā);當針對具體ECU實施測試時,依據(jù)該ECU的診斷數(shù)據(jù)表,完成上述通用腳本的參數(shù)配置,可以手動配置(效率較低)或通過解析診斷數(shù)據(jù)表完成自動配置。過往項目中,診斷數(shù)據(jù)表既有Excel表格也有ODX格式。為此,北匯開發(fā)了診斷數(shù)據(jù)表的解析模塊(支持Excel和ODX格式),實現(xiàn)對測試腳本參數(shù)的自動配置,從而提高效率。
01ODX實現(xiàn)方式
ODX使用統(tǒng)一建模語言UML類圖來描述的,ODX數(shù)據(jù)又是通過XML文件格式來儲存的。我們知道類包含屬性和方法,同時具有封裝、繼承、多態(tài)等特點。那么如何將UML映射為XML呢?ISO22901-1規(guī)范做出如下規(guī)定:
規(guī) 定
將UML類映射為XML的元素; 如果UML中類的屬性有《attr》標記,則將該屬性映射為XML元素的屬性;如果UML中類的屬性無《attr》標記,則映射為XML元素的子元素。如果UML屬性有《content》標記,則映射為XML元素的內容; 如果類B通過Aggregation和composition和類A建立聯(lián)系,則類B映射為XML 類A元素的子元素; 如果類B通過association和類A產(chǎn)生關聯(lián),則在XML中通常以引用的方式實現(xiàn),如《snref》,《snpathref》或《odxlink》; UML類圖中的繼承關系,在XML中以的方式實現(xiàn);注:Aggregation、composition和association為UML類圖之間的關系,在這里不做詳細介紹。
圖1和圖2就是根據(jù)以上規(guī)則,將UML轉化為XML的例子。圖1
圖2
02ODX繼承-值繼承
值繼承屬于ODX中的核心概念,面向對象繼承的概念用于診斷數(shù)據(jù)模型具有如下優(yōu)點:
多個ECU變體對診斷數(shù)據(jù)的復用;
對于ECU應用于多個項目的情況,可以提取公共數(shù)據(jù),ECU變體中只保留不同的數(shù)據(jù),從而減少數(shù)據(jù)冗余;
提供了數(shù)據(jù)安全和可集成性。
在上一期我們簡單介紹了下ODX繼承,為了避免數(shù)據(jù)的重復冗余,ODX將診斷層分為了5個層級。如圖3所示,其中,Protocol具有一般性,ECU Variant具有特殊性,ECU Shared Data類似一個library,可以為其他層提供數(shù)據(jù)和服務。圖3
我們知道,ODX中的繼承關系,在XML中以的方式實現(xiàn)的,如果繼承的數(shù)據(jù)中有部分數(shù)據(jù)不適用,可以通過去除不適用的數(shù)據(jù)。從圖4的例子中可以看出,該ECU不支持level3和level4解鎖等級。圖4
03ODX解析思路簡介
當我們拿到一份ODX或者PDX(PDX是將一系列ODX文件打包)時,如何開展解析工作呢?
首先找到ECU的Base Variant文件。
在Base Variant中查找繼承關系。
在Base Variant文件中查找對應的ECU變體即ECU Variant。
在ECU Variant文件中查找對應的診斷服務和數(shù)據(jù)。
圖5
04ODX解析實踐
根據(jù)章節(jié)3的ODX解析思路,獲得的解析結果見圖6、7和8。其中ECU Shared Data作為library,提供了通用的診斷服務,見圖6;而ECU變體BCM 88890251 A除了繼承Base Variant的通用診斷服務,還增加了多個DID、RID、IO Control,同時去除了19 15、27 05和27 06這些不適用的服務。圖8展示了ODX中包含的多種數(shù)據(jù)類型,這里不再詳細介紹。圖6
圖7
圖8
05總結
相較于傳統(tǒng)的Excel格式的診斷數(shù)據(jù)交換的不便性,ODX統(tǒng)一了診斷文件的格式,在研發(fā)、測試、生產(chǎn)和售后等部門傳遞交換時,不需要進行格式轉換,因此,很多OEM開始使用ODX。目前,北匯已經(jīng)開發(fā)基于ODX的診斷自動化測試方案,感興趣的小伙伴可以一起交流。
-
測試
+關注
關注
8文章
5379瀏覽量
127071 -
開發(fā)
+關注
關注
0文章
370瀏覽量
40920
發(fā)布評論請先 登錄
相關推薦
Oracle數(shù)據(jù)庫的多功能集成開發(fā)環(huán)境
![Oracle<b class='flag-5'>數(shù)據(jù)庫</b>的多功能集成<b class='flag-5'>開發(fā)</b>環(huán)境](https://file1.elecfans.com/web3/M00/05/F0/wKgZO2eF-8qAREl7AAAlkoIDMh0655.png)
MySQL數(shù)據(jù)庫的安裝
![MySQL<b class='flag-5'>數(shù)據(jù)庫</b>的安裝](https://file1.elecfans.com/web3/M00/05/E2/wKgZPGeF2XWAe83fAAAW9lhgvGk652.jpg)
云數(shù)據(jù)庫是哪種數(shù)據(jù)庫類型?
ODX診斷數(shù)據(jù)庫轉換工具 - DDC
![<b class='flag-5'>ODX</b><b class='flag-5'>診斷</b><b class='flag-5'>數(shù)據(jù)庫</b>轉換工具 - DDC](https://file1.elecfans.com/web3/M00/04/6B/wKgZO2dzYpCAeeE_AAAZKgGWPnE390.png)
基于ODX的工程診斷儀 - DST.Tester
![基于<b class='flag-5'>ODX</b>的工程<b class='flag-5'>診斷</b>儀 - DST.Tester](https://file1.elecfans.com/web3/M00/04/4A/wKgZPGdyVraAXKuAAAAfdgoHycU569.png)
數(shù)據(jù)庫數(shù)據(jù)恢復—Mysql數(shù)據(jù)庫表記錄丟失的數(shù)據(jù)恢復流程
![<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—Mysql<b class='flag-5'>數(shù)據(jù)庫</b>表記錄丟失的<b class='flag-5'>數(shù)據(jù)</b>恢復流程](https://file.elecfans.com/web2/M00/7B/26/pYYBAGNzCiiANj77AAH4iOB3xKM259.png)
數(shù)據(jù)庫數(shù)據(jù)恢復—MYSQL數(shù)據(jù)庫ibdata1文件損壞的數(shù)據(jù)恢復案例
數(shù)據(jù)庫數(shù)據(jù)恢復—通過拼接數(shù)據(jù)庫碎片恢復SQLserver數(shù)據(jù)庫
![<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—通過拼接<b class='flag-5'>數(shù)據(jù)庫</b>碎片恢復SQLserver<b class='flag-5'>數(shù)據(jù)庫</b>](https://file1.elecfans.com/web1/M00/F4/07/wKgaoWcjE32AbQdWAAJD_hojvJc119.png)
在嵌入式開發(fā)領域,有哪些好用的國產(chǎn)工具?
Oracle數(shù)據(jù)恢復—異常斷電后Oracle數(shù)據(jù)庫啟庫報錯的數(shù)據(jù)恢復案例
![Oracle<b class='flag-5'>數(shù)據(jù)</b>恢復—異常斷電后Oracle<b class='flag-5'>數(shù)據(jù)庫</b>啟<b class='flag-5'>庫</b>報錯的<b class='flag-5'>數(shù)據(jù)</b>恢復案例](https://file1.elecfans.com/web2/M00/08/B8/wKgZomb6Ns-AbiICAAFlXAFpKKU086.png)
數(shù)據(jù)庫數(shù)據(jù)恢復—SQL Server數(shù)據(jù)庫出現(xiàn)823錯誤的數(shù)據(jù)恢復案例
![<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—SQL Server<b class='flag-5'>數(shù)據(jù)庫</b>出現(xiàn)823錯誤的<b class='flag-5'>數(shù)據(jù)</b>恢復案例](https://file1.elecfans.com/web2/M00/07/F4/wKgaombs78mANJ1GAAPeSoXHVPE244.png)
恒訊科技分析:sql數(shù)據(jù)庫怎么用?
HarmonyOS開發(fā)案例:【搭建關系型數(shù)據(jù)庫】(4)
![HarmonyOS<b class='flag-5'>開發(fā)</b>案例:【搭建關系型<b class='flag-5'>數(shù)據(jù)庫</b>】(4)](https://file1.elecfans.com/web2/M00/E3/F9/wKgZomY-EPeAaulNAAB1Spd11Tg359.jpg)
數(shù)據(jù)庫數(shù)據(jù)恢復—raid5陣列上層Sql Server數(shù)據(jù)庫數(shù)據(jù)恢復案例
![<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復—raid5陣列上層Sql Server<b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復案例](https://file.elecfans.com/web2/M00/A2/AD/pYYBAGRLbSSAHhFWAAI9vWNRQec919.png)
評論