/* * 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.Search; import org.hibernate.search.exception.ErrorHandler; import org.hibernate.search.spi.SearchIntegrator; import org.hibernate.search.test.SearchTestBase; import org.hibernate.search.test.errorhandling.MockErrorHandler; import org.hibernate.search.testsupport.junit.ElasticsearchSupportInProgress; import org.jboss.byteman.contrib.bmunit.BMRule; import org.jboss.byteman.contrib.bmunit.BMUnitRunner; import org.junit.Assert; import org.junit.Test; import org.junit.experimental.categories.Category; import org.junit.runner.RunWith; @RunWith(BMUnitRunner.class) @Category(ElasticsearchSupportInProgress.class) // HSEARCH-2481 Byteman-based tests re-executed in the Elasticsearch module won't work public class MassIndexerErrorReportingTest extends SearchTestBase { @Test @BMRule(targetClass = "org.hibernate.search.batchindexing.impl.IdentifierConsumerDocumentProducer", targetMethod = "loadList", action = "throw new NullPointerException(\"Byteman created NPE\")", name = "testMassIndexerErrorsReported") public void testMassIndexerErrorsReported() throws InterruptedException { SearchIntegrator integrator = getExtendedSearchIntegrator(); MockErrorHandler mockErrorHandler = getErrorHandler( integrator ); FullTextSession fullTextSession = prepareSomeData( this ); fullTextSession.createIndexer( Book.class ).startAndWait(); getSession().close(); String errorMessage = mockErrorHandler.getErrorMessage(); Assert.assertEquals( "HSEARCH000212: An exception occurred while the MassIndexer was transforming identifiers to Lucene Documents", errorMessage ); Throwable exception = mockErrorHandler.getLastException(); Assert.assertTrue( exception instanceof NullPointerException ); Assert.assertEquals( "Byteman created NPE", exception.getMessage() ); } static MockErrorHandler getErrorHandler(SearchIntegrator integrator) { ErrorHandler errorHandler = integrator.getErrorHandler(); Assert.assertTrue( errorHandler instanceof MockErrorHandler ); MockErrorHandler mockErrorHandler = (MockErrorHandler) errorHandler; return mockErrorHandler; } static FullTextSession prepareSomeData(SearchTestBase testCase) { FullTextSession fullTextSession = Search.getFullTextSession( testCase.openSession() ); fullTextSession.beginTransaction(); Nation france = new Nation( "France", "FR" ); fullTextSession.save( france ); Book ceylonBook = new Book(); ceylonBook.setTitle( "Ceylon in Action" ); ceylonBook.setFirstPublishedIn( france ); fullTextSession.save( ceylonBook ); fullTextSession.getTransaction().commit(); return fullTextSession; } @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() ); } }