org.openrdf.sail.lucene.AbstractLuceneSailIndexedPropertiesTest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sesame-sail-lucene-test Show documentation
Show all versions of sesame-sail-lucene-test Show documentation
Generic tests for Lucene Sail implementations.
/*
* Licensed to Aduna under one or more contributor license agreements.
* See the NOTICE.txt file distributed with this work for additional
* information regarding copyright ownership.
*
* Aduna licenses this file to you under the terms of the Aduna BSD
* License (the "License"); you may not use this file except in compliance
* with the License. See the LICENSE.txt file distributed with this work
* for the full License.
*
* 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.openrdf.sail.lucene;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.openrdf.sail.lucene.LuceneSailSchema.MATCHES;
import static org.openrdf.sail.lucene.LuceneSailSchema.PROPERTY;
import static org.openrdf.sail.lucene.LuceneSailSchema.QUERY;
import static org.openrdf.sail.lucene.LuceneSailSchema.SCORE;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Properties;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openrdf.model.URI;
import org.openrdf.model.impl.LiteralImpl;
import org.openrdf.model.impl.URIImpl;
import org.openrdf.model.vocabulary.RDFS;
import org.openrdf.query.BindingSet;
import org.openrdf.query.MalformedQueryException;
import org.openrdf.query.QueryEvaluationException;
import org.openrdf.query.QueryLanguage;
import org.openrdf.query.TupleQuery;
import org.openrdf.query.TupleQueryResult;
import org.openrdf.repository.Repository;
import org.openrdf.repository.RepositoryConnection;
import org.openrdf.repository.RepositoryException;
import org.openrdf.repository.sail.SailRepository;
import org.openrdf.sail.memory.MemoryStore;
public abstract class AbstractLuceneSailIndexedPropertiesTest {
protected LuceneSail sail;
protected Repository repository;
protected RepositoryConnection connection;
public static final URI SUBJECT_1 = new URIImpl("urn:subject1");
public static final URI SUBJECT_2 = new URIImpl("urn:subject2");
public static final URI SUBJECT_3 = new URIImpl("urn:subject3");
public static final URI SUBJECT_4 = new URIImpl("urn:subject4");
public static final URI SUBJECT_5 = new URIImpl("urn:subject5");
public static final URI CONTEXT_1 = new URIImpl("urn:context1");
public static final URI CONTEXT_2 = new URIImpl("urn:context2");
public static final URI CONTEXT_3 = new URIImpl("urn:context3");
public static final URI RDFSLABEL = RDFS.LABEL;
public static final URI RDFSCOMMENT = RDFS.COMMENT;
public static final URI FOAFNAME = new URIImpl("http://xmlns.com/foaf/0.1/name");
public static final URI FOAFPLAN = new URIImpl("http://xmlns.com/foaf/0.1/plan");
protected abstract void configure(LuceneSail sail);
@Before
public void setUp()
throws IOException, RepositoryException
{
// setup a LuceneSail
MemoryStore memoryStore = new MemoryStore();
// enable lock tracking
info.aduna.concurrent.locks.Properties.setLockTrackingEnabled(true);
sail = new LuceneSail();
configure(sail);
Properties indexedFields = new Properties();
indexedFields.setProperty("index.1", RDFSLABEL.toString());
indexedFields.setProperty("index.2", RDFSCOMMENT.toString());
indexedFields.setProperty(FOAFNAME.toString(), RDFS.LABEL.toString());
ByteArrayOutputStream indexedFieldsString = new ByteArrayOutputStream();
indexedFields.store(indexedFieldsString, "For testing");
sail.setParameter(LuceneSail.INDEXEDFIELDS, indexedFieldsString.toString());
sail.setBaseSail(memoryStore);
// create a Repository wrapping the LuceneSail
repository = new SailRepository(sail);
repository.initialize();
// add some statements to it
connection = repository.getConnection();
connection.begin();
connection.add(SUBJECT_1, RDFSLABEL, new LiteralImpl("the first resource"));
connection.add(SUBJECT_1, RDFSCOMMENT, new LiteralImpl(
"Groucho Marx is going to cut away the first part of the first party of the contract."));
connection.add(SUBJECT_1, FOAFNAME, new LiteralImpl("groucho and harpo"));
connection.add(SUBJECT_2, FOAFNAME, new LiteralImpl("the second resource"));
connection.add(SUBJECT_2, RDFSCOMMENT, new LiteralImpl(
"in the night at the opera, groucho is in a cabin on a ship."));
connection.add(SUBJECT_3, RDFSLABEL, new LiteralImpl("the third resource"));
connection.add(SUBJECT_3, RDFSCOMMENT, new LiteralImpl(
"a not well known fact, groucho marx was not a smoker"));
connection.add(SUBJECT_3, FOAFPLAN, new LiteralImpl("groucho did not smoke cigars nor cigarillos")); // this
// should
connection.commit();
}
@After
public void tearDown()
throws IOException, RepositoryException
{
connection.close();
repository.shutDown();
}
@Test
public void testTriplesStored()
throws Exception
{
// are the triples stored in the underlying sail?
assertTrue(connection.hasStatement(SUBJECT_1, RDFSLABEL, new LiteralImpl("the first resource"), false));
assertTrue(connection.hasStatement(SUBJECT_1, RDFSCOMMENT, new LiteralImpl(
"Groucho Marx is going to cut away the first part of the first party of the contract."), false));
assertTrue(connection.hasStatement(SUBJECT_1, FOAFNAME, new LiteralImpl("groucho and harpo"), false));
assertTrue(connection.hasStatement(SUBJECT_2, FOAFNAME, new LiteralImpl("the second resource"), false));
assertTrue(connection.hasStatement(SUBJECT_2, RDFSCOMMENT, new LiteralImpl(
"in the night at the opera, groucho is in a cabin on a ship."), false));
assertTrue(connection.hasStatement(SUBJECT_3, RDFSLABEL, new LiteralImpl("the third resource"), false));
assertTrue(connection.hasStatement(SUBJECT_3, RDFSCOMMENT, new LiteralImpl(
"a not well known fact, groucho marx was not a smoker"), false));
assertTrue(connection.hasStatement(SUBJECT_3, FOAFPLAN, new LiteralImpl(
"groucho did not smoke cigars nor cigarillos"), false)); // this
// should
// not be
// indexed
}
@Test
public void testRegularQuery()
throws RepositoryException, MalformedQueryException, QueryEvaluationException
{
// fire a query for all subjects with a given term
String queryString = "SELECT Subject, Score " + "FROM {Subject} <" + MATCHES + "> {} " + " <" + QUERY
+ "> {Query}; " + " <" + PROPERTY + "> {Property}; " + " <" + SCORE + "> {Score} ";
{
TupleQuery query = connection.prepareTupleQuery(QueryLanguage.SERQL, queryString);
query.setBinding("Query", new LiteralImpl("resource"));
query.setBinding("Property", RDFSLABEL);
TupleQueryResult result = query.evaluate();
// check the results
ArrayList uris = new ArrayList();
BindingSet bindings = null;
while (result.hasNext()) {
bindings = result.next();
uris.add((URI)bindings.getValue("Subject"));
assertNotNull(bindings.getValue("Score"));
}
result.close();
assertEquals(3, uris.size());
assertTrue(uris.contains(SUBJECT_1));
assertTrue(uris.contains(SUBJECT_2));
assertTrue(uris.contains(SUBJECT_3));
}
{
TupleQuery query = connection.prepareTupleQuery(QueryLanguage.SERQL, queryString);
query.setBinding("Query", new LiteralImpl("groucho"));
query.setBinding("Property", RDFSLABEL);
TupleQueryResult result = query.evaluate();
// check the results
ArrayList uris = new ArrayList();
BindingSet bindings = null;
while (result.hasNext()) {
bindings = result.next();
uris.add((URI)bindings.getValue("Subject"));
assertNotNull(bindings.getValue("Score"));
}
result.close();
assertEquals(1, uris.size());
assertTrue(uris.contains(SUBJECT_1));
}
{
TupleQuery query = connection.prepareTupleQuery(QueryLanguage.SERQL, queryString);
query.setBinding("Query", new LiteralImpl("cigarillos"));
query.setBinding("Property", FOAFPLAN);
TupleQueryResult result = query.evaluate();
// check the results
assertFalse(result.hasNext());
result.close();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy