com.github.springtestdbunit.assertion.NonStrictDatabaseAssertion Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spring-test-dbunit-core Show documentation
Show all versions of spring-test-dbunit-core Show documentation
Core module for the integration between the Spring testing framework and DBUnit
/*
* Copyright 2002-2016 the original author or authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.springtestdbunit.assertion;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
import org.dbunit.Assertion;
import org.dbunit.DatabaseUnitException;
import org.dbunit.dataset.Column;
import org.dbunit.dataset.Columns;
import org.dbunit.dataset.DataSetException;
import org.dbunit.dataset.FilteredTableMetaData;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.ITable;
import org.dbunit.dataset.ITableMetaData;
import org.dbunit.dataset.filter.IColumnFilter;
/**
* Implements non-strict database assertion strategy : compares data sets ignoring all tables and columns which are not
* specified in expected data set but possibly exist in actual data set.
*
* @author Mario Zagar
* @author Sunitha Rajarathnam
*/
class NonStrictDatabaseAssertion implements DatabaseAssertion {
public void assertEquals(IDataSet expectedDataSet, IDataSet actualDataSet, List columnFilters)
throws DatabaseUnitException {
for (String tableName : expectedDataSet.getTableNames()) {
ITable expectedTable = expectedDataSet.getTable(tableName);
ITable actualTable = actualDataSet.getTable(tableName);
assertEquals(expectedTable, actualTable, columnFilters);
}
}
public void assertEquals(ITable expectedTable, ITable actualTable, List columnFilters)
throws DatabaseUnitException {
Set ignoredColumns = getColumnsToIgnore(expectedTable.getTableMetaData(),
actualTable.getTableMetaData(), columnFilters);
Assertion.assertEqualsIgnoreCols(expectedTable, actualTable,
ignoredColumns.toArray(new String[ignoredColumns.size()]));
}
private Set getColumnsToIgnore(ITableMetaData expectedMetaData, ITableMetaData actualMetaData,
List columnFilters) throws DataSetException {
if (columnFilters.size() == 0) {
return getColumnsToIgnore(expectedMetaData, actualMetaData);
}
Set ignoredColumns = new LinkedHashSet();
for (IColumnFilter filter : columnFilters) {
FilteredTableMetaData filteredExpectedMetaData = new FilteredTableMetaData(expectedMetaData, filter);
ignoredColumns.addAll(getColumnsToIgnore(filteredExpectedMetaData, actualMetaData));
}
return ignoredColumns;
}
protected Set getColumnsToIgnore(ITableMetaData expectedMetaData, ITableMetaData actualMetaData)
throws DataSetException {
Column[] notSpecifiedInExpected = Columns.getColumnDiff(expectedMetaData, actualMetaData).getActual();
Set result = new LinkedHashSet();
for (Column column : notSpecifiedInExpected) {
result.add(column.getColumnName());
}
return result;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy