| /* |
| * Copyright (c) 1998, 2021 Oracle and/or its affiliates. All rights reserved. |
| * |
| * This program and the accompanying materials are made available under the |
| * terms of the Eclipse Public License v. 2.0 which is available at |
| * http://www.eclipse.org/legal/epl-2.0, |
| * or the Eclipse Distribution License v. 1.0 which is available at |
| * http://www.eclipse.org/org/documents/edl-v10.php. |
| * |
| * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause |
| */ |
| |
| // Contributors: |
| // dmccann - June 17/2009 - 2.0 - Initial implementation |
| package org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.field; |
| |
| import java.io.InputStream; |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| import java.util.List; |
| import java.util.Map; |
| |
| import javax.xml.transform.Source; |
| import javax.xml.transform.stream.StreamSource; |
| |
| import org.eclipse.persistence.jaxb.JAXBContextFactory; |
| import org.eclipse.persistence.jaxb.JAXBContextProperties; |
| import org.eclipse.persistence.testing.jaxb.JAXBWithJSONTestCases; |
| |
| /** |
| * Tests class level @XmlAccessorType override via eclipselink-oxm.xml. |
| * Here, the Employee object has the access set to 'NONE', but this is |
| * overridden as 'FIELD'. |
| * |
| * Positive test. |
| */ |
| public class XmlAccessorTypeFieldTestCases extends JAXBWithJSONTestCases { |
| private static final String XML_RESOURCE = "org/eclipse/persistence/testing/jaxb/externalizedmetadata/xmlaccessortype/employee-field.xml"; |
| private static final String JSON_RESOURCE = "org/eclipse/persistence/testing/jaxb/externalizedmetadata/xmlaccessortype/employee-field.json"; |
| |
| /** |
| * This is the preferred (and only) constructor. |
| * |
| */ |
| public XmlAccessorTypeFieldTestCases(String name) throws Exception{ |
| super(name); |
| setClasses(new Class[]{Employee.class}); |
| setControlDocument(XML_RESOURCE); |
| setControlJSON(JSON_RESOURCE); |
| } |
| |
| @Override |
| protected Object getControlObject() { |
| Employee emp = new Employee(666); |
| emp.firstName = "firstName"; |
| emp.lastName = "lastName"; |
| return emp; |
| } |
| |
| @Override |
| public Map getProperties(){ |
| InputStream inputStream = ClassLoader.getSystemResourceAsStream("org/eclipse/persistence/testing/jaxb/externalizedmetadata/xmlaccessortype/field/eclipselink-oxm.xml"); |
| |
| HashMap<String, Source> metadataSourceMap = new HashMap<String, Source>(); |
| metadataSourceMap.put("org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.field", new StreamSource(inputStream)); |
| Map<String, Map<String, Source>> properties = new HashMap<String, Map<String, Source>>(); |
| properties.put(JAXBContextProperties.OXM_METADATA_SOURCE, metadataSourceMap); |
| |
| return properties; |
| } |
| |
| public void testInstanceDocValidation() throws Exception { |
| InputStream schema = ClassLoader.getSystemResourceAsStream("org/eclipse/persistence/testing/jaxb/externalizedmetadata/xmlaccessortype/field/employee-field.xsd"); |
| StreamSource schemaSource = new StreamSource(schema); |
| |
| MyMapStreamSchemaOutputResolver outputResolver = new MyMapStreamSchemaOutputResolver(); |
| getJAXBContext().generateSchema(outputResolver); |
| |
| InputStream instanceDocStream = ClassLoader.getSystemResourceAsStream(XML_RESOURCE); |
| String result = validateAgainstSchema(instanceDocStream, schemaSource, outputResolver ); |
| assertTrue("Instance doc validation (employee.xml) failed unxepectedly: " + result, result == null); |
| } |
| |
| public void testSchemaGen() throws Exception{ |
| List controlSchemas = new ArrayList(); |
| InputStream is = ClassLoader.getSystemResourceAsStream("org/eclipse/persistence/testing/jaxb/externalizedmetadata/xmlaccessortype/field/employee-field.xsd"); |
| controlSchemas.add(is); |
| super.testSchemaGen(controlSchemas); |
| } |
| |
| |
| /** |
| * Tests class level @XmlAccessorType override via eclipselink-oxm.xml. |
| * Here, the Employee object has the access set to 'NONE', but this is |
| * overridden as 'PROPERTY'. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testXmlAccessorTypePropertyOverride() { |
| String contextPath = CONTEXT_PATH + ".property"; |
| String path = PATH + "property/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.property.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-property.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| } |
| */ |
| /** |
| * Tests class level @XmlAccessorType override via eclipselink-oxm.xml. |
| * Here, the Employee object has the access set to 'NONE', but this is |
| * overridden as 'PUBLIC_MEMBER'. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testXmlAccessorTypePublicMemberOverride() { |
| String contextPath = CONTEXT_PATH + ".publicmember"; |
| String path = PATH + "publicmember/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.publicmember.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-publicmember.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| }*/ |
| /** |
| * Tests overriding @XmlAccessorType set in package-info.java via eclipselink-oxm.xml. |
| * Here, package-info has the access set to 'PROPERTY', but this is |
| * overridden as 'FIELD'. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testXmlAccessorTypePackageLevelOverride() { |
| String contextPath = CONTEXT_PATH + ".packagelevel"; |
| String path = PATH + "packagelevel/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.packagelevel.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-field.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| } |
| */ |
| /** |
| * Tests overriding @XmlAccessorType set at the package level in eclipselink-oxm.xml |
| * via class level override. Here, the package level setting is 'PROPERTY', which |
| * is overridden for Employee as 'PUBLIC_MEMBER'. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testXmlAccessorTypeClassOverridesPackage() { |
| String contextPath = CONTEXT_PATH + ".packagelevel.classoverride"; |
| String path = PATH + "packagelevel/classoverride/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.packagelevel.classoverride.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-publicmember.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| } |
| */ |
| /** |
| * Tests the @XmlAccessorType set in the java class will override one set in |
| * eclipselink-oxm.xml at the package level. eclipselink-oxm.xml will have |
| * 'PUBLIC_MEMBER' at the package level, but it will be set to 'FIELD' in the |
| * java class. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testXmlAccessorOrderJavaClassOverridesPackage() { |
| String contextPath = CONTEXT_PATH + ".packagelevel.javaclassoverride"; |
| String path = PATH + "packagelevel/javaclassoverride/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.packagelevel.javaclassoverride.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-field.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| } |
| */ |
| /** |
| * Tests the @XmlAccessorType set in package-info.java. No overrides will |
| * be performed. |
| * |
| * Positive test. |
| */ |
| /* |
| public void testPkgXmlAccessorOrderNoOverride() { |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.packagelevel.nooverride.Employee.class }, 1); |
| |
| String src = PATH + "employee-none.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation failed unxepectedly: " + result, result == null); |
| } |
| */ |
| /** |
| * Tests the @XmlAccessorType set in package-info.java. No overrides will |
| * be performed. |
| * |
| * Negative test. |
| */ |
| /* |
| public void testPkgXmlAccessorOrderNoOverrideFail() { |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.packagelevel.nooverride.Employee.class }, 1); |
| |
| String src = PATH + "employee-property.xml"; |
| // since package-info sets to NONE, the following should fail |
| String result = validateAgainstSchema(src, null, outputResolver); |
| assertTrue("Schema validation passed unxepectedly", result != null); |
| } |
| |
| public void testNoAccessTypePropertiesAdded() { |
| String contextPath = CONTEXT_PATH + ".none"; |
| String path = PATH + "none/"; |
| |
| outputResolver = generateSchema(new Class[] { org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlaccessortype.none.Employee.class }, contextPath, path, 1); |
| |
| String src = PATH + "employee-no-access.xml"; |
| String result = validateAgainstSchema(src, EMPTY_NAMESPACE, outputResolver); |
| assertTrue("Schema validation passed unxepectedly " + result, result == null); |
| } |
| */ |
| } |