2

我正在使用 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>
4

2 回答 2

2

抱歉,如果这不能准确回答您的问题,但在我看来,这似乎是一种使用 DBUnit 的不寻常方式。通常您使用 DBUnit 将数据加载到数据库中,然后使用 SQL 查询数据库并将其与其他一些已知结果进行比较。我还没有看到有人尝试将 DBUnit IDataSet 作为断言的一部分进行比较——我不认为 DBUnit 打算以这种方式使用。

于 2009-08-14T04:14:19.403 回答
1

我猜你正在使用flat-xml格式,这意味着你正在阅读FlatXmlDataSet实例。如果我是正确的,您可以使用FlatXmlDataSetBuilder将从数据库读取的数据集中的数据集元数据复制到从文件读取的数据集中。

另一种方法是使用 DTD 或完整的数据集格式,因为flat-xml它有一些限制。

于 2012-08-28T16:26:11.167 回答