mirror of https://github.com/apache/lucene.git
SOLR-10077: merge TestFeatureStore and TestFeatureLtrScoringModel into TestManagedFeatureStore.
This commit is contained in:
parent
ef03480743
commit
f47bbb35ae
|
@ -1,71 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You 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 org.apache.solr.ltr.feature;
|
||||
|
||||
import org.apache.solr.ltr.TestRerankBase;
|
||||
import org.apache.solr.ltr.store.rest.ManagedFeatureStore;
|
||||
import org.apache.solr.ltr.store.rest.TestManagedFeatureStore;
|
||||
import org.junit.AfterClass;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
||||
public class TestFeatureLtrScoringModel extends TestRerankBase {
|
||||
|
||||
static ManagedFeatureStore store = null;
|
||||
|
||||
@BeforeClass
|
||||
public static void setup() throws Exception {
|
||||
setuptest(true);
|
||||
store = getManagedFeatureStore();
|
||||
}
|
||||
|
||||
@AfterClass
|
||||
public static void after() throws Exception {
|
||||
aftertest();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getInstanceTest() throws FeatureException
|
||||
{
|
||||
store.addFeature(TestManagedFeatureStore.createMap("test",
|
||||
OriginalScoreFeature.class.getCanonicalName(), null),
|
||||
"testFstore");
|
||||
final Feature feature = store.getFeatureStore("testFstore").get("test");
|
||||
assertNotNull(feature);
|
||||
assertEquals("test", feature.getName());
|
||||
assertEquals(OriginalScoreFeature.class.getCanonicalName(), feature
|
||||
.getClass().getCanonicalName());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getInvalidInstanceTest()
|
||||
{
|
||||
final String nonExistingClassName = "org.apache.solr.ltr.feature.LOLFeature";
|
||||
final ClassNotFoundException expectedException =
|
||||
new ClassNotFoundException(nonExistingClassName);
|
||||
try {
|
||||
store.addFeature(TestManagedFeatureStore.createMap("test",
|
||||
nonExistingClassName, null),
|
||||
"testFstore2");
|
||||
fail("getInvalidInstanceTest failed to throw exception: "+expectedException);
|
||||
} catch (Exception actualException) {
|
||||
Throwable rootError = getRootCause(actualException);
|
||||
assertEquals(expectedException.toString(), rootError.toString());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,106 +0,0 @@
|
|||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
* contributor license agreements. See the NOTICE file distributed with
|
||||
* this work for additional information regarding copyright ownership.
|
||||
* The ASF licenses this file to You 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 org.apache.solr.ltr.feature;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.solr.ltr.TestRerankBase;
|
||||
import org.apache.solr.ltr.store.FeatureStore;
|
||||
import org.apache.solr.ltr.store.rest.ManagedFeatureStore;
|
||||
import org.apache.solr.ltr.store.rest.TestManagedFeatureStore;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
||||
public class TestFeatureStore extends TestRerankBase {
|
||||
|
||||
static ManagedFeatureStore fstore = null;
|
||||
|
||||
@BeforeClass
|
||||
public static void setup() throws Exception {
|
||||
setuptest(true);
|
||||
fstore = getManagedFeatureStore();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultFeatureStoreName()
|
||||
{
|
||||
assertEquals("_DEFAULT_", FeatureStore.DEFAULT_FEATURE_STORE_NAME);
|
||||
final FeatureStore expectedFeatureStore = fstore.getFeatureStore(FeatureStore.DEFAULT_FEATURE_STORE_NAME);
|
||||
final FeatureStore actualFeatureStore = fstore.getFeatureStore(null);
|
||||
assertEquals("getFeatureStore(null) should return the default feature store", expectedFeatureStore, actualFeatureStore);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFeatureStoreAdd() throws FeatureException
|
||||
{
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
final String name = "c" + i;
|
||||
|
||||
fstore.addFeature(TestManagedFeatureStore.createMap(name,
|
||||
OriginalScoreFeature.class.getCanonicalName(), null),
|
||||
"fstore-testFeature");
|
||||
|
||||
final Feature f = fs.get(name);
|
||||
assertNotNull(f);
|
||||
|
||||
}
|
||||
assertEquals(5, fs.getFeatures().size());
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFeatureStoreGet() throws FeatureException
|
||||
{
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature2");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
Map<String,Object> params = new HashMap<String,Object>();
|
||||
params.put("value", i);
|
||||
final String name = "c" + i;
|
||||
|
||||
fstore.addFeature(TestManagedFeatureStore.createMap(name,
|
||||
ValueFeature.class.getCanonicalName(), params),
|
||||
"fstore-testFeature2");
|
||||
|
||||
}
|
||||
|
||||
for (int i = 0; i < 5; i++) {
|
||||
final Feature f = fs.get("c" + i);
|
||||
assertEquals("c" + i, f.getName());
|
||||
assertTrue(f instanceof ValueFeature);
|
||||
final ValueFeature vf = (ValueFeature)f;
|
||||
assertEquals(i, vf.getValue());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testMissingFeatureReturnsNull() {
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature3");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
Map<String,Object> params = new HashMap<String,Object>();
|
||||
params.put("value", i);
|
||||
final String name = "testc" + (float) i;
|
||||
fstore.addFeature(TestManagedFeatureStore.createMap(name,
|
||||
ValueFeature.class.getCanonicalName(), params),
|
||||
"fstore-testFeature3");
|
||||
|
||||
}
|
||||
assertNull(fs.get("missing_feature_name"));
|
||||
}
|
||||
|
||||
}
|
|
@ -19,11 +19,27 @@ package org.apache.solr.ltr.store.rest;
|
|||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.lucene.util.LuceneTestCase;
|
||||
import org.apache.solr.SolrTestCaseJ4;
|
||||
import org.apache.solr.ltr.feature.Feature;
|
||||
import org.apache.solr.ltr.feature.FeatureException;
|
||||
import org.apache.solr.ltr.feature.OriginalScoreFeature;
|
||||
import org.apache.solr.ltr.feature.ValueFeature;
|
||||
import org.apache.solr.ltr.store.FeatureStore;
|
||||
import org.apache.solr.ltr.store.rest.ManagedFeatureStore;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
||||
public class TestManagedFeatureStore extends LuceneTestCase {
|
||||
public class TestManagedFeatureStore extends SolrTestCaseJ4 {
|
||||
|
||||
public static Map<String,Object> createMap(String name, String className, Map<String,Object> params) {
|
||||
private static ManagedFeatureStore fstore = null;
|
||||
|
||||
@BeforeClass
|
||||
public static void setup() throws Exception {
|
||||
initCore("solrconfig-ltr.xml", "schema.xml");
|
||||
fstore = ManagedFeatureStore.getManagedFeatureStore(h.getCore());
|
||||
}
|
||||
|
||||
private static Map<String,Object> createMap(String name, String className, Map<String,Object> params) {
|
||||
final Map<String,Object> map = new HashMap<String,Object>();
|
||||
map.put(ManagedFeatureStore.NAME_KEY, name);
|
||||
map.put(ManagedFeatureStore.CLASS_KEY, className);
|
||||
|
@ -33,4 +49,101 @@ public class TestManagedFeatureStore extends LuceneTestCase {
|
|||
return map;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultFeatureStoreName()
|
||||
{
|
||||
assertEquals("_DEFAULT_", FeatureStore.DEFAULT_FEATURE_STORE_NAME);
|
||||
final FeatureStore expectedFeatureStore = fstore.getFeatureStore(FeatureStore.DEFAULT_FEATURE_STORE_NAME);
|
||||
final FeatureStore actualFeatureStore = fstore.getFeatureStore(null);
|
||||
assertEquals("getFeatureStore(null) should return the default feature store", expectedFeatureStore, actualFeatureStore);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFeatureStoreAdd() throws FeatureException
|
||||
{
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
final String name = "c" + i;
|
||||
|
||||
fstore.addFeature(createMap(name,
|
||||
OriginalScoreFeature.class.getCanonicalName(), null),
|
||||
"fstore-testFeature");
|
||||
|
||||
final Feature f = fs.get(name);
|
||||
assertNotNull(f);
|
||||
|
||||
}
|
||||
assertEquals(5, fs.getFeatures().size());
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testFeatureStoreGet() throws FeatureException
|
||||
{
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature2");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
Map<String,Object> params = new HashMap<String,Object>();
|
||||
params.put("value", i);
|
||||
final String name = "c" + i;
|
||||
|
||||
fstore.addFeature(createMap(name,
|
||||
ValueFeature.class.getCanonicalName(), params),
|
||||
"fstore-testFeature2");
|
||||
|
||||
}
|
||||
|
||||
for (int i = 0; i < 5; i++) {
|
||||
final Feature f = fs.get("c" + i);
|
||||
assertEquals("c" + i, f.getName());
|
||||
assertTrue(f instanceof ValueFeature);
|
||||
final ValueFeature vf = (ValueFeature)f;
|
||||
assertEquals(i, vf.getValue());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testMissingFeatureReturnsNull() {
|
||||
final FeatureStore fs = fstore.getFeatureStore("fstore-testFeature3");
|
||||
for (int i = 0; i < 5; i++) {
|
||||
Map<String,Object> params = new HashMap<String,Object>();
|
||||
params.put("value", i);
|
||||
final String name = "testc" + (float) i;
|
||||
fstore.addFeature(createMap(name,
|
||||
ValueFeature.class.getCanonicalName(), params),
|
||||
"fstore-testFeature3");
|
||||
|
||||
}
|
||||
assertNull(fs.get("missing_feature_name"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getInstanceTest() throws FeatureException
|
||||
{
|
||||
fstore.addFeature(createMap("test",
|
||||
OriginalScoreFeature.class.getCanonicalName(), null),
|
||||
"testFstore");
|
||||
final Feature feature = fstore.getFeatureStore("testFstore").get("test");
|
||||
assertNotNull(feature);
|
||||
assertEquals("test", feature.getName());
|
||||
assertEquals(OriginalScoreFeature.class.getCanonicalName(), feature
|
||||
.getClass().getCanonicalName());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getInvalidInstanceTest()
|
||||
{
|
||||
final String nonExistingClassName = "org.apache.solr.ltr.feature.LOLFeature";
|
||||
final ClassNotFoundException expectedException =
|
||||
new ClassNotFoundException(nonExistingClassName);
|
||||
try {
|
||||
fstore.addFeature(createMap("test",
|
||||
nonExistingClassName, null),
|
||||
"testFstore2");
|
||||
fail("getInvalidInstanceTest failed to throw exception: "+expectedException);
|
||||
} catch (Exception actualException) {
|
||||
Throwable rootError = getRootCause(actualException);
|
||||
assertEquals(expectedException.toString(), rootError.toString());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue