blob: bf3c8fcc9dade820c576f44172078c429459c3ce [file] [log] [blame]
/*
* 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 org.apache.axis2.jaxws.message.databinding;
import org.apache.axis2.jaxws.message.databinding.JAXBUtils.CONSTRUCTION_TYPE;
import org.apache.ws.jaxb.a.BadData1;
import org.apache.ws.jaxb.a.BadData2;
import org.apache.ws.jaxb.a.Data1;
import org.apache.ws.jaxb.a.Data2;
import org.apache.ws.jaxb.a.Data3;
import org.apache.ws.jaxb.b.BadData3;
import javax.xml.bind.JAXBContext;
import javax.xml.ws.Holder;
import java.util.TreeSet;
import junit.framework.TestCase;
/**
* Test JAXBUtils functionality
*/
public class JAXBUtilsTests extends TestCase {
/**
* We have encountered situations where users have intermingled
* JAXB and non-JAXB classes in the same package. This practice is
* strongly discouraged; however it can happen.
* The JAXBUtils code (actually JAXBContextFromClasses) contains
* an algorithm to try and find the minimal set of valid classes
* in these cases.
*
* This test validates the code. Several good JAXB classes
* (all named Data*) are intermingled in packaes with non-JAXB classes
* (all named BadData*). This test passes if the JAXBContext contains
* the Data classes and excludes the BadData classes.
* @throws Exception
*/
public void testMixedPackages() throws Exception {
// Create a JAXBContext
TreeSet<String> contextPackages = new TreeSet<String>();
contextPackages.add("org.apache.ws.jaxb.a");
contextPackages.add("org.apache.ws.jaxb.b");
Holder<CONSTRUCTION_TYPE>constructionType = new Holder<CONSTRUCTION_TYPE>();
JAXBContext jbc = JAXBUtils.getJAXBContext(contextPackages, constructionType,
contextPackages.toString());
// The toString method lists all of the contained classes.
String jbcString = jbc.toString();
// Make sure the good Data is in the JAXBContext
assertTrue(jbcString.indexOf(Data1.class.getName()) > 0);
assertTrue(jbcString.indexOf(Data2.class.getName()) > 0);
assertTrue(jbcString.indexOf(Data3.class.getName()) > 0);
// Make sure the bad Data is not in the JAXBContext
assertTrue(jbcString.indexOf(BadData1.class.getName()) < 0);
assertTrue(jbcString.indexOf(BadData2.class.getName()) < 0);
assertTrue(jbcString.indexOf(BadData3.class.getName()) < 0);
}
}