From 9833a542bb75c2008c71809e4fdfebc41e67fb46 Mon Sep 17 00:00:00 2001 From: lresende Date: Tue, 10 Nov 2009 19:18:51 +0000 Subject: Move the SDO folder as new trunk for SDO sub project git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@834610 13f79535-47bb-0310-9956-ffa450edef68 --- .../test/java/org/apache/tuscany/sdo/AllTests.java | 41 + .../org/apache/tuscany/sdo/codegen/AllTests.java | 47 + .../java/org/apache/tuscany/sdo/codegen/Bar1.java | 26 + .../java/org/apache/tuscany/sdo/codegen/Bar2.java | 26 + .../BytecodeInterfaceGeneratorTestCase.java | 167 ++ .../java/org/apache/tuscany/sdo/codegen/Foo.java | 26 + .../codegen/JavaInterfaceGeneratorTestCase.java | 129 ++ .../apache/tuscany/sdo/codegen/MockProperty.java | 94 + .../org/apache/tuscany/sdo/codegen/MockType.java | 104 ++ .../java/org/apache/tuscany/sdo/test/AllTests.java | 87 + .../org/apache/tuscany/sdo/test/AnyTypeTest.java | 112 ++ .../apache/tuscany/sdo/test/BoundsTestCase.java | 79 + .../test/ChangeSummaryOnDataObjectTestCase.java | 216 +++ .../sdo/test/ChangeSummaryPropertyTestCase.java | 219 +++ .../tuscany/sdo/test/ChangeSummaryTestCase.java | 92 + .../tuscany/sdo/test/ContainmentCycleTestCase.java | 866 +++++++++ .../tuscany/sdo/test/ContainmentTypeUtil.java | 86 + .../tuscany/sdo/test/CrossScopeCopyTestCase.java | 474 +++++ .../apache/tuscany/sdo/test/DataGraphTestCase.java | 270 +++ .../sdo/test/DataObjectGetListTestCase.java | 129 ++ .../tuscany/sdo/test/DataTypeBaseTypeTestCase.java | 68 + .../tuscany/sdo/test/DateConversionTestCase.java | 380 ++++ .../test/DefineOpenContentPropertyTestCase.java | 133 ++ .../tuscany/sdo/test/DefineTypeTestCase.java | 704 ++++++++ .../sdo/test/DeserializationNoSchemaTestCase.java | 124 ++ .../org/apache/tuscany/sdo/test/DotNameTest.java | 78 + .../tuscany/sdo/test/DupElementTestCase.java | 99 ++ .../sdo/test/DynamicTypesComparisonTestCase.java | 256 +++ .../sdo/test/ExpectedExceptionsTestCase.java | 1878 ++++++++++++++++++++ .../org/apache/tuscany/sdo/test/FormTestCase.java | 112 ++ .../tuscany/sdo/test/HelperContextTestCase.java | 75 + .../tuscany/sdo/test/ImplSpecificTestCase.java | 74 + .../apache/tuscany/sdo/test/IsManyTestCase.java | 65 + .../sdo/test/JavaSerializeDeserializeTestCase.java | 297 ++++ .../org/apache/tuscany/sdo/test/JiraTestCases.java | 184 ++ .../test/MetadataInstancePropertiesTestCase.java | 243 +++ .../apache/tuscany/sdo/test/MixedTypeTestCase.java | 89 + .../sdo/test/NeverStaleChangeSummaryTestCase.java | 76 + .../tuscany/sdo/test/NotificationTestCase.java | 186 ++ .../apache/tuscany/sdo/test/OpenTypeTestCase.java | 139 ++ .../tuscany/sdo/test/SchemaLocationTestCase.java | 48 + .../apache/tuscany/sdo/test/SequenceTestCase.java | 100 ++ .../tuscany/sdo/test/SerializeTypesTestCase.java | 190 ++ .../tuscany/sdo/test/SimpleCopyTestCase.java | 71 + .../tuscany/sdo/test/SimpleDynamicTestCase.java | 123 ++ .../tuscany/sdo/test/SimpleEqualityTestCase.java | 91 + .../sdo/test/SubstitutionValuesTestCase.java | 83 + .../java/org/apache/tuscany/sdo/test/TestUtil.java | 285 +++ .../tuscany/sdo/test/TypeConversionTestCase.java | 1007 +++++++++++ .../tuscany/sdo/test/TypeHelperTestCase.java | 45 + .../tuscany/sdo/test/TypeRoundTripTestCase.java | 147 ++ .../tuscany/sdo/test/XMLDocumentTestCase.java | 110 ++ .../apache/tuscany/sdo/test/XMLHelperTestCase.java | 314 ++++ .../tuscany/sdo/test/XMLLoadOptionsTestCase.java | 192 ++ .../sdo/test/XMLLoadUnknownFeatureTestCase.java | 51 + .../tuscany/sdo/test/XMLSaveOptionsTestCase.java | 147 ++ .../test/XMLStreamHelperPerformanceTestCase.java | 91 + .../tuscany/sdo/test/XMLStreamHelperTestCase.java | 195 ++ .../sdo/test/XMLUnknownPropertiesTestCase.java | 132 ++ .../org/apache/tuscany/sdo/test/XPathTestCase.java | 125 ++ .../apache/tuscany/sdo/test/XSDHelperTestCase.java | 224 +++ .../apache/tuscany/sdo/test/XSDQNameTestCase.java | 123 ++ .../tuscany/sdo/test/osgi/ClassLoaderTestCase.java | 192 ++ .../apache/tuscany/sdo/test/osgi/OSGiTestCase.java | 354 ++++ .../tuscany/sdo/test/osgi/TestBundleActivator.java | 66 + 65 files changed, 13056 insertions(+) create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/AllTests.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/AllTests.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar1.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar2.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/BytecodeInterfaceGeneratorTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Foo.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/JavaInterfaceGeneratorTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockProperty.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockType.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AllTests.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AnyTypeTest.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/BoundsTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryOnDataObjectTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryPropertyTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentCycleTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentTypeUtil.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/CrossScopeCopyTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataGraphTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataObjectGetListTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataTypeBaseTypeTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DateConversionTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineOpenContentPropertyTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineTypeTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DeserializationNoSchemaTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DotNameTest.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DupElementTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DynamicTypesComparisonTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ExpectedExceptionsTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/FormTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/HelperContextTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ImplSpecificTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/IsManyTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JavaSerializeDeserializeTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JiraTestCases.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MetadataInstancePropertiesTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MixedTypeTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NeverStaleChangeSummaryTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NotificationTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/OpenTypeTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SchemaLocationTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SequenceTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SerializeTypesTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleCopyTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleDynamicTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleEqualityTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SubstitutionValuesTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TestUtil.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TypeConversionTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TypeHelperTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TypeRoundTripTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLDocumentTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLHelperTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadOptionsTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadUnknownFeatureTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLSaveOptionsTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperPerformanceTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLUnknownPropertiesTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XPathTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDHelperTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDQNameTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/ClassLoaderTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/OSGiTestCase.java create mode 100644 sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/TestBundleActivator.java (limited to 'sdo-java/trunk/impl/src/test/java/org/apache/tuscany') diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/AllTests.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/AllTests.java new file mode 100644 index 0000000000..7d91456137 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/AllTests.java @@ -0,0 +1,41 @@ +/** + * + * 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.tuscany.sdo; +import junit.framework.Test; +import junit.framework.TestSuite; + +public class AllTests { + + public static Test suite() { + + TestSuite suite = new TestSuite(); + + suite.addTest(org.apache.tuscany.sdo.codegen.AllTests.suite()); + suite.addTest(org.apache.tuscany.sdo.test.AllTests.suite()); + + return suite; + } + + + public static void main(String[] args) { + junit.textui.TestRunner.run(suite()); + } +} + diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/AllTests.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/AllTests.java new file mode 100644 index 0000000000..d67b53fb7c --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/AllTests.java @@ -0,0 +1,47 @@ +/** + * + * 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.tuscany.sdo.codegen; +import junit.framework.Test; +import junit.framework.TestSuite; + +public class AllTests { + + + public static TestSuite suite() { + + TestSuite suite = new TestSuite(); + + suite.addTestSuite(BytecodeInterfaceGeneratorTestCase.class); + suite.addTestSuite(JavaInterfaceGeneratorTestCase.class); + + + return suite; + } + + + /** + * Runs the test suite using the textual runner. + */ + public static void main(String[] args) { + junit.textui.TestRunner.run(suite()); + } +} + diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar1.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar1.java new file mode 100644 index 0000000000..4a51310cd0 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar1.java @@ -0,0 +1,26 @@ +/** + * + * 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.tuscany.sdo.codegen; + +/** + * @version $Rev$ $Date$ + */ +public interface Bar1 { +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar2.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar2.java new file mode 100644 index 0000000000..e9151b9d46 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Bar2.java @@ -0,0 +1,26 @@ +/** + * + * 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.tuscany.sdo.codegen; + +/** + * @version $Rev$ $Date$ + */ +public interface Bar2 { +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/BytecodeInterfaceGeneratorTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/BytecodeInterfaceGeneratorTestCase.java new file mode 100644 index 0000000000..218a725226 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/BytecodeInterfaceGeneratorTestCase.java @@ -0,0 +1,167 @@ +/** + * + * 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.tuscany.sdo.codegen; + +import java.lang.reflect.Method; +import java.util.List; + +import junit.framework.TestCase; + +/** + * @version $Rev$ $Date$ + */ +public class BytecodeInterfaceGeneratorTestCase extends TestCase { + private MockType foo; + private BytecodeInterfaceGenerator gen; + private TestClassLoader cl; + + public void testHeaderNoBaseClass() { + gen.visitType(foo); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals("Foo", c.getName()); + assertTrue(c.isInterface()); + assertEquals(0, c.getInterfaces().length); + assertEquals(0, c.getMethods().length); + } + + public void testHeaderWithPackage() { + gen.visitType(new MockType("org.apache.Foo", null)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals("org.apache.Foo", c.getName()); + assertEquals(0, c.getInterfaces().length); + assertEquals(0, c.getMethods().length); + } + + public void testHeaderOneBaseClass() throws NoJavaImplementationException { + foo.addBaseType(new MockType("bar1", Bar1.class)); + gen.visitType(foo); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals("Foo", c.getName()); + assertEquals(1, c.getInterfaces().length); + assertEquals(Bar1.class, c.getInterfaces()[0]); + assertEquals(0, c.getMethods().length); + } + + public void testHeaderMultipleBaseClass() throws NoJavaImplementationException { + foo.addBaseType(new MockType("bar1", Bar1.class)); + foo.addBaseType(new MockType("bar2", Bar2.class)); + gen.visitType(foo); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals("Foo", c.getName()); + assertEquals(2, c.getInterfaces().length); + assertEquals(Bar1.class, c.getInterfaces()[0]); + assertEquals(Bar2.class, c.getInterfaces()[1]); + assertEquals(0, c.getMethods().length); + } + + public void testBooleanProperty() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("true", Boolean.TYPE, false, false)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(2, c.getMethods().length); + Method getter = c.getMethod("isTrue", new Class[0]); + assertEquals(boolean.class, getter.getReturnType()); + Method setter = c.getMethod("setTrue", new Class[] {boolean.class}); + assertEquals(void.class, setter.getReturnType()); + } + + public void testByteArrayProperty() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("bytes", byte[].class, false, false)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(2, c.getMethods().length); + Method getter = c.getMethod("getBytes", new Class[0]); + assertEquals(byte[].class, getter.getReturnType()); + Method setter = c.getMethod("setBytes", new Class[] {byte[].class}); + assertEquals(void.class, setter.getReturnType()); + } + + public void testObjectProperty() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("bar", Bar1.class, false, false)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(2, c.getMethods().length); + Method getter = c.getMethod("getBar", new Class[0]); + assertEquals(Bar1.class, getter.getReturnType()); + Method setter = c.getMethod("setBar", new Class[] {Bar1.class}); + assertEquals(void.class, setter.getReturnType()); + } + + public void testReadOnlyProperty() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("int", Integer.TYPE, false, true)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(1, c.getMethods().length); + Method getter = c.getMethod("getInt", new Class[0]); + assertEquals(int.class, getter.getReturnType()); + } + + public void testManyProperty() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("list", Integer.TYPE, true, false)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(1, c.getMethods().length); + Method getter = c.getMethod("getList", new Class[0]); + assertEquals(List.class, getter.getReturnType()); + } + + public void testTwoProperties() throws NoJavaImplementationException, NoSuchMethodException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("true", Boolean.TYPE, false, false)); + gen.visitProperty(new MockProperty("int", Integer.TYPE, false, false)); + gen.visitEnd(); + Class c = cl.addClass(gen.getClassData()); + assertEquals(4, c.getMethods().length); + Method getter = c.getMethod("isTrue", new Class[0]); + assertEquals(boolean.class, getter.getReturnType()); + Method setter = c.getMethod("setTrue", new Class[] {boolean.class}); + assertEquals(void.class, setter.getReturnType()); + getter = c.getMethod("getInt", new Class[0]); + assertEquals(int.class, getter.getReturnType()); + setter = c.getMethod("setInt", new Class[] {int.class}); + assertEquals(void.class, setter.getReturnType()); + } + + protected void setUp() throws Exception { + super.setUp(); + foo = new MockType("foo", null); + gen = new BytecodeInterfaceGenerator(); + cl = new TestClassLoader(); + } + + private class TestClassLoader extends ClassLoader { + public TestClassLoader() { + super(TestClassLoader.class.getClassLoader()); + } + + Class addClass(byte[] bytes) { + return defineClass(null, bytes, 0, bytes.length); + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Foo.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Foo.java new file mode 100644 index 0000000000..56bf6af9b4 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/Foo.java @@ -0,0 +1,26 @@ +/** + * + * 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.tuscany.sdo.codegen; + +/** + * @version $Rev$ $Date$ + */ +public interface Foo { +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/JavaInterfaceGeneratorTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/JavaInterfaceGeneratorTestCase.java new file mode 100644 index 0000000000..6cc0529c5f --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/JavaInterfaceGeneratorTestCase.java @@ -0,0 +1,129 @@ +/** + * + * 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.tuscany.sdo.codegen; + +import java.io.PrintWriter; +import java.io.StringWriter; + +import junit.framework.TestCase; + +/** + * @version $Rev$ $Date$ + */ +public class JavaInterfaceGeneratorTestCase extends TestCase { + private static final String SEP = System.getProperty("line.separator"); + + private JavaInterfaceGenerator gen; + private StringWriter writer; + private MockType foo; + + public void testHeaderNoBaseClass() { + gen.visitType(foo); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n}\n"), writer.toString()); + } + + public void testHeaderWithPackage() { + gen.visitType(new MockType("org.apache.Foo", null)); + gen.visitEnd(); + assertEquals(localize("package org.apache;\n\npublic interface Foo {\n}\n"), writer.toString()); + } + + public void testHeaderOneBaseClass() throws NoJavaImplementationException { + foo.addBaseType(new MockType("bar1", Bar1.class)); + gen.visitType(foo); + gen.visitEnd(); + assertEquals(localize("public interface Foo extends org.apache.tuscany.sdo.codegen.Bar1 {\n}\n"), writer.toString()); + } + + public void testHeaderMultipleBaseClass() throws NoJavaImplementationException { + foo.addBaseType(new MockType("bar1", Bar1.class)); + foo.addBaseType(new MockType("bar2", Bar2.class)); + gen.visitType(foo); + gen.visitEnd(); + assertEquals(localize("public interface Foo extends org.apache.tuscany.sdo.codegen.Bar1, org.apache.tuscany.sdo.codegen.Bar2 {\n}\n"), writer.toString()); + } + + public void testBooleanProperty() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("true", Boolean.TYPE, false, false)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\tboolean isTrue();\n\tvoid setTrue(boolean value);\n}\n"), writer.toString()); + } + + public void testByteArrayProperty() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("bytes", byte[].class, false, false)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\tbyte[] getBytes();\n\tvoid setBytes(byte[] value);\n}\n"), writer.toString()); + } + + public void testObjectProperty() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("bar", Bar1.class, false, false)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\torg.apache.tuscany.sdo.codegen.Bar1 getBar();\n\tvoid setBar(org.apache.tuscany.sdo.codegen.Bar1 value);\n}\n"), writer.toString()); + } + + public void testReadOnlyProperty() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("int", Integer.TYPE, false, true)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\tint getInt();\n}\n"), writer.toString()); + } + + public void testManyProperty() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("list", Integer.TYPE, true, false)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\tjava.util.List getList();\n}\n"), writer.toString()); + } + + public void testTwoProperties() throws NoJavaImplementationException { + gen.visitType(foo); + gen.visitProperty(new MockProperty("true", Boolean.TYPE, false, false)); + gen.visitProperty(new MockProperty("int", Integer.TYPE, false, false)); + gen.visitEnd(); + assertEquals(localize("public interface Foo {\n\tboolean isTrue();\n\tvoid setTrue(boolean value);\n\tint getInt();\n\tvoid setInt(int value);\n}\n"), writer.toString()); + } + + protected void setUp() throws Exception { + super.setUp(); + writer = new StringWriter(); + gen = new JavaInterfaceGenerator(new PrintWriter(writer)); + foo = new MockType("foo", null); + } + + private String localize(String s) { + StringBuffer b = new StringBuffer(s.length() + s.length()/10); + for (int i = 0; i < s.length(); i++) { + char ch = s.charAt(i); + if (ch == '\t') { + b.append(" "); + } else if (ch == '\n') { + b.append(SEP); + } else { + b.append(ch); + } + } + return b.toString(); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockProperty.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockProperty.java new file mode 100644 index 0000000000..3e3e87e47b --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockProperty.java @@ -0,0 +1,94 @@ +/** + * + * 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.tuscany.sdo.codegen; + +import java.util.List; + +import commonj.sdo.Property; +import commonj.sdo.Type; + +/** + * @version $Rev$ $Date$ + */ +class MockProperty implements Property { + private final String name; + private final Type type; + private final boolean many; + private final boolean readOnly; + + public MockProperty(String name, Class type, boolean many, boolean readOnly) { + this.name = name; + this.type = new MockType(null, type); + this.many = many; + this.readOnly = readOnly; + } + + public String getName() { + return name; + } + + public Type getType() { + return type; + } + + public boolean isMany() { + return many; + } + + public boolean isContainment() { + throw new UnsupportedOperationException(); + } + + public Type getContainingType() { + throw new UnsupportedOperationException(); + } + + public Object getDefault() { + throw new UnsupportedOperationException(); + } + + public boolean isReadOnly() { + return readOnly; + } + + public Property getOpposite() { + throw new UnsupportedOperationException(); + } + + public List /*String*/ getAliasNames() { + throw new UnsupportedOperationException(); + } + + public boolean isNullable() { + throw new UnsupportedOperationException(); + } + + public boolean isOpenContent() { + throw new UnsupportedOperationException(); + } + + public List getInstanceProperties() { + throw new UnsupportedOperationException(); + } + + public Object get(Property property) { + throw new UnsupportedOperationException(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockType.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockType.java new file mode 100644 index 0000000000..ec848de4fa --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/codegen/MockType.java @@ -0,0 +1,104 @@ +/** + * + * 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.tuscany.sdo.codegen; + +import java.util.List; +import java.util.ArrayList; + +import commonj.sdo.Type; +import commonj.sdo.Property; + +/** + * @version $Rev$ $Date$ + */ +class MockType implements Type { + private final String name; + private final Class javaClass; + private final List baseTypes = new ArrayList(); + + public MockType(String name, Class javaClass) { + this.javaClass = javaClass; + this.name = name; + } + + public void addBaseType(Type baseType) { + baseTypes.add(baseType); + } + + public String getName() { + return name; + } + + public String getURI() { + throw new UnsupportedOperationException(); + } + + public Class getInstanceClass() { + return javaClass; + } + + public boolean isInstance(Object object) { + throw new UnsupportedOperationException(); + } + + public List /*Property*/ getProperties() { + throw new UnsupportedOperationException(); + } + + public Property getProperty(String propertyName) { + throw new UnsupportedOperationException(); + } + + public boolean isDataType() { + throw new UnsupportedOperationException(); + } + + public boolean isOpen() { + throw new UnsupportedOperationException(); + } + + public boolean isSequenced() { + throw new UnsupportedOperationException(); + } + + public boolean isAbstract() { + throw new UnsupportedOperationException(); + } + + public List /*Type*/ getBaseTypes() { + return baseTypes; + } + + public List /*Property*/ getDeclaredProperties() { + throw new UnsupportedOperationException(); + } + + public List /*String*/ getAliasNames() { + throw new UnsupportedOperationException(); + } + + public List getInstanceProperties() { + throw new UnsupportedOperationException(); + } + + public Object get(Property property) { + throw new UnsupportedOperationException(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AllTests.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AllTests.java new file mode 100644 index 0000000000..1bdef4b1ef --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AllTests.java @@ -0,0 +1,87 @@ + +/** + * + * 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.tuscany.sdo.test; +import junit.framework.TestCase; +import junit.framework.TestSuite; + +public class AllTests extends TestCase { + + + public static TestSuite suite() { + + TestSuite suite = new TestSuite(); + + suite.addTestSuite(ChangeSummaryOnDataObjectTestCase.class); + suite.addTestSuite(ChangeSummaryPropertyTestCase.class); + suite.addTestSuite(ChangeSummaryTestCase.class); + suite.addTestSuite(ContainmentCycleTestCase.class); + suite.addTestSuite(CrossScopeCopyTestCase.class); + suite.addTestSuite(DataGraphTestCase.class); + suite.addTestSuite(DataTypeBaseTypeTestCase.class); + suite.addTestSuite(DateConversionTestCase.class); + suite.addTestSuite(DefineOpenContentPropertyTestCase.class); + suite.addTestSuite(DefineTypeTestCase.class); + suite.addTestSuite(FormTestCase.class); + suite.addTestSuite(HelperContextTestCase.class); + suite.addTestSuite(IsManyTestCase.class); + suite.addTestSuite(BoundsTestCase.class); + suite.addTestSuite(JavaSerializeDeserializeTestCase.class); + suite.addTestSuite(MixedTypeTestCase.class); + suite.addTestSuite(NeverStaleChangeSummaryTestCase.class); + suite.addTestSuite(OpenTypeTestCase.class); + suite.addTestSuite(SchemaLocationTestCase.class); + suite.addTestSuite(SerializeTypesTestCase.class); + suite.addTestSuite(SimpleCopyTestCase.class); + suite.addTestSuite(SimpleDynamicTestCase.class); + suite.addTestSuite(SimpleEqualityTestCase.class); + suite.addTestSuite(SubstitutionValuesTestCase.class); + suite.addTestSuite(TypeConversionTestCase.class); + suite.addTestSuite(TypeRoundTripTestCase.class); + suite.addTestSuite(XMLDocumentTestCase.class); + suite.addTestSuite(XMLHelperTestCase.class); + suite.addTestSuite(XMLStreamHelperTestCase.class); + suite.addTestSuite(XPathTestCase.class); + suite.addTestSuite(XSDHelperTestCase.class); + suite.addTestSuite(XSDQNameTestCase.class); + suite.addTestSuite(XMLLoadOptionsTestCase.class); + suite.addTestSuite(XMLSaveOptionsTestCase.class); + suite.addTestSuite(XMLUnknownPropertiesTestCase.class); + suite.addTestSuite(ExpectedExceptionsTestCase.class); + suite.addTestSuite(TypeHelperTestCase.class); + suite.addTestSuite(NotificationTestCase.class); + suite.addTestSuite(ImplSpecificTestCase.class); + return suite; + } + + + + /** + * Runs the test suite using the textual runner. + */ + public static void main(String[] args) { + junit.textui.TestRunner.run(suite()); + } +} + + + + diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AnyTypeTest.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AnyTypeTest.java new file mode 100644 index 0000000000..4d085eae28 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/AnyTypeTest.java @@ -0,0 +1,112 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.io.StringReader; +import java.io.StringWriter; +import java.net.URL; + +import javax.xml.stream.XMLInputFactory; +import javax.xml.stream.XMLOutputFactory; +import javax.xml.stream.XMLStreamReader; +import javax.xml.stream.XMLStreamWriter; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.XMLStreamHelper; +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XSDHelper; + +public class AnyTypeTest extends TestCase { + private static TypeHelper typeHelper; + private static DataFactory dataFactory; + private static XMLStreamHelper streamHelper; + private static XSDHelper xsdHelper; + + private static final String TEST_MODEL = "/anytype.xsd"; + private static final String TEST_NAMESPACE = "http://www.example.com/anytype"; + + public void testAnySimpleType() throws Exception { + final Property property = typeHelper.getOpenContentProperty(TEST_NAMESPACE, "globalElement"); + final Type propertyType = property.getType(); + + DataObject dataObject = dataFactory.create(TEST_NAMESPACE, "Person"); + dataObject.set("firstName", "Fuhwei"); + + DataObject rootObject = dataFactory.create(propertyType); + rootObject.set("anyTypeElement", dataObject); + + dataObject = dataFactory.create(TEST_NAMESPACE, "Person"); + dataObject.set("firstName", "Mindy"); + rootObject.set("personElement", dataObject); + + // XMLStreamHelper.saveObject has a problem to serialize the any type + final XMLOutputFactory outputFactory = XMLOutputFactory.newInstance(); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + streamHelper.saveObject(rootObject, streamWriter); + streamWriter.flush(); + // System.out.println(writer.toString()); + + final XMLInputFactory inputFactory = XMLInputFactory.newInstance(); + final StringReader reader = new StringReader(writer.toString()); + final XMLStreamReader streamReader = inputFactory.createXMLStreamReader(reader); + final XMLDocument doc = streamHelper.load(streamReader); + rootObject = doc.getRootObject(); + DataObject testObject = rootObject.getDataObject("anyTypeElement"); + // System.out.println("anyTypeElement dataobject: " + testObject); + testObject = rootObject.getDataObject("personElement"); + // System.out.println("personElement dataobject: " + testObject); + } + + public void testAbstractTypeFails() { + try { + final DataObject abstractObj = dataFactory.create("commonj.sdo","DataObject"); + assertTrue("Should not succeed", false); + } + catch ( final IllegalArgumentException e) { + // expected result + } + } + + protected void setUp() throws Exception { + final HelperContext hc = SDOUtil.createHelperContext(); + typeHelper = hc.getTypeHelper(); + dataFactory = hc.getDataFactory(); + xsdHelper = hc.getXSDHelper(); + streamHelper = SDOUtil.createXMLStreamHelper(hc); + + // Populate the meta data for the test (Stock Quote) model + final URL url = getClass().getResource(TEST_MODEL); + final InputStream inputStream = url.openStream(); + xsdHelper.define(inputStream, url.toString()); + inputStream.close(); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/BoundsTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/BoundsTestCase.java new file mode 100644 index 0000000000..7f176fe033 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/BoundsTestCase.java @@ -0,0 +1,79 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.net.URL; + +import org.apache.tuscany.sdo.api.SDOUtil; +import org.apache.tuscany.sdo.api.SDOHelper; + +import junit.framework.TestCase; + +import commonj.sdo.*; +import commonj.sdo.helper.*; + +public class BoundsTestCase extends TestCase { + private final String TEST_MODEL = "/bounds.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/bounds"; + + private TypeHelper typeHelper; + private XSDHelper xsdHelper; + private DataFactory dataFactory; + + public void testBounds() { + Property priceProperty = typeHelper.getOpenContentProperty(TEST_NAMESPACE, "price"); + assertTrue(priceProperty.isOpenContent()); + assertEquals(SDOHelper.UNSPECIFIED, SDOUtil.getUpperBound(priceProperty)); + assertEquals(0, SDOUtil.getLowerBound(priceProperty)); + + Type quoteType = typeHelper.getType(TEST_NAMESPACE, "OpenQuote"); + DataObject quote = dataFactory.create(quoteType); + assertEquals(2, SDOUtil.getUpperBound(quote.getInstanceProperty("symbol"))); + assertEquals(0, SDOUtil.getLowerBound(quote.getInstanceProperty("symbol"))); + + //XSD default value of maxOccurs and minOccurs is 1, unbounded returns -1 for maxOccurs + Type quoteType2 = typeHelper.getType(TEST_NAMESPACE, "OpenQuote2"); + DataObject quote2 = dataFactory.create(quoteType2); + assertEquals(SDOHelper.UNBOUNDED, SDOUtil.getUpperBound(quote2.getInstanceProperty("symbol"))); + assertEquals(1, SDOUtil.getLowerBound(quote2.getInstanceProperty("symbol"))); + + //XSD default value of maxOccurs and minOccurs is 1 + Type quoteType3 = typeHelper.getType(TEST_NAMESPACE, "OpenQuote3"); + DataObject quote3 = dataFactory.create(quoteType3); + assertEquals(1, SDOUtil.getUpperBound(quote3.getInstanceProperty("symbol"))); + assertEquals(1, SDOUtil.getLowerBound(quote3.getInstanceProperty("symbol"))); + } + + protected void setUp() throws Exception { + super.setUp(); + + HelperContext hc = SDOUtil.createHelperContext(); + typeHelper = hc.getTypeHelper(); + dataFactory = hc.getDataFactory(); + xsdHelper = hc.getXSDHelper(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + xsdHelper.define(inputStream, url.toString()); + inputStream.close(); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryOnDataObjectTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryOnDataObjectTestCase.java new file mode 100644 index 0000000000..b9b9c0f2ea --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryOnDataObjectTestCase.java @@ -0,0 +1,216 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.ChangeSummary; +import commonj.sdo.DataGraph; +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XSDHelper; + + +public class ChangeSummaryOnDataObjectTestCase extends TestCase { + + + private final String TEST_DATA = "/simplechangesummary.xml"; + HelperContext hc; + XSDHelper xh; + TypeHelper th; + + public void testBasicsDO() { + Type cst = th.getType("commonj.sdo","ChangeSummaryType"); + Type strt = th.getType("commonj.sdo", "String"); + + Type newt = SDOUtil.createType(hc, "testcases.changesummary", "simpleCS", false); + Property strProp = SDOUtil.createProperty(newt, "strElem", strt); + SDOUtil.createProperty(newt, "changeSummary", cst); + + DataObject iNewt = hc.getDataFactory().create(newt); + + testBasicsBody(strProp, iNewt); +} + + public void testBasicsDG() { + + Type strt = th.getType("commonj.sdo", "String"); + + + Type newt = SDOUtil.createType(hc, "testcases.changesummary", "simpleNOCS", false); + Property strProp = SDOUtil.createProperty(newt, "strElem", strt); + + DataGraph graph = SDOUtil.createDataGraph(); + DataObject iNewt = graph.createRootObject(newt); + + testBasicsBody(strProp, iNewt); +} + + + /** + * @param strProp + * @param iNewt + */ + private void testBasicsBody(Property strProp, DataObject iNewt) { + ChangeSummary cs = iNewt.getChangeSummary(); + cs.beginLogging(); + + List co = cs.getChangedDataObjects(); + assertEquals(0, co.size()); + iNewt.set(strProp, "some text"); + assertEquals(0, co.size()); + co = cs.getChangedDataObjects(); + assertEquals(1, co.size()); + + List oldValues = cs.getOldValues((DataObject)co.get(0)); + + ChangeSummary.Setting ov1 = (ChangeSummary.Setting)oldValues.get(0); + Property p = ov1.getProperty(); + assertEquals("strElem", p.getName()); + Object v = ov1.getValue(); + assertEquals(null, v); + + assertTrue(cs.isLogging()); + cs.endLogging(); + assertFalse(cs.isLogging()); + + } + + + + public void testDynamicNestedDataObjectsDG() throws Exception { + DataGraph dataGraph = SDOUtil.createDataGraph(); + DataObject quote = dataGraph.createRootObject(th.getType("http://www.example.com/simple", "Quote")); + + testDynamicNestedDOBody(quote); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + SDOUtil.saveDataGraph(dataGraph, baos, null); + // SDOUtil.saveDataGraph(dataGraph, System.out, null); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(TEST_DATA))); + + + assertEquals(1, quote.getList("quotes").size()); + assertEquals("fbnt", quote.getString("symbol")); + dataGraph.getChangeSummary().undoChanges(); + // SDOUtil.saveDataGraph(dataGraph, System.out, null); + assertEquals(0, quote.getList("quotes").size()); + assertNull(quote.getString("symbol")); + + + } + + public void testDynamicNestedDataObjectsDO() throws Exception { + Type quoteType = th.getType("http://www.example.com/simpleCS", "RootQuote"); + DataObject quote = hc.getDataFactory().create(quoteType); + + testDynamicNestedDOBody(quote); + //hc.getXMLHelper().save(quote, "http://www.example.com/simpleCS", "stockQuote", System.out); + assertEquals(1, quote.getList("quotes").size()); + assertEquals("fbnt", quote.getString("symbol")); + + quote.getChangeSummary().undoChanges(); + + assertEquals(0, quote.getList("quotes").size()); + assertNull(quote.getString("symbol")); + + + + } + + /** + * @param quote + */ + private void testDynamicNestedDOBody(DataObject quote) { + // Begin logging changes + // + ChangeSummary changeSummary = quote.getChangeSummary(); + assertNotNull(changeSummary); + assertFalse(changeSummary.isLogging()); + changeSummary.beginLogging(); + + + // Modify the data graph in various fun and interesting ways + // + quote.setString("symbol", "fbnt"); + quote.setString("companyName", "FlyByNightTechnology"); + quote.setBigDecimal("price", new BigDecimal("1000.0")); + quote.setBigDecimal("open1", new BigDecimal("1000.0")); + quote.setBigDecimal("high", new BigDecimal("1000.0")); + quote.setBigDecimal("low", new BigDecimal("1000.0")); + quote.setDouble("volume", 1000); + quote.setDouble("change1", 1000); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + changeSummary.endLogging(); + assertEquals(2, changeSummary.getChangedDataObjects().size()); // 2 DataObjects + assertTrue(changeSummary.getChangedDataObjects().contains(quote)); + assertTrue(changeSummary.getChangedDataObjects().contains(child)); + assertFalse(changeSummary.isCreated(quote)); + assertTrue(changeSummary.isCreated(child)); + + ChangeSummary.Setting ov = changeSummary.getOldValue(quote, quote.getType().getProperty("symbol")); + assertNull(ov.getValue()); + + + } + + protected void setUp() throws Exception { + super.setUp(); + +// uncomment these lines for sending aspect trace to a file +// tracing.lib.TraceMyClasses tmc = (TraceMyClasses)Aspects.aspectOf(TraceMyClasses.class); +// tmc.initStream(new PrintStream("c:\\temp\\trace.log")); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource("/simple.xsd"); + InputStream inputStream = url.openStream(); + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + xh = hc.getXSDHelper(); + xh.define(inputStream, url.toString()); + inputStream.close(); + + URL url2 = getClass().getResource("/simpleWithChangeSummary.xsd"); + InputStream inputStream2 = url2.openStream(); + xh.define(inputStream2, url2.toString()); + inputStream.close(); + + + +} + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryPropertyTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryPropertyTestCase.java new file mode 100644 index 0000000000..ace509d1b4 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryPropertyTestCase.java @@ -0,0 +1,219 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.math.BigDecimal; +import java.net.URL; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.ChangeSummary; +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +public class ChangeSummaryPropertyTestCase extends TestCase { + private final String TEST_MODEL = "/simpleWithChangeSummary.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/simpleCS"; + + private final String TEST_DATA_BEFORE_UNDO = "/simpleWithChangeSummary.xml"; + private final String TEST_DATA_AFTER_UNDO = "/simpleWithChangeSummaryUndone.xml"; + + HelperContext hc; + DataFactory dataFactory; + XMLHelper xmlHelper; + + void verify(ChangeSummary cs, DataObject quote, String nameSpace, String element, String beforeUndo, String afterUndo) throws IOException { + // Stop logging changes and serialize the resulting data graph + // + cs.endLogging(); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save(quote, nameSpace, element, baos); + //xmlHelper.save(quote, nameSpace, element, System.out); + + byte[] bytes = baos.toByteArray(); + URL url = getClass().getResource(beforeUndo); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(bytes), url)); + + DataObject loaded = xmlHelper.load(new ByteArrayInputStream(bytes)).getRootObject(); + baos.reset(); + xmlHelper.save(loaded, nameSpace, element, baos); + //xmlHelper.save(loaded, nameSpace, element, System.out); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), url)); + + // Undo all changes and then serialize the resulting data graph again + // + cs.undoChanges(); + + baos.reset(); + xmlHelper.save(quote, nameSpace, element, baos); + //xmlHelper.save(quote, nameSpace, element, System.out); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(afterUndo))); + } + + /** + * ChangeSummary property test. + */ + protected final void change(String nameSpace, String beforeUndo, String afterUndo) throws Exception { + Type quoteType = hc.getTypeHelper().getType(nameSpace, "RootQuote"); + DataObject quote = dataFactory.create(quoteType); + + ChangeSummary cs = quote.getChangeSummary(); + ChangeSummary csp = (ChangeSummary)quote.get("changes"); + + assertSame(cs, csp); + + quote.setString("symbol", "fbnt"); + quote.setString("companyName", "FlyByNightTechnology"); + quote.setBigDecimal("price", new BigDecimal("1000.0")); + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("1500.0")); + child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + child = child.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.99")); + child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2500.0")); + + // Begin logging changes + // + cs.beginLogging(); + + // Modify the data graph in various ways + // + quote.setString("symbol", "FBNT"); + quote.setBigDecimal("price", new BigDecimal("999.0")); + quote.setDouble("volume", 1000); + + child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("3000.0")); + child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("4000.0")); + + quote.getDataObject("quotes[2]").delete(); + + verify(cs, quote, nameSpace, "stockQuote", beforeUndo, afterUndo); + } + + /** + * Simple ChangeSummary property test. + */ + public void testChangeSummary() throws Exception { + change(TEST_NAMESPACE, TEST_DATA_BEFORE_UNDO, TEST_DATA_AFTER_UNDO); + } + + static final String SequenceTest_NameSpace = "http://www.example.com/sequenceCS"; + + /** + * Mixed ChangeSummary property test. + */ + public void testMixedChangeSummary() throws Exception { + change(SequenceTest_NameSpace, "/mixedChangeSummary.xml", "/mixedChangeSummaryUndone.xml"); + } + + protected final DataObject createDataObject(Type quoteType, Object value, Sequence sequence, Property property) { + DataObject child = dataFactory.create(quoteType); + child.set("symbol", value); + sequence.add(property, child); + return child; + } + + static final String SequenceTest_ELEMENT = "openQuote"; + + private XSDHelper xsdHelper; + + /** + * Open/any ChangeSummary property test. + */ + public void testOpenChangeSummary() throws Exception { + DataObject quote = dataFactory.create(xsdHelper.getGlobalProperty(SequenceTest_NameSpace, SequenceTest_ELEMENT, true).getType()); + + ChangeSummary cs = quote.getChangeSummary(); + ChangeSummary csp = (ChangeSummary)quote.get("changes"); + + assertSame(cs, csp); + + quote.set("symbol", "fbnt"); + Property property = xsdHelper.getGlobalProperty("http://www.example.com/open", "openStockQuote", true); + Type quoteType = property.getType(); + List openStockQuotes = ((DataObject)quote).getList(property); + + addQuote(openStockQuotes, quoteType, "1500.0"); + DataObject osq2 = addQuote(openStockQuotes, quoteType, "2000.0"); + addQuote(osq2.getList(property), quoteType, "2000.99"); + addQuote(openStockQuotes, quoteType, "2500.0"); + + // Begin logging changes + // + cs.beginLogging(); + + // Modify the data graph in various ways + // + quote.set("symbol", "FBNT"); + + addQuote(openStockQuotes, quoteType, "3000.0"); + addQuote(openStockQuotes, quoteType, "4000.0"); + + openStockQuotes.remove(osq2); + + + verify(cs, quote, SequenceTest_NameSpace, SequenceTest_ELEMENT, "/openChangeSummary.xml", "/openChangeSummaryUndone.xml"); + } + + private DataObject addQuote(List openStockQuotes, Type quoteType, + Object value) { + DataObject osq = dataFactory.create(quoteType); + osq.set("symbol", value); + openStockQuotes.add(osq); + return osq; + } + + void define(String model) throws Exception { + // Populate the meta data for the test model + URL url = getClass().getResource(model); + xsdHelper.define(url.openStream(), url.toString()); + } + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + xsdHelper = hc.getXSDHelper(); + dataFactory = hc.getDataFactory(); + xmlHelper = hc.getXMLHelper(); + + // Populate the meta data for the test (Stock Quote) model + define(TEST_MODEL); + + define("/SequenceChangeSummary.xsd"); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryTestCase.java new file mode 100644 index 0000000000..e956720117 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ChangeSummaryTestCase.java @@ -0,0 +1,92 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.ChangeSummary; +import commonj.sdo.DataGraph; +import commonj.sdo.DataObject; +import commonj.sdo.helper.XSDHelper; + + +public class ChangeSummaryTestCase extends TestCase { + private final String TEST_MODEL = "/simple.xsd"; + private final String TEST_DATA = "/simplechangesummary.xml"; + + /** + * Simple ChangeSummary test. + */ + public void testChangeSummary() throws IOException { + // Create an empty data graph and add a root object, an instance of type Quote + // + + DataGraph dataGraph = SDOUtil.createDataGraph(); + DataObject quote = dataGraph.createRootObject("http://www.example.com/simple", "Quote"); + + // Begin logging changes + // + ChangeSummary changeSummary = dataGraph.getChangeSummary(); + changeSummary.beginLogging(); + + // Modify the data graph in various fun and interesting ways + // + quote.setString("symbol", "fbnt"); + quote.setString("companyName", "FlyByNightTechnology"); + quote.setBigDecimal("price", new BigDecimal("1000.0")); + quote.setBigDecimal("open1", new BigDecimal("1000.0")); + quote.setBigDecimal("high", new BigDecimal("1000.0")); + quote.setBigDecimal("low", new BigDecimal("1000.0")); + quote.setDouble("volume", 1000); + quote.setDouble("change1", 1000); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + // Stop logging changes and print the resulting data graph to stdout + // + changeSummary.endLogging(); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + SDOUtil.saveDataGraph(dataGraph, baos, null); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(TEST_DATA))); + } + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentCycleTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentCycleTestCase.java new file mode 100644 index 0000000000..843ab9b982 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentCycleTestCase.java @@ -0,0 +1,866 @@ +/** + * + * Copyright 2005 The Apache Software Foundation or its licensors, as applicable. + * + * Licensed 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.tuscany.sdo.test; + +import junit.framework.TestCase; +import commonj.sdo.DataObject; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; + +import org.apache.tuscany.sdo.api.XMLStreamHelper; +import org.apache.tuscany.sdo.api.SDOUtil; + +import javax.xml.stream.XMLOutputFactory; +import javax.xml.stream.XMLStreamException; +import javax.xml.stream.XMLStreamWriter; + +import com.example.test.Containment.ContainmentFactory; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.ObjectOutputStream; +import java.util.ArrayList; +import java.util.List; + +/** + * Tests serialization of containment cycles. For JavaSerialization, the test case + * passes if an IllegalStateException is thrown. For XMLHelper and XMLStreamHelper + * serialization, serization should complete without throwing an Exception. In all + * cases, the actual structure of the DataObject should not be changed by the + * method call to serialize the DO. + * + * The same test is run for a static model (Type created using XSD2JavaGenerator), a + * dynamic model (Type created using TypeHelper), and a 'mixed' model (Type created + * using XSDHelper - dynamic Type creation using static resources). + */ +public class ContainmentCycleTestCase extends TestCase { + + private static final String CONTAIN_URI = "http://www.example.com/ContainmentTest"; + private static final String CONTAIN_TYPE = "ContainmentTest"; + private static HelperContext staticScope; + private static HelperContext dynamicScope; + private static HelperContext mixedScope; + private static boolean initialized = false; + private static boolean mixedCreated = false; + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the static version of this test case. + */ + // Note: Static test cases are prevented due to a JVM Error in ObjectOutputStream. + // The IllegalStateException thrown by Java serialization is caught, which in turn allows + // the StackOverflowException to occur. The catcher is catching RuntimeException, so it does + // not matter which Exception is thrown by the SDO code. + public void atestStaticOneMemberSingleValueSetDataObject() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + + setSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the static version of this test case. + */ + public void atestStaticNMemberSingleValueSetDataObject() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the static version of this test case. + */ + public void atestStaticOneMemberMultiValueSetDataObject() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the static version of this test case. + */ + public void atestStaticNMemberMultiValueSetDataObject() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the static version + * of this test case. + */ + public void atestStaticOneMemberReturnedList() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + + returnedListOneMember(dataObj1); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create an n-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the static version + * of this test case. + */ + public void atestStaticNMemberReturnedList() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + returnedListNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the static version of this test case. + */ + public void atestStaticOneMemberSingleValueSequence() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + + sequenceSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the static version of this test case. + */ + public void atestStaticNMemberSingleValueSequence() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of + * serialization. This is the static version of this test case. + */ + public void atestStaticOneMemberMultiValueSequence() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of + * serialization. This is the static version of this test case. + */ + public void atestStaticNMemberMultiValueSequence() { + final DataObject dataObj1 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj2 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + final DataObject dataObj3 = (DataObject) ContainmentFactory.INSTANCE.createContainmentTest(); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, staticScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the hybrid version of this test case. + */ + public void testHybridOneMemberSingleValueSetDataObject() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + setSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the hybrid version of this test case. + */ + public void testHybridNMemberSingleValueSetDataObject() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the hybrid version of this test case. + */ + public void testHybridOneMemberMultiValueSetDataObject() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the hybrid version of this test case. + */ + public void testHybridNMemberMultiValueSetDataObject() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the hybrid version + * of this test case. + */ + public void testHybridOneMemberReturnedList() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + returnedListOneMember(dataObj1); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create an n-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the hybrid version + * of this test case. + */ + public void testHybridNMemberReturnedList() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + returnedListNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the hybrid version of this test case. + */ + public void testHybridOneMemberSingleValueSequence() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + sequenceSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the hybrid version of this test case. + */ + public void testHybridNMemberSingleValueSequence() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of serialization. + * This is the hybrid version of this test case. + */ + public void testHybridOneMemberMultiValueSequence() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of serialization. + * This is the hybrid version of this test case. + */ + public void testHybridNMemberMultiValueSequence() { + assertTrue("Test case cannot proceed due to error creating Type.", mixedCreated); + + final DataObject dataObj1 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = mixedScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, mixedScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the dynamic version of this test case. + */ + public void testDynamicOneMemberSingleValueSetDataObject() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, + CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + setSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a single valued property + * and verify the behavior of serialization. This is the dynamic version of this test case. + */ + public void testDynamicNMemberSingleValueSetDataObject() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the dynamic version of this test case. + */ + public void testDynamicOneMemberMultiValueSetDataObject() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using set____ on a multi valued property + * and verify the behavior of serialization. This is the dynamic version of this test case. + */ + public void testDynamicNMemberMultiValueSetDataObject() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + setManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the dynamic version + * of this test case. + */ + public void testDynamicOneMemberReturnedList() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + returnedListOneMember(dataObj1); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create an n-Member Containment Cycle by making updates to a List returned + * from the DataObject and verify the behavior of serialization. This is the dynamic version + * of this test case. + */ + public void testDynamicNMemberReturnedList() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + returnedListNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the dynamic version of this test case. + */ + public void testDynamicOneMemberSingleValueSequence() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + + sequenceSingleValueOneMember(dataObj1); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a single valued property, and verify the behavior of + * serialization. This is the dynamic version of this test case. + */ + public void testDynamicNMemberSingleValueSequence() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceSingleValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create a 1-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of + * serialization. This is the dynamic version of this test case. + */ + public void testDynamicOneMemberMultiValueSequence() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceMultiValueOneMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to create an n-Member Containment Cycle using by using a Sequence to make updates + * to the DataObject, affecting a multi valued property, and verify the behavior of + * serialization. This is the dynamic version of this test case. + */ + public void testDynamicNMemberMultiValueSequence() { + final DataObject dataObj1 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj2 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + final DataObject dataObj3 = dynamicScope.getDataFactory().create(CONTAIN_URI, CONTAIN_TYPE); + dataObj1.setString("Name", "dataObj1"); + dataObj2.setString("Name", "dataObj2"); + dataObj3.setString("Name", "dataObj3"); + + sequenceManyValueNMember(dataObj1, dataObj2, dataObj3); + attemptSerialization(dataObj1, dynamicScope); + } + + /** + * Attempt to serialize the DataObject in via XML, XMLStreamHelper, + * and Java serialization. + * @param dataObj + */ + private void attemptSerialization(final DataObject dataObj, final HelperContext scope) { + + assertTrue("Containment cycle was not established.", + containmentCycleExists(dataObj)); + + try { + serializeDataObjectXML(dataObj, scope); + } catch (final Exception e) { + fail("XML serialization of a containment cycle resulted in a(n) " + e.getClass().getName() + "."); + e.printStackTrace(); + } + + assertTrue("Containment cycle was affected by XMLHelper serialization.", + containmentCycleExists(dataObj)); + + try { + serializeDataObjectJava(dataObj); + fail("Java serialization of a containment cycle should result in an IllegalStateException."); + } catch (final Exception e) { + // Do nothing. An Exception is expected in this case. + } + + assertTrue("Containment cycle was affected by Java serialization.", + containmentCycleExists(dataObj)); + + try { + serializeDataObjectStream(dataObj, scope); + } catch (final Exception e) { + fail("XMLStreamHelper serialization of a containment cycle resulted in a(n) " + e.getClass().getName() + "."); + e.printStackTrace(); + } + assertTrue("Containment cycle was affected by XMLStreamHelper serialization.", + containmentCycleExists(dataObj)); + } + /** + * Uses the XMLHelper to serialize the input DataObject + * + * @param dataObject + * @param fileName + * @throws IOException + */ + private static void serializeDataObjectXML(final DataObject dataObject, final HelperContext scope) { + final ByteArrayOutputStream baos = new ByteArrayOutputStream(); + final Type type = dataObject.getType(); + + try { + scope.getXMLHelper().save(dataObject, type.getURI(), type.getName(), baos); + } + catch (final IOException e) { + fail("Could not complete test case due to IOException."); + } + } + + /** + * Uses Java serialization to serialize the input DataObject + * + * @param dataObject + * @param fileName + * @throws IOException + */ + private static void serializeDataObjectStream(final DataObject dataObject, final HelperContext scope) { + final ByteArrayOutputStream baos = new ByteArrayOutputStream(); + + final XMLOutputFactory factory = XMLOutputFactory.newInstance(); + XMLStreamWriter serializer; + final XMLStreamHelper xmlStreamHelper = SDOUtil.createXMLStreamHelper(scope); + try { + serializer = factory.createXMLStreamWriter(baos); + xmlStreamHelper.saveObject(dataObject, serializer); + serializer.flush(); + } + catch (final XMLStreamException e) { + fail("Exception encountered during XMLStreamHelper serialization."); + e.printStackTrace(); + } + } + + /** + * Uses Java serialization to serialize the input DataObject + * + * @param dataObject + * @param fileName + * @throws IOException + */ + private static void serializeDataObjectJava(final DataObject dataObject) { + final ByteArrayOutputStream baos = new ByteArrayOutputStream(); + + try { + final ObjectOutputStream out = new ObjectOutputStream(baos); + out.writeObject(dataObject); + out.close(); + } + catch (final IOException e) { + fail("Could not complete test case due to IOException."); + } + } + + /** + * Returns true if input DataObject root is part of a containment cycle, + * false otherwise. + * @param root + * @return + */ + private static boolean containmentCycleExists (final DataObject root) + { + DataObject curr = root.getContainer(); + + while (curr != null) + { + if (curr == root) { + return true; + } + + curr = curr.getContainer(); + } + return false; + } + + /** + * Use setDataObject to create a one member containment cycle. + * @param dataObj1 + */ + private void setSingleValueOneMember(final DataObject dataObj1) { + dataObj1.setDataObject("Contain", dataObj1); + } + + /** + * Use setDataObject to create an N-member containment cycle. + * @param dataObj1 + * @param dataObj2 + * @param dataobj3 + */ + private void setSingleValueNMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + dataObj1.setDataObject("Contain", dataObj2); + dataObj2.setDataObject("Contain", dataObj3); + dataObj3.setDataObject("Contain", dataObj1); + } + + /** + * Use setList to create a one member containment cycle. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void setMultiValueOneMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + final List addList = new ArrayList(); + + addList.add(dataObj2); + addList.add(dataObj1); + addList.add(dataObj3); + dataObj1.setList("ContainMany", addList); + } + + /** + * Use setList to create an N-member containment cycle. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void setManyValueNMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + final List addList = new ArrayList(); + + dataObj1.setDataObject("Contain", dataObj2); + dataObj2.setDataObject("Contain", dataObj3); + addList.add(dataObj1); + dataObj3.setList("ContainMany", addList); + } + + /** + * Create a 1-member containment cycle by making updates to a returned List. + * @param dataObj1 + */ + private void returnedListOneMember(final DataObject dataObj1) { + final List returnedList = dataObj1.getList("ContainMany"); + + returnedList.add(dataObj1); + } + + /** + * Create an n-member containment cycle by making updates to a returned List. + * @param dataObj1 + * @param dataObj2 + * @param dataobj3 + */ + private void returnedListNMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + dataObj1.setDataObject("Contain", dataObj2); + dataObj2.setDataObject("Contain", dataObj3); + + final List returnedList = dataObj3.getList("ContainMany"); + + returnedList.add(dataObj1); + } + + /** + * Create a 1-member containment cycle by making updates to a Sequence. + * The data member in this case is single valued. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void sequenceSingleValueOneMember(final DataObject dataObj1) { + assertTrue("DataObject is not Sequenced. Test case may not proceed.", dataObj1.getType().isSequenced()); + + final Sequence sequence = dataObj1.getSequence(); + + sequence.add("Contain", dataObj1); + } + + /** + * Create an n-member containment cycle by making updates to a Sequence. + * The data member in this case is single valued. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void sequenceSingleValueNMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + assertTrue("DataObject is not Sequenced. Test case may not proceed.", dataObj1.getType().isSequenced()); + + final Sequence sequence1 = dataObj1.getSequence(); + final Sequence sequence2 = dataObj2.getSequence(); + final Sequence sequence3 = dataObj3.getSequence(); + + sequence1.add("Contain", (Object) dataObj2); + sequence2.add("Contain", (Object) dataObj3); + + sequence3.add("Contain", (Object) dataObj1); + } + + /** + * Create a 1-member containment cycle by making updates to a Sequence. + * The data member in this case is many valued. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void sequenceMultiValueOneMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + assertTrue("DataObject is not Sequenced. Test case may not proceed.", dataObj1.getType().isSequenced()); + + final Sequence sequence = dataObj1.getSequence(); + + sequence.add("ContainMany", dataObj2); + sequence.add("ContainMany", dataObj3); + sequence.add("ContainMany", dataObj1); + } + + /** + * Create an n-member containment cycle by making updates to a Sequence. + * The data member in this case is many valued. + * @param dataObj1 + * @param dataObj2 + * @param dataObj3 + */ + private void sequenceManyValueNMember(final DataObject dataObj1, final DataObject dataObj2, final DataObject dataObj3) { + assertTrue("DataObject is not Sequenced. Test case may not proceed.", dataObj1.getType().isSequenced()); + + final List addList = new ArrayList(); + + addList.add(dataObj2); + dataObj1.setList("ContainMany", addList); + + addList.clear(); + addList.add(dataObj3); + dataObj2.setList("ContainMany", addList); + + final Sequence sequence = dataObj3.getSequence(); + + sequence.add("ContainMany", dataObj1); + } + + public void setUp() { + if (!initialized) { + staticScope = SDOUtil.createHelperContext(); + ContainmentFactory.INSTANCE.register(staticScope); + + dynamicScope = SDOUtil.createHelperContext(); + ContainmentTypeUtil.createDynamically(dynamicScope); + + mixedScope = SDOUtil.createHelperContext(); + mixedCreated = ContainmentTypeUtil.createDynamicWithStaticResources(mixedScope); + + initialized = true; + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentTypeUtil.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentTypeUtil.java new file mode 100644 index 0000000000..f602555fa6 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ContainmentTypeUtil.java @@ -0,0 +1,86 @@ +/** + * + * Copyright 2005 The Apache Software Foundation or its licensors, as applicable. + * + * Licensed 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + +/** + * Provides methods to dynamically create the ContainemntTest Type using the XSDHelper + * and the TypeHelper. + */ +public class ContainmentTypeUtil { + + /** + * createDynamicWithStaticResources creates the DataObject type from an existing + * XSD. The same XSD is used to create the Types statically using the XSD2JavaGenerator. + * The XSD should be kept in synch with the createDynamically method in this class. + * @throws IOException + * @return true if + */ + public static boolean createDynamicWithStaticResources(HelperContext hc) { + try { + // Populate the meta data for the test model (ContainTest) + URL url = ContainmentCycleTestCase.class.getResource("/containmenttest.xsd"); + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + } catch(IOException e) { + e.printStackTrace(); + return false; + } + return true; + } + + /** + * createDynamically() creates the SDO Types using the TypeHelper. This method should be kept in + * synch with the XSD used for createDynamicallyWithStaticResources. The same XSD is used for + * the static generation of SDO Types using XSD2JavaGenerator. + */ + public static void createDynamically(HelperContext hc) { + TypeHelper types = hc.getTypeHelper(); + Type stringType = types.getType("commonj.sdo", "String"); + + DataObject testType = hc.getDataFactory().create("commonj.sdo", "Type"); + testType.set("uri", "http://www.example.com/ContainmentTest"); + testType.set("name", "ContainmentTest"); + testType.setBoolean("sequenced", true); + + DataObject nameProperty = testType.createDataObject("property"); + nameProperty.set("name", "Name"); + nameProperty.set("type", stringType); + + DataObject containProperty = testType.createDataObject("property"); + containProperty.set("name", "Contain"); + containProperty.setBoolean("containment", true); + containProperty.set("type", testType); + + DataObject containManyProperty = testType.createDataObject("property"); + containManyProperty.set("name", "ContainMany"); + containManyProperty.setBoolean("many", true); + containManyProperty.setBoolean("containment", true); + containManyProperty.set("type", testType); + + types.define(testType); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/CrossScopeCopyTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/CrossScopeCopyTestCase.java new file mode 100644 index 0000000000..4a8ed34477 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/CrossScopeCopyTestCase.java @@ -0,0 +1,474 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; +import java.util.Iterator; +import java.util.Vector; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.CopyHelper; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + +public class CrossScopeCopyTestCase extends TestCase +{ + // Literals + private static final String TEST_NAMESPACE = "http://www.example.com/bank"; + private static final String BANK_MODEL = "/bank.xsd"; + private static final String BANK_TYPE = "bankType"; + private static final String BRANCH_TYPE = "branchType"; + private static final String SERVICE_TYPE = "serviceType"; + private static final String ACCOUNT_TYPE = "accountType"; + private static final String CUSTOMER_TYPE = "customerType"; + private static final String ADDRESS_TYPE = "addressType"; + private static final String DYNAMIC_TYPE = "dynamicType"; + + // SDO model objects + private HelperContext hca; + private HelperContext hcb; + private TypeHelper scopeA; + private TypeHelper scopeB; + + // SDO instance objects + private DataObject bankSDO; + private DataObject branchSDO1; + private DataObject branchSDO2; + private DataObject serviceSDO1; + private DataObject serviceSDO2; + private DataObject serviceSDO3; + private DataObject customerSDO1; + private DataObject customerSDO2; + private DataObject customerSDO3; + private DataObject customerSDO4; + + private int indent = 0; + + public void testCrossScopeCopy() throws IOException + { + CopyHelper copyHelperB = SDOUtil.createCrossScopeCopyHelper(hcb); + + // Perform Shallow Copy Test + DataObject copiedSDO = copyHelperB.copyShallow(bankSDO); + shallowCopyAssertions(bankSDO, copiedSDO); + + // Perform Deep Copy Test + copiedSDO = copyHelperB.copy(bankSDO); + deepCopyAssertions(bankSDO, copiedSDO); + + // Inter-Reference Copy + copiedSDO = copyHelperB.copy(customerSDO1); + DataObject prop = (DataObject)copiedSDO.get("HomeBranch"); + assertTrue(prop==null); + + // Perform invalid namespace test + DataObject sdo = hca.getDataFactory().create(TEST_NAMESPACE, DYNAMIC_TYPE ); + sdo.set("custNum", "099" ); + sdo.set("firstName", "John"); + sdo.set("lastName", "Doe"); + boolean failed = false; + try + { + // In this case, we are copying an object to a scope + // where the object's type has not been defined. That + // will generate a null pointer exception what we will + // catch. + copyHelperB.copy(sdo); + } + catch(java.lang.NullPointerException ex) + { + failed = true; + } + assertTrue(failed); + } + + protected void setUp() throws Exception + { + super.setUp(); + + // Create Two Scopes + hca = SDOUtil.createHelperContext(); + hcb = SDOUtil.createHelperContext(); + scopeA = hca.getTypeHelper(); + scopeB = hcb.getTypeHelper(); + + // Populate scopes with bank model now + URL url = getClass().getResource(BANK_MODEL); + InputStream inputStream = url.openStream(); + hca.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + inputStream = url.openStream(); + hcb.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + + // Now Populate scopeA with some dynamic models + populateScopeWithDynamicTypes(scopeA); + + // Construct Source Tree + constructSourceTree(hca.getDataFactory()); + } + + private void shallowCopyAssertions(DataObject sdo, DataObject copiedSdo) + { + assertEquals(sdo.getType().getName(), copiedSdo.getType().getName()); + assertEquals(sdo.getType().getURI(), copiedSdo.getType().getURI()); + assertNotSame(sdo.getType(), copiedSdo.getType()); + assertEquals(sdo.getInstanceProperties().size(), copiedSdo + .getInstanceProperties().size()); + + for(Iterator it = sdo.getInstanceProperties().iterator(), it2 = copiedSdo + .getInstanceProperties().iterator(); it.hasNext();) + { + Property p1 = (Property) it.next(), p2 = (Property) it2.next(); + assertEquals(p1.getName(), p2.getName()); + Object o1 = sdo.get(p1), o2 = copiedSdo.get(p2); + if(p1.getType().isDataType()) + { + assertEquals(o1, o2); + // TODO is there a way I can distinguish between mutable and + // immutable types + // so that I can do some "same object" tests + } + else + { + assertNotSame(p1, p2); + if(p2.isMany()) + { + assertEquals(copiedSdo.getList(p2).size(), 0); + } + else + { + assertNull(copiedSdo.get(p2)); + } + } + try + { + sdo.get(p2); + assertTrue(false); + } + catch(Exception e) + { + // expected route + } + try + { + copiedSdo.get(p1); + assertTrue(false); + } + catch(Exception e2) + { + // expected route + } + } + } + + private void deepCopyAssertions(DataObject sdo, DataObject copiedSdo) + { + //indent(); + + //System.out.println("checking objects of types: " + // + sdo.getType().getName() + ", " + // + copiedSdo.getType().getName()); + indent++; + + assertEquals(sdo.getType().getName(), copiedSdo.getType().getName()); + assertEquals(sdo.getType().getURI(), copiedSdo.getType().getURI()); + assertNotSame(sdo.getType(), copiedSdo.getType()); + assertEquals(sdo.getInstanceProperties().size(), copiedSdo + .getInstanceProperties().size()); + + for(Iterator it = sdo.getInstanceProperties().iterator(), it2 = copiedSdo + .getInstanceProperties().iterator(); it.hasNext();) + { + Property p1 = (Property) it.next(), p2 = (Property) it2.next(); + assertEquals(p1.getName(), p2.getName()); + Object o1 = sdo.get(p1), o2 = copiedSdo.get(p2); + if(p1.getType().isDataType()) + { + assertEquals(o1, o2); + // TODO is there a way I can distinguish between mutable and + // immutable types + // so that I can do some "same object" tests + } + else + { + assertNotSame(p1, p2); + if(p2.isMany()) + { + assertEquals(sdo.getList(p1).size(), copiedSdo.getList(p2) + .size()); + for(Iterator it3 = sdo.getList(p1).iterator(), it4 = copiedSdo + .getList(p2).iterator(); it3.hasNext();) + { + deepCopyAssertions((DataObject) it3.next(), + (DataObject) it4.next()); + } + } + else + { + deepCopyAssertions(sdo.getDataObject(p1), copiedSdo + .getDataObject(p2)); + } + } + try + { + sdo.get(p2); + assertTrue(false); + } + catch(Exception e) + { + // expected route + } + try + { + copiedSdo.get(p1); + assertTrue(false); + } + catch(Exception e2) + { + // expected route + } + } + + indent--; + } + + /* + private void indent() + { + for(int i=0; i " + + + "" + + "" + + + "" + + "" + + "" + + "" + + "" + + "" + + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + + "" + + "" + + "" + + "" + + "" + + "" + + + ""; + + /** + * Test DataObject.getList() on open type + */ + public void testUnknownPropertyOnOpenType() throws IOException { + String companyName = companyDataObject.getString("openCompany/company"); + assertEquals(companyName, "OpenCompany"); + List unknownProperty = companyDataObject.getList("openCompany/unknownProperty"); + assertNotNull(unknownProperty); + assertTrue(unknownProperty instanceof List); + + List unknownProperty2 = companyDataObject.getList("openCompany/unknownProperty"); + assertNotNull(unknownProperty2); + assertTrue(unknownProperty2 instanceof List); + + // unknownProperty and unknownProperty2 are in fact the same value for the same property + + unknownProperty.add("employee1"); + assertTrue(unknownProperty.size() == 1); + + unknownProperty2.add("employee2"); + assertTrue(unknownProperty2.size() == 2); + + unknownProperty.remove(0); + assertTrue(unknownProperty.size() == 1); + + assertEquals(unknownProperty.get(0), "employee2"); + } + + /** + * Test DataObject.getList() on non-open type + */ + public void testUnknownPropertyOnClosedType() throws IOException { + String companyName = companyDataObject.getString("closeCompany/company"); + assertEquals(companyName, "CloseCompany"); + List unknownProperty = companyDataObject.getList("closeCompany/unknownProperty"); + assertNotNull(unknownProperty); + assertTrue(unknownProperty instanceof List); + + try { + unknownProperty.add("employee1"); + fail("An exception should have been thrown."); + } + catch (Exception e) { + } + } + + protected void setUp() throws Exception { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + hc.getXSDHelper().define(xsdString); + + companyDataObject = hc.getDataFactory().create(TEST_NAMESPACE, "Company"); + DataObject openCompany = companyDataObject.createDataObject("openCompany"); + openCompany.setString("company", "OpenCompany"); + DataObject closeCompany = companyDataObject.createDataObject("closeCompany"); + closeCompany.setString("company", "CloseCompany"); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataTypeBaseTypeTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataTypeBaseTypeTestCase.java new file mode 100644 index 0000000000..a49b165386 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DataTypeBaseTypeTestCase.java @@ -0,0 +1,68 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; +import java.util.List; + +import junit.framework.TestCase; + +import commonj.sdo.Type; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XSDHelper; + + +public class DataTypeBaseTypeTestCase extends TestCase { + private final String TEST_MODEL = "/datatype.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/datatype"; + + public void testSimpleSDOType() throws IOException + { + Type type = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "SimpleSDOType"); + List baseTypes = type.getBaseTypes(); + assertTrue(baseTypes.size() == 1); + } + + public void testSimpleSDOTypeInstanceClass() throws IOException + { + Type type = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "SimpleSDOTypeInstanceClass"); + List baseTypes = type.getBaseTypes(); + assertTrue(baseTypes.size() == 0); + } + + public void testSimpleSDOTypeExtendedInstanceClass() throws IOException + { + Type type = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "SimpleSDOTypeExtendedInstanceClass"); + List baseTypes = type.getBaseTypes(); + assertTrue(baseTypes.size() == 1); + } + + public void setUp() throws Exception + { + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DateConversionTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DateConversionTestCase.java new file mode 100644 index 0000000000..86808f3b56 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DateConversionTestCase.java @@ -0,0 +1,380 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.lang.reflect.Method; +import java.util.Calendar; +import java.util.Date; +import java.util.GregorianCalendar; + +import junit.framework.TestCase; + +import commonj.sdo.helper.DataHelper; + +// DateConversionTestCase insures that the DataHelper conversions accurately +// retain the information in the specified fields (e.g. month, day or year). +// It also provides coverage for the DataHelper API. +// Note that toDate is called each time Test.initialize() is called. + +public class DateConversionTestCase extends TestCase +{ + private static Calendar test_calendar; + private static Date test_date; + private static DataHelper data_helper; + + private static final TestType TO_DATE_TIME = new TestType("toDateTime", new int [] {Calendar.YEAR, Calendar.MONTH, + Calendar.DAY_OF_MONTH, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND, Calendar.MILLISECOND}); + private static final TestType TO_DURATION = new TestType("toDuration", new int [] {Calendar.YEAR, Calendar.MONTH, + Calendar.DAY_OF_MONTH, Calendar.HOUR_OF_DAY, Calendar.MINUTE, Calendar.SECOND, Calendar.MILLISECOND}); + private static final TestType TO_TIME = new TestType("toTime", new int [] {Calendar.HOUR_OF_DAY, Calendar.MINUTE, + Calendar.SECOND, Calendar.MILLISECOND}); + private static final TestType TO_DAY = new TestType("toDay", new int[] {Calendar.DAY_OF_MONTH}); + private static final TestType TO_MONTH = new TestType("toMonth", new int[] {Calendar.MONTH}); + private static final TestType TO_MONTH_DAY = new TestType("toMonthDay", new int[] {Calendar.MONTH, Calendar.DAY_OF_MONTH}); + private static final TestType TO_YEAR = new TestType("toYear", new int[] {Calendar.YEAR}); + private static final TestType TO_YEAR_MONTH= new TestType("toYearMonth", new int[] {Calendar.YEAR, Calendar.MONTH}); + private static final TestType TO_YEAR_MONTH_DAY = new TestType("toYearMonthDay", new int[] {Calendar.YEAR, + Calendar.MONTH, Calendar.DAY_OF_MONTH}); + + public DateConversionTestCase() throws Exception + { + data_helper = DataHelper.INSTANCE; + test_calendar = new GregorianCalendar(); + test_calendar.setTime(new Date(System.currentTimeMillis())); + test_date = test_calendar.getTime(); + } + + //Test for TUSCANY-1514 + public void testNullStringToDate() throws Exception { + Date result = data_helper.toDate(null); + assertEquals(null, result); + } + + private static class TestType + { + private static final Class[] DATE_CLASS_ARRAY = {Date.class}; + private static final Class[] CALENDAR_CLASS_ARRAY = {Calendar.class}; + + Method date_method; + Method calendar_method; + int [] compare_fields; + + public TestType (String method_name, int [] compare_fields) + { + try + { + this.date_method = DataHelper.class.getMethod(method_name, DATE_CLASS_ARRAY); + } + catch (NoSuchMethodException e) + { + this.date_method = null; + } + + this.compare_fields = compare_fields; + try + { + this.calendar_method = DataHelper.class.getMethod(method_name, CALENDAR_CLASS_ARRAY); + } + catch (NoSuchMethodException e) + { + this.calendar_method = null; + } + + } + + public Method getDateMethod() + { + return this.date_method; + } + + public Method getCalendarMethod() + { + return this.calendar_method; + } + } + + private static class Test + { + String from_type; + Date from_date; + Calendar from_calendar; + Class expected_exception; + + public Test () + { + this.from_date = null; + this.from_calendar = null; + expected_exception = null; + } + + public void initialize (TestType from_type) + { + this.from_type = from_type.getDateMethod().getName(); + + try + { + String date_string = (String) from_type.getDateMethod().invoke(data_helper, new Object[] {test_date}); + + this.from_date = data_helper.toDate(date_string); + date_string = (String) from_type.getCalendarMethod().invoke(data_helper, new Object[] {test_calendar}); + this.from_calendar = data_helper.toCalendar(date_string); + } + catch (Exception e) + { + this.from_date = null; + this.from_calendar = null; + } + + } + + // This method is needed because there is not a toDate(Date) method in DataHelper. + + public void initializeToDate() + { + this.from_calendar = test_calendar; + this.from_date = test_date; + this.from_type = "toDate"; + } + + public void attemptConversion (TestType to_type) throws Exception + { + executeConversion(to_type.getDateMethod(), new Object[] {this.from_date}, to_type.compare_fields); + executeConversion(to_type.getCalendarMethod(), new Object[] {this.from_calendar}, to_type.compare_fields); + } + + private void executeConversion (Method conversion, Object[] parm, int [] compare_fields) throws Exception + { + String result; + + try + { + result = (String) conversion.invoke(data_helper, parm); + } + catch (Exception e) + { + System.err.println("An unexpected exception was thrown while calling " + conversion.getName() + + " after initializing with " + this.from_type + "."); + throw e; + } + + assertTrue("The expected value did not result when calling " + conversion.getName() + + " after initializing with " + this.from_type + ".", compareFields(parm[0], result, compare_fields)); + } + + private boolean compareFields(Object compare_to, String output, int [] compare_fields) + { + Calendar result = data_helper.toCalendar(output); + Calendar expected; + + if (compare_to instanceof Calendar) + expected = (GregorianCalendar) test_calendar; + else + { + expected = new GregorianCalendar(); + expected.setTime((Date) test_date); + } + + for (int i = 0; i < compare_fields.length; i++) + { + if (expected.get(compare_fields[i]) != result.get(compare_fields[i])) + { + System.err.println("Failed: - expected '" + expected.get(compare_fields[i]) + "' got '" + result.get(compare_fields[i]) + "' for output: " + output); + return false; + } + } + return true; + } + + } + + public void testConversionsFromDay() throws Exception + { + Test FromDay = new Test(); + + FromDay.initialize(TO_DAY); + + FromDay.attemptConversion(TO_DAY); + } + + public void testConversionsFromDate() throws Exception + { + Test FromDate = new Test(); + + FromDate.initializeToDate(); + + FromDate.attemptConversion(TO_DATE_TIME); + FromDate.attemptConversion(TO_DURATION); + FromDate.attemptConversion(TO_TIME); + FromDate.attemptConversion(TO_DAY); + FromDate.attemptConversion(TO_MONTH); + FromDate.attemptConversion(TO_MONTH_DAY); + FromDate.attemptConversion(TO_YEAR); + FromDate.attemptConversion(TO_YEAR_MONTH); + FromDate.attemptConversion(TO_YEAR_MONTH_DAY); + } + + public void testConversionsFromDateTime() throws Exception + { + Test FromDateTime = new Test(); + + FromDateTime.initialize(TO_DATE_TIME); + + FromDateTime.attemptConversion(TO_DATE_TIME); + FromDateTime.attemptConversion(TO_DURATION); + FromDateTime.attemptConversion(TO_TIME); + FromDateTime.attemptConversion(TO_DAY); + FromDateTime.attemptConversion(TO_MONTH); + FromDateTime.attemptConversion(TO_MONTH_DAY); + FromDateTime.attemptConversion(TO_YEAR); + FromDateTime.attemptConversion(TO_YEAR_MONTH); + FromDateTime.attemptConversion(TO_YEAR_MONTH_DAY); + } + + public void testConversionsFromDuration() throws Exception + { + Test FromDuration = new Test(); + + FromDuration.initialize(TO_DURATION); + + FromDuration.attemptConversion(TO_DURATION); + FromDuration.attemptConversion(TO_DATE_TIME); + FromDuration.attemptConversion(TO_TIME); + FromDuration.attemptConversion(TO_DAY); + FromDuration.attemptConversion(TO_MONTH); + FromDuration.attemptConversion(TO_MONTH_DAY); + FromDuration.attemptConversion(TO_YEAR); + FromDuration.attemptConversion(TO_YEAR_MONTH); + FromDuration.attemptConversion(TO_YEAR_MONTH_DAY); + } + + public void testConversionsFromMonth() throws Exception + { + Test FromMonth = new Test(); + + FromMonth.initialize(TO_MONTH); + + FromMonth.attemptConversion(TO_MONTH); + } + + public void testConversionsFromMonthDay() throws Exception + { + Test FromMonthDay = new Test(); + + FromMonthDay.initialize(TO_MONTH_DAY); + FromMonthDay.attemptConversion(TO_MONTH_DAY); + FromMonthDay.attemptConversion(TO_MONTH); + FromMonthDay.attemptConversion(TO_DAY); + } + + public void testConversionsFromTime() throws Exception + { + Test FromTime = new Test(); + + FromTime.initialize(TO_TIME); + + FromTime.attemptConversion(TO_TIME); + } + + public void testConversionsFromYear() throws Exception + { + Test FromYear = new Test(); + + FromYear.initialize(TO_YEAR); + + FromYear.attemptConversion(TO_YEAR); + } + + public void testConversionsFromYearMonth() throws Exception + { + Test FromYearMonth = new Test(); + + FromYearMonth.initialize(TO_YEAR_MONTH); + + FromYearMonth.attemptConversion(TO_YEAR_MONTH); + FromYearMonth.attemptConversion(TO_MONTH); + FromYearMonth.attemptConversion(TO_YEAR); + } + + public void testConversionsFromYearMonthDay() throws Exception + { + Test FromYearMonthDay = new Test(); + + FromYearMonthDay.initialize(TO_YEAR_MONTH_DAY); + + FromYearMonthDay.attemptConversion(TO_YEAR_MONTH_DAY); + FromYearMonthDay.attemptConversion(TO_YEAR_MONTH); + FromYearMonthDay.attemptConversion(TO_MONTH_DAY); + FromYearMonthDay.attemptConversion(TO_YEAR); + FromYearMonthDay.attemptConversion(TO_MONTH); + FromYearMonthDay.attemptConversion(TO_DAY); + } + + // Ensure that strings that should be recognized by toDate do not + // result in a null Date value. + + public void testToDateFormats() throws Exception + { + String[] validStrings = + { + "2006-03-31T03:30:45.123Z", + "-2006-03-31T03:30:45.1Z", + "2006-03-31T03:30:45Z", + "2006-03-31T03:30:45.123", + "2006-03-31T03:30:45.1", + "-2006-03-31T03:30:45", + "2006-03-31T03:30:45.123 EDT", + "2006-03-31T03:30:45.1 EDT", + "2006-03-31T03:30:45 EDT", + "---05 PST", + "---04", + "--12 GMT", + "--12", + "--08-08 EST", + "--08-08", + "1976-08-08 PDT", + "1976-08-08", + "88-12 CST", + "1988-12", + "2005 CDT", + "1999", + "P2006Y 08M 10D T 12H 24M 07S", + "P2006Y 10D T 12H", + "-P2006Y 08M 10D T 07S.2", + "P08M 10D T 07H", + "-P 04M 10DT12H 24S.88", + "PT12H" + }; + + for (int i = 0; i < validStrings.length; i++) + { + assertNotNull("DataHelper.toData() should not return null for '" + validStrings[i] + "'.", + data_helper.toDate(validStrings[i])); + } + + } + + public void testDateTime(){ + // a small bolt on test case resulting from a fix for JIRA TUSCANY-1044 + String date = DataHelper.INSTANCE.toDateTime(DataHelper.INSTANCE.toCalendar("2007-02-04T00:00:00.200Z")); + assertEquals("2007-02-04T00:00:00.200Z", date); + } + +} + diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineOpenContentPropertyTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineOpenContentPropertyTestCase.java new file mode 100644 index 0000000000..f6afd5c458 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineOpenContentPropertyTestCase.java @@ -0,0 +1,133 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import junit.framework.TestCase; + + +public class DefineOpenContentPropertyTestCase extends TestCase { + private final String TEST_MODEL = "/open.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/open"; + private final String TEST_DATA = "/openContentProperty.xml"; + + private TypeHelper typeHelper; + private XSDHelper xsdHelper; + private XMLHelper xmlHelper; + private DataFactory dataFactory; + + public void testDefineOpenContentProperty() throws IOException { + Type quoteType = typeHelper.getType(TEST_NAMESPACE, "OpenQuote"); + DataObject quote = dataFactory.create(quoteType); + + Property symbolProperty = quoteType.getProperty("symbol"); + assertFalse(symbolProperty.isOpenContent()); + + quote.setString(symbolProperty, "s1"); + + Property companyProperty = typeHelper.getOpenContentProperty(TEST_NAMESPACE, "company"); + assertTrue(companyProperty.isOpenContent()); + + DataObject company = quote.createDataObject(companyProperty); + company.setString("name", "FlyByNightTechnology"); + + Property priceProperty = typeHelper.getOpenContentProperty(TEST_NAMESPACE, "price"); + assertTrue(priceProperty.isOpenContent()); + + quote.getList(priceProperty).add(new BigDecimal("1000.0")); + + // Define a new SDO open content property with simple type + DataObject p = dataFactory.create("commonj.sdo", "Property"); + p.set("type", typeHelper.getType("commonj.sdo", "Decimal")); + p.set("name", "highPrice"); + Property highPrice = typeHelper.defineOpenContentProperty(TEST_NAMESPACE, p); + assertTrue(highPrice.isOpenContent()); + + quote.setBigDecimal(highPrice, new BigDecimal("1100.0")); + + // Define a new SDO open content property with complex type + DataObject mutualFundQuotePropertyDef = dataFactory.create("commonj.sdo", "Property"); + mutualFundQuotePropertyDef.set("type", quoteType); + mutualFundQuotePropertyDef.set("name", "mutualFundQuote"); + mutualFundQuotePropertyDef.setBoolean("containment", true); + Property mutualFundQuoteProperty = typeHelper.defineOpenContentProperty(TEST_NAMESPACE, mutualFundQuotePropertyDef); + assertTrue(mutualFundQuoteProperty.isOpenContent()); + + DataObject mutualFundQuote = quote.createDataObject(mutualFundQuoteProperty); + mutualFundQuote.setString("symbol", "mutual-1"); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save(quote, TEST_NAMESPACE, "openStockQuote", baos); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(TEST_DATA))); + + // validate existing property condition + Property duplicateProp = typeHelper.defineOpenContentProperty(TEST_NAMESPACE, p); + assertTrue(highPrice.equals(duplicateProp)); + + // validate error condition, where new property exists with different type + boolean errorCondition = false; + try + { + p = dataFactory.create("commonj.sdo", "Property"); + p.set("type", typeHelper.getType("commonj.sdo", "String")); + p.set("name", "highPrice"); + highPrice = typeHelper.defineOpenContentProperty(TEST_NAMESPACE, p); + } + catch( IllegalArgumentException ex ) + { + errorCondition = true; + } + assertTrue(errorCondition); + } + + protected void setUp() throws Exception { + super.setUp(); + + HelperContext hc = SDOUtil.createHelperContext(); + typeHelper = hc.getTypeHelper(); + dataFactory = hc.getDataFactory(); + xsdHelper = hc.getXSDHelper(); + xmlHelper = hc.getXMLHelper(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + xsdHelper.define(inputStream, url.toString()); + inputStream.close(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineTypeTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineTypeTestCase.java new file mode 100644 index 0000000000..5b3e814f69 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DefineTypeTestCase.java @@ -0,0 +1,704 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.math.BigDecimal; +import java.util.ArrayList; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +public class DefineTypeTestCase extends TestCase +{ + private static final String CUSTOMER1_XML = "/customer1.xml"; + private static final String CUSTOMER2_XML = "/customer2.xml"; + private static final String OPEN_XML = "/open2.xml"; + private static final String MIXED_XML = "/mixed2.xml"; + private static final String MIXEDOPEN_XML = "/mixedopen.xml"; + + HelperContext hc; + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + } + + public void testDefineTypeRoundTrip() throws Exception { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type intType = types.getType("commonj.sdo", "Int"); + Type stringType = types.getType("commonj.sdo", "String"); + + Property xmlElementProp = hc.getXSDHelper().getGlobalProperty("commonj.sdo/xml", "xmlElement", false); + + // create a new Type for Customers + DataObject customerType = factory.create("commonj.sdo", + "Type"); + customerType.set("uri", "http://example.com/customer"); + customerType.set("name", "Customer"); + + // create a customer number property as an XSD attribute + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + custNumProperty.setBoolean(xmlElementProp, false); + + // create a first name property as an XSD attribute + DataObject firstNameProperty = + customerType.createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + firstNameProperty.setBoolean(xmlElementProp, false); + + // create a last name property as an XSD attribute + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + lastNameProperty.setBoolean(xmlElementProp, false); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save(customerType, "commonj.sdo", "type", baos); + + ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray()); + XMLDocument xdoc = xmlHelper.load(bais); + + customerType = xdoc.getRootObject(); + + // now define the Customer type so that customers can be made + types.define(customerType); + + DataObject customer1 = factory.create("http://example.com/customer", + "Customer"); + + customer1.setInt("custNum", 1); + customer1.set("firstName", "John"); + customer1.set("lastName", "Adams"); + DataObject customer2 = factory.create("http://example.com/customer", + "Customer"); + customer2.setInt("custNum", 2); + customer2.set("firstName", "Jeremy"); + customer2.set("lastName", "Pavick"); + + assertNotNull(customer1); + Type type = customer1.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + assertNotNull(customer2); + type = customer2.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer1, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER1_XML))); + + baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer2, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER2_XML))); + } + + public void testDefineType() throws Exception + { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type intType = types.getType("commonj.sdo", "Int"); + Type stringType = types.getType("commonj.sdo", "String"); + + Property xmlElementProp = hc.getXSDHelper().getGlobalProperty("commonj.sdo/xml", "xmlElement", false); + + // create a new Type for Customers + DataObject customerType = factory.create("commonj.sdo", + "Type"); + customerType.set("uri", "http://example.com/customer"); + customerType.set("name", "Customer"); + + // create a customer number property + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + custNumProperty.setBoolean(xmlElementProp, false); + + // create a first name property + DataObject firstNameProperty = + customerType.createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + firstNameProperty.setBoolean(xmlElementProp, false); + + // create a last name property + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + lastNameProperty.setBoolean(xmlElementProp, false); + + // now define the Customer type so that customers can be made + types.define(customerType); + + DataObject customer1 = factory.create("http://example.com/customer", + "Customer"); + + customer1.setInt("custNum", 0); + assertTrue(customer1.isSet("custNum")); + + customer1.setInt("custNum", 1); + customer1.set("firstName", "John"); + customer1.set("lastName", "Adams"); + DataObject customer2 = factory.create("http://example.com/customer", + "Customer"); + customer2.setInt("custNum", 2); + customer2.set("firstName", "Jeremy"); + customer2.set("lastName", "Pavick"); + + assertNotNull(customer1); + Type type = customer1.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + assertNotNull(customer2); + assertNotNull(types.getOpenContentProperty("http://example.com/customer", "customer")); + + type = customer2.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer1, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER1_XML))); + + baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer2, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER2_XML))); + } + + public void testDefineDataType() throws Exception + { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + XSDHelper xsdHelper = hc.getXSDHelper(); + + Property xmlElementProp = hc.getXSDHelper().getGlobalProperty("commonj.sdo/xml", "xmlElement", false); + Property javaClassProperty = xsdHelper.getGlobalProperty("commonj.sdo/java", "javaClass", false); + + // create a data types + DataObject intType = factory.create("commonj.sdo", "Type"); + intType.set("uri", "http://example.com/customer"); + intType.set("name", "MyIntType"); + intType.setBoolean("dataType", true); + intType.set(javaClassProperty, "int"); + + DataObject stringType = factory.create("commonj.sdo", "Type"); + stringType.set("uri", "http://example.com/customer"); + stringType.set("name", "MyStringType"); + stringType.setBoolean("dataType", true); + stringType.set(javaClassProperty, "java.lang.String"); + + // create a new Type for Customers + DataObject customerType = factory.create("commonj.sdo", + "Type"); + customerType.set("uri", "http://example.com/customer"); + customerType.set("name", "Customer"); + + // create a customer number property + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + custNumProperty.setBoolean(xmlElementProp, false); + + // create a first name property + DataObject firstNameProperty = + customerType.createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + firstNameProperty.setBoolean(xmlElementProp, false); + + // create a last name property + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + lastNameProperty.setBoolean(xmlElementProp, false); + + // now define the Customer type so that customers can be made + types.define(customerType); + + DataObject customer1 = factory.create("http://example.com/customer", + "Customer"); + + customer1.setInt("custNum", 1); + customer1.set("firstName", "John"); + customer1.set("lastName", "Adams"); + DataObject customer2 = factory.create("http://example.com/customer", + "Customer"); + customer2.setInt("custNum", 2); + customer2.set("firstName", "Jeremy"); + customer2.set("lastName", "Pavick"); + + assertNotNull(customer1); + Type type = customer1.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + + type = type.getProperty("custNum").getType(); + assertEquals(type.getURI(), "http://example.com/customer"); + assertEquals(type.getName(), "MyIntType"); + assertTrue(type.isDataType()); + + assertNotNull(customer2); + assertNotNull(types.getOpenContentProperty("http://example.com/customer", "customer")); + + type = customer2.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer1, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER1_XML))); + + baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer2, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER2_XML))); + } + + public void testFastDefineType() throws Exception + { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type intType = types.getType("commonj.sdo", "Int"); + Type stringType = types.getType("commonj.sdo", "String"); + + // create a new Type for Customers + Type customerType = SDOUtil.createType(hc, "http://example.com/customer", "Customer", false); + + // create a customer number property + Property custNumProperty = SDOUtil.createProperty(customerType, "custNum", intType); + SDOUtil.setPropertyXMLKind(custNumProperty, false); + + // create a first name property + Property firstNameProperty = SDOUtil.createProperty(customerType, "firstName", stringType); + SDOUtil.setPropertyXMLKind(firstNameProperty, false); + + // create a last name property + Property lastNameProperty = SDOUtil.createProperty(customerType, "lastName", stringType); + SDOUtil.setPropertyXMLKind(lastNameProperty, false); + + DataObject customer1 = factory.create("http://example.com/customer", + "Customer"); + customer1.setInt("custNum", 1); + customer1.set("firstName", "John"); + customer1.set("lastName", "Adams"); + DataObject customer2 = factory.create("http://example.com/customer", + "Customer"); + customer2.setInt("custNum", 2); + customer2.set("firstName", "Jeremy"); + customer2.set("lastName", "Pavick"); + + assertNotNull(customer1); + Type type = customer1.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + assertNotNull(customer2); + type = customer2.getType(); + assertNotNull(type.getProperty("custNum")); + assertNotNull(type.getProperty("firstName")); + assertNotNull(type.getProperty("lastName")); + assertEquals(type.getProperty("custNum").getType(), intType); + assertEquals(type.getProperty("firstName").getType(), stringType); + assertEquals(type.getProperty("lastName").getType(), stringType); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer1, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER1_XML))); + + baos = new ByteArrayOutputStream(); + xmlHelper.save( + customer2, + "http://example.com/customer", + "Customer", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(CUSTOMER2_XML))); + } + + public void testDefineSequencedType() throws Exception + { + + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type stringType = types.getType("commonj.sdo", "String"); + Type decimalType = types.getType("commonj.sdo", "Decimal"); + + // Define a new mixed type - MixedQuote + DataObject mixedQuoteType = factory.create("commonj.sdo", "Type"); + mixedQuoteType.set("uri", "http://www.example.com/mixed"); + mixedQuoteType.set("name", "MixedQuote"); + mixedQuoteType.set("sequenced", Boolean.TRUE); + + DataObject symbolProperty = mixedQuoteType.createDataObject("property"); + symbolProperty.set("name", "symbol"); + symbolProperty.set("type", stringType); + + DataObject companyNameProperty = mixedQuoteType.createDataObject("property"); + companyNameProperty.set("name", "companyName"); + companyNameProperty.set("type", stringType); + + DataObject priceProperty = mixedQuoteType.createDataObject("property"); + priceProperty.set("name", "price"); + priceProperty.set("type", decimalType); + + DataObject quotesProperty = mixedQuoteType.createDataObject("property"); + quotesProperty.set("name", "quotes"); + quotesProperty.set("type", mixedQuoteType); + quotesProperty.set("many", Boolean.TRUE); + quotesProperty.set("containment", Boolean.TRUE); + + types.define(mixedQuoteType); + + DataObject quote = factory.create("http://www.example.com/mixed", "MixedQuote"); + + assertTrue(quote.getType().isSequenced()); + + Sequence sequence = quote.getSequence(); + + sequence.addText("\n "); + + quote.setString("symbol", "fbnt"); + + sequence.addText("\n "); + + quote.setString("companyName", "FlyByNightTechnology"); + + sequence.addText("\n some text\n "); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + sequence.addText("\n more text\n "); + + // quote.setBigDecimal("price", new BigDecimal("1000.0")); + sequence.add("price", new BigDecimal("1000.0")); + + sequence.addText("\n"); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save(quote, "http://www.example.com/mixed", "mixedStockQuote", baos); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(MIXED_XML))); + } + + public void testDefineSequencedOpenType() throws Exception + { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type stringType = types.getType("commonj.sdo", "String"); + Type decimalType = types.getType("commonj.sdo", "Decimal"); + + // Define a new mixed type - MixedQuote + DataObject mixedQuoteType = factory.create("commonj.sdo", "Type"); + mixedQuoteType.set("uri", "http://www.example.com/mixed"); + mixedQuoteType.set("name", "MixedOpenQuote"); + mixedQuoteType.set("sequenced", Boolean.TRUE); + mixedQuoteType.set("open", Boolean.TRUE); + +// DataObject symbolProperty = mixedQuoteType.createDataObject("property"); +// symbolProperty.set("name", "symbol"); +// symbolProperty.set("type", stringType); + + DataObject companyNameProperty = mixedQuoteType.createDataObject("property"); + companyNameProperty.set("name", "companyName"); + companyNameProperty.set("type", stringType); + + DataObject priceProperty = mixedQuoteType.createDataObject("property"); + priceProperty.set("name", "price"); + priceProperty.set("type", decimalType); + + DataObject quotesProperty = mixedQuoteType.createDataObject("property"); + quotesProperty.set("name", "quotes"); + quotesProperty.set("type", mixedQuoteType); + quotesProperty.set("many", Boolean.TRUE); + quotesProperty.set("containment", Boolean.TRUE); + + types.define(mixedQuoteType); + + // Define a global type + DataObject globalType = factory.create("commonj.sdo", "Type"); + globalType.set("uri", "http://www.example.com/open"); + // Don't set the type's name - null is used for types containing global properties. + + DataObject symbolProperty = globalType.createDataObject("property"); + symbolProperty.set("name", "symbol"); + symbolProperty.set("type", stringType); + symbolProperty.set("containment", Boolean.TRUE); + + types.define(globalType); + + DataObject quote = factory.create("http://www.example.com/mixed", "MixedOpenQuote"); + + assertTrue(quote.getType().isSequenced()); + + Sequence sequence = quote.getSequence(); + + sequence.addText("\n "); + + Type definedGlobalType = types.getType("http://www.example.com/open", "DocumentRoot"); + + Property definedSymbolProperty = definedGlobalType.getProperty("symbol"); + quote.setString(definedSymbolProperty, "fbnt"); + + sequence.addText("\n "); + + quote.setString("companyName", "FlyByNightTechnology"); + + sequence.addText("\n some text\n "); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + sequence.addText("\n more text\n "); + + // quote.setBigDecimal("price", new BigDecimal("1000.0")); + sequence.add("price", new BigDecimal("1000.0")); + + sequence.addText("\n"); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save(quote, "http://www.example.com/mixed", "mixedOpenStockQuote", baos); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(MIXEDOPEN_XML))); + } + + + public void testDefineOpenType() throws Exception + { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + Type stringType = types.getType("commonj.sdo", "String"); + Type decimalType = types.getType("commonj.sdo", "Decimal"); + + Property xmlElementProp = hc.getXSDHelper().getGlobalProperty("commonj.sdo/xml", "xmlElement", false); + + // Define a new open type - OpenQuote + DataObject openQuoteType = factory.create("commonj.sdo", "Type"); + openQuoteType.set("uri", "http://www.example.com/open"); + openQuoteType.set("name", "OpenQuote"); + openQuoteType.set("open", Boolean.TRUE); + openQuoteType.setBoolean("open", true); + + types.define(openQuoteType); + + // Define new type - CompanyType + DataObject companyType = factory.create("commonj.sdo", "Type"); + companyType.set("uri", "http://www.example.com/open"); + companyType.set("name", "CompanyType"); + + // Create CompanyType property - "name" as an XSD attribute + DataObject nameProperty = companyType.createDataObject("property"); + nameProperty.set("name", "name"); + nameProperty.set("type", stringType); + nameProperty.set("containment", Boolean.TRUE); + nameProperty.setBoolean(xmlElementProp, false); + + types.define(companyType); + + // Define open content property - company + DataObject symbolProperty = factory.create("commonj.sdo", "Property"); + symbolProperty.set("name", "symbol"); + symbolProperty.set("type", stringType); + types.defineOpenContentProperty("http://www.example.com/open", symbolProperty); + + // Define open content property - company + DataObject companyProperty = factory.create("commonj.sdo", "Property"); + companyProperty.set("name", "company"); + companyProperty.set("type", companyType); + companyProperty.set("containment", Boolean.TRUE); + types.defineOpenContentProperty("http://www.example.com/open", companyProperty); + + // Define open content property - price + DataObject priceProperty = factory.create("commonj.sdo", "Property"); + priceProperty.set("name", "price"); + priceProperty.set("type", decimalType); + types.defineOpenContentProperty("http://www.example.com/open", priceProperty); + + // Create DataObject instances + DataObject openQuote = factory.create("http://www.example.com/open", "OpenQuote"); + assertTrue(openQuote.getType().isOpen()); + + Property definedSymbolProperty = types.getOpenContentProperty("http://www.example.com/open", "symbol"); + openQuote.set(definedSymbolProperty, "s1"); + + Property definedCompanyProperty = types.getOpenContentProperty("http://www.example.com/open", "company"); + DataObject company = openQuote.createDataObject(definedCompanyProperty); + company.setString("name", "FlyByNightTechnology"); + + Property definedPriceProperty = types.getOpenContentProperty("http://www.example.com/open", "price"); + openQuote.setBigDecimal(definedPriceProperty, new BigDecimal("1000.0")); + + assertEquals(definedPriceProperty.getType(), decimalType); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlHelper.save( + openQuote, + "http://www.example.com/open", + "openStockQuote", baos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(baos.toByteArray()), + getClass().getResource(OPEN_XML))); + } + +/** + * Type T1 has property t1p of type T2, type T2 has property t2p of type T1. + * Ensure that the typehelper can handle this circularity + */ +public void testInterdependentTypes() + { + DataObject t1 = DataFactory.INSTANCE.create("commonj.sdo", "Type"); + DataObject t1p = DataFactory.INSTANCE.create("commonj.sdo", "Property"); + DataObject t2 = DataFactory.INSTANCE.create("commonj.sdo", "Type"); + DataObject t2p = DataFactory.INSTANCE.create("commonj.sdo", "Property"); + + t1.set("name", "T1"); + t1.set("uri", "foo"); + t2.set("name", "T2"); + t2.set("uri", "foo"); + + t1.getList("property").add(t1p); + t2.getList("property").add(t2p); + t1p.set("name", "t1p"); + t1p.set("type", t2); + t2p.set("name", "t2p"); + t2p.set("type", t1); + + List ts = new ArrayList(); + ts.add(t1); + ts.add(t2); + List types = hc.getTypeHelper().define(ts); + + Type first = (Type)types.get(0); + Type second = (Type)types.get(1); + + Type firstsPropsType = ((Property)first.getProperties().get(0)).getType(); + Type secondPropsType = ((Property)second.getProperties().get(0)).getType(); + + assertNotNull(first); + assertNotNull(second); + assertEquals(first, secondPropsType); + assertEquals(second, firstsPropsType); + + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DeserializationNoSchemaTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DeserializationNoSchemaTestCase.java new file mode 100644 index 0000000000..65a838bb52 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DeserializationNoSchemaTestCase.java @@ -0,0 +1,124 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; +import java.net.URL; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; + + +public class DeserializationNoSchemaTestCase extends TestCase +{ + HelperContext hc; + + TypeHelper th; + + private final String xmlStr = + " " + + " " + + "fbnt " + + "FlyByNightTechnology " + + "1000.0 " + + "1000.0 " + + "1000.0 " + + "1000.0 " + + "1000.0 " + + "1000.0 " + + " " + + "2000.0 " + + " " + + ""; + + public void testLoadQuoteXMLDoc() throws IOException + { + XMLHelper xmlHelper = hc.getXMLHelper(); +/* URL url = getClass().getResource("/quote.xml"); + InputStream inputStream = url.openStream();*/ + XMLDocument doc = xmlHelper.load(xmlStr); + DataObject root = doc.getRootObject(); + + List symbols = root.getList("symbol"); + DataObject symbol = (DataObject)symbols.get(0); + + String seqValue = (String)symbol.getSequence().getValue(0); + assertEquals(seqValue, "fbnt"); + + //String symbol = root.getString("symbol"); + //System.out.println("symbol: " + symbol); + } + + public void testAnyTypeContainer() throws Exception + { + HelperContext hc = SDOUtil.createHelperContext(); + + URL url = getClass().getResource("/simple.xsd"); + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + + XMLHelper xmlHelper = hc.getXMLHelper(); + url = getClass().getResource("/quoteInSOAP.xml"); + inputStream = url.openStream(); + XMLDocument doc = xmlHelper.load(inputStream); + DataObject root = doc.getRootObject(); + DataObject body = (DataObject)root.getList("Body").get(0); + DataObject stockQuote = (DataObject)body.getList("stockQuote").get(0); + + //xmlHelper.save(stockQuote, stockQuote.getType().getURI(), "stockQuote", System.out); + + ByteArrayOutputStream bos = new ByteArrayOutputStream(); + ObjectOutputStream oos = SDOUtil.createObjectOutputStream(bos, hc); + oos.writeObject(stockQuote); + oos.close(); + bos.close(); + + ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray()); + ObjectInputStream ois = SDOUtil.createObjectInputStream(bis, hc); + DataObject objectCopy = (DataObject)ois.readObject(); + ois.close(); + bis.close(); + + assertEquals(objectCopy.getString("symbol"), "fbnt"); + + //xmlHelper.save(objectCopy, stockQuote.getType().getURI(), "stockQuote", System.out); + } + + protected void setUp() throws Exception + { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DotNameTest.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DotNameTest.java new file mode 100644 index 0000000000..476f34c328 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DotNameTest.java @@ -0,0 +1,78 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + + +public class DotNameTest extends TestCase { + private final String TEST_MODEL = "/dotNames.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/dotNames"; + private HelperContext hc; + private TypeHelper th; + private DataFactory df; + + /** + * Simple Dynamic SDO 2 test. + */ + public void testDynamic() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "DotNameType"); + DataObject quote = df.create(quoteType); + + + quote.getList("property.2.1").add(TEST_NAMESPACE); + assertTrue(quote.isSet("property.2.1")); + assertSame(quote.get("property.2.1.0"), TEST_NAMESPACE); + quote.getList("foo.bar").add(TEST_NAMESPACE); + assertTrue(quote.isSet("foo.bar")); + assertSame(quote.get("foo.bar.0"), TEST_NAMESPACE); + } + + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + df = hc.getDataFactory(); + + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + + + } + +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DupElementTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DupElementTestCase.java new file mode 100644 index 0000000000..9c4f487b6a --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DupElementTestCase.java @@ -0,0 +1,99 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.net.URL; +import java.util.List; +//import java.util.regex.MatchResult; +//import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; + +public class DupElementTestCase extends TestCase { + HelperContext hc; + + private final String TEST_MODEL = "/dupelement.xsd"; + private final String TEST_URI = "http://www.example.com/dupelement"; + + protected void setUp() throws Exception { + super.setUp(); + + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + + hc = SDOUtil.createHelperContext(); + + hc.getXSDHelper().define(inputStream, url.toString()); + + inputStream.close(); + } + + + public void test() { + Type quoteType = hc.getTypeHelper().getType(TEST_URI, "Quote"); + + DataObject quote = hc.getDataFactory().create(quoteType); + quote.set("symbol", "ACME"); + quote.set("companyName", "ACME Corp."); + + DataObject quote2 = hc.getDataFactory().create(quoteType); + + List quotes = quote.getList("quotes"); + quotes.add(quote2); + + try { + quote.set("quotes.0/symbol", "ACME-CHILD"); + quote.set("quotes.0/companyName", "ACME subsidiary corp."); + quote.setInt("quotes.0/companyNameInInt", 99); + quote.setInt("quotes.0/symbolInInt", 55); + } + catch (Exception e) { + fail("Set value on the wrong properties with the same name"); + } + assert(quote.get("quotes.0/companyName") instanceof String); + assert(quote.get("quotes.0/symbol") instanceof String); + assert(quote.get("quotes.0/companyNameInInt") instanceof Integer); + assert(quote.get("quotes.0/symbolInInt") instanceof Integer); + + String doc = hc.getXMLHelper().save(quote, "http://www.example.com/dupelement", "stockQuote"); + //System.out.println(doc); + assertTrue( + Pattern.matches("[\\s\\S]*[\\s]*ACME Corp.[\\s]*[\\s\\S]*", + doc)); + assertTrue( + Pattern.matches("[\\s\\S]*[\\s]*99[\\s]*[\\s\\S]*", + doc)); + assertTrue( + Pattern.matches("[\\s\\S]*symbol[\\s]*=[\\s]*\"55\"[\\s\\S]*", + doc)); + assertTrue( + Pattern.matches("[\\s\\S]*[\\s]*ACME-CHILD[\\s]*[\\s\\S]*", + doc)); + + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DynamicTypesComparisonTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DynamicTypesComparisonTestCase.java new file mode 100644 index 0000000000..4c347867e0 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/DynamicTypesComparisonTestCase.java @@ -0,0 +1,256 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +/** + * Test to compare data objects created with SDO API with one created from XML + */ +public class DynamicTypesComparisonTestCase extends TestCase { + private final String COMMONJ_SDO = "commonj.sdo"; + + private final String DYNAMIC_ROOT_TYPE_0 = "TestType0"; + + private final String DYNAMIC_TYPES_SCHEMA_STRING = "\n" + "\n" + " \n" + + " \n" + " \n" + + " \n" + + " \n" + + " \n" + + " \n" + " \n" + " \n" + + " \n" + " \n" + "\n"; + + private final String DYNAMIC_TYPES_URI = "http://www.example.com/dynamicTypesFromSchemaSimple"; + + private final String SDO_FROM_API_AND_DYN = "object created with API with dynamic type "; + + private final String SDO_FROM_API_AND_REF = "object created with API with type from XSD"; + + private final String SDO_FROM_XML_AND_REF = "object created with XML with type from XSD"; + + private final String TEST_XML_DOC_0_STRING = "\n" + + "\n" + + " This is a repeated string.\n" + " This is a repeated string.\n" + + " true\n" + " false\n" + " true\n" + + " 1\n" + " 0\n" + " 0\n" + + " 12.5\n" + " 0\n" + "\n"; + + private void comparePropertyObjects(String propName, String name1, String name2, Object propObj1, Object propObj2) { + if (propObj1 == null) { + if (propObj2 != null) { + localFail("property " + propName + " for " + name1 + " was null but " + name2 + " was '" + propObj2 + + "'"); + } + } else if (propObj2 == null) { + localFail("property " + propName + " for " + name2 + " was null but " + name1 + " was '" + propObj1 + "'"); + } else { + if (!propObj1.equals(propObj2)) { + localFail("property " + propName + " for " + name1 + " was '" + propObj1 + "' but " + name2 + " was '" + + propObj2 + "'"); + } + } + } + + private void compareSequencesIgnoringWhitespace(String name1, String name2, Sequence sequence1, Sequence sequence2) { + if (sequence1 == null) { + if (sequence2 != null) { + localFail("sequence for " + name1 + " was null but " + name2 + " was not null"); + } + } else if (sequence2 == null) { + localFail("sequence for " + name2 + " was null but " + name1 + " was not null"); + } else { + List trimmedSeq1 = new ArrayList(); + List trimmedSeq2 = new ArrayList(); + trimWhitespaceFromSequence(trimmedSeq1, sequence1); + trimWhitespaceFromSequence(trimmedSeq2, sequence2); + int size1 = trimmedSeq1.size(); + int size2 = trimmedSeq2.size(); + if (size1 != size2) { + localFail("lengths of trimmed sequences differ: " + name1 + " was " + size1 + ", " + name2 + " was " + + size2); + } else { + Object[] objArr1 = trimmedSeq1.toArray(); + Object[] objArr2 = trimmedSeq2.toArray(); + for (int i = 0; i < size1; i++) { + Object obj1 = objArr1[i]; + Object obj2 = objArr2[i]; + if (obj1 == null) { + if (obj2 != null) { + localFail("sequence for " + name1 + " had null element for which " + name2 + " had '" + obj2 + + "'"); + } + } else if (obj2 == null) { + localFail("sequence for " + name2 + " had null element for which " + name1 + " had '" + obj1 + "'"); + } else { + if (!obj1.equals(obj2)) { + localFail("sequences did not match: " + name1 + " had '" + obj1 + "' but " + name2 + " had '" + + obj2 + "'"); + } + } + } + } + } + } + + private void getAndCompareProperties(String propName, DataObject xmlAndRefTypDO, DataObject apiAndDynTypDO, + DataObject apiAndRefTypDO) { + Object xmlRefProperty = xmlAndRefTypDO.get(propName); + Object apiDynProperty = apiAndDynTypDO.get(propName); + Object apiRefProperty = apiAndRefTypDO.get(propName); + comparePropertyObjects(propName, SDO_FROM_XML_AND_REF, SDO_FROM_API_AND_DYN, xmlRefProperty, apiDynProperty); + comparePropertyObjects(propName, SDO_FROM_XML_AND_REF, SDO_FROM_API_AND_REF, xmlRefProperty, apiRefProperty); + } + + private void localFail(String message) { + // System.err.println(message); + fail(message); + } + + protected void setUp() throws Exception { + super.setUp(); + } + + private void specifyProperty(DataObject containingTypeDO, String nameString, Type typ, boolean isMany) { + DataObject subordinateProperty = containingTypeDO.createDataObject("property"); + subordinateProperty.set("name", nameString); + subordinateProperty.set("type", typ); + subordinateProperty.setBoolean("many", isMany); + } + + /** + * test #0 of Data Object primitive datatypes + */ + public void testDynamicTypesGroup0DO() throws IOException { + HelperContext hcDO = SDOUtil.createHelperContext(); + + TypeHelper thDO = hcDO.getTypeHelper(); + DataFactory dfDO = hcDO.getDataFactory(); + + // create a container object type + DataObject containerTypeDO = dfDO.create("commonj.sdo", "Type"); + containerTypeDO.set("uri", DYNAMIC_TYPES_URI); + containerTypeDO.set("name", DYNAMIC_ROOT_TYPE_0); + containerTypeDO.set("sequenced", Boolean.TRUE); + + specifyProperty(containerTypeDO, "aString", thDO.getType(COMMONJ_SDO, "String"), true); + specifyProperty(containerTypeDO, "aBoolean", thDO.getType(COMMONJ_SDO, "Boolean"), true); + specifyProperty(containerTypeDO, "aFloat", thDO.getType(COMMONJ_SDO, "Float"), true); + + Type containerType = thDO.define(containerTypeDO); + assertNotNull(containerType); + + DataObject doFromApiAndDynTyp = dfDO.create(containerType); + assertNotNull(doFromApiAndDynTyp); + doFromApiAndDynTyp.getList("aString").add("This is a repeated string."); + doFromApiAndDynTyp.getList("aString").add("This is a repeated string."); + doFromApiAndDynTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndDynTyp.getList("aBoolean").add(new Boolean(false)); + doFromApiAndDynTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndDynTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndDynTyp.getList("aBoolean").add(new Boolean(false)); + doFromApiAndDynTyp.getList("aFloat").add(new Float(0)); + doFromApiAndDynTyp.getList("aFloat").add(new Float(12.5)); + doFromApiAndDynTyp.getList("aFloat").add(new Float(0)); + + Type rootType = thDO.getType(DYNAMIC_TYPES_URI, DYNAMIC_ROOT_TYPE_0); + assertNotNull(rootType); + assertSame(containerType, rootType); + + // now load xml to get a reference data object using schema + HelperContext hcRef = SDOUtil.createHelperContext(); + XSDHelper xsdHelper = hcRef.getXSDHelper(); + List typeList = xsdHelper.define(DYNAMIC_TYPES_SCHEMA_STRING); + assertNotNull(typeList); + TypeHelper thRef = hcRef.getTypeHelper(); + Type rootTypeRef = thRef.getType(DYNAMIC_TYPES_URI, DYNAMIC_ROOT_TYPE_0); + + assertNotNull(rootTypeRef); + + XMLHelper xhRef = hcRef.getXMLHelper(); + // XMLDocument docRef = + // xhRef.load(getClass().getResourceAsStream(TEST_XML_DOC_0)); + XMLDocument docRef = xhRef.load(TEST_XML_DOC_0_STRING); + DataObject doFromXmlAndRefTyp = docRef.getRootObject(); + + assertNotNull(doFromXmlAndRefTyp); + + // create a data object using dynamic API from reference type + DataFactory dfRef = hcRef.getDataFactory(); + DataObject doFromApiAndRefTyp = dfRef.create(rootTypeRef); + assertNotNull(doFromApiAndRefTyp); + doFromApiAndRefTyp.getList("aString").add("This is a repeated string."); + doFromApiAndRefTyp.getList("aString").add("This is a repeated string."); + doFromApiAndRefTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndRefTyp.getList("aBoolean").add(new Boolean(false)); + doFromApiAndRefTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndRefTyp.getList("aBoolean").add(new Boolean(true)); + doFromApiAndRefTyp.getList("aBoolean").add(new Boolean(false)); + doFromApiAndRefTyp.getList("aFloat").add(new Float(0)); + doFromApiAndRefTyp.getList("aFloat").add(new Float(12.5)); + doFromApiAndRefTyp.getList("aFloat").add(new Float(0)); + + getAndCompareProperties("aString", doFromXmlAndRefTyp, doFromApiAndDynTyp, doFromApiAndRefTyp); + getAndCompareProperties("aBoolean", doFromXmlAndRefTyp, doFromApiAndDynTyp, doFromApiAndRefTyp); + getAndCompareProperties("aFloat", doFromXmlAndRefTyp, doFromApiAndDynTyp, doFromApiAndRefTyp); + Sequence seqFromXmlAndRefTyp = doFromXmlAndRefTyp.getSequence(); + Sequence seqFromApiAndDynTyp = doFromApiAndDynTyp.getSequence(); + Sequence seqFromApiAndRefTyp = doFromApiAndRefTyp.getSequence(); + compareSequencesIgnoringWhitespace(SDO_FROM_XML_AND_REF, SDO_FROM_API_AND_DYN, seqFromXmlAndRefTyp, + seqFromApiAndDynTyp); + compareSequencesIgnoringWhitespace(SDO_FROM_XML_AND_REF, SDO_FROM_API_AND_REF, seqFromXmlAndRefTyp, + seqFromApiAndRefTyp); + } + + private void trimWhitespaceFromSequence(List trimmedSeq, Sequence sequence) { + if (sequence != null) { + for (int i = 0; i < sequence.size(); i++) { + Object obj = sequence.getValue(i); + if (obj instanceof String) { + String str = ((String) obj).trim(); + if (str.length() > 0) { + trimmedSeq.add(str); + } + } else { + trimmedSeq.add(obj); + } + } + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ExpectedExceptionsTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ExpectedExceptionsTestCase.java new file mode 100644 index 0000000000..af4bb4d928 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ExpectedExceptionsTestCase.java @@ -0,0 +1,1878 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; +import java.util.List; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import com.example.ExpectedException.ExpectedExceptionFactory; + +import commonj.sdo.DataGraph; +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + +import junit.framework.TestCase; + +/** + * Verifies the Exception related behavior which is explicitly identified in + * the 2.1 SDO Specification. + */ +public class ExpectedExceptionsTestCase extends TestCase { + + private static final String TEST_URI = "http://example.com/ExpectedException"; + private static final String TEST_TYPE_NAME = "ExpectedExceptionType"; + private static final String SEQ_TYPE_NAME = "SequenceReadOnlyType"; + private static boolean typeDefined = false; + private static HelperContext helperContext; + private static DataObject testDO; + private static DataObject seqDO; + + /** + * Verifies the following statement. + * Get(String path) will not throw exceptions other than ClassCastException + * if it is impossible to convert between the actual and expected types. + * Note: This test case will not be implmented because it is already covered + * by testCannnotConvertClassCastException. + */ + + public void testGetTStringClassCastExceptionOnly() { + // This test case will not be implemented. + } + + /** + * Verifies the following statement. + * get(Property property) throws an IllegalArgumentException when + * getInstanceProperties().contains(property) == false. + */ + public void testGetViaPropertyIllegalArgumentException() { + DataObject invalidPropDO = helperContext.getDataFactory().create(TEST_URI, SEQ_TYPE_NAME); + Property invalidProp = invalidPropDO.getInstanceProperty("uniqueName"); + + try { + testDO.get(invalidProp); + fail("get(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("get(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBoolean(invalidProp); + fail("getBoolean(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte(invalidProp); + fail("getByte(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar(invalidProp); + fail("getChar(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble(invalidProp); + fail("getDouble(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat(invalidProp); + fail("getFloat(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt(invalidProp); + fail("getInt(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong(invalidProp); + fail("getLong(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort(invalidProp); + fail("getShort(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes(invalidProp); + fail("getBytes(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal(invalidProp); + fail("getBigDecimal(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger(invalidProp); + fail("getBigInteger(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject(invalidProp); + fail("getDataObject(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate(invalidProp); + fail("getDate(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString(invalidProp); + fail("getString(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getList(invalidProp); + fail("getList(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(propert)== false. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(Property property) should throw an IllegalArgumentException when getInstanceProperties().contains(property)== false. " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Verfies the following statement. + * get(int propertyIndex) throws an IllegalArgumentException when + * propertIndex <0 or >= getInstanceProerties().size() + */ + public void testGetViaIndexIllegalArgumentException() { + int numProps = testDO.getInstanceProperties().size(); + + try { + testDO.get(-1); + fail("get(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("get(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBoolean(-1); + fail("getBoolean(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte(-1); + fail("getByte(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar(-1); + fail("getChar(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble(-1); + fail("getDouble(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat(-1); + fail("getFloat(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt(-1); + fail("getInt(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong(-1); + fail("getLong(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort(-1); + fail("getShort(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes(-1); + fail("getBytes(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal(-1); + fail("getBigDecimal(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger(-1); + fail("getBigInteger(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject(-1); + fail("getDataObject(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate(-1); + fail("getDate(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString(-1); + fail("getString(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getList(-1); + fail("getList(-1) should throw an IllegalArgumentException. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(-1) should throw an IllegalArgumentException. " + e.getClass().getName() + " was thrown."); + } + + try { + testDO.get(numProps); + fail("get(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("get(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBoolean(numProps); + fail("getBoolean(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte(numProps); + fail("getByte(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar(numProps); + fail("getChar(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble(numProps); + fail("getDouble(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat(numProps); + fail("getFloat(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt(numProps); + fail("getInt(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong(numProps); + fail("getLong(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort(numProps); + fail("getShort(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes(numProps); + fail("getBytes(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal(numProps); + fail("getBigDecimal(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger(numProps); + fail("getBigInteger(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject(numProps); + fail("getDataObject(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate(numProps); + fail("getDate(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString(numProps); + fail("getString(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getList(numProps); + fail("getList(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(int) should throw an IllegalArgumentException when int >= getInstanceProperties.size(). " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Verifies the following statement. + * Using an Index out of range (index < 0 or >= getList(Property property).size()) + * will result in an IndexOutOfBoundsException. + */ + public void testListIndexOutOfBoundsException() { + List list = testDO.getList("listVal"); + +// Not fixed in TUSCANY-578 +// try { +// list.get(-1); +// fail("list.get(-1) should throw an IndexOutOfBoundsException. No Exception was thrown."); +// } catch (IndexOutOfBoundsException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("list.get(-1) should throw an IndexOutOfBoundsException. " + e.getClass().getName() + " was thrown."); +// } +// try { +// list.get(list.size()); +// fail("list.get(int) should throw an IndexOutOfBoundsException when int >= list.size(). No Exception was thrown."); +// } catch (IndexOutOfBoundsException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("list.get(int) should throw an IndexOutOfBoundsException when int >= list.size(). " + e.getClass().getName() + " was thrown."); +// } +// try { +// list.remove(-1); +// fail("list.remove(-1) should throw an IndexOutOfBoundsException. No Exception was thrown."); +// } catch (IndexOutOfBoundsException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("list.remove(-1) should throw an IndexOutOfBoundsException. " + e.getClass().getName() + " was thrown."); +// } + try { + list.remove(list.size()); + fail("list.remove(int) should throw an IndexOutOfBoundsException when int >= list.size(). No Exception was thrown."); + } catch (IndexOutOfBoundsException e) { + // Success - do nothing + } catch (Exception e) { + fail("list.remove(int) should throw an IndexOutOfBoundsException when int >= list.size(). " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Verifies the following statement. + * Modification of a read-only property results in UnsupportedOperationException. + * This test case is for modifications done through the DataObject API. + */ + public void testModifyReadOnlyUnsupportedOperationException() { + Property readOnlyProp = testDO.getInstanceProperty("readOnlyVal"); + List properties = testDO.getInstanceProperties(); + Property currProp; + int readOnlyIndex = -1, i = 0, size = properties.size(); + + // Verify the precondition + assertTrue("readOnlyVal should be read-only.", readOnlyProp.isReadOnly()); + + while (readOnlyIndex < 0 && i < size) { + currProp = (Property) properties.get(i); + if (currProp.equals(readOnlyProp)) + readOnlyIndex = i; + i++; + } + + try { + testDO.set("readOnlyVal", "NewValue"); + fail("DataObject.set(string, value) should throw an UnsupportedOperationException when the Property represented by string is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.set(string, value) should throw an UnsupportedOperationException when the Property represented by string is read-only. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.set(readOnlyProp, "NewValue"); + System.out.println("propname =" + readOnlyProp.getName()); + fail("DataObject.set(property, value) should throw an UnsupportedOperationException when the Property represented by property is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.set(property, value) should throw an UnsupportedOperationException when the Property represented by property is read-only. " + e.getClass().getName() + " was thrown."); + } + assertTrue("The test case could not procede because the index of the read only Property was not found.", readOnlyIndex > -1); + try { + testDO.set(readOnlyIndex, "NewValue"); + fail("DataObject.set(index, value) should throw an UnsupportedOperationException when the Property represented by index is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.set(index, value) should throw an UnsupportedOperationException when the Property represented by index is read-only. " + e.getClass().getName() + " was thrown."); + } + + try { + testDO.unset("readOnlyVal"); + fail("DataObject.unset(string) should throw an UnsupportedOperationException when the Property represented by string is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.unset(string) should throw an UnsupportedOperationException when the Property represented by string is read-only. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.unset(readOnlyProp); + fail("DataObject.unset(property) should throw an UnsupportedOperationException when the Property represented by property is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.unset(property) should throw an UnsupportedOperationException when the Property represented by property is read-only. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.unset(readOnlyIndex); + fail("DataObject.unset(index) should throw an UnsupportedOperationException when the Property represented by index is read-only. No Exception was thrown."); + } catch (UnsupportedOperationException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataObject.unset(index) should throw an UnsupportedOperationException when the Property represented by index is read-only. " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Verifies the following statement. + * Modification of a read-only property results in UnsupportedOperationException. + * This test case is for modification done through the List API. + */ + public void testModifyReadOnlyUnsupportedOperationExceptionList() { + Property readOnlyProp = testDO.getInstanceProperty("readOnlyVal"); + List properties = testDO.getInstanceProperties(); + Property currProp; + int readOnlyIndex = -1, i = 0, size = properties.size(); + + while (readOnlyIndex < 0 && i < size) { + currProp = (Property) properties.get(i); + if (currProp.equals(readOnlyProp)) + readOnlyIndex = i; + i++; + } + +// Not fixed in TUSCANY-578 +// try { +// List temp = testDO.getList("readOnlyListVal"); +// temp.add("String to add."); +// fail("DataObject.getList(path).add(value) should throw an UnsupportedOperationException when the Property represented by path is read-only. No Exception was thrown."); +// } catch (UnsupportedOperationException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("DataObject.getList(path).add(value) should throw an IllegalArgumentException when the Property represented by path is read-only. " + e.getClass().getName() + " was thrown."); +// } +// try { +// Sequence temp = testDO.getSequence(); +// temp.add("readOnlyListVal", "String to add."); +// fail("DataObject.getSequence().add(path, value) should throw an UnsupportedOperationException when the Property represtend by path is read-only. No Exception was thrown."); +// } catch (UnsupportedOperationException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("DataObject.getSequence().add(path, value) should throw an UnsupportedOperationException when the Property represtend by path is read-only. " + e.getClass().getName() + " was thrown."); +// } + } + + /** + * Verifies the following statement. + * Modification of a read-only property results in UnsupportedOperationException. + * This test case is for modification done through the List API. + */ + public void testModifyReadOnlyUnsupportedOperationExceptionSequence() { + Property readOnlyProp = seqDO.getInstanceProperty("readOnlyVal"); + List properties = seqDO.getInstanceProperties(); + Property currProp; + int readOnlyIndex = -1, i = 0, size = properties.size(); + + while (readOnlyIndex < 0 && i < size) { + currProp = (Property) properties.get(i); + if (currProp.equals(readOnlyProp)) + readOnlyIndex = i; + i++; + } + +// Not fixed in TUSCANY-578 +// try { +// Sequence sequence = seqDO.getSequence(); +// sequence.add(readOnlyProp, "New Value"); +// fail("Sequence.add(property, value) should throw an UnsupportedOperationException when the Property represented by property is read-only. No Exception was thrown."); +// } catch (UnsupportedOperationException e) { +// // Success - do nothing +// } catch (Exception e) { +// fail("Sequence.add(property, value) should throw an UnsupportedOperationException when the Property represented by property is read-only. " + e.getClass().getName() + " was thrown."); +// } + } + + /** + * Verifies the following statement. + * A ClassCastException results when cannot convert between value and requested Type. + */ + + public void testCannotConvertClassCastException() { + // Attempt conversion from boolean + + try { + testDO.getByte("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDouble("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getFloat("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getInt("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getLong("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigInteger("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("booleanVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + + // Attempt conversion from byte + try { + testDO.getBoolean("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigInteger("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("byteVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + // Attempt conversion from character + try { + testDO.getBoolean("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getByte("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDouble("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getFloat("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getInt("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getLong("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigInteger("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("charVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from double + try { + testDO.getBoolean("doubleVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("doubleVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("doubleVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("doubleVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from float + try { + testDO.getBoolean("floatVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("floatVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("floatVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("floatVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from int + try { + testDO.getBoolean("intVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("intVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("intVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("intVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from long + try { + testDO.getBoolean("longVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("longVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("longVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from short + try { + testDO.getBoolean("shortVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("shortVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("shortVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("shortVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigInteger("shortVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("shortVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from bytes + try { + testDO.getBoolean("bytesVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getByte("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDouble("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getFloat("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getInt("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getLong("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("bytesVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from decimal + try { + testDO.getBoolean("decimalVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getByte("decimalVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("decimalVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("decimalVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("decimalVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("decimalVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from BigInteger + try { + testDO.getBoolean("integerVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getByte("integerVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("integerVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("integerVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDate("integerVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + +// Attempt conversion from date + try { + testDO.getBoolean("dateVal"); + } catch (ClassCastException e) { + // success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getByte("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getChar("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getDouble("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getFloat("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getInt("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getShort("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBytes("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigDecimal("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + try { + testDO.getBigInteger("dateVal"); + } catch (ClassCastException e) { +// success - do nothing + } catch (Exception e) { + fail("Attempted implicit unsupported conversion did not throw the correct Exception. Expected: ClassCastException. Received: " + e.getClass().getName()); + } + } + + + /** + * Verifies the following statement. + * Mixing single-valued and multi-valued Property access results in + * ClassCastException. + */ + public void testMixSingleMultiValueClassCastException() { + Property testedProp = testDO.getInstanceProperty("intVal"); + List properties = testDO.getInstanceProperties(); + Property currProp; + int testedIndex = -1, i = 0, size = properties.size(); + + while (testedIndex < 0 && i < size) { + currProp = (Property) properties.get(i); + + if (currProp.equals(testedProp)) + testedIndex = i; + i++; + } + + try { + testDO.getList("intVal"); + fail("getList(string) should throw a ClassCastException when the property represented by string is single-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(string) should throw a ClassCastException when the property represented by string is single-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getList(testedProp); + fail("getList(property) should throw a ClassCastException when the property represented by property is single-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(property) should throw a ClassCastException when the property represented by property is single-valued. " + e.getClass().getName() + " was thrown."); + } + + assertTrue("The test case could not procede because the index of the single-valued Property was not found.", testedIndex > -1); + + try { + testDO.getList(testedIndex); + fail("getList(index) should throw a ClassCastException when the property represented by index is single-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getList(index) should throw a ClassCastException when the property represented by index is single-valued. " + e.getClass().getName() + " was thrown."); + } + + testedProp = testDO.getInstanceProperty("listVal"); + testedIndex = -1; + i = 0; + while (testedIndex < 0 && i < size) { + currProp = (Property) properties.get(i); + if (currProp.equals(testedProp)) + testedIndex = i; + i++; + } + + try { + testDO.getBoolean("listVal"); + fail("getBoolean(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte("listVal"); + fail("getByte(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar("listVal"); + fail("getChar(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble("listVal"); + fail("getDouble(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat("listVal"); + fail("getFloat(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt("listVal"); + fail("getInt(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong("listVal"); + fail("getLong(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort("listVal"); + fail("getShort(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes("listVal"); + fail("getBytes(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal("listVal"); + fail("getBigDecimal(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger("listVal"); + fail("getBigInteger(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject("listVal"); + fail("getDataObject(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate("listVal"); + fail("getDate(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString("listVal"); + fail("getString(string) should throw a ClassCastException when the property represented by string is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(string) should throw a ClassCastException when the property represented by string is multi-valued. " + e.getClass().getName() + " was thrown."); + } + + try { + testDO.getBoolean(testedProp); + fail("getBoolean(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte(testedProp); + fail("getByte(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar(testedProp); + fail("getChar(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble(testedProp); + fail("getDouble(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat(testedProp); + fail("getFloat(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt(testedProp); + fail("getInt(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong(testedProp); + fail("getLong(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort(testedProp); + fail("getShort(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes(testedProp); + fail("getBytes(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal(testedProp); + fail("getBigDecimal(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger(testedProp); + fail("getBigInteger(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject(testedProp); + fail("getDataObject(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate(testedProp); + fail("getDate(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString(testedProp); + fail("getString(property) should throw a ClassCastException when the property represented by property is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(property) should throw a ClassCastException when the property represented by property is multi-valued. " + e.getClass().getName() + " was thrown."); + } + + assertTrue("The test case could not procede because the index of the multi-valued Property was not found.", testedIndex > -1); + + try { + testDO.getBoolean(testedIndex); + fail("getBoolean(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBoolean(index) should throw a ClassCastException when the property represented by is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getByte(testedIndex); + fail("getByte(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getByte(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getChar(testedIndex); + fail("getChar(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getChar(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDouble(testedIndex); + fail("getDouble(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDouble(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getFloat(testedIndex); + fail("getFloat(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getFloat(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getInt(testedIndex); + fail("getInt(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getInt(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getLong(testedIndex); + fail("getLong(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getLong(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getShort(testedIndex); + fail("getShort(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getShort(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBytes(testedIndex); + fail("getBytes(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBytes(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigDecimal(testedIndex); + fail("getBigDecimal(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigDecimal(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getBigInteger(testedIndex); + fail("getBigInteger(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getBigInteger(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDataObject(testedIndex); + fail("getDataObject(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDataObject(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getDate(testedIndex); + fail("getDate(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getDate(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + try { + testDO.getString(testedIndex); + fail("getString(index) should throw a ClassCastException when the property represented by index is multi-valued. No Exception was thrown."); + } catch (ClassCastException e) { + // Success - do nothing + } catch (Exception e) { + fail("getString(index) should throw a ClassCastException when the property represented by index is multi-valued. " + e.getClass().getName() + " was thrown."); + } + } + + /* + /** + * Verifies the following statement. + * Establishing circular containment results in an IllegalArgumentException. + * Note: This test case will not be implemented because it has been determined + * that the statement will be removed from the spec. + */ + /* + public void testContainmentCycleIllegalArgumentException() { + // This test case will not be implemented. + } + */ + + /** + * Verifies the following statement. + * An empty DataGraph can have a root assigned by the createRootObject() methods. + * However, if a previous root DataObject exists than an IllegalStateException is + * thrown. + */ + public void testCreateRootObjectAgainIllegalStateException() { + DataGraph dataGraph = SDOUtil.createDataGraph(); + Type type = testDO.getType(); + + // verify the initial condition + assertNull("The DataGraph should have been created without a root DataObject.", dataGraph.getRootObject()); + assertNotNull("DataObject.getType() returned null.", type); + + dataGraph.createRootObject(type); + + // verify the pre-condition + assertNotNull("The DataGraph.createRootObject() should have created a root DataObject for the DataGraph.", dataGraph.getRootObject()); + + try { + dataGraph.createRootObject(type); + fail("DataGraph.createRootObject(Type) should throw an IllegalStateException a root Object already exists for the DataGraph. No Exception was thrown."); + } catch (IllegalStateException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataGraph.createRootObject(Type) should throw an IllegalStateException a root Object already exists for the DataGraph. " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Verifies the following statement. + * DataFactory.create() throws an IllegalArgumentException if the instanceClass does + * not correspond to a Type this factory can instantiate. + */ + public void testDataFactoryCreateIllegalArgumentException() { + try { + helperContext.getDataFactory().create(java.lang.Object.class); + fail("DataFactory.create(Object) should throw an IllegalArgumentException when it cannot instantiate the Type specified. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataFactory.create(Object) should throw an IllegalArgumentException when it cannot instantiate the Type specified. " + e.getClass().getName() + " was thrown."); + } + + try { + helperContext.getDataFactory().create(commonj.sdo.DataObject.class); + fail("DataFactory.create(DataObject) should throw an IllegalArgumentException when it cannot instantiate the Type specified. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataFactory.create(DataObject) should throw an IllegalArgumentException when it cannot instantiate the Type specified. " + e.getClass().getName() + " was thrown."); + } + + try { + helperContext.getDataFactory().create(commonj.sdo.ChangeSummary.class); + fail("DataFactory.create(ChangeSummary) should throw an IllegalArgumentException when it cannot instantiate the Type specified. No Exception was thrown."); + } catch (IllegalArgumentException e) { + // Success - do nothing + } catch (Exception e) { + fail("DataFactory.create(ChangeSummary) should throw an IllegalArgumentException when it cannot instantiate the Type specified. " + e.getClass().getName() + " was thrown."); + } + } + + /** + * Defines the Type the first time through. + */ + public void setUp() { + if (!typeDefined) { + helperContext = SDOUtil.createHelperContext(); +// createWithXSD(helperContext); +// createDynamically(helperContext); + createStatically(helperContext); + typeDefined = true; + } +// testDO = helperContext.getDataFactory().create(TEST_URI, TEST_TYPE_NAME); +// seqDO = helperContext.getDataFactory().create(TEST_URI, SEQ_TYPE_NAME); + testDO = (DataObject) ExpectedExceptionFactory.INSTANCE.createExpectedExceptionType(); + seqDO = (DataObject) ExpectedExceptionFactory.INSTANCE.createSequenceReadOnlyType(); + } + + public static void createStatically(HelperContext hc) { + ExpectedExceptionFactory.INSTANCE.register(hc); + } + + public static void createWithXSD(HelperContext hc) { + // Populate the meta data for the test model + URL url = ExpectedExceptionsTestCase.class.getResource("/expectedExceptions.xsd"); + try { + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + } catch(IOException e) { + e.printStackTrace(); + } + } + + /** + * createDynamically() creates the SDO Types using the TypeHelper. This + * method should be kept in synch with the XSD used for + * createDynamicallyWithStaticResources. The same XSD is used for the static + * generation of SDO Types using XSD2JavaGenerator. + */ + public static void createDynamically(HelperContext hc) { + + TypeHelper types = hc.getTypeHelper(); + Type stringType = types.getType("commonj.sdo", "String"); + Type intType = types.getType("commonj.sdo", "Int"); + Type booleanType = types.getType("commonj.sdo", "Boolean"); + Type byteType = types.getType("commonj.sdo", "Byte"); + Type decimalType = types.getType("commonj.sdo", "Decimal"); + Type floatType = types.getType("commonj.sdo", "Float"); + Type doubleType = types.getType("commonj.sdo", "Double"); + Type dateType = types.getType("commonj.sdo", "Date"); + Type shortType = types.getType("commonj.sdo", "Short"); + Type longType = types.getType("commonj.sdo", "Long"); + Type bytesType = types.getType("commonj.sdo", "Bytes"); + Type integerType = types.getType("commonj.sdo", "Integer"); + Type charType = types.getType("commonj.sdo", "Character"); + + DataObject testType = hc.getDataFactory().create("commonj.sdo", "Type"); + testType.set("uri", TEST_URI); + testType.set("name", TEST_TYPE_NAME); + + DataObject stringProperty = testType.createDataObject("property"); + stringProperty.set("name", "stringVal"); + stringProperty.set("type", stringType); + + DataObject booleanProperty = testType.createDataObject("property"); + booleanProperty.set("name", "booleanVal"); + booleanProperty.set("type", booleanType); + + DataObject byteProperty = testType.createDataObject("property"); + byteProperty.set("name", "byteVal"); + byteProperty.set("type", byteType); + + DataObject decimalProperty = testType.createDataObject("property"); + decimalProperty.set("name", "decimalVal"); + decimalProperty.set("type", decimalType); + + DataObject intProperty = testType.createDataObject("property"); + intProperty.set("name", "intVal"); + intProperty.set("type", intType); + + DataObject floatProperty = testType.createDataObject("property"); + floatProperty.set("name", "floatVal"); + floatProperty.set("type", floatType); + + DataObject doubleProperty = testType.createDataObject("property"); + doubleProperty.set("name", "doubleVal"); + doubleProperty.set("type", doubleType); + + DataObject dateProperty = testType.createDataObject("property"); + dateProperty.set("name", "dateVal"); + dateProperty.set("type", dateType); + + DataObject shortProperty = testType.createDataObject("property"); + shortProperty.set("name", "shortVal"); + shortProperty.set("type", shortType); + + DataObject longProperty = testType.createDataObject("property"); + longProperty.set("name", "longVal"); + longProperty.set("type", longType); + + DataObject childrenProperty = testType.createDataObject("property"); + childrenProperty.set("name", "listVal"); + childrenProperty.setBoolean("many", true); + childrenProperty.set("type", stringType); + + DataObject bytesProperty = testType.createDataObject("property"); + bytesProperty.set("name", "bytesVal"); + bytesProperty.set("type", bytesType); + + DataObject integerProperty = testType.createDataObject("property"); + integerProperty.set("name", "integerVal"); + integerProperty.set("type", integerType); + + DataObject charProperty = testType.createDataObject("property"); + charProperty.set("name", "charVal"); + charProperty.set("type", charType); + + DataObject readOnlyProperty = testType.createDataObject("property"); + readOnlyProperty.set("name", "readOnlyVal"); + readOnlyProperty.set("type", stringType); + readOnlyProperty.setBoolean("readOnly", true); + + DataObject readOnlyListProperty = testType.createDataObject("property"); + readOnlyListProperty.set("name", "readOnlyListVal"); + readOnlyListProperty.set("type", stringType); + readOnlyListProperty.setBoolean("readOnly", true); + readOnlyListProperty.setBoolean("many", true); + + types.define(testType); + + DataObject seqType = hc.getDataFactory().create("commonj.sdo", "Type"); + seqType.set("uri", TEST_URI); + seqType.set("name", SEQ_TYPE_NAME); + seqType.setBoolean("sequenced", true); + + DataObject seqROProperty = seqType.createDataObject("property"); + seqROProperty.set("name", "readOnlyVal"); + seqROProperty.set("type", stringType); + seqROProperty.setBoolean("readOnly", true); + + DataObject seqROListProperty = seqType.createDataObject("property"); + seqROListProperty.set("name", "readOnlyListVal"); + seqROListProperty.set("type", stringType); + seqROListProperty.setBoolean("readOnly", true); + seqROListProperty.setBoolean("many", true); + + DataObject uniqueNameProperty = seqType.createDataObject("property"); + uniqueNameProperty.set("name", "uniqueName"); + uniqueNameProperty.set("type", stringType); + + types.define(seqType); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/FormTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/FormTestCase.java new file mode 100644 index 0000000000..e630a8f903 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/FormTestCase.java @@ -0,0 +1,112 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.StringReader; +import java.util.HashMap; +import java.util.Map; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; +import org.eclipse.emf.ecore.resource.Resource; + +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLHelper; + +public class FormTestCase extends TestCase { + XMLHelper xmlHelper; + Map options; + + protected void setUp() throws Exception { + super.setUp(); + HelperContext hc = SDOUtil.createHelperContext(); + hc.getXSDHelper().define( +""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ +""); + xmlHelper = hc.getXMLHelper(); + options = new HashMap(); + /* + * turn off default behaviour of tolerating malformed xml + * tests using this option and bad xml should demonstrate failure to load + */ + options.put(SDOUtil.XML_LOAD_LaxForm, new Integer(0)); + } + + void load(String xml, Object options) throws IOException { + assertNotNull(xmlHelper.load(new StringReader(xml), null, options).getRootObject()); + } + + /* + * this malformed xml will load, as it uses the default lax approach + */ + public void testLaxForm() throws IOException { + load( +""+ + ""+ + ""+ +"", null); + } + + /* + * any malformed xml through this method will fail to load + * since the options instance member disables lax processing + */ + protected final void load(String xml) throws IOException { + try { + load(xml, options); + fail(); + } catch (Resource.IOWrappedException featureNotFound) { + } + } + + public void testUnqualifiedAttribute() throws IOException { + load(""); + } + + public void testQualifiedAttribute() throws IOException { + load(""); + } + + public void testUnqualifiedElement() throws IOException { + load( +""+ + ""+ +""); + } + + public void testQualifiedElement() throws IOException { + load( +""+ + ""+ +""); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/HelperContextTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/HelperContextTestCase.java new file mode 100644 index 0000000000..14e81b6a32 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/HelperContextTestCase.java @@ -0,0 +1,75 @@ +/** + * + * 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.tuscany.sdo.test; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.helper.CopyHelper; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.DataHelper; +import commonj.sdo.helper.EqualityHelper; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import commonj.sdo.impl.HelperProvider; + +public class HelperContextTestCase extends TestCase { + + public void testDefaultHelperContext() { + HelperContext defaultHelperContext = HelperProvider.getDefaultContext(); + + assertNotNull(defaultHelperContext.getCopyHelper()); + assertEquals(defaultHelperContext.getCopyHelper(), CopyHelper.INSTANCE); + assertNotNull(defaultHelperContext.getDataFactory()); + assertEquals(defaultHelperContext.getDataFactory(), DataFactory.INSTANCE); + assertNotNull(defaultHelperContext.getDataHelper()); + assertEquals(defaultHelperContext.getDataHelper(), DataHelper.INSTANCE); + assertNotNull(defaultHelperContext.getEqualityHelper()); + assertEquals(defaultHelperContext.getEqualityHelper(), EqualityHelper.INSTANCE); + assertNotNull(defaultHelperContext.getTypeHelper()); + assertEquals(defaultHelperContext.getTypeHelper(), TypeHelper.INSTANCE); + assertNotNull(defaultHelperContext.getXMLHelper()); + assertEquals(defaultHelperContext.getXMLHelper(), XMLHelper.INSTANCE); + assertNotNull(defaultHelperContext.getXSDHelper()); + assertEquals(defaultHelperContext.getXSDHelper(), XSDHelper.INSTANCE); + + } + + public void testCreateHelperContext() { + HelperContext hc = SDOUtil.createHelperContext(); + assertNotNull(hc.getCopyHelper()); + assertNotNull(hc.getDataFactory()); + assertNotNull(hc.getDataHelper()); + assertNotNull(hc.getEqualityHelper()); + assertNotNull(hc.getTypeHelper()); + assertNotNull(hc.getXMLHelper()); + assertNotNull(hc.getXSDHelper()); + + assertNotSame(hc.getDataFactory(), DataFactory.INSTANCE); + assertNotSame(hc.getTypeHelper(), TypeHelper.INSTANCE); + assertNotSame(hc.getXMLHelper(), XMLHelper.INSTANCE); + assertNotSame(hc.getXSDHelper(), XSDHelper.INSTANCE); + // the other "stateless" helpers may be the same as the singletons + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ImplSpecificTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ImplSpecificTestCase.java new file mode 100644 index 0000000000..d5117c3fed --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/ImplSpecificTestCase.java @@ -0,0 +1,74 @@ +/** + * + * 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.tuscany.sdo.test; + +import junit.framework.TestCase; + +public class ImplSpecificTestCase extends TestCase { + + public void testThreadSafeHashmapIsAvailable() { + // this will fail if using Java 1.4.x and the backport library has been removed from the classpath. + // It is here because ChangeSummaryImpl contains the same logic for finding a threadsafe hashmap implementation + // but it will fallback to a synchronized hashmap + // if no threadsafe hashmap is available, hence no test failure will occur, but a performance hit + // will. This test is here top show a failure with java 1.4 to ensure that no-one removes the backport + // dependency introduced for TUSCANY-1006. + assertNotNull(loadConcurrentHashMapClazz()); + } + + protected void setUp() throws Exception { + super.setUp(); + + } + + private static String[] concurrentHashMapClazzNames = new String[] { + "java.util.concurrent.ConcurrentHashMap", + "edu.emory.mathcs.backport.java.util.concurrent.ConcurrentHashMap"}; + + private static Class loadConcurrentHashMapClazz() + { + Class mapClazz = null; + for (int i = 0; i < concurrentHashMapClazzNames.length; i++) + { + String concurrentHashMapClazzName = concurrentHashMapClazzNames[i]; + try + { + mapClazz = Class.forName(concurrentHashMapClazzName, true, Thread.currentThread().getContextClassLoader()); + } + catch (Exception ignored) {} + if (mapClazz != null) + { + break; + } + try + { + mapClazz = Class.forName(concurrentHashMapClazzName); + } + catch (Exception ignored) {} + if (mapClazz != null) + { + break; + } + } + // System.out.println("threadsafe hashmap = " + mapClazz.getName()); + return mapClazz; + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/IsManyTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/IsManyTestCase.java new file mode 100644 index 0000000000..1eef4ea657 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/IsManyTestCase.java @@ -0,0 +1,65 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.net.URL; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import junit.framework.TestCase; + +import commonj.sdo.*; +import commonj.sdo.helper.*; + +public class IsManyTestCase extends TestCase { + private final String TEST_MODEL = "/open.xsd"; + private final String TEST_MODEL1ANY = "/open1any.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/open"; + private final String TEST_NAMESPACE1ANY = "http://www.example.com/open1any"; + + public void testIsMany() { + Property priceProperty = XSDHelper.INSTANCE.getGlobalProperty(TEST_NAMESPACE, "price", true); + + Type quoteType = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "OpenQuote"); + DataObject quote = DataFactory.INSTANCE.create(quoteType); + assertTrue( SDOUtil.isMany(priceProperty, quote)); + + quoteType = TypeHelper.INSTANCE.getType(TEST_NAMESPACE1ANY, "OpenQuote"); + quote = DataFactory.INSTANCE.create(quoteType); + assertFalse( SDOUtil.isMany(priceProperty, quote)); + } + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + + // Populate the meta data for the test (Stock Quote) model with maxOccurs=1 + url = getClass().getResource(TEST_MODEL1ANY); + inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JavaSerializeDeserializeTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JavaSerializeDeserializeTestCase.java new file mode 100644 index 0000000000..df69555d76 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JavaSerializeDeserializeTestCase.java @@ -0,0 +1,297 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; +import java.util.ArrayList; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataGraph; +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + +public class JavaSerializeDeserializeTestCase extends TestCase +{ + + public void testScopeDefinedSerializeDeserializeOfDataObject() + { + HelperContext hc = SDOUtil.createHelperContext(); + Object originalDataObject = createDynamically(hc,true); + + runSerializeDeserialize((DataObject)originalDataObject, hc); + } + + public void testScopeDefinedSerializeDeserializeOfDataGraph() + { + HelperContext hc = SDOUtil.createHelperContext(); + DataGraph testDO = (DataGraph)createDynamically(hc,false); + + runSerializeDeserializeWithDataGraph(testDO, hc); + } + + private String xsdString = "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + + "" + + "" + + "" + + "" + + "" + + "" + + ""; + + public void testLargePayload() + { + HelperContext hc = SDOUtil.createHelperContext(); + hc.getXSDHelper().define(xsdString); + DataObject company = hc.getDataFactory().create("http://www.example.com/simple", "Company"); + company.setString("symbol", "EXAMPLE"); + company.setString("companyName", "Example Inc."); + List employees = company.getList("employees"); + DataObject employee; + for (int i=0; i<1000; i++) { + employee = hc.getDataFactory().create("http://www.example.com/simple", "Employee"); + employee.setString("employeeID", "ID #" + i); + employee.setString("employeeName", "Empoyee #" + i); + employees.add(employee); + } + try { + ByteArrayOutputStream bos = new ByteArrayOutputStream(); + ObjectOutputStream oos = SDOUtil.createObjectOutputStream(bos, hc); + oos.writeObject(company); + oos.flush(); + byte[] bytes = bos.toByteArray(); + oos.close(); + bos.close(); + + ByteArrayInputStream bis = new ByteArrayInputStream(bytes); + ObjectInputStream ois = SDOUtil.createObjectInputStream(bis, hc); + ois.readObject(); + ois.close(); + bis.close(); + } + catch (Exception e) { + e.printStackTrace(); + fail("An Exception occurred while deserializing the output of the serialization: " + e.toString()); + } + } + + + /** + * Serialize the DataObject then Deserialize the output. + * to testDO. + * @param testDO + * @param scope + */ + + public void runSerializeDeserialize(DataObject originalDataObject, HelperContext hc) + { + + populateFields(originalDataObject); + DataObject tempDO = null; + ByteArrayOutputStream baos = null; + + try + { + baos = serialize(originalDataObject, hc); + + } + catch (Exception e) + { + e.printStackTrace(); + fail("An Exception occurred while serializing the DataObject: " + e.toString()); + } + + try + { + tempDO = deserialize(baos, hc); + + } + catch (Exception e) + { + e.printStackTrace(); + fail("An Exception occurred while deserializing the output of the serialization: " + e.toString()); + } + + assertNotNull("Deserialization returned a null value.", tempDO); + + assertSame(tempDO.getType(), originalDataObject.getType()); + + + } + + /** + * Serialize the DataGraph + * @param dataGraph + * @param scope + */ + public void runSerializeDeserializeWithDataGraph(DataGraph dataGraph, HelperContext hc) + { + DataObject originalDataObject = dataGraph.getRootObject(); + populateFields(originalDataObject); + DataObject tempDO = null; + ByteArrayOutputStream baos = null; + + try + { + baos = serialize(dataGraph, hc); + + } + catch (Exception e) + { + e.printStackTrace(); + fail("An Exception occurred while serializing the DataObject: " + e.toString()); + } + + try + { + tempDO = deserialize(baos, hc); + + } + catch (Exception e) + { + e.printStackTrace(); + fail("An Exception occurred while deserializing the output of the serialization: " + e.toString()); + } + + assertNotNull("Deserialization returned a null value.", tempDO); + + assertSame(tempDO.getType(), originalDataObject.getType()); + + + + } + + /** + * serializeDataObject is a private method to be called by the other methods + * in the ScrenarioLibrary + * + * @param dataObject + * @param fileName + * @throws IOException + */ + public ByteArrayOutputStream serialize(Object object, HelperContext hc) throws IOException + { + //FileOutputStream fos = new FileOutputStream("temp"); + ByteArrayOutputStream byteArrayOutput = new ByteArrayOutputStream(); + ObjectOutputStream out = SDOUtil.createObjectOutputStream(byteArrayOutput, hc); + out.writeObject(object); + out.close(); + return byteArrayOutput; + } + + /** + * deserializeDataObject is a private method to be called by the other + * methods in the ScrenarioLibrary + * + * @param fileName + * @return + * @throws IOException + * @throws ClassNotFoundException + */ + public DataObject deserialize(ByteArrayOutputStream baos, HelperContext hc) throws IOException, ClassNotFoundException + { + //FileInputStream fis = new FileInputStream("temp"); + ObjectInputStream input = null; + ByteArrayInputStream byteArrayInput = new ByteArrayInputStream(baos.toByteArray()); + + input = SDOUtil.createObjectInputStream(byteArrayInput, hc); + + Object object = input.readObject(); + input.close(); + if(object instanceof DataGraph) + return ((DataGraph)object).getRootObject(); + else + return (DataObject)object; + } + + /** + * populateFields uses set to set each of the fields in the + * DataObject. It is used to ensure a known set of expected values that are + * not other than the default values for the various fields. + * + * @param testDO + * @throws ExpectedConditionError + */ + public static void populateFields(DataObject testDO) + { + + testDO.setString("stringVal", "Testing"); + + } + /** + * createDynamically() creates the SDO Types using the TypeHelper. This method should be kept in + * synch with the XSD used for createDynamicallyWithStaticResources. The same XSD is used for + * the static generation of SDO Types using XSD2JavaGenerator. + */ + public Object createDynamically(HelperContext hc, boolean createDataObject) + { + + TypeHelper types = hc.getTypeHelper(); + DataFactory dataFactory = hc.getDataFactory(); + + Type stringType = types.getType("commonj.sdo", "String"); + + DataObject testType = dataFactory.create("commonj.sdo", "Type"); + testType.set("uri", "http://www.example.com/api_test"); + testType.set("name", "APITest"); + + DataObject stringProperty = testType.createDataObject("property"); + stringProperty.set("name", "stringVal"); + stringProperty.set("type", stringType); + + + List types2Define = new ArrayList(); + types2Define.add(testType); + List apiXSD = types.define(types2Define); + Type apiXSDType = (Type) apiXSD.get(0); + + if(createDataObject) + return dataFactory.create(apiXSDType);; + + // Create an empty DataGraph and attach the document root to it. Otherwise, where is the documentRoot ? + DataGraph dataGraph = SDOUtil.createDataGraph(); + /*DataObject testDO =*/ dataGraph.createRootObject(apiXSDType); + + + return dataGraph; + + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JiraTestCases.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JiraTestCases.java new file mode 100644 index 0000000000..bd66949c89 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/JiraTestCases.java @@ -0,0 +1,184 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.util.List; + +import junit.framework.TestCase; +import commonj.sdo.*; +import commonj.sdo.helper.*; +import commonj.sdo.impl.HelperProvider; + +import org.apache.tuscany.sdo.api.SDOUtil; +import java.util.HashMap; + +/** + * The follow test cases are based upon code snipets in the SDO specification. + * They are also implemented as working samples in the sample-sdo artifact + * + */ +public class JiraTestCases extends TestCase { + + /** + * Bogus company namespace + */ + public static final String COMPANY_NAMESPACE = "company.xsd"; + + /** + * previously defined XSD file used + */ + public static final String COMPANY_XSD = "/company.xsd"; + + /** + * XML file containing DataGraph representing a company. This xml file + * conforms to the company model defined in 'Complete DataGraph for Company + * Example' section of the SDO specification + */ + public static final String COMPANY_DATAGRAPH_XML = "/companyDataGraphGenerated.xml"; + + /** + * Generated DataGraph + * {@link org.apache.tuscany.samples.sdo.company.CreateCompany} + */ + public static final String COMPANY_DATAOBJECT_XML = "/companyGenerated.xml"; + + /** + * Defines xsd resource contained within jar file for PurchaseOrder + * DataObject + */ + public static final String PO_XSD_RESOURCE = "/po.xsd"; + + /** + * Defines xml resource contained within jar file that is used to populate + * PurchaseOrder DataObjects + */ + public static final String PO_XML_RESOURCE = "/po.xml"; + + /** + * previously created XSD file used + */ + public static final String LETTER_XSD = "/letter.xsd"; + + /** + * JIRA Details : Add a method to SDOUtil to return all Types associated + * with a specific URI + */ + public void test_TUSCANY583() { + HelperContext hc = HelperProvider.getDefaultContext(); + XSDHelper xsdHelper = hc.getXSDHelper(); + // define some types + try { + xsdHelper.define(getClass().getResourceAsStream( + PO_XSD_RESOURCE), null); + + xsdHelper.define(getClass().getResourceAsStream( + COMPANY_XSD), null); + + createDynamicType(); + + String[] expectedPoTypeNames = {"item", "Items", + "PurchaseOrderType", "quantity", "SKU", "USAddress"}; + + String[] expectedCompanyTypeNames = {"EmployeeType", "DepartmentType", "CompanyType"}; + + String[] expectedCustomerTypeNames = {"Customer"}; + + confirmTypes("http://www.example.com/PO", expectedPoTypeNames); + confirmTypes("company.xsd", expectedCompanyTypeNames); + confirmTypes("http://example.com/customer", + expectedCustomerTypeNames); + + } catch (Exception e) { + fail("Unexpected error " + e.toString()); + e.printStackTrace(); + } + + } + + /** + * Dynamically define customer Type + */ + public static void createDynamicType() { + // get an instance of the type helper + TypeHelper typeH = TypeHelper.INSTANCE; + Type intType = typeH.getType("commonj.sdo", "Int"); + Type stringType = typeH.getType("commonj.sdo", "String"); + + // create a new Type for Customers + DataObject customerType = DataFactory.INSTANCE.create("commonj.sdo", + "Type"); + + customerType.set("uri", "http://example.com/customer"); + customerType.set("name", "Customer"); + + // create a customer number property + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + + // create a last name property + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + + // create a first name property + DataObject firstNameProperty = customerType + .createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + + // now define the Customer type so that customers can be made + typeH.define(customerType); + } + + private void confirmTypes(String uri, String[] expectedTypeNames) { + HelperContext hc = HelperProvider.getDefaultContext(); + try { + + List actualTypes = SDOUtil.getTypes(hc, uri); + assertNotNull("Testing that list of types for " + uri + + " is not null", actualTypes); + + // test the number of Types + assertEquals("Testing number of types for " + uri, + expectedTypeNames.length, actualTypes.size()); + + // put into a HashMap for easy lookup + HashMap typeLookup = new HashMap(); + for (int i = 0; i < actualTypes.size(); i++) { + Type type = (Type) actualTypes.get(i); + typeLookup.put(type.getName(), type); + } + + // check that we have the same types + for (int i = 0; i < expectedTypeNames.length; i++) { + assertTrue("testing that type " + expectedTypeNames[i] + + "was returned for " + uri, typeLookup + .containsKey(expectedTypeNames[i])); + } + + } catch (Exception e) { + fail("Exception caught comparing expected types to actual types for uri " + + uri + ":" + e.toString()); + e.printStackTrace(); + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MetadataInstancePropertiesTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MetadataInstancePropertiesTestCase.java new file mode 100644 index 0000000000..885153b62e --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MetadataInstancePropertiesTestCase.java @@ -0,0 +1,243 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.net.URL; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XSDHelper; + + +public class MetadataInstancePropertiesTestCase extends TestCase +{ + private final String TEST_MODEL = "/TypePropertyMetadataInfo.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/metadata/retrievaltest"; + private final String DYNAMIC_TEST_NAMESPACE = "http://www.example.com/metadata/dynamicmetadata"; + + private HelperContext helperContext; + private TypeHelper typeHelper; + private XSDHelper xsdHelper; + private DataFactory dataFactory; + + public void testXSDTypeProperties() + { + // Note: We won't check the actual value of XSD instance properties yet since they're not defined + // in the SDO spec yet. + + //displayInstanceProperties(TEST_NAMESPACE); + + Type type = typeHelper.getType(TEST_NAMESPACE, "Example"); + assertTrue(getInstanceProperty(type, "appinfo") != null); + assertTrue(getInstanceProperty(type, "foo") == null); + + Property property = type.getProperty("number"); + assertTrue(getInstanceProperty(property, "appinfo") != null); + assertTrue(getInstanceProperty(property, "foo") == null); + + property = type.getProperty("Exampletype"); + assertTrue(getInstanceProperty(property, "appinfo") != null); + assertTrue(getInstanceProperty(property, "foo") == null); + + type = typeHelper.getType(TEST_NAMESPACE, "ExampleNumber"); + assertTrue(getInstanceProperty(type, "appinfo") != null); + assertTrue(getInstanceProperty(type, "minInclusive") != null); + assertTrue(getInstanceProperty(type, "maxInclusive") != null); + assertTrue(getInstanceProperty(type, "foo") == null); + + type = typeHelper.getType(TEST_NAMESPACE, "ExampleRating"); + assertTrue(getInstanceProperty(type, "enumeration") != null); + assertTrue(getInstanceProperty(type, "foo") == null); + + type = typeHelper.getType(TEST_NAMESPACE, "PhoneNumber"); + assertTrue(getInstanceProperty(type, "appinfo") != null); + assertTrue(getInstanceProperty(type, "length") != null); + assertTrue(getInstanceProperty(type, "pattern") != null); + assertTrue(getInstanceProperty(type, "foo") == null); + } + + public void testDynamicTypeProperties() + { + // Create dynamic model + Type intType = typeHelper.getType("commonj.sdo", "Int"); + Type stringType = typeHelper.getType("commonj.sdo", "String"); + + Property openContentProperty = typeHelper.getOpenContentProperty("commonj.sdo/xml", "xmlElement"); + + // create a new Type for Customers + DataObject customerType = dataFactory.create("commonj.sdo", "Type"); + customerType.set("uri", DYNAMIC_TEST_NAMESPACE); + customerType.set("name", "Customer"); + customerType.set(openContentProperty, Boolean.TRUE); + + // create a customer number property + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + + // create a first name property + DataObject firstNameProperty = + customerType.createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + firstNameProperty.set(openContentProperty, Boolean.FALSE); + + // create a last name property + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + + // now define the Customer type so that customers can be made + typeHelper.define(customerType); + + //displayInstanceProperties(DYNAMIC_TEST_NAMESPACE); + + Type type = typeHelper.getType(DYNAMIC_TEST_NAMESPACE, "Customer"); + assertTrue(getInstanceProperty(type, "xmlElement") == openContentProperty); + assertTrue(type.get(openContentProperty) == Boolean.TRUE); + assertTrue(getInstanceProperty(type, "foo") == null); + + Property property = type.getProperty("custNum"); + assertTrue(getInstanceProperty(property, "xmlElement") == null); + assertTrue(getInstanceProperty(property, "foo") == null); + + property = type.getProperty("firstName"); + assertTrue(getInstanceProperty(property, "xmlElement") == openContentProperty); + assertTrue(property.get(openContentProperty) == Boolean.FALSE); + assertTrue(getInstanceProperty(property, "foo") == null); + + property = type.getProperty("lastName"); + assertTrue(getInstanceProperty(property, "xmlElement") == null); + assertTrue(getInstanceProperty(property, "foo") == null); + } + + //Amita + public void testEnumProperty() + { + Type type = typeHelper.getType(TEST_NAMESPACE, "ExampleRating"); + assertTrue(getInstanceProperty(type, "enumeration") != null); + List enumFacet = SDOUtil.getEnumerationFacet(type); + assertEquals(3, enumFacet.size()); + assertEquals("", enumFacet.get(0)); + assertEquals("Good", enumFacet.get(1)); + assertEquals("Bad", enumFacet.get(2)); + } + + //Amita + public void testPatternProperty() + { + Type type = typeHelper.getType(TEST_NAMESPACE, "PhoneNumber"); + assertTrue(getInstanceProperty(type, "pattern") != null); + List patternFacet = SDOUtil.getPatternFacet(type); + assertEquals(2, patternFacet.size()); + assertEquals("\\d{3}-\\d{4}", patternFacet.get(0)); + assertEquals("\\d{6}-\\d{8}", patternFacet.get(1)); + } + + public void setUp() throws Exception + { + super.setUp(); + + helperContext = SDOUtil.createHelperContext(); + + typeHelper = helperContext.getTypeHelper(); + xsdHelper = helperContext.getXSDHelper(); + dataFactory = helperContext.getDataFactory(); + + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + + xsdHelper.define(inputStream, url.toString()); + inputStream.close(); + } + + public Property getInstanceProperty(Type type, String propertyName) + { + return getInstanceProperty(type.getInstanceProperties(), propertyName); + } + + public Property getInstanceProperty(Property property, String propertyName) + { + return getInstanceProperty(property.getInstanceProperties(), propertyName); + } + + private Property getInstanceProperty(List instProps, String propertyName) + { + for (int i = 0; i < instProps.size(); i++) + { + Property prop = (Property)instProps.get(i); + if (propertyName.equals(prop.getName())) + return prop; + } + return null; + } + + private void displayInstanceProperties(Type type) + { + System.out.println("Type's name: " + type.getName()); + List instProps = type.getInstanceProperties(); + for (int i = 0; i < instProps.size(); i++) + { + Property prop = (Property)instProps.get(i); + System.out.println("\tType's instance property name: " + prop.getName()); + System.out.println("\tType's instance property value: \"" + type.get(prop) + "\""); + } + } + + private void displayInstanceProperties(Property prop) + { + System.out.println("\tProperty's name: " + prop.getName()); + List propsInstProps = prop.getInstanceProperties(); + for (int j = 0; j < propsInstProps.size(); j++) + { + Property propsInstProp = (Property)propsInstProps.get(j); + System.out.println("\t\tProperty's instance property name: " + propsInstProp.getName()); + System.out.println("\t\tProperty's instance property value: \"" + prop.get(propsInstProp) + "\""); + } + } + + public void displayInstanceProperties(String namespace) + { + List types = SDOUtil.getTypes(helperContext, namespace); + for (int i = 0; i < types.size(); i++) + { + Type type = (Type)types.get(i); + displayInstanceProperties(type); + List properties = type.getProperties(); + for (int j = 0; j < properties.size(); j++) + { + Property property = (Property)properties.get(j); + displayInstanceProperties(property); + } + System.out.println("**************************************"); + } + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MixedTypeTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MixedTypeTestCase.java new file mode 100644 index 0000000000..806662a83c --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/MixedTypeTestCase.java @@ -0,0 +1,89 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; + +import commonj.sdo.DataObject; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import junit.framework.TestCase; + + +public class MixedTypeTestCase extends TestCase { + private final String TEST_MODEL = "/mixed.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/mixed"; + private final String TEST_DATA = "/mixed.xml"; + + /** + * Sequenced type SDO 2 test. + */ + public void testSequencedType() throws IOException { + Type quoteType = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "MixedQuote"); + DataObject quote = DataFactory.INSTANCE.create(quoteType); + + Sequence sequence = quote.getSequence(); + + sequence.add("\n "); + + quote.setString("symbol", "fbnt"); + + sequence.add("\n "); + + quote.setString("companyName", "FlyByNightTechnology"); + + sequence.add("\n some text\n "); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + sequence.add("\n more text\n "); + + // quote.setBigDecimal("price", new BigDecimal("1000.0")); + sequence.add("price", new BigDecimal("1000.0")); + + sequence.add("\n"); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + XMLHelper.INSTANCE.save(quote, TEST_NAMESPACE, "mixedStockQuote", baos); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(TEST_DATA))); + } + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NeverStaleChangeSummaryTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NeverStaleChangeSummaryTestCase.java new file mode 100644 index 0000000000..544672a8b1 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NeverStaleChangeSummaryTestCase.java @@ -0,0 +1,76 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.InputStream; +import java.net.URL; + +import junit.framework.TestCase; + +import commonj.sdo.ChangeSummary; +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XSDHelper; + +public class NeverStaleChangeSummaryTestCase extends TestCase { + private final String TEST_MODEL = "/simpleWithChangeSummary.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/simpleCS"; + + /** + * Simple ChangeSummary test. + */ + public void testChangeSummary() throws Exception { + Type quoteType = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "RootQuote"); + DataObject quote = DataFactory.INSTANCE.create(quoteType); + + ChangeSummary cs = quote.getChangeSummary(); + + // Begin logging changes + // + cs.beginLogging(); + + DataObject child = quote.createDataObject("quotes"); + cs.isCreated(child); + child = quote.createDataObject("quotes"); + assertTrue(cs.isCreated(child)); + + // Stop logging changes and print the resulting data graph to stdout + // + cs.endLogging(); + + cs.isCreated(child); + + cs.undoChanges(); + + assertFalse(cs.isCreated(child)); + } + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NotificationTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NotificationTestCase.java new file mode 100644 index 0000000000..5d1637865b --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/NotificationTestCase.java @@ -0,0 +1,186 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; +import java.util.ArrayList; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; +import org.apache.tuscany.sdo.api.Event; +import org.apache.tuscany.sdo.impl.ListenerBase; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + +/** + * Test DataObject Property value change notification + */ +public class NotificationTestCase extends TestCase { + + HelperContext hc; + TypeHelper th; + + private class Observer extends ListenerBase { + + private int notificationCount; + private Event lastEvent; + + public int getNotificationCount() { + return notificationCount; + } + + public Event getLastEvent() { + return lastEvent; + } + + public Observer() { + notificationCount = 0; + } + + public void eventNotification(Event e) { + + if (e.getEventType() != Event.REMOVE_LISTENER) { + notificationCount++; + lastEvent = e; + } + } + + } + + public void testTransitions() throws IOException { + final String TEST_MODEL = "/simple.xsd"; + final String TEST_NAMESPACE = "http://www.example.com/simple"; + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + + Type quoteType = th.getType(TEST_NAMESPACE, "Quote"); + DataObject quote = hc.getDataFactory().create(quoteType); + Observer o = new Observer(); + SDOUtil.addChangeListener(quote, o); + + Event e; + + String firstName = "FlyByNightTechnology"; + + int changeCount = 0; + + quote.setString("companyName", firstName); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertEquals(Event.SET, e.getEventType()); + assertEquals(null, e.getOldValue()); + assertFalse(e.wasSet()); + + quote.setString("companyName", "FBNT"); + e = o.getLastEvent(); + assertTrue(e.wasSet()); + + assertEquals(firstName, e.getOldValue()); + assertEquals(++changeCount, o.getNotificationCount()); + assertEquals("companyName", e.getProperty().getName()); + + SDOUtil.removeChangeListener(quote, o); + + quote.setString("companyName", "3rdValue"); + e = o.getLastEvent(); + + assertEquals(firstName, e.getOldValue()); + assertEquals(changeCount /* no ++ */, o.getNotificationCount()); + + SDOUtil.addChangeListener(quote, o); + + quote.setString("companyName", "3rdValue"); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertTrue(e.isTouch()); + assertTrue(e.wasSet()); + + quote.unset("companyName"); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertTrue(e.wasSet()); + + + quote.set("companyName", "4thValue"); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertFalse(e.wasSet()); + + assertEquals(Event.NO_INDEX, e.getPosition()); + + DataObject child = quote.createDataObject("quotes"); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertFalse(e.wasSet()); + assertEquals(0, e.getPosition()); + assertEquals(Event.ADD, e.getEventType()); + + DataObject child2 = quote.createDataObject("quotes"); + assertEquals(++changeCount, o.getNotificationCount()); + e = o.getLastEvent(); + assertTrue(e.wasSet()); // the quotes property was previously set to a non empty list + assertEquals(1, e.getPosition()); + + child2.setString("companyName", "subsidiary"); + + assertEquals(changeCount /* no ++ */, o.getNotificationCount()); // not monitoring the child + + quote.getList("quotes").clear(); + e = o.getLastEvent(); + assertEquals(++changeCount, o.getNotificationCount()); + assertEquals(Event.REMOVE_MANY, e.getEventType()); + + List newList = new ArrayList(); + + newList.add(hc.getDataFactory().create(quoteType)); + newList.add(hc.getDataFactory().create(quoteType)); + + quote.getList("quotes").addAll(newList); + e = o.getLastEvent(); + assertEquals(++changeCount, o.getNotificationCount()); + assertEquals(Event.ADD_MANY, e.getEventType()); + + + + + } + + + protected void setUp() throws Exception { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/OpenTypeTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/OpenTypeTestCase.java new file mode 100644 index 0000000000..3e5a410aa3 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/OpenTypeTestCase.java @@ -0,0 +1,139 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; +import java.util.Iterator; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import junit.framework.TestCase; + + +public class OpenTypeTestCase extends TestCase { + private HelperContext hc; + private TypeHelper th; + private XSDHelper xsdh; + private XMLHelper xmlh; + private DataFactory df; + private final String TEST_MODEL = "/open.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/open"; + private final String TEST_DATA = "/open.xml"; + + /** + * Open content SDO 2 test. + */ + public void testOpenType() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "OpenQuote"); + DataObject quote = df.create(quoteType); + + quote.setString("symbol", "s1"); + + for (Iterator iter = quote.getInstanceProperties().iterator(); iter.hasNext();) { + iter.next(); + } + + Property companyProperty = xsdh.getGlobalProperty(TEST_NAMESPACE, "company", true); + DataObject company = quote.createDataObject(companyProperty); + company.setString("name", "FlyByNightTechnology"); + + Property priceProperty = xsdh.getGlobalProperty(TEST_NAMESPACE, "price", true); + quote.getList(priceProperty).add(new BigDecimal("1000.0")); + + for (Iterator iter = quote.getInstanceProperties().iterator(); iter.hasNext();) { + iter.next(); + } + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlh.save(quote, TEST_NAMESPACE, "openStockQuote", baos); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(TEST_DATA))); + } + + + public void testOpenType_Tuscany_396() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "OpenQuote2"); + DataObject quote = df.create(quoteType); + + Property priceProperty = xsdh.getGlobalProperty(TEST_NAMESPACE, "price", true); + // the importance of this is that the maxOccurs=1 attribute on the xsd:any + // allows is to use the !isMany getters and setters for open content + quote.set(priceProperty, new BigDecimal("1000.0")); + + } + + /** + * Although this behavior is not mandated by the SDO 2.1 specification it should be possible + * to demand-create DataObject properties by calling createDataObject(String name). + * The behavior should be the same as that specified in section 9.10 for parsing XML that has + * no types defined e.g. the property should be created as an open, sequenced type with many=true. + * + * See https://issues.apache.org/jira/browse/TUSCANY-1397 for more information. + * + * @throws Exception + */ + public void testOnDemandCreateDataObject() throws Exception { + // define an open type with no properties + DataObject typeDef = df.create( "commonj.sdo", "Type" ); + typeDef.set( "uri", TEST_NAMESPACE ); + typeDef.set( "name", "testOnDemandCreateDataObjectType" ); + typeDef.setBoolean( "open", true ); + Type t = th.define( typeDef ); + + // create a DataObject that uses this type + DataObject testDO = df.create(t); + + // create an on-demand property + DataObject foo = testDO.createDataObject( "foo" ); + assertNotNull( "createDataObject() demand created a DataObject", foo ); + assertTrue( "DataObject is open", foo.getType().isOpen() ); + assertTrue( "DataObject is sequenced", foo.getType().isSequenced() ); + } + + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + xsdh = hc.getXSDHelper(); + df = hc.getDataFactory(); + xmlh = hc.getXMLHelper(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SchemaLocationTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SchemaLocationTestCase.java new file mode 100644 index 0000000000..eaec327007 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SchemaLocationTestCase.java @@ -0,0 +1,48 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.util.*; + +import org.apache.tuscany.sdo.SDOPackage; +import org.apache.tuscany.sdo.util.SDOUtil; + +import junit.framework.TestCase; + +import commonj.sdo.helper.*; + +public class SchemaLocationTestCase extends TestCase { + private final String TEST_XML_DOCUMENT = "/SchemaLocationTestCase.xml"; + + /** + * This method will load an xml document consisting of a xsi:schemaLocation and xsi:noNamespaceSchemaLocation defined. It will then use the + * XMLDocument API to get and set the schemaLocation property. + * + * @throws IOException + */ + public void testSchemaLocation() throws IOException { + // load the xml document which has xsi:noNamespaceSchemaLocation and xsi:schemaLocation defined + Map options = new HashMap(); + options.put(SDOUtil.XML_LOAD_SCHEMA, Boolean.TRUE); + XMLDocument doc = XMLHelper.INSTANCE.load(getClass().getResourceAsStream(TEST_XML_DOCUMENT), "whatever", options); + assertNotSame(doc.getRootObject().getType(), SDOPackage.eINSTANCE.getAnyTypeDataObject()); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SequenceTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SequenceTestCase.java new file mode 100644 index 0000000000..e02ace5d2a --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SequenceTestCase.java @@ -0,0 +1,100 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XSDHelper; + +public class SequenceTestCase extends TestCase { + HelperContext hc; + Type type; + Property localA, choiceX, choiceY, localB, open; + + String xml = ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""; + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + hc.getXSDHelper().define(xml); + type = hc.getTypeHelper().getType("testNS", "Sequenced"); + localA = type.getProperty("localA"); + choiceX = type.getProperty("choiceX"); + choiceY = type.getProperty("choiceY"); + localB = type.getProperty("localB"); + XSDHelper xsdHelper = hc.getXSDHelper(); + open = xsdHelper.getGlobalProperty("testNS", "open", true); + } + + public void testSequenced() { + DataObject dataObject = hc.getDataFactory().create(type); + Sequence sequence = dataObject.getSequence(); + + sequence.add(choiceX, "x1"); + sequence.add(0, localA, "a"); + sequence.add(choiceY, "y1"); + sequence.add(choiceX, "x2"); + sequence.add(localB, "b"); + sequence.add(open, "open"); + + List list = dataObject.getList(localA); + assertEquals(list.size(), 1); + assertEquals(list.get(0), "a"); + + assertEquals(dataObject.getString(localB), "b"); + + list = dataObject.getList(choiceX); + assertEquals(list.size(), 2); + assertEquals(list.get(0), "x1"); + assertEquals(list.get(1), "x2"); + + list = dataObject.getList(choiceY); + assertEquals(list.size(), 1); + assertEquals(list.get(0), "y1"); + + list = dataObject.getList(open); + assertEquals(list.size(), 1); + assertEquals(list.get(0), "open"); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SerializeTypesTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SerializeTypesTestCase.java new file mode 100644 index 0000000000..a8e00d5eb2 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SerializeTypesTestCase.java @@ -0,0 +1,190 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.util.ArrayList; +import java.util.List; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataGraph; +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; + +public class SerializeTypesTestCase extends TestCase { + + HelperContext hc; + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + } + + public void testSerializeTypesRoundTrip() throws Exception { + TypeHelper types = hc.getTypeHelper(); + DataFactory factory = hc.getDataFactory(); + + Type intType = types.getType("commonj.sdo", "Int"); + Type stringType = types.getType("commonj.sdo", "String"); + + // create a new Type for Addresses + DataObject addressType = factory.create("commonj.sdo", "Type"); + addressType.set("uri", "http://example.com/address"); + addressType.set("name", "Address"); + + // create a address street property + DataObject addrStProperty = addressType.createDataObject("property"); + addrStProperty.set("name", "addrSt"); + addrStProperty.set("type", stringType); + + // create a new Type for Customers + DataObject customerType = factory.create("commonj.sdo", "Type"); + customerType.set("uri", "http://example.com/customer"); + customerType.set("name", "Customer"); + + // create a customer number property + DataObject custNumProperty = customerType.createDataObject("property"); + custNumProperty.set("name", "custNum"); + custNumProperty.set("type", intType); + + // create a first name property + DataObject firstNameProperty = customerType.createDataObject("property"); + firstNameProperty.set("name", "firstName"); + firstNameProperty.set("type", stringType); + + // create a last name property + DataObject lastNameProperty = customerType.createDataObject("property"); + lastNameProperty.set("name", "lastName"); + lastNameProperty.set("type", stringType); + + // create an address property + DataObject addressProperty = customerType.createDataObject("property"); + addressProperty.set("name", "address"); + addressProperty.set("type", addressType); + addressProperty.setBoolean("containment", true); + + // now define the Address and Customer type so that addresses and customers can be made + List types2define = new ArrayList(); + types2define.add(addressType); + types2define.add(customerType); + List typesDefined = types.define(types2define); + + // Create an empty data graph and add a root object, an instance of customerType + // + + DataGraph dataGraph = SDOUtil.createDataGraph(); + Type customerTypeDefined = (Type) typesDefined.get(1); + DataObject customer1 = dataGraph.createRootObject(customerTypeDefined); + + customer1.setInt("custNum", 1); + customer1.set("firstName", "John"); + customer1.set("lastName", "Adams"); + DataObject address = customer1.createDataObject("address"); + address.set("addrSt", "577 Airport Blvd"); + + SDOUtil.registerDataGraphTypes(dataGraph, typesDefined); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + SDOUtil.saveDataGraph(dataGraph, baos, null); + //SDOUtil.saveDataGraph(dataGraph, System.out, null); + + byte[] serialized = baos.toByteArray(); + ByteArrayInputStream bais = new ByteArrayInputStream(serialized); + DataGraph loadedDataGraph = SDOUtil.loadDataGraph(bais, null, hc); + + DataObject loadedRootObject = loadedDataGraph.getRootObject(); + assertNotSame(loadedRootObject.getType(), customer1.getType()); + + // EqualityHelper requires same Type + assertEquals(loadedRootObject.getInt("custNum"), customer1.getInt("custNum")); + assertEquals(loadedRootObject.get("firstName"), customer1.get("firstName")); + assertEquals(loadedRootObject.get("lastName"), customer1.get("lastName")); + DataObject loadedAddress = loadedRootObject.getDataObject("address"); + assertEquals(loadedAddress.get("addrSt"), address.get("addrSt")); + } + + private String xsdString = + " " + + " " + + " " + + " " + + " " + + " " + + " " + + " " + + ""; + + + private String testString = "Hello World"; + private String testStringInBase64 = "SGVsbG8gV29ybGQ="; + private String testStringInHex = "48656C6C6F20576F726C64"; + + public void testSerializeXSDBase64BinaryRoundTrip() throws Exception { + hc.getXSDHelper().define(xsdString); + + DataObject typeTest = hc.getDataFactory().create("http://www.example.com/simple", "BytesTypeTest"); + typeTest.setBytes("base64Binary", testString.getBytes()); + + String output = hc.getXMLHelper().save(typeTest, typeTest.getType().getURI(), "bytesTypeTest"); + + String startTag = ""; + String endTag = ""; + int start = output.indexOf(startTag) + startTag.length(); + int end = output.indexOf(endTag); + + String value = output.substring(start, end); + assertEquals(testStringInBase64, value); + + XMLDocument xmlDoc = hc.getXMLHelper().load(output); + typeTest = xmlDoc.getRootObject(); + assertEquals(testString, new String(typeTest.getBytes("base64Binary"))); + } + + public void testSerializeXSDHexBinaryRoundTrip() throws Exception { + hc.getXSDHelper().define(xsdString); + + DataObject typeTest = hc.getDataFactory().create("http://www.example.com/simple", "BytesTypeTest"); + typeTest.setBytes("hexBinary", testString.getBytes()); + + String output = hc.getXMLHelper().save(typeTest, typeTest.getType().getURI(), "bytesTypeTest"); + + String startTag = ""; + String endTag = ""; + int start = output.indexOf(startTag) + startTag.length(); + int end = output.indexOf(endTag); + + String value = output.substring(start, end); + assertEquals(testStringInHex, value); + + XMLDocument xmlDoc = hc.getXMLHelper().load(output); + typeTest = xmlDoc.getRootObject(); + assertEquals(testString, new String(typeTest.getBytes("hexBinary"))); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleCopyTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleCopyTestCase.java new file mode 100644 index 0000000000..36f038d779 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleCopyTestCase.java @@ -0,0 +1,71 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +import commonj.sdo.DataObject; +import commonj.sdo.helper.CopyHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import junit.framework.TestCase; + +public class SimpleCopyTestCase extends TestCase { + + private final String TEST_MODEL = "/simple.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/simple"; + private final String QUOTE_XML = "/quote.xml"; + private final String SHALLOW_QUOTE_XML = "/shallowquote.xml"; + + public void testSimpleCopy() throws IOException { + XMLDocument doc = XMLHelper.INSTANCE.load(getClass().getResourceAsStream(QUOTE_XML)); + DataObject sdo = doc.getRootObject(); + + DataObject copiedSdo = CopyHelper.INSTANCE.copyShallow(sdo); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + XMLHelper.INSTANCE.save(copiedSdo, TEST_NAMESPACE, "stockQuote", baos); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(SHALLOW_QUOTE_XML))); + assertFalse(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(QUOTE_XML))); + + copiedSdo = CopyHelper.INSTANCE.copy(sdo); + + baos.reset(); + XMLHelper.INSTANCE.save(copiedSdo, TEST_NAMESPACE, "stockQuote", baos); + assertFalse(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(SHALLOW_QUOTE_XML))); + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(QUOTE_XML))); + } + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleDynamicTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleDynamicTestCase.java new file mode 100644 index 0000000000..55aae9d396 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleDynamicTestCase.java @@ -0,0 +1,123 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.math.BigDecimal; +import java.net.URL; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; + + +public class SimpleDynamicTestCase extends TestCase { + private final String TEST_MODEL = "/simple.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/simple"; + private final String QUOTE_XML = "/quote.xml"; + + //private final String TEST_MODEL2 = "/simple2.xsd"; + //private final String TEST_NAMESPACE2 = "http://www.example.com/simple2"; + //private final String QUOTE_XML2 = "/quote2.xml"; + + HelperContext hc; + TypeHelper th; + + /** + * Simple Dynamic SDO 2 test. + */ + public void testDynamic() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "Quote"); + DataObject quote = hc.getDataFactory().create(quoteType); + + quote.setString("symbol", "fbnt"); + quote.setString("companyName", "FlyByNightTechnology"); + quote.setBigDecimal("price", new BigDecimal("1000.0")); + quote.setBigDecimal("open1", new BigDecimal("1000.0")); + quote.setBigDecimal("high", new BigDecimal("1000.0")); + quote.setBigDecimal("low", new BigDecimal("1000.0")); + quote.setDouble("volume", 1000); + quote.setDouble("change1", 1000); + + DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + hc.getXMLHelper().save(quote, TEST_NAMESPACE, "stockQuote", baos); + + assertFalse(quote.isSet("undefined")); + assertSame(quote.get("undefined"), null); + + assertTrue(TestUtil.equalXmlFiles(new ByteArrayInputStream(baos.toByteArray()), getClass().getResource(QUOTE_XML))); + } + + /* + public void dontTestResolveXSDWithoutSchemaLocation() throws IOException { + + URL url = getClass().getResource(TEST_MODEL2); + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, null); + inputStream.close(); + + Type quote2Type = th.getType(TEST_NAMESPACE2, "Quote2"); + DataObject quote2 = hc.getDataFactory().create(quote2Type); + + quote2.setString("symbol", "fbnt"); + quote2.setString("companyName", "FlyByNightTechnology"); + quote2.setBigDecimal("price", new BigDecimal("1000.0")); + quote2.setBigDecimal("open1", new BigDecimal("1000.0")); + quote2.setBigDecimal("high", new BigDecimal("1000.0")); + quote2.setBigDecimal("low", new BigDecimal("1000.0")); + quote2.setDouble("volume", 1000); + quote2.setDouble("change1", 1000); + + DataObject child = quote2.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + hc.getXMLHelper().save(quote2, TEST_NAMESPACE2, "stockQuote", System.out); + } + */ + + protected void setUp() throws Exception { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + + + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleEqualityTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleEqualityTestCase.java new file mode 100644 index 0000000000..8db9ba9d04 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SimpleEqualityTestCase.java @@ -0,0 +1,91 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.EqualityHelper; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; +import commonj.sdo.impl.HelperProvider; +import junit.framework.TestCase; + +public class SimpleEqualityTestCase extends TestCase { + private static final String TEST_MODEL = "/simple.xsd"; + private static final String QUOTE_XML = "/quote.xml"; + private static final String SHALLOW_QUOTE_XML = "/shallowquote.xml"; + + public void testEquality() throws IOException { + + XMLDocument doc = XMLHelper.INSTANCE.load(getClass().getResourceAsStream(QUOTE_XML)); + DataObject sdo = doc.getRootObject(); + + doc = XMLHelper.INSTANCE.load(getClass().getResourceAsStream(SHALLOW_QUOTE_XML)); + DataObject shallowSdo = doc.getRootObject(); + + boolean result = EqualityHelper.INSTANCE.equalShallow(sdo, shallowSdo); + assertTrue(result); + + result = EqualityHelper.INSTANCE.equal(sdo, shallowSdo); + assertFalse(result); + } + + + protected void setUp() throws Exception { + super.setUp(); + + // Populate the meta data for the test (Stock Quote) model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + } + + public void testBytesEquality() { + // Dynamically create a type + HelperContext scope = HelperProvider.getDefaultContext(); + TypeHelper types = scope.getTypeHelper(); + Type BytesType = types.getType("commonj.sdo", "Bytes"); + DataObject customerType = DataFactory.INSTANCE.create("commonj.sdo", "Type"); + customerType.set("uri", "http://example.com/simple"); + customerType.set("name", "Simple"); + DataObject BytesProperty = customerType.createDataObject("property"); + BytesProperty.set("name", "BytesVal"); + BytesProperty.set("type", BytesType); + types.define(customerType); + + // Create two instances + DataObject obj1 = DataFactory.INSTANCE.create("http://example.com/simple", "Simple"); + DataObject obj2 = DataFactory.INSTANCE.create("http://example.com/simple", "Simple"); + + obj1.setBytes("BytesVal", new byte[] {120, 80, -40}); + obj2.setBytes("BytesVal", new byte[] {120, 80, -40}); + + assertTrue( scope.getEqualityHelper().equal(obj1, obj2) ); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SubstitutionValuesTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SubstitutionValuesTestCase.java new file mode 100644 index 0000000000..fb729ea125 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/SubstitutionValuesTestCase.java @@ -0,0 +1,83 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.net.URL; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.Property; +import commonj.sdo.Sequence; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +public final class SubstitutionValuesTestCase extends TestCase +{ + public void test() throws IOException + { + HelperContext hc = SDOUtil.createHelperContext(); + URL url = getClass().getResource("/SubstitutionValues.xsd"); + XSDHelper xsdHelper = hc.getXSDHelper(); + xsdHelper.define(url.openStream(), url.toString()); + + XMLHelper xmlHelper = hc.getXMLHelper(); + DataObject loadedObject = + xmlHelper.load(getClass().getResourceAsStream("/substitutionValues1.xml")).getRootObject(); + Type type = loadedObject.getType(); + Sequence groupHeadSubstitutionValues = SDOUtil.getSubstitutionValues(loadedObject, type.getProperty("groupHead")); + assertNotNull(groupHeadSubstitutionValues); + assertNull(SDOUtil.getSubstitutionValues(loadedObject, type.getProperty("nonGroupHead"))); + + String nsURI = "http://www.apache.org/tuscany/SubstitutionValues"; + DataObject createdObject = hc.getDataFactory().create(nsURI, "TestObject"); + Property groupMemberProperty = xsdHelper.getGlobalProperty(nsURI, "groupMember", true); + createdObject.set(groupMemberProperty, groupHeadSubstitutionValues.getValue(0)); + createdObject.setString("nonGroupHead", loadedObject.getString("nonGroupHead")); + + assertTrue(hc.getEqualityHelper().equal(loadedObject, createdObject)); + + ByteArrayOutputStream loadedBaos = new ByteArrayOutputStream(); + xmlHelper.save(loadedObject, nsURI, "testObject", loadedBaos); + ByteArrayOutputStream createdBaos = new ByteArrayOutputStream(); + xmlHelper.save(createdObject, nsURI, "testObject", createdBaos); + assertTrue( + TestUtil.equalXmlFiles( + new ByteArrayInputStream(loadedBaos.toByteArray()), + new ByteArrayInputStream(createdBaos.toByteArray()))); + + loadedObject = + xmlHelper.load(getClass().getResourceAsStream("/substitutionValues2.xml")).getRootObject(); + groupHeadSubstitutionValues = SDOUtil.getSubstitutionValues(loadedObject, type.getProperty("groupHead")); + + createdObject = hc.getDataFactory().create(nsURI, "TestObject"); + createdObject.set("groupHead", groupHeadSubstitutionValues.getValue(0)); + createdObject.setString("nonGroupHead", loadedObject.getString("nonGroupHead")); + + assertTrue(hc.getEqualityHelper().equal(loadedObject, createdObject)); + } +} \ No newline at end of file diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TestUtil.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TestUtil.java new file mode 100644 index 0000000000..a7ab3f954a --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/TestUtil.java @@ -0,0 +1,285 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; +import java.util.ArrayList; +import java.util.List; + +import javax.xml.parsers.DocumentBuilderFactory; +import javax.xml.parsers.DocumentBuilder; +import javax.xml.parsers.FactoryConfigurationError; +import javax.xml.parsers.ParserConfigurationException; + +import org.w3c.dom.Document; +import org.w3c.dom.DocumentType; +import org.w3c.dom.NamedNodeMap; +import org.w3c.dom.Node; +import org.w3c.dom.NodeList; +import org.xml.sax.SAXException; + +public class TestUtil +{ + private static void getAllNodes(NodeList nodeList, List nodes) + { + int length = nodeList.getLength(); + if (length == 0) + { + return; + } + + for (int i=0; i, but within + // the array exist the get(index), get(property), and get(path). Rather than + // referring to each of the three in every circumstance, the more compact array appears. + private static ConversionType TO_BOOLEAN = new ConversionType("Boolean", boolean.class ); + private static ConversionType TO_BYTE = new ConversionType("Byte", byte.class ); + private static ConversionType TO_CHAR = new ConversionType("Char", char.class ); + private static ConversionType TO_DOUBLE = new ConversionType("Double", double.class ); + private static ConversionType TO_FLOAT = new ConversionType("Float", float.class ); + private static ConversionType TO_INT = new ConversionType("Int", int.class ); + private static ConversionType TO_LONG = new ConversionType("Long", long.class ); + private static ConversionType TO_SHORT = new ConversionType("Short", short.class ); + private static ConversionType TO_BYTES = new ConversionType("Bytes", byte[].class ); + private static ConversionType TO_BIGDECIMAL = new ConversionType("BigDecimal", java.math.BigDecimal.class ); + private static ConversionType TO_BIGINTEGER = new ConversionType("BigInteger", java.math.BigInteger.class ); + private static ConversionType TO_DATAOBJECT = new ConversionType("DataObject", commonj.sdo.DataObject.class ); + private static ConversionType TO_DATE = new ConversionType("Date", java.util.Date.class ); + private static ConversionType TO_STRING = new ConversionType("String", java.lang.String.class ); + private static ConversionType TO_LIST = new ConversionType("List", java.util.List.class ); + // There is no setXXXX methods for sequence... + private static ConversionType TO_SEQUENCE = new ConversionType("Sequence", null ); + + private static GeneralComparator COMPARE_ANY; + + // There will be several instances where a Property must be passed as a parameter. Have available the Type + // to call getProperty() as needed. + + private static Type API_TEST_TYPE; + + // The default constructor establishes each of the Method and Method[] variables. + + public TypeConversionTestCase() throws Exception + { + COMPARE_ANY = new GeneralComparator(); + + // Populate the meta data for the test model + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + XSDHelper.INSTANCE.define(inputStream, url.toString()); + inputStream.close(); + + API_TEST_TYPE = TypeHelper.INSTANCE.getType(TEST_NAMESPACE, "APITest"); + + } + + private static class ConversionType + { + // The following constants are used because the getMethod function requires an Class + // array describing the parameters to the functions. + + private static final Class[] GET_INT_CLASS_ARRAY = {int.class}; + private static final Class[] GET_PROPERTY_CLASS_ARRAY = {Property.class}; + private static final Class[] GET_STRING_CLASS_ARRAY = {String.class}; + private static final Class[] SET_INT_CLASS_ARRAY = {int.class, Class.class}; + private static final Class[] SET_PROPERTY_CLASS_ARRAY = {Property.class, Class.class}; + private static final Class[] SET_STRING_CLASS_ARRAY = {String.class, Class.class}; + + Method get_index_method; + Method get_property_method; + Method get_path_method; + Method set_index_method; + Method set_property_method; + Method set_path_method; + + public ConversionType (String method_name, Class type ) + { + try + { + this.get_index_method = DataObject.class.getMethod("get"+method_name, GET_INT_CLASS_ARRAY); + this.get_property_method = DataObject.class.getMethod("get"+method_name, GET_PROPERTY_CLASS_ARRAY); + this.get_path_method = DataObject.class.getMethod("get"+method_name, GET_STRING_CLASS_ARRAY); + if( type != null ) + { + SET_INT_CLASS_ARRAY[1] = type; + this.set_index_method = DataObject.class.getMethod("set"+method_name, SET_INT_CLASS_ARRAY); + SET_PROPERTY_CLASS_ARRAY[1] = type; + this.set_property_method = DataObject.class.getMethod("set"+method_name, SET_PROPERTY_CLASS_ARRAY); + SET_STRING_CLASS_ARRAY[1] = type; + this.set_path_method = DataObject.class.getMethod("set"+method_name, SET_STRING_CLASS_ARRAY); + } + else + { + this.set_index_method = null; + this.set_property_method = null; + this.set_path_method = null; + } + } + catch (NoSuchMethodException e) + { + this.get_index_method = null; + this.get_property_method = null; + this.get_path_method = null; + this.set_index_method = null; + this.set_property_method = null; + this.set_path_method = null; + } + } + + public Method getIndexGetMethod() + { + return this.get_index_method; + } + + public Method getPropertyGetMethod() + { + return this.get_property_method; + } + + public Method getPathGetMethod() + { + return this.get_path_method; + } + public Method getIndexSetMethod() + { + return this.set_index_method; + } + + public Method getPropertySetMethod() + { + return this.set_property_method; + } + + public Method getPathSetMethod() + { + return this.set_path_method; + } + } + + // Each instance of Test describes a convert-from type. The index, property and path parms + // will refer to the same field, which is a field of the convert-from type. + + private static class Test + { + DataObject test_obj; + Object[] get_index_parm; + Object[] get_property_parm; + Object[] get_path_parm; + Object[] set_index_parm; + Object[] set_property_parm; + Object[] set_path_parm; + Object expected_value; + String from_type; + Class from_type_class; + + // The constructor prepares a test DataObject and determines how to access the field + // in three different ways - index, property, and path. + + Test(String path, int index) + { + this.test_obj = DataFactory.INSTANCE.create(API_TEST_TYPE); + this.get_index_parm = new Object[] {new Integer(index)}; + this.get_property_parm = new Object[] {API_TEST_TYPE.getProperty(path)}; + this.get_path_parm = new Object[] {path}; + this.set_index_parm = new Object[] {new Integer(index), null}; + this.set_property_parm = new Object[] {API_TEST_TYPE.getProperty(path), null}; + this.set_path_parm = new Object[] {path, null}; + this.expected_value = null; + } + + // The initialize() function establishes the initial value of the test field. + + public void initialize(Class type, String type_name, Object initial_value) throws Exception + { + this.expected_value = initial_value; + this.from_type = type_name; + this.from_type_class = type; + + setDefaultValue(); + } + + private void setDefaultValue() throws Exception + { + Class[] classArray = {int.class, from_type_class}; + Object[] initValueArray = new Object[] {this.get_index_parm[0], expected_value}; + Method setter = DataObject.class.getMethod("set" + from_type, classArray); + setter.invoke(test_obj, initValueArray); + } + + // Attempts the conversion to the specified type, using DataObject.get____(). + // The get___() function can be called with an index, path, and property. attemptConversion() + // calls each of those three. + + public void attemptConversion(ConversionType to_type) throws Exception + { + performConversion(to_type.getIndexGetMethod(), this.get_index_parm, to_type.getIndexSetMethod(), this.set_index_parm); + performConversion(to_type.getPathGetMethod(), this.get_path_parm, to_type.getPathSetMethod(), this.set_path_parm ); + performConversion(to_type.getPropertyGetMethod(), this.get_property_parm, to_type.getPropertySetMethod(), this.set_property_parm ); + } + + public void checkConversionException(ConversionType to_type, Class expected_exception) throws Exception + { + boolean index_err, path_err, property_err, consistency_err = false; + + index_err = executeExceptionCase(to_type.getIndexGetMethod(), this.get_index_parm, expected_exception); + path_err = executeExceptionCase(to_type.getPathGetMethod(), this.get_path_parm, expected_exception); + property_err = executeExceptionCase(to_type.getPropertyGetMethod(), this.get_property_parm, expected_exception); + + if (index_err != path_err || path_err != property_err) + consistency_err = true; + else if (index_err == false) + attemptConversion(to_type); + + assertFalse("An exception inconsistency exists for " + to_type.getPathGetMethod().getName() + " when called " + + "for a " + this.from_type + " property.", consistency_err); + } + + private void performConversion (Method getMeth, Object[] getParm, Method setMeth, Object[] setParm ) throws Exception + { + // First use the set + try + { + // get the set value + setParm[1] = getMeth.invoke(test_obj, getParm);; + // now set it... + setMeth.invoke(test_obj, setParm); + } + catch (Exception e) + { + Throwable cause = e.getCause(); + if (cause == null) + { + System.err.println("An exception of type " + e.getClass() + " occurred while performing " + setMeth.getName() + + " on a " + this.from_type + " property."); + } + else + { + System.err.println("An exception of type " + cause.getClass() + " occurred while performing " + setMeth.getName() + + " on a " + this.from_type + " property."); + } + + throw e; + } + + try + { + + assertTrue("Conversion did not yield expected value for get" + getMeth.getName() + " on a " + this.from_type + " property.", + COMPARE_ANY.compare(getMeth.invoke(test_obj, getParm), this.expected_value) == 0); + } + catch (Exception e) + { + Throwable cause = e.getCause(); + if (cause == null) + { + System.err.println("An exception of type " + e.getClass() + " occurred while performing " + getMeth.getName() + + " on a " + this.from_type + " property."); + } + else + { + System.err.println("An exception of type " + cause.getClass() + " occurred while performing " + getMeth.getName() + + " on a " + this.from_type + " property."); + } + + throw e; + } + + // reset to default + setDefaultValue(); + } + + + + private boolean executeExceptionCase (Method convert, Object[] parm, Class expected_exception) throws Exception + { + boolean exception_thrown = false; + try + { + convert.invoke(test_obj, parm); + } + catch (Exception e) + { + exception_thrown = true; + Throwable cause = e.getCause(); + if (cause == null) + { + assertEquals("An unexpected exception occurred while performing " + convert.getName() + + " on a " + this.from_type + " property.", expected_exception, e.getClass()); + } + else + { + assertEquals("An unexpected exception occurred while performing " + convert.getName() + + " on a " + this.from_type + " property.", expected_exception, cause.getClass()); + } + } + + return exception_thrown; + } + } + + private static class GeneralComparator implements Comparator + { + public int compare(Object obj1, Object obj2) + { + if (obj1.getClass() == obj2.getClass()) + { + if (obj1.equals(obj2)) + return 0; + else + return 1; + } + + else if ( (obj1.getClass() == byte[].class && obj2.getClass() == String.class) || + (obj2.getClass() == byte[].class && obj1.getClass() == String.class) ) + { + String strVal; + byte [] byteVal; + + if( obj1.getClass() == String.class ) + { + strVal = (String)obj1; + byteVal = (byte [])obj2; + } + else + { + strVal = (String)obj2; + byteVal = (byte [])obj1; + } + + if( strVal.length()/2 != byteVal.length ) + return -1; + + for( int i=0; i" +LINE_BREAK+ +MARGIN+ "" +LINE_BREAK+ +MARGIN+INDENT+ "FBNT" +LINE_BREAK+ +MARGIN+INDENT+ "FlyByNightTechnology" +LINE_BREAK+ +MARGIN+INDENT+ "999.0" +LINE_BREAK+ +MARGIN+INDENT+ "1000.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "1500.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "2500.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "3000.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "4000.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "fbnt" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "1000.0" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "2000.02000.99" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+ ""); + } + + public void notestSaveMixedOutputStreamObject() throws IOException { + format("/mixedChangeSummary.xml", +MARGIN+ "" +LINE_BREAK+ +MARGIN+ "" +LINE_BREAK+ +INDENT+ "" +LINE_BREAK+ +INDENT+INDENT+ "fbnt" +LINE_BREAK+ +INDENT+INDENT+ "FlyByNightTechnology" +LINE_BREAK+ +INDENT+INDENT+ "1000.0" +LINE_BREAK+ +INDENT+INDENT+ "" +LINE_BREAK+ +INDENT+INDENT+ "2000.02000.99" +LINE_BREAK+ +INDENT+INDENT+ "" +LINE_BREAK+ +INDENT+ "" +LINE_BREAK+ +"FBNTFlyByNightTechnology999.01500.02500.01000.03000.04000.0"); + } + + public void notestOpenMixedOutputStreamObject() throws IOException { + format("/openChangeSummary.xml", +MARGIN+ "" +LINE_BREAK+ +MARGIN+ "" +LINE_BREAK+ +MARGIN+INDENT+ "FBNT" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "1500.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "2500.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "3000.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "4000.0" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "fbnt" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "2000.02000.99" +LINE_BREAK+ +MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ +MARGIN+INDENT+ "" +LINE_BREAK+ +MARGIN+ ""); + } + + private String quoteXML = + "" + + "" + + "fbnt" + + "FlyByNightTechnology" + + "1000.0" + + "1000.0" + + "1000.0" + + "1000.0" + + "1000.0" + + "1000.0" + + "" + + "2000.0" + + "" + + ""; + + public void testLoadDOMSource() throws IOException, ParserConfigurationException, SAXException + { + DocumentBuilderFactory dFactory = DocumentBuilderFactory.newInstance(); + dFactory.setNamespaceAware(true); + + DocumentBuilder dBuilder = dFactory.newDocumentBuilder(); + Document document = dBuilder.parse(new ByteArrayInputStream(quoteXML.getBytes())); + + DOMSource domSource = new DOMSource(document); + + XMLDocument xmlDocument = hc.getXMLHelper().load(domSource, null, null); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + + Map options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_SAVE_INDENT, ""); + options.put(SDOHelper.XMLOptions.XML_SAVE_MARGIN, ""); + options.put(SDOHelper.XMLOptions.XML_SAVE_LINE_BREAK, ""); + + hc.getXMLHelper().save(xmlDocument, baos, options); + + boolean isEqual = TestUtil.equalXmlFiles(new ByteArrayInputStream(quoteXML.getBytes()), new ByteArrayInputStream(baos.toByteArray())); + assertTrue(isEqual); + } + + private String xsdStr = + "" + + "" + +// "" + + "" + + "" + + "" + + "" + + "" + + ""; + + /** + * Test the scenario of serializing and deserializing an SDO with an undefined global SDO property + * In this scenario, the target XSD namespace doesn't have any global element defined + * + */ + public void testDemandCreateRootObject() { + HelperContext hc = SDOUtil.createHelperContext(); + hc.getXSDHelper().define(xsdStr); + DataObject quote = hc.getDataFactory().create("http://www.example.com/simple", "Quote"); + quote.set("symbol", "abc"); + + String xmlStr = hc.getXMLHelper().save(quote, quote.getType().getURI(), "demandcreate"); + + XMLDocument doc = hc.getXMLHelper().load(xmlStr); + try { + doc.getRootObject(); + } + catch (ClassCastException e) { + fail(e.toString()); + } + } + + /** + * This test case is similar to the testDemandCreateRootObject above. The only difference is + * the data model was created using SDO APIs instead of XSD. + * + */ + public void testDemandCreateRootObject2() { + HelperContext hc1 = SDOUtil.createHelperContext(); + Type stringType = hc1.getTypeHelper().getType("commonj.sdo", "String"); + + DataObject quoteTypeDef = hc1.getDataFactory().create("commonj.sdo", "Type"); + quoteTypeDef.set("uri", "http://www.example.com/simple"); + quoteTypeDef.set("name", "Quote"); + + DataObject symbolPropDef = quoteTypeDef.createDataObject("property"); + symbolPropDef.set("name", "symbol"); + symbolPropDef.set("type", stringType); + + hc1.getTypeHelper().define(quoteTypeDef); + + DataObject quote = hc1.getDataFactory().create("http://www.example.com/simple", "Quote"); + quote.set("symbol", "abc"); + + String xmlStr = hc1.getXMLHelper().save(quote, quote.getType().getURI(), "demandcreate"); + + HelperContext hc2 = SDOUtil.createHelperContext(); + hc2.getXSDHelper().define(xsdStr); + + XMLDocument doc = hc2.getXMLHelper().load(xmlStr); + try { + doc.getRootObject(); + } + catch (ClassCastException e) { + fail(e.toString()); + } + } + + public void testEncoding() throws IOException + { + TypeHelper types = hc.getTypeHelper(); + Type stringType = types.getType("commonj.sdo", "String"); + DataObject customerType = hc.getDataFactory().create("commonj.sdo", "Type"); + customerType.set("uri", "http://example.com/simple"); + customerType.set("name", "Simple"); + DataObject multiProperty = customerType.createDataObject("property"); + multiProperty.set("name", "name"); + multiProperty.set("type", stringType); + types.define(customerType); + DataObject obj = hc.getDataFactory().create("http://example.com/simple", + "Simple"); + obj.set("name", "John Smith"); + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + hc.getXMLHelper().save(obj, "http://www.example.com/company" , "company", baos); + ByteArrayInputStream bais = new ByteArrayInputStream(baos.toString().getBytes()); + XMLDocument xmlDoc = hc.getXMLHelper().load(bais); + if( !"UTF-8".equals(xmlDoc.getEncoding()) ) + { + fail("Encoding ('" + xmlDoc.getEncoding() +"' is not correct. UTF-8 is the expected encoding."); + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadOptionsTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadOptionsTestCase.java new file mode 100644 index 0000000000..d58b070a90 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadOptionsTestCase.java @@ -0,0 +1,192 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.StringReader; +import java.util.HashMap; +import java.util.Map; + +import javax.xml.stream.XMLInputFactory; +import javax.xml.stream.XMLStreamConstants; +import javax.xml.stream.XMLStreamException; +import javax.xml.stream.XMLStreamReader; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.SDOPackage; +import org.apache.tuscany.sdo.api.SDOHelper; +import org.apache.tuscany.sdo.api.SDOUtil; +import org.apache.tuscany.sdo.api.XMLStreamHelper; +import org.eclipse.emf.ecore.resource.Resource; + +import commonj.sdo.DataObject; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; + +public class XMLLoadOptionsTestCase extends TestCase { + XMLHelper xmlHelper; + Map options; + + protected void setUp() throws Exception { + super.setUp(); + } + + //SDOUtil->SDOHelper->SDOHelperImpl->HelperContextImpl->XMLHelperImpl + public void testXMLOptionsSchema1() throws IOException{ + final String TEST_XML_DOCUMENT = "/SchemaLocationTestCase.xml"; + + options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_LOAD_SCHEMA, Boolean.TRUE); + + final XMLHelper xmlHelper = SDOUtil.createHelperContext(true, options).getXMLHelper(); + + final XMLDocument xmlDoc = xmlHelper.load(getClass().getResourceAsStream(TEST_XML_DOCUMENT), "whatever", null); + final DataObject root = xmlDoc.getRootObject(); + assertNotSame(root.getType(), SDOPackage.eINSTANCE.getAnyTypeDataObject()); + } + +// SDOUtil->SDOHelper->SDOHelperImpl->HelperContextImpl->XMLHelperImpl + public void testXMLOptionsSchema2() throws IOException{ + final String TEST_XML_DOCUMENT = "/SchemaLocationTestCase.xml"; + + options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_LOAD_SCHEMA, Boolean.FALSE); + final XMLHelper xmlHelper = SDOUtil.createHelperContext(true, options).getXMLHelper(); + final XMLDocument xmlDoc = xmlHelper.load(getClass().getResourceAsStream(TEST_XML_DOCUMENT), "whatever", null); + final DataObject root = xmlDoc.getRootObject(); + assertSame(root.getType(), SDOPackage.eINSTANCE.getAnyTypeDataObject()); + } + + public void testXMLOptionsLax1() throws IOException{ + options = new HashMap(); + /* + * turn off default behaviour of tolerating malformed xml + * tests using this option and bad xml should demonstrate failure to load + */ + options.put(SDOHelper.XMLOptions.XML_LOAD_LAX_FORM, new Integer(0)); + final HelperContext hc = SDOUtil.createHelperContext(true, options); + hc.getXSDHelper().define( + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""); + + final String xml=""+ + ""+ +""; + + /* + * this malformed xml will not load, as lax is forced OFF + * changing p:unqualifiedElement to unqualifiedElement + * will work */ + try{ + hc.getXMLHelper().load(new StringReader(xml), null, null); + fail(); + } catch (final Resource.IOWrappedException featureNotFound) { + assertTrue(true); + } + + } + + public void testXMLOptionsLax2() throws IOException{ + options = new HashMap(); + /* + * turn on default behaviour of tolerating malformed xml + * tests using this option and bad xml will load + */ + options.put(SDOHelper.XMLOptions.XML_LOAD_LAX_FORM, new Integer(1)); + final HelperContext hc = SDOUtil.createHelperContext(true, options); + hc.getXSDHelper().define( + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""); + + final String xml=""+ + ""+ + ""+ + ""; + + /* + * this malformed xml will load, as lax is forced ON + */ + assertNotNull(hc.getXMLHelper().load(new StringReader(xml), null, null).getRootObject()); + } + + //SDOUtil->SDOHelper->SDOHelperImpl->XMLStreamHelperImpl->XMLDocumentImpl + public void testXMLStreamHelper() throws IOException, XMLStreamException{ + options = new HashMap(); + /* + * turn off default behaviour of tolerating malformed xml + * tests using this option and bad xml will load + */ + options.put(SDOHelper.XMLOptions.XML_LOAD_LAX_FORM, new Integer(1)); + final HelperContext hc = SDOUtil.createHelperContext(false, options); + final XMLStreamHelper streamHelper = SDOUtil.createXMLStreamHelper(hc); + hc.getXSDHelper().define( + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""+ + ""); + + final String xml=""+ + ""+ + ""+ + ""; + + final XMLInputFactory inputFactory = XMLInputFactory.newInstance(); + final XMLStreamReader reader1 = inputFactory.createXMLStreamReader(new StringReader(xml)); + int event = reader1.getEventType(); + while (!(event == XMLStreamConstants.START_ELEMENT)){ + event = reader1.next(); + } + final DataObject dataObject = streamHelper.loadObject(reader1); + /* + * this malformed xml will load, as lax is forced ON + */ + assertNotNull(dataObject); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadUnknownFeatureTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadUnknownFeatureTestCase.java new file mode 100644 index 0000000000..7888a82043 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLLoadUnknownFeatureTestCase.java @@ -0,0 +1,51 @@ +/* + * 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.tuscany.sdo.test; + +import java.io.InputStream; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; + +import commonj.sdo.helper.HelperContext; + +/** + * @version $Rev$ $Date$ + */ +public class XMLLoadUnknownFeatureTestCase extends TestCase { + private static final String XML = + "" + + "cb1a1a12008-04-16T16:22:07.812Z"; + + public void testLoad() { + HelperContext context = SDOUtil.createHelperContext(); + InputStream is = getClass().getResourceAsStream("/comment.xsd"); + context.getXSDHelper().define(is, null); + try { + // Comment out as it fails + // context.getXMLHelper().load(XML); + } catch (StackOverflowError e) { + // FIXME: This test case is failing at this point + e.printStackTrace(); + } + + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLSaveOptionsTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLSaveOptionsTestCase.java new file mode 100644 index 0000000000..27b750b0ff --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLSaveOptionsTestCase.java @@ -0,0 +1,147 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.io.StringWriter; +import java.net.URL; +import java.util.HashMap; + +import javax.xml.stream.XMLOutputFactory; +import javax.xml.stream.XMLStreamWriter; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOHelper; +import org.apache.tuscany.sdo.api.SDOUtil; +import org.apache.tuscany.sdo.api.XMLStreamHelper; + +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +public class XMLSaveOptionsTestCase extends TestCase { + HelperContext hc; + private XSDHelper xsdHelper; + XMLHelper xmlh; + XMLStreamHelper xmlStreamHelper; + static final String INDENT = " ", MARGIN = " ", LINE_BREAK = "\n"; + String formatted1 = MARGIN+ "" +LINE_BREAK+ + MARGIN+ "" +LINE_BREAK+ + MARGIN+INDENT+ "FBNT" +LINE_BREAK+ + MARGIN+INDENT+ "FlyByNightTechnology" +LINE_BREAK+ + MARGIN+INDENT+ "999.0" +LINE_BREAK+ + MARGIN+INDENT+ "1000.0" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "1500.0" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "2500.0" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "3000.0" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "4000.0" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+INDENT+ "fbnt" +LINE_BREAK+ + MARGIN+INDENT+INDENT+INDENT+ "1000.0" +LINE_BREAK+ + MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+INDENT+ "2000.02000.99" +LINE_BREAK+ + MARGIN+INDENT+INDENT+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+INDENT+ "" +LINE_BREAK+ + MARGIN+INDENT+ "" +LINE_BREAK+ + MARGIN+ ""; + + String formatted2 = + //MARGIN+ "" +LINE_BREAK+ + MARGIN+ "" +LINE_BREAK+ + MARGIN+INDENT+"fbnt" +LINE_BREAK+ + MARGIN+INDENT+"FlyByNightTechnology" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+INDENT+"1000.0" +LINE_BREAK+ + MARGIN+"" +LINE_BREAK; + + void define(final String model) throws IOException { + // Populate the meta data for the test model + final URL url = getClass().getResource(model); + xsdHelper.define(url.openStream(), url.toString()); + } + + protected void setUp() throws Exception { + super.setUp(); + } + + protected void tearDown() throws Exception { + super.tearDown(); + } + + //use XMLHelper + public void testSaveXMLDocumentXMLHelper() throws IOException { + final HashMap options = new HashMap(); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_INDENT, INDENT); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_MARGIN, MARGIN); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_LINE_BREAK, LINE_BREAK); + hc = SDOUtil.createHelperContext(false,options); + xsdHelper = hc.getXSDHelper(); + xmlh = hc.getXMLHelper(); + + // Populate the meta data for the test (Stock Quote) model + define("/simpleWithChangeSummary.xsd"); + final XMLDocument doc = xmlh.load(getClass().getResource("/simpleWithChangeSummary.xml").openStream()); + final ByteArrayOutputStream baos = new ByteArrayOutputStream(); + xmlh.save(xmlh.createDocument(doc.getRootObject(), doc.getRootElementURI(), doc.getRootElementName()), baos, null); + assertEquals(formatted1, baos.toString()); + } + + //use XMLStreamHelper + public void testSaveXMLDocumentXMLStreamHelper() throws Exception { + final HashMap options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_LOAD_SCHEMA, Boolean.FALSE); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_INDENT, INDENT); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_MARGIN, MARGIN); + options.put(org.apache.tuscany.sdo.api.SDOHelper.XMLOptions.XML_SAVE_LINE_BREAK, LINE_BREAK); + final HelperContext hc = SDOUtil.createHelperContext(false, options); + xmlStreamHelper = SDOUtil.createXMLStreamHelper(hc); + + xsdHelper = hc.getXSDHelper(); + define("/simple.xsd"); + + final InputStream inStrm = getClass().getResourceAsStream("/shallowquote.xml"); + final XMLDocument document = hc.getXMLHelper().load(inStrm, null, null); + + final XMLOutputFactory outputFactory = XMLOutputFactory.newInstance(); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + + xmlStreamHelper.save(document, streamWriter, null); + streamWriter.flush(); + assertEquals(formatted2, writer.toString()); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperPerformanceTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperPerformanceTestCase.java new file mode 100644 index 0000000000..ef701059c4 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperPerformanceTestCase.java @@ -0,0 +1,91 @@ +/** + * + * 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.tuscany.sdo.test; + + +import java.io.*; +import java.math.BigDecimal; +import java.net.URL; + +import javax.xml.stream.*; + +import org.apache.tuscany.sdo.api.XMLStreamHelper; +import org.apache.tuscany.sdo.api.SDOUtil; + +import junit.framework.TestCase; + +import commonj.sdo.*; +import commonj.sdo.helper.*; + + +public class XMLStreamHelperPerformanceTestCase extends TestCase { + private final String TEST_MODEL = "/XMLStreamHelper.xsd"; + private final String TEST_NAMESPACE = "http://www.example.com/simple"; + + HelperContext hc; + + /** + * Simple Dynamic SDO 2 test. + */ + public void testDynamic() throws Exception { + final TypeHelper typeHelper = hc.getTypeHelper(); + final Type quoteType = typeHelper.getType(TEST_NAMESPACE, "Quote"); + final DataObject quote = hc.getDataFactory().create(quoteType); + + quote.setString("symbol", "fbnt"); + quote.setString("companyName", "FlyByNightTechnology"); + quote.setBigDecimal("price", new BigDecimal("1000.0")); + quote.setBigDecimal("open1", new BigDecimal("1000.0")); + quote.setBigDecimal("high", new BigDecimal("1000.0")); + quote.setBigDecimal("low", new BigDecimal("1000.0")); + quote.setDouble("volume", 1000); + quote.setDouble("change1", 1000); + + final DataObject child = quote.createDataObject("quotes"); + child.setBigDecimal("price", new BigDecimal("2000.0")); + + final DataObject quote3 = quote.createDataObject("quotes3"); + quote3.setString("symbol3", "IBM"); + quote3.setString("company3", "IBM Corp."); + + final XMLStreamHelper streamHelper = SDOUtil.createXMLStreamHelper(hc); + final XMLOutputFactory outputFactory = XMLOutputFactory.newInstance(); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + + final XMLDocument doc = hc.getXMLHelper().createDocument(quote, TEST_NAMESPACE, "stockQuote"); + streamHelper.save(doc, streamWriter); + streamWriter.flush(); + assertEquals("fbntFlyByNightTechnology1000.01000.01000.01000.01000.01000.02000.0IBMIBM Corp.",writer.toString()); + } + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + + // Populate the meta data for the test (Stock Quote) model + final URL url = getClass().getResource(TEST_MODEL); + final InputStream inputStream = url.openStream(); + hc.getXSDHelper().define(inputStream, url.toString()); + inputStream.close(); + + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperTestCase.java new file mode 100644 index 0000000000..d63d63b5fb --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLStreamHelperTestCase.java @@ -0,0 +1,195 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStreamReader; +import java.io.StringReader; +import java.io.StringWriter; +import java.net.URL; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import javax.xml.namespace.QName; +import javax.xml.stream.XMLInputFactory; +import javax.xml.stream.XMLOutputFactory; +import javax.xml.stream.XMLStreamConstants; +import javax.xml.stream.XMLStreamException; +import javax.xml.stream.XMLStreamReader; +import javax.xml.stream.XMLStreamWriter; + +import junit.framework.Assert; +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.api.SDOUtil; +import org.apache.tuscany.sdo.api.XMLStreamHelper; + +import commonj.sdo.DataObject; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLDocument; + +public class XMLStreamHelperTestCase extends TestCase { + + private HelperContext hc; + + private XMLStreamHelper streamHelper; + + private XMLInputFactory inputFactory; + + private XMLOutputFactory outputFactory; + + private final QName module = new QName("http://foo", "module"); + + private final QName name = new QName("http://bar", "implementation.mock"); + + private final String testName = "foo-ext"; + // private String testName = "complex"; + + private String xml; + + // = "1Dummy2"; + + protected void setUp() throws Exception { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + streamHelper = SDOUtil.createXMLStreamHelper(hc); + + URL url = getClass().getClassLoader().getResource(testName + ".xsd"); + hc.getXSDHelper().define(url.openStream(), url.toExternalForm()); + url = getClass().getResource("/mixed.xsd"); + hc.getXSDHelper().define(url.openStream(), url.toString()); + + inputFactory = XMLInputFactory.newInstance(); + outputFactory = XMLOutputFactory.newInstance(); + + url = getClass().getClassLoader().getResource(testName + ".xml"); + final InputStreamReader reader = new InputStreamReader(url.openStream()); + final StringBuffer stringBuffer = new StringBuffer(); + final char buf[] = new char[1024]; + int size; + while ((size = reader.read(buf)) != -1) { + stringBuffer.append(buf, 0, size); + } + xml = stringBuffer.toString(); + reader.close(); + } + + public void testLoadObject() throws Exception { + final XMLStreamReader reader = inputFactory.createXMLStreamReader(new StringReader(xml)); + int event = reader.getEventType(); + while (!((event == XMLStreamConstants.START_ELEMENT) && reader.getName().equals(name)) && reader.hasNext()) { + event = reader.next(); + } + final DataObject dataObject = streamHelper.loadObject(reader); + Assert.assertNotNull(dataObject); + Assert.assertTrue(dataObject.getString("myAttr").equals("helloworld.HelloWorldImpl")); + } + + public void testLoadUnqualifiedObject() throws Exception { + final XMLStreamReader reader = inputFactory.createXMLStreamReader(new StringReader(xml.replaceAll("bar:", ""))); + int event = reader.getEventType(); + while (!((event == XMLStreamConstants.START_ELEMENT) && reader.getName().getLocalPart().equals(name.getLocalPart())) && reader.hasNext()) { + event = reader.next(); + } + final Map options = new HashMap(); + options.put(XMLStreamHelper.OPTION_DEFAULT_ROOT_TYPE, hc.getTypeHelper().getType(name.getNamespaceURI(), "MockImplementation")); + final DataObject dataObject = streamHelper.loadObject(reader, options); + Assert.assertNotNull(dataObject); + Assert.assertTrue(dataObject.getString("myAttr").equals("helloworld.HelloWorldImpl")); + } + + public void testLoad() throws Exception { + final XMLStreamReader reader = inputFactory.createXMLStreamReader(new StringReader(xml)); + final XMLDocument document = streamHelper.load(reader); + Assert.assertNotNull(document); + Assert.assertEquals(document.getRootElementURI(), module.getNamespaceURI()); + Assert.assertEquals(document.getRootElementName(), module.getLocalPart()); + final DataObject moduleObject = document.getRootObject(); + final List components = moduleObject.getList("component"); + final DataObject componentObject = (DataObject) components.get(0); + final DataObject implObject = componentObject.getDataObject("implementation.mock"); + Assert.assertTrue(implObject.getString("myAttr").equals("helloworld.HelloWorldImpl")); + } + + public void testSave() throws XMLStreamException { + final XMLDocument document = hc.getXMLHelper().load(xml); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + streamHelper.save(document, streamWriter); + streamWriter.flush(); + final String xmlStr = writer.toString(); + //System.out.println(xmlStr); + Assert.assertTrue(xmlStr.indexOf("myAttr=\"helloworld.HelloWorldImpl\"")!=-1); + } + + public void testSaveObject() throws XMLStreamException { + final XMLDocument document = hc.getXMLHelper().load(xml); + final DataObject moduleObject = document.getRootObject(); + final List components = moduleObject.getList("component"); + final DataObject componentObject = (DataObject) components.get(0); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + streamHelper.saveObject(componentObject, streamWriter); + streamWriter.flush(); + Assert.assertTrue(writer.toString().indexOf("myAttr=\"helloworld.HelloWorldImpl\"")!=-1); + } + + public void testSaveSequence() throws IOException, XMLStreamException { + final DataObject quote = hc.getDataFactory().create("http://www.example.com/mixed", "MixedQuote"); + quote.setString("symbol", "fbnt"); + quote.getSequence().addText(0, "testing"); + quote.getSequence().addText("more testing"); + + final StringWriter writer = new StringWriter(); + final XMLStreamWriter streamWriter = outputFactory.createXMLStreamWriter(writer); + streamHelper.saveObject(quote, streamWriter); + streamWriter.flush(); + //System.out.println(writer); + assertTrue(writer.toString().indexOf("fbnt") != -1); + } + + // Test case for TUSCANY-1788 + public void testXSIType() throws Exception { + URL ipo = getClass().getResource("/ipo.xsd"); + hc.getXSDHelper().define(ipo.openStream(), ipo.toString()); + DataObject d = hc.getDataFactory().create("http://www.example.com/IPO", "PurchaseOrderType"); + DataObject billTo = hc.getDataFactory().create("http://www.example.com/IPO", "USAddress"); + billTo.setString("city", "San Jose"); + billTo.setString("state", "CA"); + d.setDataObject("billTo", billTo); + XMLDocument ipoDoc = hc.getXMLHelper().createDocument(d, "http://www.example.com/IPO", "purchaseOrder"); + final StringWriter writer = new StringWriter(); + final XMLStreamWriter xmlWriter = outputFactory.createXMLStreamWriter(writer); + streamHelper.save(ipoDoc, xmlWriter, null); + xmlWriter.close(); + String xml = writer.toString(); + assertTrue(xml.indexOf("xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"") != -1); + assertTrue(xml.indexOf("xsi:type") != -1); + } + + protected void tearDown() throws Exception { + super.tearDown(); + } + +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLUnknownPropertiesTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLUnknownPropertiesTestCase.java new file mode 100644 index 0000000000..8824ae7f13 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XMLUnknownPropertiesTestCase.java @@ -0,0 +1,132 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.StringReader; +import java.util.HashMap; +import java.util.Map; + +import junit.framework.Assert; +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.SDOPackage; +import org.apache.tuscany.sdo.api.SDOHelper; +import org.apache.tuscany.sdo.api.SDOUtil; +import commonj.sdo.DataObject; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; + +public class XMLUnknownPropertiesTestCase extends TestCase { + XMLHelper xmlHelper; + Map options; + + protected void setUp() throws Exception { + super.setUp(); + } + + protected void tearDown() throws Exception { + super.tearDown(); + } + + // SDOUtil->SDOHelper->SDOHelperImpl->HelperContextImpl->XMLHelperImpl + public void testOptionUnknownProperties() throws IOException { + options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_LOAD_UNKNOWN_PROPERTIES, Boolean.TRUE); + + final HelperContext hc = SDOUtil.createHelperContext(true); + hc + .getXSDHelper() + .define("" + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + ""); + + final String xml = + "" + "" + + "my test data0" + + "my test data1" + + ""; + + try { + final XMLDocument xmlDoc = hc.getXMLHelper().load(new StringReader(xml), null, options);// pass + // during + // invoke + + final DataObject root = xmlDoc.getRootObject(); + assertNotSame(root.getType(), SDOPackage.eINSTANCE.getAnyTypeDataObject()); + final ByteArrayOutputStream baos = new ByteArrayOutputStream(); + hc.getXMLHelper().save(xmlDoc, baos, null); + assertTrue(baos.toString().indexOf("my test data0") != -1); + assertTrue(baos.toString().indexOf("my test data1") != -1); + } catch (final Exception e) {// (Resource.IOWrappedException featureNotFound) + e.printStackTrace(); + } + } + + public void testOptionUnknownProperties2() throws IOException { + options = new HashMap(); + options.put(SDOHelper.XMLOptions.XML_LOAD_UNKNOWN_PROPERTIES, Boolean.FALSE); + + final HelperContext hc = SDOUtil.createHelperContext(true); + hc + .getXSDHelper() + .define("" + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + "" + + ""); + + final String xml = + "" + "" + + "my test data" + + "my test data" + + ""; + + try { + final XMLDocument xmlDoc = hc.getXMLHelper().load(new StringReader(xml), null, options);// pass + // on + // invokation + final DataObject root = xmlDoc.getRootObject(); + assertNotSame(root.getType(), SDOPackage.eINSTANCE.getAnyTypeDataObject()); + fail(); + } catch (final Exception e) {// (Resource.IOWrappedException featureNotFound) + // e.printStackTrace(); + if (e.getMessage().indexOf("telem") != -1) { + Assert.assertTrue(true); + } + } + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XPathTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XPathTestCase.java new file mode 100644 index 0000000000..45f92a73b2 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XPathTestCase.java @@ -0,0 +1,125 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import commonj.sdo.DataObject; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.XMLDocument; +import commonj.sdo.helper.XMLHelper; +import commonj.sdo.helper.XSDHelper; + +public class XPathTestCase extends TestCase { + + HelperContext hc; + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + } + + private final String TEST_MODEL = "/xpath.xsd"; + private final String XPATH_XML = "/xpath.xml"; + + /** + * The presence or absence of the @ sign in a path has no meaning. + * Properties are always matched by name independent of their XML representation. + * @throws IOException + */ + public void testAtSignProperty() throws IOException { + XSDHelper xsdHelper = hc.getXSDHelper(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + xsdHelper.define(inputStream, url.toString()); + + inputStream.close(); + + XMLDocument doc = xmlHelper.load(getClass().getResourceAsStream(XPATH_XML)); + + DataObject drive = doc.getRootObject(); + DataObject folder1 = (DataObject) drive.get("Folder.1"); + String value = folder1.getString("@creation_date"); + + assertEquals(value, "2000-03-23"); + } + + public void testListIndexing() throws Exception { + XSDHelper xsdHelper = hc.getXSDHelper(); + XMLHelper xmlHelper = hc.getXMLHelper(); + + URL url = getClass().getResource(TEST_MODEL); + InputStream inputStream = url.openStream(); + xsdHelper.define(inputStream, url.toString()); + + inputStream.close(); + + XMLDocument doc = xmlHelper.load(getClass().getResourceAsStream(XPATH_XML)); + + DataObject root = doc.getRootObject(); + DataObject folder1 = root.getDataObject("Folder[1]"); + assertNotNull(folder1); + DataObject folder1a = root.getDataObject("Folder.0"); + assertEquals(folder1, folder1a); + folder1a = root.getDataObject("Folder[FolderName=Folder00000000000]"); + assertEquals(folder1, folder1a); + + DataObject noFolder = null; + + try { + noFolder = root.getDataObject("Folder[3]"); + assertNull(noFolder); + } catch (Exception e) { + assertFalse("bad indexing generated exception" + e, true); + } + + try { + noFolder = root.getDataObject("Folder[0]"); + assertNull(noFolder); + } catch (Exception e) { + assertFalse("bad indexing generated exception" + e, true); + } + + try { + noFolder = root.getDataObject("Folder.2"); + assertNull(noFolder); + } catch (Exception e) { + assertFalse("bad indexing generated exception" + e, true); + } + + try { + noFolder = root.getDataObject("Folder.-1"); + assertNull(noFolder); + } catch (Exception e) { + assertFalse("bad indexing generated exception" + e, true); + } + + noFolder = root.getDataObject("Folder[FolderName=foo]"); + assertNull(noFolder); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDHelperTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDHelperTestCase.java new file mode 100644 index 0000000000..b8d3402172 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDHelperTestCase.java @@ -0,0 +1,224 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.net.URL; +import java.util.Hashtable; +import java.util.List; +import java.util.Vector; + +import junit.framework.TestCase; + +import org.apache.tuscany.sdo.util.SDOUtil; + +import com.example.simple.SimpleFactory; +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.DataFactory; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XSDHelper; + +/** + * @version $Rev$ $Date$ + */ +public class XSDHelperTestCase extends TestCase { + private static final String TEST_MODEL = "/simple.xsd"; + private static final String TEST_MODEL2 = "/xsdCorners.xsd"; + private URL modelURL; + private URL xsdCornersURL; + + HelperContext hc; + + protected void setUp() throws Exception { + super.setUp(); + hc = SDOUtil.createHelperContext(); + modelURL = getClass().getResource(TEST_MODEL); + xsdCornersURL = getClass().getResource(TEST_MODEL2); + } + + public void testDefineWithLocation() throws IOException { + XSDHelper xsdHelper = hc.getXSDHelper(); + List types = xsdHelper.define(modelURL.openStream(), modelURL.toString()); + assertEquals(2, types.size()); + } + + public void testDefineWithNoLocation() { + XSDHelper xsdHelper = hc.getXSDHelper(); + List types = xsdHelper.define(getClass().getResourceAsStream(TEST_MODEL), null); + assertEquals(2, types.size()); + } + + public void testDuplicateDefineWithLocation() throws IOException { + XSDHelper xsdHelper = hc.getXSDHelper(); + List types = xsdHelper.define(modelURL.openStream(), modelURL.toString()); + assertEquals(2, types.size()); + + List types2 = xsdHelper.define(modelURL.openStream(), modelURL.toString()); + assertEquals(0, types2.size()); + } + + public void testXSDGeneration_staticSDOType() throws IOException + { + //test for static sdo type. The test succeeds if the IllegalArgumentException is thrown + //by XSDHelper.generate method in which case the string xsd must be null; + + SimpleFactory.INSTANCE.register(hc); + XSDHelper xsdHelper = hc.getXSDHelper(); + DataObject quoteSDO = (DataObject)SimpleFactory.INSTANCE.createQuote(); + List typeList = new Vector(); + typeList.add(quoteSDO.getType()); + String xsd = null; + + try + { + xsd = xsdHelper.generate(typeList); + xsd = ""; + } + catch ( IllegalArgumentException e ) + { + } + assertNull(xsd); + } + + public void testXSDGeneration_DynamicSDOType() throws IOException + { + //test for dynamic SDOs that have no XSD model. Here the testcase succeeds only if the + //xsd is generated by XSDHelper in which case xsd must not be null + XSDHelper xsdHelper = hc.getXSDHelper(); + DataObject quoteType = DataFactory.INSTANCE.create("commonj.sdo", "Type"); + quoteType.set("uri", "http://www.example.com/dynamic"); + quoteType.set("name", "DynamicQuote"); + + DataObject aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "symbol"); + aProperty.set("type", TypeHelper.INSTANCE.getType("commonj.sdo", "String")); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "price"); + aProperty.set("type", TypeHelper.INSTANCE.getType("commonj.sdo", "Decimal")); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "volume"); + aProperty.set("type", TypeHelper.INSTANCE.getType("commonj.sdo", "Double")); + + TypeHelper.INSTANCE.define(quoteType); + + Type dynamicQuoteType = + TypeHelper.INSTANCE.getType("http://www.example.com/dynamic", "DynamicQuote"); + + Vector types = new Vector(); + types.add(dynamicQuoteType); + String xsd = null; + + try + { + xsd = xsdHelper.generate(types); + //System.out.println(xsd); + } + catch ( IllegalArgumentException e ) + { + } + assertNotNull(xsd); + + } + + public void testXSDGeneration_DynamicWithNestedStaticSDOType() throws IOException + { + //testing static SDO with XSD Model being contained in a Dynamic SDO not having an XSD Model. + //the schema must be generated with imports / includes for the XSD corresponding to the static + //sdo types. + TypeHelper typeHelper = hc.getTypeHelper(); + XSDHelper xsdHelper = hc.getXSDHelper(); + + SimpleFactory.INSTANCE.register(hc); + DataObject quoteSDO = (DataObject)SimpleFactory.INSTANCE.createQuote(); + + + DataObject quoteType = DataFactory.INSTANCE.create("commonj.sdo", "Type"); + quoteType.set("uri", "http://www.example.com/dynamic"); + quoteType.set("name", "DynamicQuote"); + + DataObject aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "symbol"); + aProperty.set("type", typeHelper.getType("commonj.sdo", "String")); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "price"); + aProperty.set("type", typeHelper.getType("commonj.sdo", "Decimal")); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "volume"); + aProperty.set("type", typeHelper.getType("commonj.sdo", "Double")); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "containedQuotes"); + aProperty.set("type", typeHelper.getType(quoteSDO.getType().getURI(), quoteSDO.getType().getName())); + aProperty.set("containment", new Boolean(true)); + + aProperty = quoteType.createDataObject("property"); + aProperty.set("name", "referredQuotes"); + aProperty.set("type", typeHelper.getType(quoteSDO.getType().getURI(), quoteSDO.getType().getName())); + + typeHelper.define(quoteType); + + Type dynamicQuoteType = + typeHelper.getType("http://www.example.com/dynamic", "DynamicQuote"); + Vector types = new Vector(); + types.add(dynamicQuoteType); + String xsd = null; + + try + { + Hashtable schemaLocationMap = new Hashtable(); + schemaLocationMap.put("http://www.example.com/simple", "http://www.example.com/simple/xsd"); + xsd = xsdHelper.generate(types, schemaLocationMap); + //System.out.println(xsd); + } + catch ( IllegalArgumentException e ) + { + } + assertNotNull(xsd); + + } + + public void testPrefixFromNSWithHyphenNumber() throws IOException { + XSDHelper xsdHelper = hc.getXSDHelper(); + xsdHelper.define(xsdCornersURL.openStream(), xsdCornersURL.toString()); + DataFactory df = hc.getDataFactory(); + DataObject root = df.create("http://www.example.com/simple-1", "A"); + root.setString("a1", "a1s"); + root.setString("a2", "a2s"); + + String doc = hc.getXMLHelper().save(root, "http://www.example.com/simple-1", "a"); + assertTrue(doc.indexOf("xmlns:s1=\"http://www.example.com/simple-1\"") != -1); + } + + public void testShortPrefix() throws IOException { + XSDHelper xsdHelper = hc.getXSDHelper(); + URL url = getClass().getResource("/prefix.xsd"); + xsdHelper.define(url.openStream(), url.toString()); + DataObject cmd = hc.getDataFactory().create("http://soaassureservice.soabench.ibm.com", "CreateClaim"); + cmd.setString("requestInfo", "cost"); + String doc = hc.getXMLHelper().save(cmd, "http://soaassureservice.soabench.ibm.com", "createClaim"); + assertTrue(doc.indexOf("xmlns:as=\"http://soaassureservice.soabench.ibm.com\"") != -1); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDQNameTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDQNameTestCase.java new file mode 100644 index 0000000000..f369b340ed --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/XSDQNameTestCase.java @@ -0,0 +1,123 @@ +/** + * + * 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.tuscany.sdo.test; + +import java.io.IOException; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import junit.framework.TestCase; + +import commonj.sdo.DataObject; +import commonj.sdo.Type; +import commonj.sdo.helper.HelperContext; +import commonj.sdo.helper.TypeHelper; +import commonj.sdo.helper.XMLDocument; +import org.apache.tuscany.sdo.api.SDOUtil; + +public class XSDQNameTestCase extends TestCase { + private final String xsdString = + " " + + " " + + " " + + " " + + " " + + " " + + " " + + " " + + ""; + + private final String xmlString = + " " + + " " + + "fbnt " + + "simple:stockQuote " + + ""; + + private final String TEST_NAMESPACE = "http://www.example.com/simple"; + + HelperContext hc; + TypeHelper th; + + /** + * Based on Spec 2.1, section 9.4.1, the return value of DataObject.get() on XSD QName property + * should be http://www.example.com/simple#stockQuote + * TODO add this to the CTS + * + * @throws IOException + */ + public void testLoad() throws IOException { + XMLDocument doc = hc.getXMLHelper().load(xmlString); + DataObject root = doc.getRootObject(); + assertEquals("http://www.example.com/simple#stockQuote", root.get("policy")); + } + + /** + * After serialization, the value of XSD QName property in XML should be :stockQuote + */ + public void testSave() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "Quote"); + DataObject quote = hc.getDataFactory().create(quoteType); + + quote.setString("symbol", "fbnt"); + quote.set("policy", "http://www.example.com/simple#stockQuote"); + + String str = hc.getXMLHelper().save(quote, TEST_NAMESPACE, "stockQuote"); + int start = str.indexOf(""); + int end = str.indexOf(""); + assertTrue(start != -1 && end != -1); + + String policyValue = str.substring(start + "".length(), end); + + Pattern pattern = Pattern.compile(".*:stockQuote"); // prefix can be anything + + Matcher matcher = pattern.matcher(policyValue); + assertTrue(matcher.find()); + } + + /** + * Test the scenario that the xsd:QName property value contains non-existent namespace + */ + public void testSave2() throws IOException { + Type quoteType = th.getType(TEST_NAMESPACE, "Quote"); + DataObject quote = hc.getDataFactory().create(quoteType); + + quote.setString("symbol", "fbnt"); + quote.set("policy", "http://www.example.com/simple2#stockQuote"); + + String str = hc.getXMLHelper().save(quote, TEST_NAMESPACE, "stockQuote"); + + // Make sure the non-existent namespace was serialized + Pattern pattern = Pattern.compile(".*xmlns:.*=\"http://www.example.com/simple2\""); + Matcher matcher = pattern.matcher(str); + assertTrue(matcher.find()); + } + + protected void setUp() throws Exception { + super.setUp(); + + hc = SDOUtil.createHelperContext(); + th = hc.getTypeHelper(); + + hc.getXSDHelper().define(xsdString); + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/ClassLoaderTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/ClassLoaderTestCase.java new file mode 100644 index 0000000000..8fbd74ac0d --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/ClassLoaderTestCase.java @@ -0,0 +1,192 @@ +/** + * + * 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.tuscany.sdo.test.osgi; + + +import java.io.File; +import java.io.IOException; +import java.lang.reflect.Method; +import java.net.URL; +import java.net.URLClassLoader; +import java.util.HashSet; + +import org.apache.tuscany.sdo.test.AllTests; +import commonj.sdo.impl.HelperProvider; + +import junit.framework.Assert; +import junit.framework.TestCase; +import junit.framework.TestResult; +import junit.framework.TestSuite; + +/* + * This test runs the SDO implementation test suite in a multi-classloader environment + */ +public class ClassLoaderTestCase extends TestCase { + + private ClassLoader contextClassLoader; + + protected void setUp() throws Exception { + + contextClassLoader = Thread.currentThread().getContextClassLoader(); + super.setUp(); + } + + protected void tearDown() throws Exception { + super.tearDown(); + Thread.currentThread().setContextClassLoader(contextClassLoader); + } + + // Load the test class using a separate test classloader which + // loads SDO API, LIB and IMPL using different classloaders + // Run the SDO test suite under this multi-classloader environment + // Third party libraries and test classes/resources are available + // on the thread context classloader when this test is run + public void test() throws Exception { + ClassLoader testClassLoader = createTestClassLoader(); + + Class testClass = testClassLoader.loadClass(this.getClass().getName()); + Method testMethod = testClass.getMethod("runSDOTest", null); + Object testObj = testClass.newInstance(); + testMethod.invoke(testObj, null); + + + } + + + public void runSDOTest() throws Exception { + + HelperProvider.setDefaultInstance(this.getClass().getClassLoader()); + + TestSuite allTests = AllTests.suite(); + TestResult testResult = new TestResult(); + allTests.run(testResult); + Assert.assertEquals(0, testResult.errorCount()); + } + + + // Get all the URLs for a classloader, remove these from dependentJars + private URL[] getClassLoaderURLs( + URL[] classPathEntries, + HashSet dependentJars, + String[] jarList) + throws IOException { + + String pathSeparator = "/"; + HashSet classPathEntrySet; + + classPathEntrySet = new HashSet(); + + for (int i = 0; i < classPathEntries.length; i++) { + + URL classPathEntry = classPathEntries[i]; + String classPathEntryStr = classPathEntry.getPath(); + if (jarList != null) { + for (int k = 0; k < jarList.length; k++) { + String jarName = "tuscany-" + jarList[k]; + String alternateJarName = "tuscany-sdo-" + jarList[k]; + String folderName = pathSeparator + jarList[k] + pathSeparator; + if (classPathEntryStr.indexOf(jarName) >= 0 || + classPathEntryStr.indexOf(alternateJarName) >=0 || + classPathEntryStr.indexOf(folderName) >=0) { + + classPathEntrySet.add(classPathEntry); + dependentJars.remove(classPathEntry); + } + } + } + } + return (URL [])classPathEntrySet.toArray(new URL[classPathEntrySet.size()]); + } + + + // Create the test classloader. It uses separate classloaders to load SDO API, SDO LIB, + // SDO IMPL and 3rd part libraries + private ClassLoader createTestClassLoader() throws Exception { + + String[] sdoApiJars = {"sdo-api"}; + String[] sdoLibJars = {"lib"}; + String[] sdoImplJars = {"impl"}; + + URL[] sdoApiUrls; + URL[] sdoLibUrls; + URL[] sdoImplUrls; + URL[] dependencyUrls; + + if (!(this.getClass().getClassLoader() instanceof URLClassLoader)) + return this.getClass().getClassLoader(); + + HashSet dependentJars = new HashSet(); + URL[] classPathEntries = ((URLClassLoader)this.getClass().getClassLoader()).getURLs(); + for (int i = 0; i < classPathEntries.length; i++) { + dependentJars.add(classPathEntries[i]); + } + sdoApiUrls = getClassLoaderURLs(classPathEntries, dependentJars, sdoApiJars); + sdoLibUrls = getClassLoaderURLs(classPathEntries, dependentJars, sdoLibJars); + sdoImplUrls = getClassLoaderURLs(classPathEntries, dependentJars, sdoImplJars); + dependencyUrls = (URL [])dependentJars.toArray(new URL[dependentJars.size()]); + + ClassLoader dependencyLoader = new URLClassLoader(dependencyUrls, null); + ClassLoader sdoApiLoader = new URLClassLoader(sdoApiUrls, dependencyLoader); + ClassLoader sdoLibClassLoader = new URLClassLoader(sdoLibUrls, sdoApiLoader); + ClassLoader sdoImplClassLoader = new URLClassLoader(sdoImplUrls, sdoLibClassLoader); + + + TestClassLoader testClassLoader = new TestClassLoader( + new ClassLoader[] {sdoApiLoader, sdoLibClassLoader, sdoImplClassLoader, dependencyLoader} + ); + + + // Test classes and 3rd party libraries should be on the context classloader + URL testUrl = new File("./target/test-classes").toURL(); + ClassLoader contextClassLoader = new URLClassLoader(new URL[]{testUrl}, dependencyLoader); + Thread.currentThread().setContextClassLoader(contextClassLoader); + + return testClassLoader; + } + + + + private class TestClassLoader extends ClassLoader { + + ClassLoader[] parentLoaders; + + private TestClassLoader(ClassLoader[] parentLoaders) { + this.parentLoaders = parentLoaders; + } + + public Class loadClass(String className) throws ClassNotFoundException { + + Class clazz = findLoadedClass(className); + if (clazz != null) + return clazz; + + for (int i = 0; i < parentLoaders.length; i++) { + try { + return parentLoaders[i].loadClass(className); + } catch (Exception e) { + // speculative load using parent class loader failed, but that's OK + } + } + return super.loadClass(className); + } + + + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/OSGiTestCase.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/OSGiTestCase.java new file mode 100644 index 0000000000..5a67fc41c5 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/OSGiTestCase.java @@ -0,0 +1,354 @@ +/** + * + * 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.tuscany.sdo.test.osgi; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.File; +import java.io.FileInputStream; +import java.io.FilenameFilter; +import java.net.URL; +import java.net.URLClassLoader; +import java.util.ArrayList; +import java.util.List; +import java.util.Properties; +import java.util.jar.Attributes; +import java.util.jar.JarEntry; +import java.util.jar.JarInputStream; +import java.util.jar.JarOutputStream; +import java.util.jar.Manifest; +import java.util.zip.ZipEntry; + +import org.apache.felix.framework.Felix; +import org.apache.felix.main.Main; +import org.osgi.framework.Bundle; +import org.osgi.framework.BundleContext; + +import junit.framework.TestCase; + +/* + * This test runs the SDO implementation test suite under a Felix OSGi runtime + */ +public class OSGiTestCase extends TestCase { + + private Felix felix; + private BundleContext bundleContext; + private ClassLoader contextClassLoader; + + protected void setUp() throws Exception { + + contextClassLoader = Thread.currentThread().getContextClassLoader(); + + super.setUp(); + + // Start a Felix OSGi runtime + File profileDir = new File(".felix"); + if (profileDir.isDirectory()) + deleteDirectory(profileDir); + else + profileDir.delete(); + profileDir.mkdir(); + + Properties props = Main.loadConfigProperties(); + props.put("felix.cache.profiledir", profileDir.getAbsolutePath()); + props.put("felix.embedded.execution", "true"); + props.put("org.osgi.framework.system.packages", + "org.osgi.framework; version=1.3.0," + + "org.osgi.service.packageadmin; version=1.2.0, " + + "org.osgi.service.startlevel; version=1.0.0, " + + "org.osgi.service.url; version=1.0.0, " + "javax.xml, " + + "javax.xml.parsers, " + "javax.xml.namespace, " + + "org.xml.sax, " + "org.xml.sax.helpers, " + "org.xml.sax.ext, " + + "org.w3c.dom, " + "org.w3c.dom.events, " + "javax.xml.stream, " + + "javax.xml.transform, " + "javax.xml.transform.dom, " + + "javax.xml.transform.stream, " + "org.objectweb.asm, " + + "junit.framework"); + + List activators = new ArrayList(); + Felix felix = new Felix(props, activators); + felix.start(); + bundleContext = felix.getBundleContext(); + } + + protected void tearDown() throws Exception { + + super.tearDown(); + Thread.currentThread().setContextClassLoader(contextClassLoader); + + if (felix != null) { + felix.stop(); + felix = null; + } + } + + // Install SDO spec, SDO lib, SDO impl, and its EMF dependencies + // Create a test bundle containing all the SDO tests, and run the entire + // test suite inside an OSGi container + public void test() throws Exception { + + ArrayList bundles = new ArrayList(); + FilenameFilter jarFileFilter = new JarFileFilter(); + + File apiDir = new File("../sdo-api/target"); + File[] apiJars = apiDir.listFiles(jarFileFilter); + for (int i = 0; i < apiJars.length; i++) { + Bundle bundle = bundleContext + .installBundle(apiJars[i].toURL().toString()); + bundles.add(bundle); + } + + File libDir = new File("../lib/target"); + File[] libJars = libDir.listFiles(jarFileFilter); + for (int i = 0; i < libJars.length; i++) { + Bundle bundle = bundleContext + .installBundle(libJars[i].toURL().toString()); + bundles.add(bundle); + } + + if (!(contextClassLoader instanceof URLClassLoader)) + return; + + URL[] classPathURLs = ((URLClassLoader) contextClassLoader).getURLs(); + for (int i = 0; i < classPathURLs.length; i++) { + String url = classPathURLs[i].toString(); + if (url.indexOf("eclipse") > 0 && url.endsWith(".jar")) { + Bundle bundle = installEclipseBundle(classPathURLs[i]); + if (bundle != null) + bundles.add(bundle); + } + } + + // When this test is run during the build, sdo.impl.jar would not yet have + // been created + // Create this bundle - use the manifest file provided in the test + // directory, which works + // with Felix. + Bundle implBundle = installBundle("file:sdo.impl", + "../impl/target/test-classes/osgi/sdo.impl.mf", + new String[] { "../impl/target/classes" }); + bundles.add(implBundle); + + // Start all the installed bundles + for (int i = 0; i < bundles.size(); i++) { + Bundle bundle = (Bundle) bundles.get(i); + try { + bundle.start(); + } catch (Exception e) { + e.printStackTrace(); + System.out.println("Could not start bundle " + bundle); + // don't stop on first failure, so we document all failures + // any failure will be re-triggered by the testBundle.start() call below + } + } + + // Install the test bundle - it contains all the test classes. The bundle + // activator for + // this class runs the entire test suite + Bundle testBundle = installBundle("file:sdo.osgi.test", + "../impl/target/test-classes/osgi/sdo.osgi.test.mf", + new String[] { "../impl/target/test-classes" }); + + TestClassLoader testClassLoader = new TestClassLoader(testBundle, + contextClassLoader); + Thread.currentThread().setContextClassLoader(testClassLoader); + + // The test suite is run inside an OSGi container by this call. + testBundle.start(); + } + + // Delete any old Felix configuration files left over from previous runs + private static void deleteDirectory(File dir) { + + File[] files = dir.listFiles(); + for (int i = 0; i < files.length; i++) { + if (files[i].isDirectory()) + deleteDirectory(files[i]); + else + files[i].delete(); + } + dir.delete(); + + } + + // Create and install a bundle with the specified manifest file + // The bundle contains all files from the list of directories specified + public Bundle installBundle(String bundleLocation, String manifestFileName, + String[] dirNames) throws Exception { + + ByteArrayOutputStream out = new ByteArrayOutputStream(); + + File manifestFile = new File(manifestFileName); + Manifest manifest = new Manifest(); + manifest.read(new FileInputStream(manifestFile)); + + JarOutputStream jarOut = new JarOutputStream(out, manifest); + + for (int i = 0; i < dirNames.length; i++) { + File dir = new File(dirNames[i]); + addFilesToJar(dir, dirNames[i], jarOut); + } + + jarOut.close(); + out.close(); + + ByteArrayInputStream inStream = new ByteArrayInputStream(out.toByteArray()); + return bundleContext.installBundle(bundleLocation, inStream); + + } + + // Add all the files from a build directory into a jar file + // This method is used to create bundles on the fly + private void addFilesToJar(File dir, String rootDirName, + JarOutputStream jarOut) throws Exception { + + if (dir.getName().equals(".svn")) + return; + + File[] files = dir.listFiles(); + + for (int i = 0; i < files.length; i++) { + + if (files[i].isDirectory()) { + addFilesToJar(files[i], rootDirName, jarOut); + continue; + } + if (files[i].getName().endsWith("MANIFEST.MF")) + continue; + + String entryName = files[i].getPath().substring(rootDirName.length() + 1); + entryName = entryName.replaceAll("\\\\", "/"); + ZipEntry ze = new ZipEntry(entryName); + + jarOut.putNextEntry(ze); + FileInputStream file = new FileInputStream(files[i]); + byte[] fileContents = new byte[file.available()]; + file.read(fileContents); + jarOut.write(fileContents); + } + } + + // Install a bundle corresponding to an jar file from Eclipse (eg. EMF jars) + // These bundle manifest entries use Require-Bundle of + // eclipse core runtime. The Plugin class from the Eclipse runtime + // is loaded by the bundle activator of some of these bundles. + // Since this test is run under Felix, remove the dependency on + // Eclipse runtime by removing the Require-Bundle and + // Bundle-Activator entries from the manifest + private Bundle installEclipseBundle(URL jarURL) throws Exception { + + JarInputStream jarInput = new JarInputStream(jarURL.openStream()); + + Manifest manifest = jarInput.getManifest(); + if (manifest == null) { + manifest = new Manifest(); + ZipEntry entry; + while ((entry = jarInput.getNextEntry()) != null) { + if (entry.getName().equals("META-INF/MANIFEST.MF")) { + byte bytes[] = new byte[(int) entry.getSize()]; + jarInput.read(bytes); + manifest.read(new ByteArrayInputStream(bytes)); + } + } + jarInput.close(); + jarInput = new JarInputStream(jarURL.openStream()); + } + if (manifest == null + || manifest.getMainAttributes() == null + || !manifest.getMainAttributes().containsKey( + new Attributes.Name("Bundle-SymbolicName"))) { + + return null; + } + manifest.getMainAttributes().remove(new Attributes.Name("Require-Bundle")); + manifest.getMainAttributes() + .remove(new Attributes.Name("Bundle-Activator")); + manifest.getMainAttributes().put( + new Attributes.Name("DynamicImport-Package"), "*"); + + ByteArrayOutputStream out = new ByteArrayOutputStream(); + + JarOutputStream jarOut = new JarOutputStream(out, manifest); + ZipEntry entry; + byte bytes[] = new byte[1024]; + while ((entry = jarInput.getNextEntry()) != null) { + if (!entry.getName().equals("META-INF/MANIFEST.MF")) { + jarOut.putNextEntry((JarEntry) entry); + int len; + while ((len = jarInput.read(bytes)) != -1) { + jarOut.write(bytes, 0, len); + } + jarOut.closeEntry(); + } + jarInput.closeEntry(); + } + jarOut.close(); + out.close(); + jarInput.close(); + + ByteArrayInputStream byteStream = new ByteArrayInputStream(out + .toByteArray()); + + return bundleContext.installBundle(jarURL.toString(), byteStream); + + } + + // Filter used to list jar files from a directory + private class JarFileFilter implements FilenameFilter { + + public boolean accept(File dir, String name) { + if (name.endsWith(".jar") && !name.endsWith("javadoc.jar")) + return true; + else + return false; + } + + } + + // Test classloader - used as context classloader + private static class TestClassLoader extends ClassLoader { + + Bundle testBundle; + + private TestClassLoader(Bundle testBundle, ClassLoader parentClassLoader) { + super(parentClassLoader); + this.testBundle = testBundle; + } + + public Class loadClass(String className) throws ClassNotFoundException { + Class clazz = findLoadedClass(className); + if (clazz != null) + return clazz; + + try { + return testBundle.loadClass(className); + } catch (Exception e) { + } + return super.loadClass(className); + } + + public URL getResource(String resName) { + URL resource = testBundle.getResource(resName); + if (resource == null) + resource = super.getResource(resName); + return resource; + } + + } +} diff --git a/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/TestBundleActivator.java b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/TestBundleActivator.java new file mode 100644 index 0000000000..4458a13959 --- /dev/null +++ b/sdo-java/trunk/impl/src/test/java/org/apache/tuscany/sdo/test/osgi/TestBundleActivator.java @@ -0,0 +1,66 @@ +package org.apache.tuscany.sdo.test.osgi; +/** + * + * 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. + */ +import java.util.Enumeration; + +import junit.framework.Assert; +import junit.framework.Test; +import junit.framework.TestFailure; +import junit.framework.TestResult; + +import org.apache.tuscany.sdo.AllTests; +import org.osgi.framework.BundleActivator; +import org.osgi.framework.BundleContext; + + +/* + * Bundle activator for running the SDO test suite under OSGi + * The SDO test suite is run inside an OSGi container when the bundle is started. + */ +public class TestBundleActivator implements BundleActivator { + + public void start(BundleContext bundleContext) throws Exception { + runSDOTests(); + } + + public void stop(BundleContext bundleContext) throws Exception { + + } + + + public void runSDOTests() throws Exception { + + Test allTests = AllTests.suite(); + TestResult testResult = new TestResult(); + allTests.run(testResult); + System.out.println("Runs " + testResult.runCount() + ", Errors: " + + testResult.errorCount()); + + Enumeration e = testResult.errors(); + while (e.hasMoreElements()) { + TestFailure f = (TestFailure) e.nextElement(); + System.out.println(f); + System.out.println(f.exceptionMessage()); + } + + Assert.assertEquals(0, testResult.errorCount()); + + } +} -- cgit v1.2.3