📄 testmodelexpansion.java
字号:
/*
(c) Copyright 2006, 2007 Hewlett-Packard Development Company, LP
All rights reserved - see end of file.
$Id: TestModelExpansion.java,v 1.5 2007/01/02 11:52:50 andy_seaborne Exp $
*/
package com.hp.hpl.jena.assembler.test;
import java.util.*;
import com.hp.hpl.jena.assembler.ModelExpansion;
import com.hp.hpl.jena.rdf.model.*;
public class TestModelExpansion extends AssemblerTestBase
{
public TestModelExpansion( String name )
{ super( name ); }
public void testAddsSubclasses()
{
Model base = model( "a R b" );
Model schema = model( "x rdfs:subClassOf y; y P z" );
Model answer = ModelExpansion.withSchema( base, schema );
assertIsoModels( model( "a R b; x rdfs:subClassOf y" ), answer );
}
public void testOmitsAnonynousSubclasses()
{
Model base = model( "a R b" );
Model schema = model( "x rdfs:subClassOf _y; z rdfs:subClassOf _a" );
Model answer = ModelExpansion.withSchema( base, schema );
assertIsoModels( model( "a R b" ), answer );
}
public void testAddsDomainTypes()
{
Model base = model( "a R b" );
Model schema = model( "R rdfs:domain T" );
Model answer = ModelExpansion.withSchema( base, schema );
assertIsoModels( model( "a R b; a rdf:type T" ), answer );
}
public void testAddsRangeTypes()
{
Model base = model( "a R b" );
Model schema = model( "R rdfs:range T" );
Model answer = ModelExpansion.withSchema( base, schema );
assertIsoModels( model( "a R b; b rdf:type T" ), answer );
}
public void testLabelsDontCrashExpansion()
{
Model base = ModelFactory.createRDFSModel( model( "a R b; a rdfs:label 'hello'" ) );
Model schema = ModelFactory.createRDFSModel( model( "R rdfs:range T" ) );
Model answer = ModelExpansion.withSchema( base, schema );
}
public void testIntersection()
{
testIntersection( "x rdf:type T; x rdf:type U", true, "T U" );
testIntersection( "x rdf:type T; x rdf:type U", true, "T" );
testIntersection( "x rdf:type T; x rdf:type U", false, "T U V" );
testIntersection( "x rdf:type T; x rdf:type U; x rdf:type V", true, "T U V" );
}
private void testIntersection( String xTyped, boolean infers, String intersectionTypes )
{
Model base = model( xTyped );
Model schema = intersectionModel( "I", intersectionTypes );
Model answer = ModelExpansion.withSchema( base, schema );
assertEquals( "should [not] infer (x rdf:type I)", infers, answer.contains( statement( "x rdf:type I" ) ) );
}
private Model intersectionModel( String inter, String types )
{
return model( "I owl:equivalentClass _L; _L owl:intersectionOf _L1" + rdfList( "_L", types ) );
}
private String rdfList( String base, String types )
{
StringBuffer result = new StringBuffer();
List L = listOfStrings( types );
String rest = "rdf:nil";
for (int i = L.size(); i > 0; i -= 1)
{
String current = base + i;
result.append( "; " ).append( current ).append( " rdf:rest " ).append( rest );
result.append( "; " ).append( current ).append( " rdf:first " ).append( L.get(i-1) );
rest = current;
}
return result.toString();
}
public void testAddsSupertypes()
{
Model base = model( "a rdf:type T; T rdfs:subClassOf U" );
Model schema = model( "T rdfs:subClassOf V" );
Model answer = ModelExpansion.withSchema( base, schema );
assertIsoModels( model( "a rdf:type T; a rdf:type U; a rdf:type V; T rdfs:subClassOf U; T rdfs:subClassOf V" ), answer );
}
}
/*
* (c) Copyright 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 + -