我正在使用 dBUnit 并试图用实际的 DB 数据集断言我的预定义 FlatXmlDataSet 的一行。问题是当数据来自 FlatXmlDataSet 时,我的验证码字段的 getValue 返回一个字符串,而当它来自实际的实时数据库时,它返回一个整数。对于任何不是字符串的数据类型都是如此。我可以写一些东西在比较之前将所有内容转换为字符串,但是有更好的方法吗?
我的代码:
IDataSet initialSet = setupDBWithData("test.xml", true);
ITable initialTable = initialSet.getTable("USER");
String response = doTestSendVerificationPin();
assertOKResponse(response);
ITable userTable = _databaseTester.getConnection().createTable("USER");
// Make sure old user row is left unchanged
assertRowsEqual(initialTable, 0, userTable, 0);
... (再向下)
protected void assertRowsEqual(ITable expected, int rowExpected, ITable actual, int rowActual) throws Exception
{
ITableMetaData metaData = expected.getTableMetaData();
Column [] cols = metaData.getColumns();
for (int i = 0; i < cols.length; i++)
{
String colName = cols[i].getColumnName();
assertEquals(expected.getValue(rowExpected, colName), actual.getValue(rowActual, colName));
}
}
这是我啜饮的 test.xml:
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE dataset SYSTEM "../Tests/testdata/common/some.dtd">
<dataset>
<USER ID="132" FIRST_NAME="Joe" LAST_NAME="Bob" VERIFICATION_CODE="1869" />
</dataset>