495821f1b2
Reviewed-by: lancea
197 lines
8.3 KiB
Java
197 lines
8.3 KiB
Java
/*
|
|
* 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 validation.jdk8036951;
|
|
|
|
import java.io.File;
|
|
import java.io.FileNotFoundException;
|
|
import java.net.URL;
|
|
import javax.xml.XMLConstants;
|
|
import javax.xml.transform.Source;
|
|
import javax.xml.transform.stream.StreamSource;
|
|
import javax.xml.validation.Schema;
|
|
import javax.xml.validation.SchemaFactory;
|
|
import javax.xml.validation.Validator;
|
|
import org.testng.annotations.AfterClass;
|
|
import org.testng.annotations.BeforeClass;
|
|
import org.testng.annotations.Test;
|
|
import org.xml.sax.SAXException;
|
|
import org.xml.sax.SAXNotRecognizedException;
|
|
import org.xml.sax.SAXNotSupportedException;
|
|
import validation.BaseTest;
|
|
|
|
/**
|
|
* @author Peter McCracken, IBM
|
|
* @version $Id$
|
|
*/
|
|
public class FeaturePropagationTest extends BaseTest {
|
|
|
|
public final String FEATURE_STRING_DEFAULT_FALSE = "http://apache.org/xml/features/honour-all-schemaLocations";
|
|
public final String FEATURE_STRING_DEFAULT_TRUE = "http://apache.org/xml/features/validation/schema-full-checking";
|
|
public final String SECURITY_MANAGER = "http://apache.org/xml/properties/security-manager";
|
|
|
|
public FeaturePropagationTest(String name) {
|
|
super(name);
|
|
}
|
|
|
|
@BeforeClass
|
|
protected void setUp() throws Exception {
|
|
super.setUp();
|
|
}
|
|
|
|
@AfterClass
|
|
protected void tearDown() throws Exception {
|
|
super.tearDown();
|
|
}
|
|
|
|
@Test
|
|
public void testPropertyReset() throws Exception {
|
|
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
|
Schema schema = makeSchema(factory, null);
|
|
Validator validator = schema.newValidator();
|
|
Object beforeReset = validator.getProperty(SECURITY_MANAGER);
|
|
validator.setProperty(SECURITY_MANAGER, null);
|
|
Object changed = validator.getProperty(SECURITY_MANAGER);
|
|
//for JDK, this is changed since by default the security manager is set
|
|
assertTrue("Property value should have changed after calling setProperty().", beforeReset != changed);
|
|
validator.reset();
|
|
Object afterReset = validator.getProperty(SECURITY_MANAGER);
|
|
assertTrue("Property value should be the same after calling reset()", beforeReset == afterReset);
|
|
}
|
|
|
|
@Test
|
|
public void testFeatureReset() throws Exception {
|
|
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
|
Schema schema = makeSchema(factory, null);
|
|
Validator validator = schema.newValidator();
|
|
validator.setFeature(FEATURE_STRING_DEFAULT_TRUE, false);
|
|
validator.setFeature(FEATURE_STRING_DEFAULT_FALSE, true);
|
|
validator.reset();
|
|
boolean value = validator.getFeature(FEATURE_STRING_DEFAULT_TRUE);
|
|
assertTrue("After reset, value of feature on Validator should be true.", value);
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_FALSE);
|
|
assertFalse("After reset, value of feature on Validator should be false.", value);
|
|
}
|
|
|
|
@Test
|
|
public void testSecureProcessingFeaturePropagationAndReset() throws Exception {
|
|
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
|
boolean value;
|
|
value = factory.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING);
|
|
//default is true for JDK
|
|
//assertFalse("Default value of feature on SchemaFactory should have been false.", value);
|
|
assertTrue("Default value of feature on SchemaFactory should have been false.", value);
|
|
factory.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);
|
|
Schema schema = makeSchema(factory, null);
|
|
Validator validator = schema.newValidator();
|
|
value = validator.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING);
|
|
assertTrue("Value of feature on Validator should have been true.", value);
|
|
validator.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, false);
|
|
value = validator.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING);
|
|
assertFalse("Value of feature on Validator should have been false.", value);
|
|
validator.reset();
|
|
value = validator.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING);
|
|
assertTrue("After reset, value of feature on Validator should be true.", value);
|
|
}
|
|
/*
|
|
* Using four basically identical tests to try out the different
|
|
* instance classes of Schema. They shouldn't differ, because the relevant
|
|
* code is in a common base class.
|
|
*/
|
|
|
|
@Test
|
|
public void testFeaturePropagationNull() throws Exception {
|
|
checkFeaturesOnValidator(null);
|
|
}
|
|
|
|
@Test
|
|
public void testFeaturePropagationEmpty() throws Exception {
|
|
checkFeaturesOnValidator(new Source[] {});
|
|
}
|
|
|
|
@Test
|
|
public void testFeaturePropagationSingle() throws Exception {
|
|
checkFeaturesOnValidator(new Source[] {makeSource("base.xsd")});
|
|
}
|
|
|
|
@Test
|
|
public void testFeaturePropagationMultiple() throws Exception {
|
|
checkFeaturesOnValidator(new Source[] {makeSource("base.xsd"), makeSource("idc.xsd")});
|
|
}
|
|
|
|
private void checkFeaturesOnValidator(Source[] sources) throws Exception {
|
|
try {
|
|
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
|
Schema schema = makeSchema(factory, sources);
|
|
Validator validator = schema.newValidator();
|
|
boolean value;
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_TRUE);
|
|
assertTrue("Default value of feature on Validator should have been true.", value);
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_FALSE);
|
|
assertFalse("Default value of feature on Validator should have been false.", value);
|
|
|
|
// checking that the value propagates to the validator
|
|
factory.setFeature(FEATURE_STRING_DEFAULT_TRUE, false);
|
|
factory.setFeature(FEATURE_STRING_DEFAULT_FALSE, true);
|
|
schema = makeSchema(factory, sources);
|
|
validator = schema.newValidator();
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_TRUE);
|
|
assertFalse("Value of feature on Validator should have been false.", value);
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_FALSE);
|
|
assertTrue("Value of feature on Validator should have been true.", value);
|
|
|
|
// checking that the validator contains a copy of the features, not a reference
|
|
factory.setFeature(FEATURE_STRING_DEFAULT_TRUE, true);
|
|
factory.setFeature(FEATURE_STRING_DEFAULT_FALSE, false);
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_TRUE);
|
|
assertFalse("Value of feature on Validator should have stayed false.", value);
|
|
value = validator.getFeature(FEATURE_STRING_DEFAULT_FALSE);
|
|
assertTrue("Value of feature on Validator should have stayed true.", value);
|
|
}
|
|
catch (SAXNotRecognizedException e) {
|
|
fail(e.getMessage());
|
|
}
|
|
catch (SAXNotSupportedException e) {
|
|
fail(e.getMessage());
|
|
}
|
|
}
|
|
|
|
private Schema makeSchema(SchemaFactory factory, Source[] sources) throws SAXException {
|
|
if (sources == null) {
|
|
return factory.newSchema();
|
|
}
|
|
else {
|
|
return factory.newSchema(sources);
|
|
}
|
|
}
|
|
|
|
private Source makeSource(String xsd) throws FileNotFoundException {
|
|
return new StreamSource(fSchemaURL.toExternalForm());
|
|
}
|
|
|
|
@Override
|
|
protected String getSchemaFile() {
|
|
return "base.xsd";
|
|
}
|
|
|
|
@Override
|
|
protected String getXMLDocument() {
|
|
//not needed
|
|
return null;
|
|
}
|
|
}
|