/* * JBoss, Home of Professional Open Source * Copyright 2012 Red Hat Inc. and/or its affiliates and other contributors * as indicated by the @author tags. All rights reserved. * See the copyright.txt in the distribution for a * full listing of individual contributors. * * This copyrighted material is made available to anyone wishing to use, * modify, copy, or redistribute it subject to the terms and conditions * of the GNU Lesser General Public License, v. 2.1. * This program is distributed in the hope that it will be useful, but WITHOUT A * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. * You should have received a copy of the GNU Lesser General Public License, * v.2.1 along with this distribution; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301, USA. */ package org.infinispan.query.api; import static junit.framework.Assert.assertEquals; import org.apache.lucene.search.Query; import org.infinispan.configuration.cache.ConfigurationBuilder; import org.infinispan.manager.EmbeddedCacheManager; import org.infinispan.query.Search; import org.infinispan.query.SearchManager; import org.infinispan.test.SingleCacheManagerTest; import org.infinispan.test.fwk.TestCacheManagerFactory; import org.testng.annotations.Test; @Test(groups = "functional", testName = "query.api.NonIndexedValuesTest") public class NonIndexedValuesTest extends SingleCacheManagerTest { protected EmbeddedCacheManager createCacheManager() throws Exception { ConfigurationBuilder c = getDefaultStandaloneCacheConfig(true); c.indexing() .enable() .addProperty("hibernate.search.default.directory_provider", "ram") .addProperty("hibernate.search.lucene_version", "LUCENE_CURRENT"); return TestCacheManagerFactory.createCacheManager(c); } @Test public void testReplaceSimpleSearchable() { TestEntity se1 = new TestEntity("ISPN-1949", "Allow non-indexed values in indexed caches", 10, "note"); cache.put(se1.getId(), se1); cache.put("name2", "some string value"); cache.put("name3", "some string value"); cache.put("name3", new NotIndexedType("some string value")); SearchManager qf = Search.getSearchManager(cache); Query ispnIssueQuery = qf.buildQueryBuilderForClass(TestEntity.class) .get() .keyword() .onField("name") .ignoreAnalyzer() .matching("ISPN-1949") .createQuery(); assertEquals(1, qf.getQuery(ispnIssueQuery).list().size()); cache.put(se1.getId(), "some string value" ); assertEquals(0, qf.getQuery(ispnIssueQuery).list().size()); AnotherTestEntity indexBEntity = new AnotherTestEntity("ISPN-1949"); cache.put("name", indexBEntity); assertEquals(1, qf.getQuery(ispnIssueQuery).list().size()); TestEntity se2 = new TestEntity("HSEARCH-1077", "Mutable SearchFactory should return which classes are actually going to be indexed", 10, "note"); cache.replace("name", indexBEntity, se2); assertEquals(0, qf.getQuery(ispnIssueQuery).list().size()); Query searchIssueQuery = qf.buildQueryBuilderForClass(TestEntity.class) .get() .keyword() .onField("name") .ignoreAnalyzer() .matching("HSEARCH-1077") .createQuery(); assertEquals(1, qf.getQuery(searchIssueQuery).list().size()); //a failing atomic replace should not change the index: cache.replace("name", "notMatching", "notImportant"); assertEquals(1, qf.getQuery(searchIssueQuery).list().size()); assertEquals(0, qf.getQuery(ispnIssueQuery).list().size()); cache.remove("name"); assertEquals(0, qf.getQuery(searchIssueQuery).list().size()); cache.put("name", se2); assertEquals(1, qf.getQuery(searchIssueQuery).list().size()); cache.put("name", "replacement String"); assertEquals(0, qf.getQuery(searchIssueQuery).list().size()); cache.put("name", se1); assertEquals(1, qf.getQuery(ispnIssueQuery).list().size()); cache.put("second name", se1); assertEquals(2, qf.getQuery(ispnIssueQuery).list().size()); assertEquals(2, qf.getQuery(ispnIssueQuery, TestEntity.class).list().size()); //now actually replace one with a different indexed type (matches same query) cache.replace("name", se1, indexBEntity); assertEquals(2, qf.getQuery(ispnIssueQuery).list().size()); assertEquals(1, qf.getQuery(ispnIssueQuery, TestEntity.class).list().size()); assertEquals(1, qf.getQuery(ispnIssueQuery, AnotherTestEntity.class).list().size()); //replace with a non indexed type cache.replace("name", indexBEntity, new NotIndexedType("this is not indexed")); assertEquals(1, qf.getQuery(ispnIssueQuery).list().size()); } }