All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.deltaspikedbunit.assertion.DatabaseAssertionMode Maven / Gradle / Ivy

Go to download

Integration between Deltaspike and DBUnit. It allows, using simple annotations, to setup and teardown database tables as well as checking expected table contents once a test completes.

The newest version!
/*
 * Copyright 2002-2015 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.deltaspikedbunit.assertion;

import com.github.deltaspikedbunit.annotation.ExpectedDatabase;

/**
 * Determines {@link ExpectedDatabase} behavior.
 *
 * @author Luigi Bitonti
 * @author Mario Zagar
 * @author Mehmet Aslan
 */
public enum DatabaseAssertionMode {

	/**
	 * Default DbUnit data sets assertions (i.e. checks all columns and their order).
	 */
	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; DatabaseAssertionMode(DatabaseAssertion databaseAssertion) { this.databaseAssertion = databaseAssertion; } public DatabaseAssertion getDatabaseAssertion() { return this.databaseAssertion; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy