com.github.springtestdbunit.assertion.DatabaseAssertionMode Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dbunit-spring Show documentation
Show all versions of dbunit-spring Show documentation
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 com.github.springtestdbunit.annotation.ExpectedDatabase;
/**
* Database assertion modes which determine {@link ExpectedDatabase} behavior.
*
* @author Mario Zagar
* @author Mehmet Aslan
*/
public enum DatabaseAssertionMode {
/**
* Will use default DbUnit data sets assertions.
*/
DEFAULT(new DefaultDatabaseAssertion()),
/**
* Allows specifying only specific columns and tables in expected data set. Unspecified tables and columns are
* ignored.
*
* Notes:
*
* - Expected row order must match order in actual data set.
* - Specified columns must match in all rows, e.g. specifying 'column1' value without 'column2' value in one row
* and only 'column2' value in another is not allowed - both 'column1' and 'column2' values must be specified in all
* rows.
*
*/
NON_STRICT(new NonStrictDatabaseAssertion()),
/**
* Allows specifying only specific columns and tables in expected data set and ignoring row orders in expected and
* actual data set. Unspecified tables and columns are ignored. Row orders in expected and actual data sets are
* ignored.
*
* Notes:
*
* - Expected row order does not need to match order in actual data set.
* - Specified columns must match in all rows, e.g. specifying 'column1' value without 'column2' value in one row
* and only 'column2' value in another is not allowed - both 'column1' and 'column2' values must be specified in all
* rows.
*
*/
NON_STRICT_UNORDERED(new NonStrictUnorderedDatabaseAssertion());
private DatabaseAssertion databaseAssertion;
private DatabaseAssertionMode(DatabaseAssertion databaseAssertion) {
this.databaseAssertion = databaseAssertion;
}
public DatabaseAssertion getDatabaseAssertion() {
return this.databaseAssertion;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy