xml檔案對比或xml大字串對比方法(蠻精簡的)

2021-05-11 03:24:12 字數 1000 閱讀 8284

現在測試很多介面返回的型別是xml的字串,當返回值為較小的值的時候。期望結果直接寫在**裡邊是靠普的。

但是當返回結果相當大的時候,期望值儲存在**呢,以前我也做過直接寫在**裡,結果造成**行相當的長,幾乎

乙個測試用例只能看見期望結果的資料了,自然不好。那麼如果存在檔案裡如何呢?可能會有這樣的問題存在檔案裡如何對比

呢,採用文字內容對比嗎?總覺得不太靠普,至少xml特性沒能體現,譬如不能告訴我是哪個節點出錯了。

今天我發現xmlunit有這個功能(有點後知後覺,大家不要笑話);而且結合xml其他的jar包可以快速解決這個問題,而且**

也很精簡

特貼**如下

public void tet() throws exception

這裡為了方便**展示沒有將actxmltext寫成大字串,實際上通常測試場景中這個代表呼叫介面返回值

**會是類似下面的**

webconversation conversation = new webconversation();

webrequest request = new postmethodwebrequest(url);

webresponse response = conversation.getresponse(request);

system.out.println(response.gettext());

string actxmltext = response.gettext();

測試結果錯誤會報如下內容,明確告訴你哪個節點出錯了:

junit.framework.assertionfailederror: org.custommonkey.xmlunit.diff

[different] expected text value 『16′ but was 『15′ – comparing 16 at /error_response[1]/code[1]/text()[1] to 15 at /error_response[1]/code[1]/text()[1]

xml檔案對比或xml大字串對比方法(蠻精簡的)

現在測試很多介面返回的型別是xml的字串,當返回值為較小的值的時候。期望結果直接寫在 裡邊是靠普的。但是當返回結果相當大的時候,期望值儲存在 呢,以前我也做過直接寫在 裡,結果造成 行相當的長,幾乎乙個測試用例只能看見期望結果的資料了,自然不好。那麼如果存在檔案裡如何呢?可能會有這樣的問題存在檔案裡...

XML字串對比技巧二

之前都使用xmlunit來對比xml字串,今天發現當出現如下需求時,xmlunit無法滿足或者說有bug,特自己寫了對比方法。需求 需要對比如下xml字串,要求不對比其中的sign和time欄位,其他欄位都需要對比。elb wsi 001 1236586307734 822a379aec82755a...

XML字串對比技巧二

之前都使用xmlunit來對比xml字串,今天發現當出現如下需求時,xmlunit無法滿足或者說有bug,特自己寫了對比方法。需求 需要對比如下xml字串,要求不對比其中的sign和time欄位,其他欄位都需要對比。elb wsi 001 1236586307734 822a379aec82755a...