/*
* 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.id;
import java.util.List;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.NumericRangeQuery;
import org.apache.lucene.search.TermQuery;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.search.Search;
import org.hibernate.search.exception.SearchException;
import org.hibernate.search.test.SearchTestBase;
import org.hibernate.search.testsupport.TestForIssue;
import org.junit.Test;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
/**
* @author Hardy Ferentschik
*/
public class ExplicitIdTest extends SearchTestBase {
/**
* Tests that @DocumentId can be specified on a field other than the @Id annotated one. See HSEARCH-574.
*
* @throws Exception in case the test fails.
*/
@Test
public void testExplicitDocumentIdSingleResult() throws Exception {
Article hello = new Article();
hello.setDocumentId( 1 );
hello.setText( "Hello World" );
Session s = openSession();
Transaction tx = s.beginTransaction();
s.save( hello );
tx.commit();
s.clear();
tx = s.beginTransaction();
List results = Search.getFullTextSession( s ).createFullTextQuery(
new TermQuery( new Term( "text", "world" ) )
).list();
assertEquals( 1, results.size() );
tx.commit();
s.close();
}
/**
* Tests that @DocumentId can be specified on a field other than the @Id annotated one. See HSEARCH-574.
*
* @throws Exception in case the test fails.
*/
@Test
public void testExplicitDocumentIdMultipleResults() throws Exception {
Article hello = new Article();
hello.setDocumentId( 1 );
hello.setText( "Hello World" );
Article goodbye = new Article();
goodbye.setDocumentId( 2 );
goodbye.setText( "Goodbye World" );
Session s = openSession();
Transaction tx = s.beginTransaction();
s.save( hello );
s.save( goodbye );
tx.commit();
s.clear();
tx = s.beginTransaction();
List results = Search.getFullTextSession( s ).createFullTextQuery(
new TermQuery( new Term( "text", "world" ) )
).list();
assertEquals( 2, results.size() );
tx.commit();
s.close();
}
/**
* Tests that the document id must be unique
*
* @throws Exception in case the test fails.
*/
@Test
public void testDocumentIdMustBeUnique() throws Exception {
Article hello = new Article();
hello.setDocumentId( 1 );
hello.setText( "Hello World" );
Article goodbye = new Article();
goodbye.setDocumentId( 1 );
goodbye.setText( "Goodbye World" );
Session s = openSession();
Transaction tx = s.beginTransaction();
s.save( hello );
s.save( goodbye );
tx.commit();
s.clear();
tx = s.beginTransaction();
try {
Search.getFullTextSession( s ).createFullTextQuery(
new TermQuery( new Term( "text", "world" ) )
).list();
fail( "Test should fail, because document id is not unique." );
}
catch (SearchException e) {
assertEquals(
"Loading entity of type org.hibernate.search.test.id.Article using 'documentId' as document id and '1' as value was not unique",
e.getMessage()
);
}
tx.commit();
s.close();
}
/**
* Tests that one can query on the default-named field of the JPA {@code @Id} property also if there is another
* property marked with {@code @DocumentId}.
*/
@Test
@TestForIssue(jiraKey = "HSEARCH-2056")
public void testQueryOnIdPropertyWithExplicitDocumentIdPresent() throws Exception {
Article hello = new Article();
hello.setDocumentId( 1 );
hello.setText( "Hello World" );
Session s = openSession();
Transaction tx = s.beginTransaction();
s.save( hello );
tx.commit();
s.clear();
tx = s.beginTransaction();
List results = Search.getFullTextSession( s ).createFullTextQuery(
NumericRangeQuery.newLongRange( "articleId", hello.getArticleId(), hello.getArticleId(), true, true )
).list();
assertEquals( 1, results.size() );
tx.commit();
s.close();
}
@Override
public Class<?>[] getAnnotatedClasses() {
return new Class[] {
Article.class
};
}
}