/* * Hibernate Search, full-text search for your domain model * * License: GNU Lesser General Public License (LGPL), version 2.1 or later * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.search.test.batchindexing; import java.util.Map; import org.hibernate.search.cfg.Environment; import org.hibernate.search.FullTextSession; import org.hibernate.search.spi.SearchIntegrator; import org.hibernate.search.test.SearchTestBase; import org.hibernate.search.test.errorhandling.MockErrorHandler; import org.hibernate.testing.RequiresDialect; import org.junit.Assert; import org.junit.Test; /** * Verifies that {@link org.hibernate.search.MassIndexer#idFetchSize(int)} is applied by checking for errors thrown by * the JDBC Dialect. We use this approach especially as we want to make sure that using * {@link Integer#MIN_VALUE} is an acceptable option on MySQL as we suggest it on the documentation. * * @author Sanne Grinovero (C) 2011 Red Hat Inc. */ public class FetchSizeConfigurationTest extends SearchTestBase { @Test @RequiresDialect(comment = "H2 does not accept negative fetch sizes", strictMatching = true, value = org.hibernate.dialect.H2Dialect.class) public void testSetFetchSizeOnH2Fails() throws InterruptedException { SearchIntegrator searchIntegrator = getExtendedSearchIntegrator(); MockErrorHandler mockErrorHandler = MassIndexerErrorReportingTest.getErrorHandler( searchIntegrator ); FullTextSession fullTextSession = MassIndexerErrorReportingTest.prepareSomeData( this ); fullTextSession.createIndexer( Book.class ).idFetchSize( -1 ).startAndWait(); getSession().close(); String errorMessage = mockErrorHandler.getErrorMessage(); Assert.assertEquals( "HSEARCH000211: An exception occurred while the MassIndexer was fetching the primary identifiers list", errorMessage ); Throwable exception = mockErrorHandler.getLastException(); Assert.assertTrue( exception instanceof org.hibernate.exception.GenericJDBCException ); } @Test @RequiresDialect(comment = "MySQL definitely should accept Integer.MIN_VALUE", strictMatching = false, value = org.hibernate.dialect.MySQLDialect.class) public void testSetFetchSizeOnMySQL() throws InterruptedException { SearchIntegrator searchIntegrator = getExtendedSearchIntegrator(); MockErrorHandler mockErrorHandler = MassIndexerErrorReportingTest.getErrorHandler( searchIntegrator ); FullTextSession fullTextSession = MassIndexerErrorReportingTest.prepareSomeData( this ); fullTextSession.createIndexer( Book.class ).idFetchSize( Integer.MIN_VALUE ).startAndWait(); getSession().close(); String errorMessage = mockErrorHandler.getErrorMessage(); Assert.assertEquals( null, errorMessage ); } @Override public Class<?>[] getAnnotatedClasses() { return new Class[] { Book.class, Nation.class }; } @Override public void configure(Map<String,Object> cfg) { cfg.put( Environment.ERROR_HANDLER, MockErrorHandler.class.getName() ); } }