📄 testontdocumentmanager.java
字号:
assertTrue( "b should be imported", m.hasLoadedImport( "file:testing/ontology/testImport3/b.owl" ) );
m.setDynamicImports( true );
Resource a = m.getResource( "file:testing/ontology/testImport3/a.owl" );
Resource b = m.getResource( "file:testing/ontology/testImport3/b.owl" );
m.remove( m.createStatement( a, m.getProfile().IMPORTS(), b ) );
assertEquals( "Marker count not correct", 1, countMarkers( m ) );
assertFalse( "c should not be imported", m.hasLoadedImport( "file:testing/ontology/testImport3/c.owl" ) );
assertFalse( "b should not be imported", m.hasLoadedImport( "file:testing/ontology/testImport3/b.owl" ) );
}
public void testSearchPath() {
OntDocumentManager o1 = new OntDocumentManager( "file:etc/ont-policy-test.rdf" );
assertEquals( "Did not return correct loaded search path", "file:etc/ont-policy-test.rdf", o1.getLoadedPolicyURL() );
OntDocumentManager o2 = new OntDocumentManager( "file:etc/ont-policy-test.notexist.rdf;file:etc/ont-policy-test.rdf" );
assertEquals( "Did not return correct loaded search path", "file:etc/ont-policy-test.rdf", o2.getLoadedPolicyURL() );
OntDocumentManager o3 = new OntDocumentManager( (String) null );
assertNull( "Most recent policy should be null", o3.getLoadedPolicyURL() );
o3.setMetadataSearchPath( "file:etc/ont-policy-test.rdf", true );
assertEquals( "Did not return correct loaded search path", "file:etc/ont-policy-test.rdf", o2.getLoadedPolicyURL() );
o3.setMetadataSearchPath( "file:etc/ont-policy-test.notexist.rdf", true );
assertNull( "Most recent policy should be null", o3.getLoadedPolicyURL() );
}
public void testReadFailHandler0() {
OntDocumentManager o1 = new OntDocumentManager( "file:etc/ont-policy-test.rdf" );
assertNull( o1.getReadFailureHandler() );
OntDocumentManager.ReadFailureHandler rfh = new OntDocumentManager.ReadFailureHandler() {
public void handleFailedRead( String url, Model model, Exception e ) {}};
o1.setReadFailureHandler( rfh );
assertSame( rfh, o1.getReadFailureHandler() );
}
public void testReadFailHandler1() {
OntDocumentManager o1 = new OntDocumentManager( "file:etc/ont-policy-test.rdf" );
TestFailHandler rfh = new TestFailHandler();
o1.setReadFailureHandler( rfh );
// trigger the odm to read a non-existant source
String source = "@prefix owl: <http://www.w3.org/2002/07/owl#> . <> a owl:Ontology ; owl:imports <http://example.com/not/exist>. ";
OntModelSpec spec = new OntModelSpec( OntModelSpec.OWL_MEM );
spec.setDocumentManager( o1 );
OntModel m = ModelFactory.createOntologyModel( spec );
m.read( new StringReader( source ), "http://example.com/foo#", "N3" );
assertTrue( rfh.m_seen );
}
public void testReadHook0() {
TestReadHook rh = new TestReadHook( false );
OntDocumentManager o1 = new OntDocumentManager( "file:etc/ont-policy-test.rdf" );
o1.setReadHook( rh );
o1.reset();
String source = "@prefix owl: <http://www.w3.org/2002/07/owl#> . <> a owl:Ontology ; owl:imports <file:testing/ontology/testImport3/a.owl>. ";
OntModelSpec spec = new OntModelSpec( OntModelSpec.OWL_MEM );
spec.setDocumentManager( o1 );
OntModel m = ModelFactory.createOntologyModel( spec );
m.read( new StringReader( source ), "http://example.com/foo#", "N3" );
assertEquals( "Wrong number of calls to before load hook", 3, rh.m_before );
assertEquals( "Wrong number of calls to before load hook", 3, rh.m_after );
}
public void testReadHook1() {
TestReadHook rh = new TestReadHook( true );
OntDocumentManager o1 = new OntDocumentManager( "file:etc/ont-policy-test.rdf" );
o1.setReadHook( rh );
o1.reset();
String source = "@prefix owl: <http://www.w3.org/2002/07/owl#> . <> a owl:Ontology ; owl:imports <file:testing/ontology/testImport3/a.owl>. ";
OntModelSpec spec = new OntModelSpec( OntModelSpec.OWL_MEM );
spec.setDocumentManager( o1 );
OntModel m = ModelFactory.createOntologyModel( spec );
m.read( new StringReader( source ), "http://example.com/foo#", "N3" );
assertEquals( "Wrong number of calls to before load hook", 1, rh.m_before );
assertEquals( "Wrong number of calls to after load hook", 1, rh.m_after );
}
/* count the number of marker statements in the combined model */
public static int countMarkers( Model m ) {
int count = 0;
Resource marker = m.getResource( "http://jena.hpl.hp.com/2003/03/testont#Marker" );
for (StmtIterator i = m.listStatements( null, RDF.type, marker ); i.hasNext(); ) {
count++;
i.next();
}
return count;
}
// Internal implementation methods
//////////////////////////////////
//==============================================================================
// Inner class definitions
//==============================================================================
/**
* Document manager imports test case. Each test case starts with a root model (always a.owl in some
* directory), and loads the model. Depending on the model contents, and the settings of the doc
* manager, other models will be loaded. Each model is set to contain a fixed number of marker
* statements of the form:
* <code><pre>
* <Marker rdf:ID="a0" />
* </pre></code>
* the test for having correctly loaded the models is to count the markers and compare to the predicted
* total.
*/
static class DocManagerImportTest
extends TestCase
{
String m_dir;
int m_count;
String m_path;
boolean m_processImports;
/* constuctor */
DocManagerImportTest( String dir, int count, boolean processImports, String path ) {
super( dir );
m_dir = dir;
m_count = count;
m_path = path;
m_processImports = processImports;
}
// external contract methods
public void runTest() {
OntDocumentManager dm = new OntDocumentManager();
// adjust the doc manager properties according to the test setup
dm.setProcessImports( m_processImports );
if (m_path != null) {
dm.setMetadataSearchPath( m_path, true );
}
// now load the model - we always start from a.owl in the given directory
OntModelSpec spec = new OntModelSpec( null, dm, null, ProfileRegistry.OWL_LANG );
OntModel m = ModelFactory.createOntologyModel( spec, null );
assertNotNull( "Ontology model should not be null", m );
m.read( "file:" + m_dir + "/a.owl" );
assertEquals( "Marker count not correct", m_count, countMarkers( m ));
}
}
static class TestFailHandler
implements ReadFailureHandler
{
public boolean m_seen = false;
public void handleFailedRead( String url, Model model, Exception e ) {
m_seen = true;
log.debug( "Seeing failed read of " + url, e );
}
}
static class TestReadHook
implements OntDocumentManager.ReadHook
{
private int m_before = 0;
private int m_after = 0;
private boolean m_renaming = false;
TestReadHook( boolean renaming ) {
m_renaming = renaming;
}
public void afterRead( Model model, String source, OntDocumentManager odm ) {
m_after++;
}
public String beforeRead( Model model, String source, OntDocumentManager odm ) {
if (m_renaming) {
// local rewrite of the source file, which could be used e.g. to
// get the source from a .jar file
m_before++;
return "file:testing/ontology/testImport3/c.owl";
}
else {
m_before++;
return source;
}
}
}
}
/*
(c) Copyright 2002, 2003, 2004, 2005, 2006, 2007 Hewlett-Packard Development Company, LP
All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
3. The name of the author may not be used to endorse or promote products
derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -