From 6d0e93c68d3aeaeb4bb6d96ac0460eec40ef786e Mon Sep 17 00:00:00 2001 From: lresende Date: Wed, 11 Nov 2009 23:13:23 +0000 Subject: Moving 1.x branches git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@835143 13f79535-47bb-0310-9956-ffa450edef68 --- .../containers/container.javascript/LICENSE.txt | 202 ---- .../containers/container.javascript/NOTICE.txt | 14 - .../containers/container.javascript/pom.xml | 105 -- .../container/javascript/JavaScriptComponent.java | 120 --- .../javascript/JavaScriptComponentBuilder.java | 152 --- .../javascript/JavaScriptComponentType.java | 57 - .../javascript/JavaScriptComponentTypeLoader.java | 113 -- .../javascript/JavaScriptImplementation.java | 38 - .../javascript/JavaScriptImplementationLoader.java | 111 -- .../javascript/JavaScriptIntrospector.java | 173 --- .../container/javascript/JavaScriptInvoker.java | 53 - .../javascript/JavaScriptRefInvocInterceptor.java | 132 --- .../javascript/JavaScriptReferenceProxy.java | 132 --- .../javascript/rhino/RhinoFunctionInvoker.java | 123 --- .../container/javascript/rhino/RhinoSCAConfig.java | 157 --- .../container/javascript/rhino/RhinoScript.java | 210 ---- .../javascript/rhino/RhinoScriptInstance.java | 109 -- .../utils/xmlfromxsd/CmdLineArgsHandler.java | 28 - .../utils/xmlfromxsd/CmdLineArgsProcessor.java | 79 -- .../utils/xmlfromxsd/TuscanySampleXmlUtil.java | 1097 -------------------- .../utils/xmlfromxsd/XBbasedXMLGenerator.java | 253 ----- .../javascript/utils/xmlfromxsd/XMLGenerator.java | 52 - .../utils/xmlfromxsd/XMLGeneratorFactory.java | 55 - .../utils/xmlfromxsd/XMLfromXSDConfiguration.java | 246 ----- .../utils/xmlfromxsd/XMLfromXSDGenerator.java | 82 -- .../xmlfromxsd/XmlInstanceCreationException.java | 34 - .../utils/xmlfromxsd/XmlInstanceRegistry.java | 31 - .../utils/xmlfromxsd/XmlInstanceRegistryImpl.java | 68 -- .../src/main/resources/META-INF/sca/default.scdl | 51 - .../src/main/resources/META-INF/sca/js.system.scdl | 45 - .../test/java/helloworld/HelloWorldService.java | 27 - .../java/helloworld/HelloWorldServiceImpl.java | 55 - .../JavaScriptImplementationLoaderTestCase.java | 107 -- .../container/javascript/PropertyTestCase.java | 65 -- .../RhinoScriptIntrospectorTestCase.java | 114 -- .../container/javascript/ScriptInvokeTestCase.java | 61 -- .../tuscany/container/javascript/WireTestCase.java | 161 --- .../javascript/function/HelloWorldTestCase.java | 104 -- .../javascript/function/ScopeTestCase.java | 65 -- .../container/javascript/mock/Greeting.java | 26 - .../tuscany/container/javascript/rhino/Foo.java | 34 - .../rhino/RhinoFunctionInvokerTestCase.java | 174 ---- .../javascript/rhino/RhinoSCAConfigTestCase.java | 116 --- .../rhino/RhinoScriptInstanceTestCase.java | 50 - .../javascript/rhino/RhinoScriptTestCase.java | 83 -- .../xmlfromxsd/XMLfromXSDGeneratorTestCase.java | 129 --- .../src/test/resources/AccountService.wsdl | 242 ----- .../src/test/resources/interopdoc.wsdl | 180 ---- .../javascript/function/HelloWorld.componentType | 26 - .../container/javascript/function/HelloWorld.js | 21 - .../function/IntrospectableHelloWorld.js | 25 - .../javascript/function/compositeScope.js | 29 - .../javascript/function/e4x.componentType | 33 - .../tuscany/container/javascript/function/e4x.js | 45 - .../container/javascript/function/helloworld.scdl | 50 - .../javascript/function/propertyTest.componentType | 28 - .../container/javascript/function/propertyTest.js | 21 - .../container/javascript/function/requestScope.js | 30 - .../container/javascript/function/scopeTest.scdl | 37 - .../javascript/function/statelessScope.js | 29 - .../tuscany/container/javascript/mock/test.js | 1 - .../container/javascript/rhino/helloworld.wsdl | 78 -- .../src/test/resources/sequences.xsd | 100 -- 63 files changed, 6468 deletions(-) delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/LICENSE.txt delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/NOTICE.txt delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/pom.xml delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponent.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentBuilder.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentType.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentTypeLoader.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementation.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoader.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptIntrospector.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptInvoker.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptRefInvocInterceptor.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptReferenceProxy.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvoker.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfig.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScript.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstance.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsHandler.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsProcessor.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/TuscanySampleXmlUtil.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XBbasedXMLGenerator.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGenerator.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGeneratorFactory.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDConfiguration.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGenerator.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceCreationException.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistry.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistryImpl.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/default.scdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/js.system.scdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldService.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldServiceImpl.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoaderTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/PropertyTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/RhinoScriptIntrospectorTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/ScriptInvokeTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/WireTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/HelloWorldTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/ScopeTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/mock/Greeting.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/Foo.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvokerTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfigTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstanceTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGeneratorTestCase.java delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/AccountService.wsdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/interopdoc.wsdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.componentType delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/IntrospectableHelloWorld.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/compositeScope.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.componentType delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/helloworld.scdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.componentType delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/requestScope.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/scopeTest.scdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/statelessScope.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/mock/test.js delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/rhino/helloworld.wsdl delete mode 100644 branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/sequences.xsd (limited to 'branches/sca-java-M2/sca/services/containers/container.javascript') diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/LICENSE.txt b/branches/sca-java-M2/sca/services/containers/container.javascript/LICENSE.txt deleted file mode 100644 index d645695673..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/LICENSE.txt +++ /dev/null @@ -1,202 +0,0 @@ - - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - - APPENDIX: How to apply the Apache License to your work. - - To apply the Apache License to your work, attach the following - boilerplate notice, with the fields enclosed by brackets "[]" - replaced with your own identifying information. (Don't include - the brackets!) The text should be enclosed in the appropriate - comment syntax for the file format. We also recommend that a - file or class name and description of purpose be included on the - same "printed page" as the copyright notice for easier - identification within third-party archives. - - Copyright [yyyy] [name of copyright owner] - - 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. diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/NOTICE.txt b/branches/sca-java-M2/sca/services/containers/container.javascript/NOTICE.txt deleted file mode 100644 index d83ebbe236..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/NOTICE.txt +++ /dev/null @@ -1,14 +0,0 @@ -${pom.name} -Copyright (c) 2005 - 2006 The Apache Software Foundation - -Apache Tuscany is an effort undergoing incubation at The Apache Software -Foundation (ASF), sponsored by the Apache Web Services PMC. Incubation is -required of all newly accepted projects until a further review indicates that -the infrastructure, communications, and decision making process have stabilized -in a manner consistent with other successful ASF projects. While incubation -status is not necessarily a reflection of the completeness or stability of the -code, it does indicate that the project has yet to be fully endorsed by the ASF. - -This product includes software developed by -The Apache Software Foundation (http://www.apache.org/). - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/pom.xml b/branches/sca-java-M2/sca/services/containers/container.javascript/pom.xml deleted file mode 100644 index f01f232c8f..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/pom.xml +++ /dev/null @@ -1,105 +0,0 @@ - - - - - - org.apache.tuscany.sca.services.containers - parent - 1.0-incubator-M2-SNAPSHOT - - - 4.0.0 - javascript - Apache Tuscany JavaScript Container - Apache Tuscany JavaScript Container - - - - - org.apache.tuscany.sca.kernel - core - ${sca.version} - test - - - - org.apache.tuscany.sca.services.idl - wsdl - ${sca.version} - compile - - - - rhino - js - 1.6R2 - compile - - - - xmlbeans - xbean - 2.1.0 - compile - - - - org.apache.tuscany.sca - test - ${sca.version} - test - - - - org.easymock - easymock - - - org.easymock - easymockclassextension - - - org.apache.ws.commons.axiom - axiom-api - - - org.apache.ws.commons.axiom - axiom-impl - - - commons-logging - commons-logging - 1.1 - test - - - woodstox - wstx-asl - - - cglib - cglib-nodep - 2.1_3 - compile - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponent.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponent.java deleted file mode 100644 index 9872788a05..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponent.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * 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.container.javascript; - -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import org.apache.tuscany.spi.ObjectCreationException; -import org.apache.tuscany.spi.component.CompositeComponent; -import org.apache.tuscany.spi.component.ScopeContainer; -import org.apache.tuscany.spi.component.TargetException; -import org.apache.tuscany.spi.component.WorkContext; -import org.apache.tuscany.spi.extension.AtomicComponentExtension; -import org.apache.tuscany.spi.model.Operation; -import org.apache.tuscany.spi.wire.InboundWire; -import org.apache.tuscany.spi.wire.OutboundWire; -import org.apache.tuscany.spi.wire.TargetInvoker; -import org.apache.tuscany.spi.wire.WireService; - -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.container.javascript.rhino.RhinoScriptInstance; - -/** - * The JavaScript component implementation. - */ -public class JavaScriptComponent extends AtomicComponentExtension { - - private final List> services; - - private final Map properties; - - private RhinoScript rhinoScript; - - public JavaScriptComponent(String name, RhinoScript rhinoScript, Map properties, List> services, - CompositeComponent parent, ScopeContainer scopeContainer, WireService wireService, - WorkContext workContext) { - super(name, parent, scopeContainer, wireService, workContext, null, 0); - - this.rhinoScript = rhinoScript; - this.services = services; - this.scope = scopeContainer.getScope(); - this.properties = properties; - } - - public Object createInstance() throws ObjectCreationException { - - Map context = new HashMap(getProperties()); - - for (List referenceWires : getOutboundWires().values()) { - for (OutboundWire wire : referenceWires) { - Object wireProxy = wireService.createProxy(wire); - //since all types that may be used in the reference interface may not be known to Rhino - //using the wireProxy as is will fail result in type conversion exceptions in cases where - //Rhino does not know enough of the tpypes used. Hence introduce a interceptor proxy, - //with weak typing (java.lang.Object) so that Rhino's call to the proxy succeeds. Then - //within this interceptor proxy perform data mediations required to correctly call the - //referenced service. - Class businessInterface = wire.getServiceContract().getInterfaceClass(); - JavaScriptReferenceProxy interceptingProxy = - new JavaScriptReferenceProxy(businessInterface, - wireProxy, - rhinoScript.createInstanceScope(context)); - context.put(wire.getReferenceName(), interceptingProxy.createProxy()); - - } - } - - return rhinoScript.createRhinoScriptInstance(context); - } - - public TargetInvoker createTargetInvoker(String targetName, Operation operation) { - return new JavaScriptInvoker(operation.getName(), (Class)operation.getOutputType().getLogical(), this); - } - - // TODO: move all the following up to AtomicComponentExtension? - - public List> getServiceInterfaces() { - return services; - } - - public Map getProperties() { - return properties; - } - - public RhinoScriptInstance getTargetInstance() throws TargetException { - return (RhinoScriptInstance) scopeContainer.getInstance(this); - } - - public Object getServiceInstance() throws TargetException { - return getServiceInstance(null); - } - - public Object getServiceInstance(String service) throws TargetException { - InboundWire wire = getInboundWire(service); - if (wire == null) { - TargetException e = new TargetException("ServiceDefinition not found"); // TODO better error message - e.setIdentifier(service); - throw e; - } - return wireService.createProxy(wire); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentBuilder.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentBuilder.java deleted file mode 100644 index 1987026e59..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentBuilder.java +++ /dev/null @@ -1,152 +0,0 @@ -/* - * 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.container.javascript; - -import java.util.ArrayList; -import java.util.Collection; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.container.javascript.utils.xmlfromxsd.XmlInstanceRegistry; -import org.apache.tuscany.spi.annotation.Autowire; -import org.apache.tuscany.spi.builder.BuilderConfigException; -import org.apache.tuscany.spi.component.Component; -import org.apache.tuscany.spi.component.CompositeComponent; -import org.apache.tuscany.spi.component.ScopeContainer; -import org.apache.tuscany.spi.deployer.DeploymentContext; -import org.apache.tuscany.spi.extension.ComponentBuilderExtension; -import org.apache.tuscany.spi.model.ComponentDefinition; -import org.apache.tuscany.spi.model.PropertyValue; -import org.apache.tuscany.spi.model.Scope; -import org.apache.tuscany.spi.model.ServiceDefinition; -import org.apache.xmlbeans.XmlObject; -import org.osoa.sca.annotations.Constructor; - -/** - * Extension point for creating {@link JavaScriptComponent}s from an assembly configuration - */ -public class JavaScriptComponentBuilder extends ComponentBuilderExtension { - - private static String head = "var xmlInstanceMap = new Array();"; - - private static String part1 = "xmlInstanceMap[\""; - - private static String part2 = "\"] = "; - - private static String part3 = ";"; - - private static String getXmlObjectFunction = - "function getXmlObject(xmlElementNamespace, xmlElementName){\n" + - "return xmlInstanceMap[xmlElementNamespace + \"#\" + xmlElementName];\n}"; - - XmlInstanceRegistry xmlInstRegistry; - - @Constructor({"xmlInstRegistry"}) - public JavaScriptComponentBuilder(@Autowire XmlInstanceRegistry reg) { - this.xmlInstRegistry = reg; - } - - protected Class getImplementationType() { - return JavaScriptImplementation.class; - } - - @SuppressWarnings("unchecked") - public Component build(CompositeComponent parent, ComponentDefinition componentDefinition, - DeploymentContext deploymentContext) throws BuilderConfigException { - - String name = componentDefinition.getName(); - JavaScriptImplementation implementation = componentDefinition.getImplementation(); - JavaScriptComponentType componentType = implementation.getComponentType(); - - // get list of services provided by this component - Collection collection = componentType.getServices().values(); - List> services = new ArrayList>(collection.size()); - for (ServiceDefinition serviceDefinition : collection) { - services.add(serviceDefinition.getServiceContract().getInterfaceClass()); - //do this for the set of references also - enhanceRhinoScript(serviceDefinition, implementation); - } - - // get the properties for the component - Collection> propertyValues = componentDefinition.getPropertyValues().values(); - Map properties = new HashMap(); - for (PropertyValue propertyValue : propertyValues) { - properties.put(propertyValue.getName(), propertyValue.getValueFactory().getInstance()); - } - - RhinoScript rhinoScript = implementation.getRhinoScript(); - - // TODO: have ComponentBuilderExtension pass ScopeContainer in on build method? - ScopeContainer scopeContainer; - Scope scope = componentType.getLifecycleScope(); - if (Scope.MODULE == scope) { - scopeContainer = deploymentContext.getModuleScope(); - } else { - scopeContainer = scopeRegistry.getScopeContainer(scope); - } - - return new JavaScriptComponent(name, rhinoScript, properties, services, parent, scopeContainer, wireService, workContext); - } - - private void enhanceRhinoScript(ServiceDefinition serviceDefn, JavaScriptImplementation implementation) throws BuilderConfigException { - //if the service interface of the component is a wsdl get the wsdl interface and generate - //xml instances for the elements in it. Add these xml instances to the rhinoscript. - //TODO : when interface.wsdl and wsdl registry is integrated remove this hardcoding and - //obtain wsdl from the interface.wsdl or wsdl registry - String wsdlPath = "org/apache/tuscany/container/javascript/rhino/helloworld.wsdl"; - - //this if block is a tempfix to get other testcases working. Again when a the interface.wsdl - //extension is in place this will be deleted. Right now this is the only way we know that - //a js has to do with an interface that is wsdl. - if (!implementation.getRhinoScript().getScriptName().endsWith("e4x.js")) { - return; - } - - try { - Map xmlInstanceMap = xmlInstRegistry.getXmlInstance(wsdlPath); - StringBuffer sb = new StringBuffer(); - - sb.append(head); - sb.append("\n"); - for (String xmlInstanceKey : xmlInstanceMap.keySet()) { - sb.append(part1); - sb.append(xmlInstanceKey); - sb.append(part2); - sb.append(xmlInstanceMap.get(xmlInstanceKey).toString()); - sb.append(part3); - sb.append("\n"); - } - // System.out.println(" **** - " + sb.toString()); - - sb.append(getXmlObjectFunction); - - RhinoScript rhinoScript = implementation.getRhinoScript(); - sb.append(rhinoScript.getScript()); - rhinoScript.setScript(sb.toString()); - rhinoScript.initScriptScope(rhinoScript.getScriptName(), sb.toString(), null, rhinoScript.getClassLoader()); - implementation.setRhinoScript(rhinoScript); - - } catch (Exception e) { - throw new BuilderConfigException(e); - } - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentType.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentType.java deleted file mode 100644 index 31a4db14b6..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentType.java +++ /dev/null @@ -1,57 +0,0 @@ -/* - * 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.container.javascript; - -import org.apache.tuscany.spi.model.ComponentType; -import org.apache.tuscany.spi.model.Property; -import org.apache.tuscany.spi.model.ReferenceDefinition; -import org.apache.tuscany.spi.model.Scope; -import org.apache.tuscany.spi.model.ServiceDefinition; - -public class JavaScriptComponentType extends ComponentType> { - - private Scope lifecycleScope = Scope.MODULE; - - public JavaScriptComponentType() { - } - - @SuppressWarnings("unchecked") - public JavaScriptComponentType(ComponentType ct) { - // TODO: A bit hacky but this is so the non-JavaScript .componentType side file can be used for now - setInitLevel(ct.getInitLevel()); - for (Object property : ct.getProperties().values()) { - add((Property)property); - } - for (Object reference : ct.getReferences().values()) { - add((ReferenceDefinition)reference); - } - for (Object service : ct.getServices().values()) { - add((ServiceDefinition)service); - } - } - - public Scope getLifecycleScope() { - return lifecycleScope; - } - - public void setLifecycleScope(Scope lifecycleScope) { - this.lifecycleScope = lifecycleScope; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentTypeLoader.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentTypeLoader.java deleted file mode 100644 index e28daeceb0..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptComponentTypeLoader.java +++ /dev/null @@ -1,113 +0,0 @@ -/* - * 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.container.javascript; - -import java.net.URL; - -import org.apache.tuscany.spi.annotation.Autowire; -import org.apache.tuscany.spi.component.CompositeComponent; -import org.apache.tuscany.spi.deployer.DeploymentContext; -import org.apache.tuscany.spi.extension.ComponentTypeLoaderExtension; -import org.apache.tuscany.spi.idl.InvalidServiceContractException; -import org.apache.tuscany.spi.idl.java.JavaInterfaceProcessorRegistry; -import org.apache.tuscany.spi.loader.LoaderException; -import org.apache.tuscany.spi.loader.MissingResourceException; -import org.apache.tuscany.spi.model.ComponentType; - -import org.apache.tuscany.container.javascript.rhino.RhinoSCAConfig; -import org.apache.tuscany.container.javascript.rhino.RhinoScript; - -/** - * @version $Rev$ $Date$ - */ -public class JavaScriptComponentTypeLoader extends ComponentTypeLoaderExtension { - - private JavaInterfaceProcessorRegistry processorRegistry; - - public JavaScriptComponentTypeLoader(@Autowire JavaInterfaceProcessorRegistry processorRegistry) { - this.processorRegistry = processorRegistry; - } - - @Override - protected Class getImplementationClass() { - return JavaScriptImplementation.class; - } - - protected JavaScriptComponentType loadByIntrospection(CompositeComponent parent, - JavaScriptImplementation implementation, - DeploymentContext deploymentContext) throws - MissingResourceException, - InvalidServiceContractException { - - RhinoScript rhinoScript = implementation.getRhinoScript(); - RhinoSCAConfig scaConfig = rhinoScript.getSCAConfig(); - if (!scaConfig.hasSCAConfig()) { - throw new IllegalArgumentException( - "must use either .componentType side file or JS SCA varriable definition"); - } - - // FIXME this should be a system service, not instantiated here - JavaScriptComponentType componentType = new JavaScriptIntrospector(null, processorRegistry) - .introspectScript(scaConfig, rhinoScript.getClassLoader()); - - return componentType; - } - - protected String getResourceName(JavaScriptImplementation implementation) { - return implementation.getRhinoScript().getScriptName(); - } - - // TODO: must be possible to move all the following up in to ComponentTypeLoaderExtension - - public void load(CompositeComponent parent, JavaScriptImplementation implementation, - DeploymentContext deploymentContext) - throws LoaderException { - - URL resource = implementation.getRhinoScript().getClassLoader().getResource(getSideFileName(implementation)); - JavaScriptComponentType componentType; - if (resource == null) { - try { - componentType = loadByIntrospection(parent, implementation, deploymentContext); - } catch (InvalidServiceContractException e) { - throw new LoaderException("Invalid service contract", e); - } - } else { - componentType = loadFromSidefile(resource, deploymentContext); - } - - implementation.setComponentType(componentType); - } - - protected JavaScriptComponentType loadFromSidefile(URL url, DeploymentContext deploymentContext) - throws LoaderException { - ComponentType ct = loaderRegistry.load(null, url, ComponentType.class, deploymentContext); - JavaScriptComponentType jsct = new JavaScriptComponentType(ct); - return jsct; - } - - private String getSideFileName(JavaScriptImplementation implementation) { - String baseName = getResourceName(implementation); - int lastDot = baseName.lastIndexOf('.'); - if (lastDot != -1) { - baseName = baseName.substring(0, lastDot); - } - return baseName + ".componentType"; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementation.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementation.java deleted file mode 100644 index 7de479f096..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementation.java +++ /dev/null @@ -1,38 +0,0 @@ -/* - * 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.container.javascript; - -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.spi.model.AtomicImplementation; - -/** - * Model object for a JavaScript implementation. - */ -public class JavaScriptImplementation extends AtomicImplementation { - - private RhinoScript rhinoScript; - - public RhinoScript getRhinoScript() { - return rhinoScript; - } - - public void setRhinoScript(RhinoScript rhinoScript) { - this.rhinoScript = rhinoScript; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoader.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoader.java deleted file mode 100644 index 67cc35afc2..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoader.java +++ /dev/null @@ -1,111 +0,0 @@ -/* - * 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.container.javascript; - -import java.io.IOException; -import java.io.InputStream; -import java.io.InputStreamReader; -import java.io.Reader; -import java.net.URL; -import javax.xml.namespace.QName; -import javax.xml.stream.XMLStreamException; -import javax.xml.stream.XMLStreamReader; - -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.spi.annotation.Autowire; -import org.apache.tuscany.spi.component.CompositeComponent; -import org.apache.tuscany.spi.deployer.DeploymentContext; -import org.apache.tuscany.spi.extension.LoaderExtension; -import org.apache.tuscany.spi.loader.LoaderException; -import org.apache.tuscany.spi.loader.LoaderRegistry; -import org.apache.tuscany.spi.loader.LoaderUtil; -import org.apache.tuscany.spi.loader.MissingResourceException; -import org.osoa.sca.annotations.Constructor; - -/** - * Loader for handling JavaScript elements. - */ -public class JavaScriptImplementationLoader extends LoaderExtension { - private static final QName IMPLEMENTATION_JAVASCRIPT = - new QName("http://incubator.apache.org/tuscany/xmlns/container/js/1.0-incubator-M2", "implementation.js"); - - @Constructor({"registry"}) - public JavaScriptImplementationLoader(@Autowire LoaderRegistry registry) { - super(registry); - } - - public QName getXMLType() { - return IMPLEMENTATION_JAVASCRIPT; - } - - public JavaScriptImplementation load(CompositeComponent parent, XMLStreamReader reader, DeploymentContext deploymentContext) - throws XMLStreamException, LoaderException { - - String script = reader.getAttributeValue(null, "script"); - if (script == null) { - throw new MissingResourceException("No script supplied"); - } - - ClassLoader cl = deploymentContext.getClassLoader(); - String source = loadSource(cl, script); - - LoaderUtil.skipToEndElement(reader); - - JavaScriptImplementation implementation = new JavaScriptImplementation(); - RhinoScript rhinoScript = new RhinoScript(script, source, null, cl); - implementation.setRhinoScript(rhinoScript); - registry.loadComponentType(parent, implementation, deploymentContext); - return implementation; - } - - protected String loadSource(ClassLoader cl, String resource) throws LoaderException { - URL url = cl.getResource(resource); - if (url == null) { - throw new MissingResourceException(resource); - } - InputStream is; - try { - is = url.openStream(); - } catch (IOException e) { - MissingResourceException mre = new MissingResourceException(resource, e); - mre.setIdentifier(resource); - throw mre; - } - try { - Reader reader = new InputStreamReader(is, "UTF-8"); - char[] buffer = new char[1024]; - StringBuilder source = new StringBuilder(); - int count; - while ((count = reader.read(buffer)) > 0) { - source.append(buffer, 0, count); - } - return source.toString(); - } catch (IOException e) { - LoaderException le = new LoaderException(e); - le.setIdentifier(resource); - throw le; - } finally { - try { - is.close(); - } catch (IOException e) { - // ignore - } - } - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptIntrospector.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptIntrospector.java deleted file mode 100644 index 542504b62e..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptIntrospector.java +++ /dev/null @@ -1,173 +0,0 @@ -/* - * 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.container.javascript; - -import java.util.Iterator; -import java.util.Map; -import javax.wsdl.Definition; -import javax.wsdl.PortType; -import javax.wsdl.WSDLException; -import javax.wsdl.factory.WSDLFactory; -import javax.wsdl.xml.WSDLReader; -import javax.xml.namespace.QName; - -import org.apache.tuscany.spi.annotation.Autowire; -import org.apache.tuscany.spi.idl.InvalidServiceContractException; -import org.apache.tuscany.spi.idl.java.JavaInterfaceProcessorRegistry; -import org.apache.tuscany.spi.loader.MissingResourceException; -import org.apache.tuscany.spi.model.ComponentType; -import org.apache.tuscany.spi.model.Scope; -import org.apache.tuscany.spi.model.ServiceContract; -import org.apache.tuscany.spi.model.ServiceDefinition; - -import org.apache.tuscany.container.javascript.rhino.RhinoSCAConfig; -import org.apache.tuscany.idl.wsdl.WSDLDefinitionRegistry; -import org.apache.tuscany.idl.wsdl.WSDLServiceContract; - -/** - * Introspects JavaScript files for SCA configuration - */ -public class JavaScriptIntrospector { - - private WSDLDefinitionRegistry wsdlRegistry; - private JavaInterfaceProcessorRegistry processorRegistry; - - public JavaScriptIntrospector(@Autowire WSDLDefinitionRegistry wsdlRegistry, - @Autowire JavaInterfaceProcessorRegistry processorRegistry) { - this.wsdlRegistry = wsdlRegistry; - this.processorRegistry = processorRegistry; - } - - public JavaScriptComponentType introspectScript(RhinoSCAConfig scaConfig, ClassLoader cl) - throws MissingResourceException, InvalidServiceContractException { - JavaScriptComponentType componentType = new JavaScriptComponentType(); - introspectJavaInterface(componentType, cl, scaConfig.getJavaInterface()); - introspectWSDLInterface(componentType, cl, scaConfig.getWSDLNamespace(), scaConfig.getWSDLPortType(), - scaConfig.getWSDLLocation()); - introspectReferences(componentType, cl, scaConfig.getReferences()); - introspectProperties(componentType, cl, scaConfig.getProperties()); - introspectScope(componentType, scaConfig.getScope()); - return componentType; - } - - private void introspectScope(JavaScriptComponentType componentType, Scope scope) { - if (scope != null) { - componentType.setLifecycleScope(scope); - } - } - - @SuppressWarnings("unchecked") - private void introspectJavaInterface(ComponentType componentType, ClassLoader cl, String serviceClass) - throws MissingResourceException, InvalidServiceContractException { - if (serviceClass != null) { - ServiceDefinition service = new ServiceDefinition(); - try { - ServiceContract sc = processorRegistry.introspect(Class.forName(serviceClass)); - service.setServiceContract(sc); - componentType.add(service); - } catch (ClassNotFoundException e) { - throw new MissingResourceException("Interface not found", e); - } - } - } - - @SuppressWarnings("unchecked") - private void introspectWSDLInterface(ComponentType componentType, ClassLoader cl, String wsdlNamespace, - String wsdlPortType, String wsdlLocation) { - if (wsdlNamespace == null && wsdlPortType == null && wsdlLocation == null) { - return; - } - - PortType portType = null; - if (wsdlLocation != null) { - portType = readWSDLPortType(wsdlNamespace, wsdlPortType, wsdlLocation, portType); - } else { - portType = getPortType(wsdlNamespace, wsdlPortType); - } - - ServiceDefinition service = new ServiceDefinition(); - WSDLServiceContract wsdlSC = new WSDLServiceContract(); - wsdlSC.setPortType(portType); - service.setServiceContract(wsdlSC); - componentType.add(service); - } - - private PortType readWSDLPortType(String wsdlNamespace, String wsdlPortType, String wsdlLocation, - PortType portType) { - Definition wsdlDefinition; - try { - WSDLReader reader = WSDLFactory.newInstance().newWSDLReader(); - reader.setFeature("javax.wsdl.verbose", false); - wsdlDefinition = reader.readWSDL(wsdlLocation.toString()); - } catch (WSDLException e) { - throw new RuntimeException(e); - - } - Map portTypes = wsdlDefinition.getPortTypes(); - for (Iterator i = portTypes.keySet().iterator(); i.hasNext();) { - QName portTypeQN = (QName) i.next(); - if (wsdlNamespace != null) { - if (!portTypeQN.getNamespaceURI().equals(wsdlNamespace)) { - continue; - } - } - if (wsdlPortType != null) { - if (!portTypeQN.getLocalPart().equals(wsdlPortType)) { - continue; - } - } - if (portType != null) { - throw new RuntimeException("multiple matching portTypes in wsdl: " + wsdlLocation); - } - portType = (PortType) portTypes.get(portTypeQN); - } - if (portType == null) { - throw new RuntimeException("portType not found in wsdl: " + wsdlLocation); - } - return portType; - } - - private PortType getPortType(String wsdlNamespace, String wsdlPortType) { - if (wsdlPortType == null) { - throw new IllegalArgumentException("must specify the wsdlPortType in script SCA config"); - } - PortType portType = null; - if (wsdlNamespace != null) { - QName portTypeQN = new QName(wsdlNamespace.toString(), wsdlPortType.toString()); - portType = wsdlRegistry.getPortType(portTypeQN); - if (portType == null) { - throw new IllegalArgumentException("no WSDL registered for portType: " + portTypeQN); - } - } else { - // wsdlRegistry.getPortType(wsdlPortType.toString()); - if (portType == null) { - throw new IllegalArgumentException("no WSDL registered for portType:" + wsdlPortType); - } - } - return portType; - } - - - private void introspectProperties(ComponentType componentType, ClassLoader cl, Map properties) { - } - - private void introspectReferences(ComponentType componentType, ClassLoader cl, Map references) { - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptInvoker.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptInvoker.java deleted file mode 100644 index 281b417d64..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptInvoker.java +++ /dev/null @@ -1,53 +0,0 @@ -/* - * 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.container.javascript; - -import java.lang.reflect.InvocationTargetException; - -import org.apache.tuscany.container.javascript.rhino.RhinoScriptInstance; -import org.apache.tuscany.spi.extension.TargetInvokerExtension; - -/** - * Dispatches to a JavaScript implementation instance - * - * @version $$Rev$$ $$Date$$ - */ -public class JavaScriptInvoker extends TargetInvokerExtension { - - private JavaScriptComponent context; - - private String functionName; - - private Class responseClass; - - public JavaScriptInvoker(String functionName, Class respClass, JavaScriptComponent context) { - this.functionName = functionName; - this.context = context; - this.responseClass = respClass; - } - - /** - * Invokes a function on a script instance - */ - public Object invokeTarget(final Object payload) throws InvocationTargetException { - RhinoScriptInstance target = context.getTargetInstance(); - return target.invokeFunction(functionName, (Object[]) payload, responseClass); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptRefInvocInterceptor.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptRefInvocInterceptor.java deleted file mode 100644 index f8c978f833..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptRefInvocInterceptor.java +++ /dev/null @@ -1,132 +0,0 @@ -/* - * 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.container.javascript; - -import java.io.ByteArrayInputStream; -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.Method; - -import javax.xml.stream.XMLStreamReader; - -import org.apache.axiom.om.OMAbstractFactory; -import org.apache.axiom.om.OMElement; -import org.apache.axiom.om.impl.builder.StAXOMBuilder; -import org.apache.axiom.om.util.StAXUtils; -import org.apache.xmlbeans.XmlObject; -import org.mozilla.javascript.Context; -import org.mozilla.javascript.Scriptable; -import org.mozilla.javascript.ScriptableObject; -import org.mozilla.javascript.Wrapper; -import org.mozilla.javascript.xml.XMLObject; - -/** - * This Interceptor encasulates the data mediation required by the JavaScriptReferenceProxy. The - * invocation handler of this class traps the javascript reference calls, performs data mediation - * and calls then calls the actual referred service. This classes implementation is subject to - * review and change when the DataMediation infrastructure of Tuscany is ready. - * - */ -public class JavaScriptRefInvocInterceptor implements InvocationHandler { - private Object actualProxy; - - private Class wireInterface; - - private Scriptable instanceScope; - - JavaScriptRefInvocInterceptor(Object wireProxy, Class wireIfc, Scriptable instScope) { - this.actualProxy = wireProxy; - this.wireInterface = wireIfc; - this.instanceScope = instScope; - } - - public Object invoke(Object arg0, Method method, Object[] args) throws Throwable { - // TODO Auto-generated method stub - Context cx = Context.enter(); - try { - Method invokedMethod = getInvokedMethod(method.getName()); - Object[] tranformedArgs = new Object[args.length]; - for (int count = 0; count < args.length; ++count) { - tranformedArgs[count] = fromJavaScript(invokedMethod.getParameterTypes()[count], args[count]); - } - - Object response = invokedMethod.invoke(actualProxy, tranformedArgs); - response = toJavaScript(response, instanceScope, cx); - return response; - } finally { - Context.exit(); - } - } - - private Method getInvokedMethod(String methodName) { - Method[] methods = wireInterface.getMethods(); - - for (int count = 0; count < methods.length; ++count) { - if (methods[count].getName().equals(methodName)) { - return methods[count]; - } - } - throw new RuntimeException("Unable to find invocation method"); - } - - protected Object fromJavaScript(Class reqArgType, Object jsArg) throws Exception { - Object javaArg; - if (Context.getUndefinedValue().equals(jsArg)) { - javaArg = null; - } else if (jsArg instanceof XMLObject) { - // TODO: E4X Bug? Shouldn't need this copy, but without it the outer element gets lost??? - Scriptable jsXML = (Scriptable) ScriptableObject.callMethod((Scriptable) jsArg, "copy", new Object[0]); - Wrapper wrapper = (Wrapper) ScriptableObject.callMethod(jsXML, "getXmlObject", new Object[0]); - javaArg = wrapper.unwrap(); - - XMLStreamReader xmlReader = StAXUtils.createXMLStreamReader(new ByteArrayInputStream(javaArg.toString().getBytes())); - StAXOMBuilder staxOMBuilder = new StAXOMBuilder(OMAbstractFactory.getOMFactory(), xmlReader); - javaArg = staxOMBuilder.getDocumentElement(); - } else if (jsArg instanceof Wrapper) { - javaArg = ((Wrapper) jsArg).unwrap(); - } else { - if (reqArgType != null) { - javaArg = Context.jsToJava(jsArg, reqArgType); - } else { - javaArg = Context.jsToJava(jsArg, String.class); - } - } - - return javaArg; - } - - protected Object toJavaScript(Object retVal, Scriptable scope, Context cx) throws RuntimeException { - Object jsRetVal; - if (retVal instanceof OMElement) { - try { - XmlObject xmlObject = XmlObject.Factory.parse(retVal.toString()); - Object jsXML = cx.getWrapFactory().wrap(cx, scope, xmlObject, XmlObject.class); - jsRetVal = cx.newObject(scope, "XML", new Object[] { jsXML }); - } catch (Exception e) { - throw new RuntimeException(e); - } - } else if (retVal instanceof XmlObject) { - Object jsXML = cx.getWrapFactory().wrap(cx, scope, (XmlObject) retVal, XmlObject.class); - jsRetVal = cx.newObject(scope, "XML", new Object[] { jsXML }); - } else { - jsRetVal = Context.toObject(retVal, scope); - } - - return jsRetVal; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptReferenceProxy.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptReferenceProxy.java deleted file mode 100644 index 8b432872b8..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/JavaScriptReferenceProxy.java +++ /dev/null @@ -1,132 +0,0 @@ -/* - * 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.container.javascript; - -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.Method; -import java.lang.reflect.Proxy; - -import net.sf.cglib.asm.ClassWriter; -import net.sf.cglib.asm.CodeVisitor; -import net.sf.cglib.asm.Constants; -import net.sf.cglib.asm.Type; - -import org.apache.tuscany.spi.wire.WireInvocationHandler; -import org.mozilla.javascript.Context; -import org.mozilla.javascript.Scriptable; -import org.mozilla.javascript.ScriptableObject; -import org.mozilla.javascript.Wrapper; -import org.mozilla.javascript.xml.XMLObject; - -/** - * This is a proxy that will mediate reference calls from the JavaScript. The mediation code here will be reviewed when the DataMediation - * infrastructure is ready. This proxy assmes that there is no verloading of service methods on the reference interface i.e. there are no two service - * methods that have the same method name or operation name. - */ -public class JavaScriptReferenceProxy { - - private Class interfaze; - - private Object wireProxy; - - private Scriptable instanceScope; - - public JavaScriptReferenceProxy(Class interfaze, Object wireProxy, Scriptable instScope) { - this.interfaze = interfaze; - this.wireProxy = wireProxy; - this.instanceScope = instScope; - } - - public Object createProxy() { - try { - GenericProxyClassLoader classloader = new GenericProxyClassLoader(); - final byte[] byteCode = generateGenericInterface(interfaze); - - Class genericInterface = classloader.defineClass(byteCode); - InvocationHandler proxyHandler = new JavaScriptRefInvocInterceptor(wireProxy, - interfaze, instanceScope); - // return genericInterface.cast(Proxy.newProxyInstance(classloader, new Class[]{genericInterface}, proxyHandler)); - return Proxy.newProxyInstance(classloader, - new Class[]{genericInterface}, - proxyHandler); - } catch (Exception e) { - return null; - } - } - - private static byte[] generateGenericInterface(Class serviceInterface) { - String interfazeName = serviceInterface.getCanonicalName(); - ClassWriter cw = new ClassWriter(false); - - cw.visit(Constants.V1_5, - Constants.ACC_PUBLIC + Constants.ACC_ABSTRACT + Constants.ACC_INTERFACE, - interfazeName.replace('.', - '/'), - "java/lang/Object", - null, - serviceInterface.getSimpleName() + ".java"); - - StringBuffer argsAndReturn = new StringBuffer("("); - Method[] methods = serviceInterface.getMethods(); - for (int count = 0; count < methods.length; ++count) { - argsAndReturn = new StringBuffer("("); - Class[] paramTypes = methods[count].getParameterTypes(); - Class returnType = methods[count].getReturnType(); - - for (int paramCount = 0; paramCount < paramTypes.length; ++paramCount) { - argsAndReturn.append(Type.getType(Object.class)); - } - argsAndReturn.append(")"); - argsAndReturn.append(Type.getType(Object.class)); - - Class[] exceptionTypes = methods[count].getExceptionTypes(); - String[] exceptions = new String[exceptionTypes.length]; - for (int excCount = 0; excCount < exceptionTypes.length; ++excCount) { - exceptions[excCount] = exceptionTypes[excCount].getName(); - exceptions[excCount] = exceptions[excCount].replace('.', - '/'); - } - - CodeVisitor cv = cw.visitMethod(Constants.ACC_PUBLIC + Constants.ACC_ABSTRACT, - methods[count].getName(), - argsAndReturn.toString(), - exceptions, - null); - cw.visitEnd(); - } - - cw.visitEnd(); - - return cw.toByteArray(); - } - - private class GenericProxyClassLoader extends ClassLoader { - public Class defineClass(byte[] byteArray) { - try { - return defineClass(null, - byteArray, - 0, - byteArray.length); - } catch (Throwable e) { - return null; - } - } - - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvoker.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvoker.java deleted file mode 100644 index b2064f9110..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvoker.java +++ /dev/null @@ -1,123 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.io.ByteArrayInputStream; - -import javax.xml.stream.XMLStreamReader; - -import org.apache.axiom.om.OMAbstractFactory; -import org.apache.axiom.om.OMElement; -import org.apache.axiom.om.impl.builder.StAXOMBuilder; -import org.apache.axiom.om.util.StAXUtils; -import org.apache.xmlbeans.XmlObject; -import org.mozilla.javascript.Context; -import org.mozilla.javascript.Function; -import org.mozilla.javascript.Scriptable; -import org.mozilla.javascript.ScriptableObject; -import org.mozilla.javascript.Wrapper; -import org.mozilla.javascript.xml.XMLObject; - -/** - * An invoker for a specific function in a JavaScript script - */ -public class RhinoFunctionInvoker { - - private Scriptable instanceScope; - - private Function function; - - private Class responseClass; - - public RhinoFunctionInvoker(Scriptable instanceScope, Function function, Class responseClass) { - this.instanceScope = instanceScope; - this.function = function; - this.responseClass = responseClass; - } - - public Object invoke(Object[] args) { - Context cx = Context.enter(); - try { - - Object[] jsArgs = toJavaScript(args, instanceScope, cx); - Object jsResponse = function.call(cx, instanceScope, instanceScope, jsArgs); - Object response = fromJavaScript(jsResponse); - return response; - - } catch ( Exception e ) { - throw new RuntimeException(e); - } - finally { - Context.exit(); - } - } - - protected Object[] toJavaScript(Object[] arg, Scriptable scope, Context cx) throws RuntimeException { - Object[] jsArgs; - if (arg == null) { - jsArgs = new Object[0]; - } else if (arg.length == 1 && arg[0] instanceof OMElement) { - try { - XmlObject xmlObject = XmlObject.Factory.parse(arg[0].toString()); - Object jsXML = cx.getWrapFactory().wrap(cx, scope, xmlObject, XmlObject.class); - jsArgs = new Object[] { cx.newObject(scope, "XML", new Object[] { jsXML }) }; - } catch ( Exception e ) { - throw new RuntimeException(e); - } - } else if (arg.length == 1 && arg[0] instanceof XmlObject) { - Object jsXML = cx.getWrapFactory().wrap(cx, scope, (XmlObject)arg[0], XmlObject.class); - jsArgs = new Object[] { cx.newObject(scope, "XML", new Object[] { jsXML }) }; - } else { - jsArgs = new Object[arg.length]; - for (int i = 0; i < jsArgs.length; i++) { - jsArgs[i] = Context.toObject(arg[i], scope); - } - } - - return jsArgs; - } - - protected Object fromJavaScript(Object o) throws Exception { - Object response; - if (Context.getUndefinedValue().equals(o)) { - response = null; - } else if (o instanceof XMLObject) { - // TODO: E4X Bug? Shouldn't need this copy, but without it the outer element gets lost??? - Scriptable jsXML = (Scriptable) ScriptableObject.callMethod((Scriptable) o, "copy", new Object[0]); - Wrapper wrapper = (Wrapper) ScriptableObject.callMethod(jsXML, "getXmlObject", new Object[0]); - response = wrapper.unwrap(); - - XMLStreamReader xmlReader = - StAXUtils.createXMLStreamReader(new ByteArrayInputStream(response.toString().getBytes())); - StAXOMBuilder staxOMBuilder = new StAXOMBuilder(OMAbstractFactory.getOMFactory(), xmlReader); - response = staxOMBuilder.getDocumentElement(); - - } else if (o instanceof Wrapper) { - response = ((Wrapper) o).unwrap(); - } else { - if (responseClass != null) { - response = Context.jsToJava(o, responseClass); - } else { - response = Context.jsToJava(o, String.class); - } - } - return response; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfig.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfig.java deleted file mode 100644 index af27403c03..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfig.java +++ /dev/null @@ -1,157 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.util.HashMap; -import java.util.Map; - -import org.apache.tuscany.spi.model.Scope; -import org.mozilla.javascript.Scriptable; -import org.mozilla.javascript.UniqueTag; - -/** - * Represents the variable defining the SCA aspects of the script - * - * SCA = { - * javaInterface : "my.pkg.ClassName", - * wsdlPortType : "wsdlPortTypeName", - * wsdlNameSpace : "http://my.namespace.com", - * wsdlLocation : "\wsdl\mywsdl.txt", - * properties : { "foo" : ["java.lang.String", "defaultValue"],}, - * references : {}, - * scope : 'stateless'|'request'|'conversational'|'composite', - * } - * - * The config must define the service with either javaInterface or wsdl. When - * using wsdl the three parameters are optional. If wsdlLocation is used that is the - * WSDL document used, and the namespace and portType parameters are only required if - * the WSDL definition defines multiple portTypes. - */ -public class RhinoSCAConfig { - - private boolean hasSCAConfig; - - private String javaInterface; - - private String wsdlLocation; - - private String wsdlNamespace; - - private String wsdlPortType; - - private Map properties; - - private Map references; - - private Scope scope; - - public RhinoSCAConfig(Scriptable scriptScope) { - Object o = scriptScope.get("SCA", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - hasSCAConfig = true; - Scriptable scaVar = (Scriptable) o; - o = scaVar.get("javaInterface", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - this.javaInterface = o.toString(); - } - o = scaVar.get("wsdlLocation", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - this.wsdlLocation = o.toString(); - } - o = scaVar.get("wsdlPortType", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - this.wsdlPortType = o.toString(); - } - o = scaVar.get("wsdlNamespace", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - this.wsdlNamespace = o.toString(); - } - if (javaInterface != null) { - if (wsdlLocation != null || wsdlPortType != null || wsdlNamespace != null) { - throw new IllegalArgumentException("script SCA config defines both Java and WSDL service interface"); - } - } else { - if (wsdlLocation == null && wsdlPortType == null && wsdlNamespace == null) { - throw new IllegalArgumentException("script SCA config must define either Java or WSDL service interface"); - } - } - - this.properties = new HashMap(); - o = scaVar.get("properties", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - // TODO parse properties - } - - this.references = new HashMap(); - o = scaVar.get("references", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - // TODO parse references - } - - o = scaVar.get("scope", scriptScope); - if (o != null && UniqueTag.NOT_FOUND != o) { - if ("stateless".equalsIgnoreCase(String.valueOf(o))) { - this.scope = Scope.STATELESS; - } else if ("request".equalsIgnoreCase(String.valueOf(o))) { - this.scope = Scope.REQUEST; - } else if ("conversational".equalsIgnoreCase(String.valueOf(o))) { - this.scope = Scope.SESSION; // TODO: where's CONVERSATIONAL? - } else if ("composite".equalsIgnoreCase(String.valueOf(o))) { - this.scope = Scope.MODULE; // TODO: composite = MODULE for now? - } else { - throw new IllegalArgumentException("invalid scope value: " + o); - } - } - - } - } - - public boolean hasSCAConfig() { - return hasSCAConfig; - } - - public String getJavaInterface() { - return javaInterface; - } - - public Map getProperties() { - return properties; - } - - public Map getReferences() { - return references; - } - - public String getWSDLLocation() { - return wsdlLocation; - } - - public String getWSDLNamespace() { - return wsdlNamespace; - } - - public String getWSDLPortType() { - return wsdlPortType; - } - - public Scope getScope() { - return scope; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScript.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScript.java deleted file mode 100644 index 3552372223..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScript.java +++ /dev/null @@ -1,210 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.util.HashMap; -import java.util.Iterator; -import java.util.Map; - -import org.mozilla.javascript.Context; -import org.mozilla.javascript.ContextFactory; -import org.mozilla.javascript.ImporterTopLevel; -import org.mozilla.javascript.Script; -import org.mozilla.javascript.Scriptable; - -/** - * A RhinoScript represents a compiled JavaScript script - */ -public class RhinoScript { - - protected String scriptName; - - protected String script; - - protected Scriptable scriptScope; - - protected Map responseClasses; - - protected ClassLoader classLoader; - - /* - * Enable dynamic scopes so a script can be used concurrently with a global shared scope and individual execution scopes. See - * http://www.mozilla.org/rhino/scopes.html - */ - private static class MyFactory extends ContextFactory { - protected boolean hasFeature(Context cx, int featureIndex) { - if (featureIndex == Context.FEATURE_DYNAMIC_SCOPE) { - return true; - } - return super.hasFeature(cx, featureIndex); - } - } - - static { - ContextFactory.initGlobal(new MyFactory()); - } - - /** - * Create a new RhinoScript. - * - * @param scriptName - * the name of the script. Can be anything, only used in messages to identify the script - * @param script - * the complete script - */ - public RhinoScript(String scriptName, String script) { - this(scriptName, script, (Map) null, null); - } - - /** - * Create a new RhinoInvoker. - * - * @param scriptName - * the name of the script. Can be anything, only used in messages to identify the script - * @param script - * the complete script - * @param context - * name-value pairs that are added in to the scope where the script is compiled. May be null. The value objects are made available to - * the script by using a variable with the name. - * @param classLoader - * the ClassLoader Rhino should use to locate any user Java classes used in the script - */ - public RhinoScript(String scriptName, String script, Map context, ClassLoader classLoader) { - this.scriptName = scriptName; - this.script = script; - this.responseClasses = new HashMap(); - this.classLoader = classLoader; - initScriptScope(scriptName, script, context, classLoader); - } - - /** - * Create a new invokeable instance of the script - * - * @return a RhinoScriptInstance - */ - public RhinoScriptInstance createRhinoScriptInstance() { - return createRhinoScriptInstance(null); - } - - /** - * Create a new invokeable instance of the script - * - * @param context - * objects to add to scope of the script instance - * @return a RhinoScriptInstance - */ - public RhinoScriptInstance createRhinoScriptInstance(Map context) { - Scriptable instanceScope = createInstanceScope(context); - RhinoScriptInstance rsi = new RhinoScriptInstance(scriptScope, instanceScope, context, responseClasses); - return rsi; - } - - /** - * Initialize the Rhino Scope for this script instance - */ - public Scriptable createInstanceScope(Map context) { - Context cx = Context.enter(); - try { - - Scriptable instanceScope = cx.newObject(scriptScope); - instanceScope.setPrototype(scriptScope); - instanceScope.setParentScope(null); - - addContexts(instanceScope, context); - - return instanceScope; - - } finally { - Context.exit(); - } - } - - /** - * Create a Rhino scope and compile the script into it - */ - public void initScriptScope(String fileName, String scriptCode, Map context, ClassLoader cl) { - Context cx = Context.enter(); - try { - if (cl != null) { - // TODO: broken with the way the tuscany launcher now uses class loaders - // cx.setApplicationClassLoader(cl); - } - this.scriptScope = new ImporterTopLevel(cx, true); - Script compiledScript = cx.compileString(scriptCode, fileName, 1, null); - compiledScript.exec(cx, scriptScope); - addContexts(scriptScope, context); - - } finally { - Context.exit(); - } - } - - /** - * Add the context to the scope. This will make the objects available to a script by using the name it was added with. - */ - protected void addContexts(Scriptable scope, Map contexts) { - if (contexts != null) { - for (Iterator i = contexts.keySet().iterator(); i.hasNext();) { - String name = (String) i.next(); - Object value = contexts.get(name); - if (value != null) { - scope.put(name, scope, Context.toObject(value, scope)); - } - } - } - } - - public String getScript() { - return script; - } - - public String getScriptName() { - return scriptName; - } - - public Scriptable getScriptScope() { - return scriptScope; - } - - public Map getResponseClasses() { - return responseClasses; - } - - public ClassLoader getClassLoader() { - return classLoader; - } - - /** - * Set the Java type of a response value. JavaScript is dynamically typed so Rhino cannot always work out what the intended Java type of a - * response should be, for example should the statement "return 42" be a Java int, or Integer or Double etc. When Rhino can't determine the type - * it will default to returning a String, using this method enables overriding the Rhino default to use a specific Java type. - */ - public void setResponseClass(String functionName, Class responseClasses) { - this.responseClasses.put(functionName, responseClasses); - } - - public RhinoSCAConfig getSCAConfig() { - return new RhinoSCAConfig(getScriptScope()); - } - - public void setScript(String script) { - this.script = script; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstance.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstance.java deleted file mode 100644 index 508bc2a90a..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstance.java +++ /dev/null @@ -1,109 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.util.HashMap; -import java.util.Iterator; -import java.util.Map; - -import org.mozilla.javascript.Context; -import org.mozilla.javascript.Function; -import org.mozilla.javascript.Scriptable; -import org.mozilla.javascript.UniqueTag; - -/** - * An invokeable instance of a JavaScript script. - */ -public class RhinoScriptInstance { - - private Scriptable scriptScope; - - private Scriptable instanceScope; - - private Map responseClasses; - - public RhinoScriptInstance(Scriptable scriptScope, Scriptable instanceScope, Map context, Map responseClasses) { - this.scriptScope = scriptScope; - this.instanceScope = instanceScope; - this.responseClasses = responseClasses; - if (this.responseClasses == null) { - this.responseClasses = new HashMap(); - } - addContexts(instanceScope, context); - } - - public Object invokeFunction(String functionName, Object[] args) { - return invokeFunction(functionName, args, null); - } - - public Object invokeFunction(String functionName, Object[] args, Class respClass) { - RhinoFunctionInvoker invoker = createRhinoFunctionInvoker(functionName, respClass); - return invoker.invoke(args); - } - - public RhinoFunctionInvoker createRhinoFunctionInvoker(String functionName) { - return createRhinoFunctionInvoker(functionName, null); - } - - - public RhinoFunctionInvoker createRhinoFunctionInvoker(String functionName, Class responseClass) { - Function function = getFunction(functionName); - //Class responseClass = responseClasses.get(functionName); - RhinoFunctionInvoker invoker = new RhinoFunctionInvoker(instanceScope, function, responseClass); - return invoker; - } - - /** - * Add the context to the scope. This will make the objects available to a script by using the name it was added with. - */ - protected void addContexts(Scriptable scope, Map contexts) { - if (contexts != null) { - Context.enter(); - try { - for (Iterator i = contexts.keySet().iterator(); i.hasNext();) { - String name = (String) i.next(); - Object value = contexts.get(name); - if (value != null) { - scope.put(name, scope, Context.toObject(value, scope)); - } - } - } finally { - Context.exit(); - } - } - } - - /** - * Get the Rhino Function object for the named script function - */ - protected Function getFunction(String functionName) { - - Object handleObj = scriptScope.get(functionName, instanceScope); - if (UniqueTag.NOT_FOUND.equals(handleObj)) { - // Bit of a hack so E4X scripts don't need to define a function for every operation - handleObj = scriptScope.get("process", instanceScope); - } - if (!(handleObj instanceof Function)) { - throw new RuntimeException("script function '" + functionName + "' is undefined or not a function"); - } - - return (Function) handleObj; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsHandler.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsHandler.java deleted file mode 100644 index b724b33ac3..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsHandler.java +++ /dev/null @@ -1,28 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -/** - * This interface is to be implemented by classes that wish to - * handle commandline arguments. - * - */ -public interface CmdLineArgsHandler { - public void handleArgument(String optionFlag, String argValue) throws IllegalArgumentException; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsProcessor.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsProcessor.java deleted file mode 100644 index 914f1d03f2..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/CmdLineArgsProcessor.java +++ /dev/null @@ -1,79 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -/** - * This class provides a generic command line arguments processing utility. The processArgs - * method of this class processes the command line arguments that could contain option flags, - * options and values and calls a ArgumentHanlder instance for handling the agruments. - * - */ -public class CmdLineArgsProcessor { - private String printUsageMessage = "No hints available on Usage!"; - - private CmdLineArgsHandler argsHandler = null; - - public static final String HYPEN = "-"; - - public void processArgs(String[] args) { - try { - if (args.length == 0) { - printUsage(); - } else { - parseAndHandleArgs(args); - } - } catch (Exception e) { - System.out.println("Exception in processing argument - " + e); - printUsage(); - } - - } - - public void parseAndHandleArgs(String[] args) throws Exception { - int index = 0; - while (index < args.length - 1) { - if (args[index].startsWith(HYPEN) && !args[index + 1].startsWith(HYPEN)) { - argsHandler.handleArgument(args[index].substring(1), args[index + 1]); - index = index + 2; - } else { - throw new IllegalArgumentException("Wrong Usage of options!"); - } - } - } - - protected void printUsage() { - - } - - public CmdLineArgsHandler getArgsHandler() { - return argsHandler; - } - - public void setArgsHandler(CmdLineArgsHandler argsHandler) { - this.argsHandler = argsHandler; - } - - public String getPrintUsageMessage() { - return printUsageMessage; - } - - public void setPrintUsageMessage(String printUsageMessage) { - this.printUsageMessage = printUsageMessage; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/TuscanySampleXmlUtil.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/TuscanySampleXmlUtil.java deleted file mode 100644 index a0155c76e6..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/TuscanySampleXmlUtil.java +++ /dev/null @@ -1,1097 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import org.apache.xmlbeans.SchemaType; -import org.apache.xmlbeans.XmlCursor; -import org.apache.xmlbeans.SchemaParticle; -import org.apache.xmlbeans.SchemaLocalElement; -import org.apache.xmlbeans.SchemaProperty; -import org.apache.xmlbeans.GDuration; -import org.apache.xmlbeans.GDurationBuilder; -import org.apache.xmlbeans.GDate; -import org.apache.xmlbeans.GDateBuilder; -import org.apache.xmlbeans.XmlAnySimpleType; -import org.apache.xmlbeans.SimpleValue; -import org.apache.xmlbeans.XmlOptions; -import org.apache.xmlbeans.XmlObject; -import org.apache.xmlbeans.XmlInteger; -import org.apache.xmlbeans.XmlDate; -import org.apache.xmlbeans.XmlDateTime; -import org.apache.xmlbeans.XmlTime; -import org.apache.xmlbeans.XmlGYear; -import org.apache.xmlbeans.XmlGYearMonth; -import org.apache.xmlbeans.XmlGMonth; -import org.apache.xmlbeans.XmlGMonthDay; -import org.apache.xmlbeans.XmlGDay; -import org.apache.xmlbeans.XmlDecimal; -import org.apache.xmlbeans.XmlDuration; -import org.apache.xmlbeans.soap.SchemaWSDLArrayType; -import org.apache.xmlbeans.soap.SOAPArrayType; -import org.apache.xmlbeans.impl.util.Base64; -import org.apache.xmlbeans.impl.util.HexBin; - -import java.math.BigDecimal; -import java.math.BigInteger; -import java.util.ArrayList; -import java.util.Calendar; -import java.util.Date; -import java.util.Random; -import java.util.Set; -import java.util.HashSet; -import java.util.Arrays; - -import javax.xml.namespace.QName; - -/** - * This class is a replication of the XMLBeans SampleXMLutil class. This replication - * is required to overide the XMLBeans behaviour of this class in certain places. Since - * most methods of the XMLBeans implementation of this class is private, no overiding - * has been possible using inheritance. Hence this replication. - * - */ -public class TuscanySampleXmlUtil { - private static final String BLANK_STRING = " "; - - private boolean generate_sample_data = false; - - private boolean _soapEnc; - - private static final int MAX_ELEMENTS = 1000; - - private int _nElements; - - boolean flag = true; - - private TuscanySampleXmlUtil(boolean soapEnc) { - _soapEnc = soapEnc; - } - - public TuscanySampleXmlUtil() { - this(false); - } - - public String createSampleForType(SchemaType sType) { - XmlObject object = XmlObject.Factory.newInstance(); - XmlCursor cursor = object.newCursor(); - // Skip the document node - cursor.toNextToken(); - // Using the type and the cursor, call the utility method to get a - // sample XML payload for that Schema element - createSampleForType(sType, cursor); - // Cursor now contains the sample payload - // Pretty print the result. Note that the cursor is positioned at the - // end of the doc so we use the original xml object that the cursor was - // created upon to do the xmlText() against. - XmlOptions options = new XmlOptions(); - options.put(XmlOptions.SAVE_PRETTY_PRINT); - options.put(XmlOptions.SAVE_PRETTY_PRINT_INDENT, 2); - options.put(XmlOptions.SAVE_AGGRESSIVE_NAMESPACES); - String result = object.xmlText(options); - return result; - } - - Random _picker = new Random(1); - - /** - * Cursor position - * Before: - * ^ - * After: - * ^ - */ - private void createSampleForType(SchemaType stype, XmlCursor xmlc) { - if (_typeStack.contains(stype)) - //if ( !flag ) - return; - //else - // flag = false; - - _typeStack.add(stype); - - try { - if (stype.isSimpleType() || stype.isURType()) { - processSimpleType(stype, xmlc); - return; - } - - // complex Type - // ^ - processAttributes(stype, xmlc); - - // ^ - switch (stype.getContentType()) { - case SchemaType.NOT_COMPLEX_TYPE: - case SchemaType.EMPTY_CONTENT: - // noop - break; - case SchemaType.SIMPLE_CONTENT: { - processSimpleType(stype, xmlc); - } - break; - case SchemaType.MIXED_CONTENT: - if (isGenerate_sample_data()) - xmlc.insertChars(pick(WORDS) + " "); - if (stype.getContentModel() != null) { - processParticle(stype.getContentModel(), xmlc, true); - } - if (isGenerate_sample_data()) - xmlc.insertChars(pick(WORDS)); - - break; - case SchemaType.ELEMENT_CONTENT: - if (stype.getContentModel() != null) { - processParticle(stype.getContentModel(), xmlc, false); - } - break; - } - } finally { - _typeStack.remove(_typeStack.size() - 1); - } - } - - private void processSimpleType(SchemaType stype, XmlCursor xmlc) { - String sample = sampleDataForSimpleType(stype); - xmlc.insertChars(sample); - - } - - private String sampleDataForSimpleType(SchemaType sType) { - if (isGenerate_sample_data()) { - return generateSampleDataForSimpleType(sType); - } else { - return BLANK_STRING; - } - } - - private String generateSampleDataForSimpleType(SchemaType sType) { - if (XmlObject.type.equals(sType)) - return "anyType"; - - if (XmlAnySimpleType.type.equals(sType)) - return "anySimpleType"; - - if (sType.getSimpleVariety() == SchemaType.LIST) { - SchemaType itemType = sType.getListItemType(); - StringBuffer sb = new StringBuffer(); - int length = pickLength(sType); - if (length > 0) - sb.append(sampleDataForSimpleType(itemType)); - for (int i = 1; i < length; i += 1) { - sb.append(' '); - sb.append(sampleDataForSimpleType(itemType)); - } - return sb.toString(); - } - - if (sType.getSimpleVariety() == SchemaType.UNION) { - SchemaType[] possibleTypes = sType.getUnionConstituentTypes(); - if (possibleTypes.length == 0) - return ""; - return sampleDataForSimpleType(possibleTypes[pick(possibleTypes.length)]); - } - - XmlAnySimpleType[] enumValues = sType.getEnumerationValues(); - if (enumValues != null && enumValues.length > 0) { - return enumValues[pick(enumValues.length)].getStringValue(); - } - - switch (sType.getPrimitiveType().getBuiltinTypeCode()) { - default: - case SchemaType.BTC_NOT_BUILTIN: - return ""; - - case SchemaType.BTC_ANY_TYPE: - case SchemaType.BTC_ANY_SIMPLE: - return "anything"; - - case SchemaType.BTC_BOOLEAN: - return pick(2) == 0 ? "true" : "false"; - - case SchemaType.BTC_BASE_64_BINARY: { - String result = null; - try { - result = new String(Base64.encode(formatToLength(pick(WORDS), sType).getBytes("utf-8"))); - } catch (java.io.UnsupportedEncodingException e) { /* Can't possibly happen */ - } - return result; - } - - case SchemaType.BTC_HEX_BINARY: - return HexBin.encode(formatToLength(pick(WORDS), sType)); - - case SchemaType.BTC_ANY_URI: - return formatToLength("http://www." + pick(DNS1) + "." + pick(DNS2) + "/" + pick(WORDS) + "/" + pick(WORDS), sType); - - case SchemaType.BTC_QNAME: - return formatToLength("qname", sType); - - case SchemaType.BTC_NOTATION: - return formatToLength("notation", sType); - - case SchemaType.BTC_FLOAT: - return "1.5E2"; - case SchemaType.BTC_DOUBLE: - return "1.051732E7"; - case SchemaType.BTC_DECIMAL: - switch (closestBuiltin(sType).getBuiltinTypeCode()) { - case SchemaType.BTC_SHORT: - return formatDecimal("1", sType); - case SchemaType.BTC_UNSIGNED_SHORT: - return formatDecimal("5", sType); - case SchemaType.BTC_BYTE: - return formatDecimal("2", sType); - case SchemaType.BTC_UNSIGNED_BYTE: - return formatDecimal("6", sType); - case SchemaType.BTC_INT: - return formatDecimal("3", sType); - case SchemaType.BTC_UNSIGNED_INT: - return formatDecimal("7", sType); - case SchemaType.BTC_LONG: - return formatDecimal("10", sType); - case SchemaType.BTC_UNSIGNED_LONG: - return formatDecimal("11", sType); - case SchemaType.BTC_INTEGER: - return formatDecimal("100", sType); - case SchemaType.BTC_NON_POSITIVE_INTEGER: - return formatDecimal("-200", sType); - case SchemaType.BTC_NEGATIVE_INTEGER: - return formatDecimal("-201", sType); - case SchemaType.BTC_NON_NEGATIVE_INTEGER: - return formatDecimal("200", sType); - case SchemaType.BTC_POSITIVE_INTEGER: - return formatDecimal("201", sType); - default: - case SchemaType.BTC_DECIMAL: - return formatDecimal("1000.00", sType); - } - - case SchemaType.BTC_STRING: { - String result; - switch (closestBuiltin(sType).getBuiltinTypeCode()) { - case SchemaType.BTC_STRING: - case SchemaType.BTC_NORMALIZED_STRING: - result = "string"; - break; - - case SchemaType.BTC_TOKEN: - result = "token"; - break; - - default: - result = "string"; - break; - } - - return formatToLength(result, sType); - } - - case SchemaType.BTC_DURATION: - return formatDuration(sType); - - case SchemaType.BTC_DATE_TIME: - case SchemaType.BTC_TIME: - case SchemaType.BTC_DATE: - case SchemaType.BTC_G_YEAR_MONTH: - case SchemaType.BTC_G_YEAR: - case SchemaType.BTC_G_MONTH_DAY: - case SchemaType.BTC_G_DAY: - case SchemaType.BTC_G_MONTH: - return formatDate(sType); - } - } - - // a bit from the Aenid - public static final String[] WORDS = new String[] { "ipsa", "iovis", "rapidum", "iaculata", "e", "nubibus", "ignem", "disiecitque", "rates", - "evertitque", "aequora", "ventis", "illum", "exspirantem", "transfixo", "pectore", "flammas", "turbine", "corripuit", "scopuloque", - "infixit", "acuto", "ast", "ego", "quae", "divum", "incedo", "regina", "iovisque", "et", "soror", "et", "coniunx", "una", "cum", "gente", - "tot", "annos", "bella", "gero", "et", "quisquam", "numen", "iunonis", "adorat", "praeterea", "aut", "supplex", "aris", "imponet", - "honorem", "talia", "flammato", "secum", "dea", "corde", "volutans", "nimborum", "in", "patriam", "loca", "feta", "furentibus", - "austris", "aeoliam", "venit", "hic", "vasto", "rex", "aeolus", "antro", "luctantis", "ventos", "tempestatesque", "sonoras", "imperio", - "premit", "ac", "vinclis", "et", "carcere", "frenat", "illi", "indignantes", "magno", "cum", "murmure", "montis", "circum", "claustra", - "fremunt", "celsa", "sedet", "aeolus", "arce", "sceptra", "tenens", "mollitque", "animos", "et", "temperat", "iras", "ni", "faciat", - "maria", "ac", "terras", "caelumque", "profundum", "quippe", "ferant", "rapidi", "secum", "verrantque", "per", "auras", "sed", "pater", - "omnipotens", "speluncis", "abdidit", "atris", "hoc", "metuens", "molemque", "et", "montis", "insuper", "altos", "imposuit", "regemque", - "dedit", "qui", "foedere", "certo", "et", "premere", "et", "laxas", "sciret", "dare", "iussus", "habenas", }; - - private static final String[] DNS1 = new String[] { "corp", "your", "my", "sample", "company", "test", "any" }; - - private static final String[] DNS2 = new String[] { "com", "org", "com", "gov", "org", "com", "org", "com", "edu" }; - - private int pick(int n) { - return _picker.nextInt(n); - } - - private String pick(String[] a) { - return a[pick(a.length)]; - } - - private String pick(String[] a, int count) { - if (count <= 0) - return ""; - - int i = pick(a.length); - StringBuffer sb = new StringBuffer(a[i]); - while (count-- > 0) { - i += 1; - if (i >= a.length) - i = 0; - sb.append(' '); - sb.append(a[i]); - } - return sb.toString(); - } - - private String pickDigits(int digits) { - StringBuffer sb = new StringBuffer(); - while (digits-- > 0) - sb.append(Integer.toString(pick(10))); - return sb.toString(); - } - - private int pickLength(SchemaType sType) { - XmlInteger length = (XmlInteger) sType.getFacet(SchemaType.FACET_LENGTH); - if (length != null) - return length.getBigIntegerValue().intValue(); - XmlInteger min = (XmlInteger) sType.getFacet(SchemaType.FACET_MIN_LENGTH); - XmlInteger max = (XmlInteger) sType.getFacet(SchemaType.FACET_MAX_LENGTH); - int minInt, maxInt; - if (min == null) - minInt = 0; - else - minInt = min.getBigIntegerValue().intValue(); - if (max == null) - maxInt = Integer.MAX_VALUE; - else - maxInt = max.getBigIntegerValue().intValue(); - // We try to keep the length of the array within reasonable limits, - // at least 1 item and at most 3 if possible - if (minInt == 0 && maxInt >= 1) - minInt = 1; - if (maxInt > minInt + 2) - maxInt = minInt + 2; - if (maxInt < minInt) - maxInt = minInt; - return minInt + pick(maxInt - minInt); - } - - /** - * Formats a given string to the required length, using the following operations: - * - append the source string to itself as necessary to pass the minLength; - * - truncate the result of previous step, if necessary, to keep it within minLength. - */ - private String formatToLength(String s, SchemaType sType) { - String result = s; - try { - SimpleValue min = (SimpleValue) sType.getFacet(SchemaType.FACET_LENGTH); - if (min == null) - min = (SimpleValue) sType.getFacet(SchemaType.FACET_MIN_LENGTH); - if (min != null) { - int len = min.getIntValue(); - while (result.length() < len) - result = result + result; - } - SimpleValue max = (SimpleValue) sType.getFacet(SchemaType.FACET_LENGTH); - if (max == null) - max = (SimpleValue) sType.getFacet(SchemaType.FACET_MAX_LENGTH); - if (max != null) { - int len = max.getIntValue(); - if (result.length() > len) - result = result.substring(0, len); - } - } catch (Exception e) // intValue can be out of range - { - } - return result; - } - - private String formatDecimal(String start, SchemaType sType) { - BigDecimal result = new BigDecimal(start); - XmlDecimal xmlD; - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - BigDecimal min = xmlD != null ? xmlD.getBigDecimalValue() : null; - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - BigDecimal max = xmlD != null ? xmlD.getBigDecimalValue() : null; - boolean minInclusive = true, maxInclusive = true; - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (xmlD != null) { - BigDecimal minExcl = xmlD.getBigDecimalValue(); - if (min == null || min.compareTo(minExcl) < 0) { - min = minExcl; - minInclusive = false; - } - } - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (xmlD != null) { - BigDecimal maxExcl = xmlD.getBigDecimalValue(); - if (max == null || max.compareTo(maxExcl) > 0) { - max = maxExcl; - maxInclusive = false; - } - } - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_TOTAL_DIGITS); - int totalDigits = -1; - if (xmlD != null) { - totalDigits = xmlD.getBigDecimalValue().intValue(); - - StringBuffer sb = new StringBuffer(totalDigits); - for (int i = 0; i < totalDigits; i++) - sb.append('9'); - BigDecimal digitsLimit = new BigDecimal(sb.toString()); - if (max != null && max.compareTo(digitsLimit) > 0) { - max = digitsLimit; - maxInclusive = true; - } - digitsLimit = digitsLimit.negate(); - if (min != null && min.compareTo(digitsLimit) < 0) { - min = digitsLimit; - minInclusive = true; - } - } - - int sigMin = min == null ? 1 : result.compareTo(min); - int sigMax = max == null ? -1 : result.compareTo(max); - boolean minOk = sigMin > 0 || sigMin == 0 && minInclusive; - boolean maxOk = sigMax < 0 || sigMax == 0 && maxInclusive; - - // Compute the minimum increment - xmlD = (XmlDecimal) sType.getFacet(SchemaType.FACET_FRACTION_DIGITS); - int fractionDigits = -1; - BigDecimal increment; - if (xmlD == null) - increment = new BigDecimal(1); - else { - fractionDigits = xmlD.getBigDecimalValue().intValue(); - if (fractionDigits > 0) { - StringBuffer sb = new StringBuffer("0."); - for (int i = 1; i < fractionDigits; i++) - sb.append('0'); - sb.append('1'); - increment = new BigDecimal(sb.toString()); - } else - increment = new BigDecimal(1.0); - } - - if (minOk && maxOk) { - // OK - } else if (minOk && !maxOk) { - // TOO BIG - if (maxInclusive) - result = max; - else - result = max.subtract(increment); - } else if (!minOk && maxOk) { - // TOO SMALL - if (minInclusive) - result = min; - else - result = min.add(increment); - } else { - // MIN > MAX!! - } - - // We have the number - // Adjust the scale according to the totalDigits and fractionDigits - int digits = 0; - BigDecimal ONE = new BigDecimal(BigInteger.ONE); - for (BigDecimal n = result; n.abs().compareTo(ONE) >= 0; digits++) - n = n.movePointLeft(1); - - if (fractionDigits > 0) - if (totalDigits >= 0) - result.setScale(Math.max(fractionDigits, totalDigits - digits)); - else - result.setScale(fractionDigits); - else if (fractionDigits == 0) - result.setScale(0); - - return result.toString(); - } - - private String formatDuration(SchemaType sType) { - XmlDuration d = (XmlDuration) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - GDuration minInclusive = null; - if (d != null) - minInclusive = d.getGDurationValue(); - - d = (XmlDuration) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - GDuration maxInclusive = null; - if (d != null) - maxInclusive = d.getGDurationValue(); - - d = (XmlDuration) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - GDuration minExclusive = null; - if (d != null) - minExclusive = d.getGDurationValue(); - - d = (XmlDuration) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - GDuration maxExclusive = null; - if (d != null) - maxExclusive = d.getGDurationValue(); - - GDurationBuilder gdurb = new GDurationBuilder(); - BigInteger min, max; - - gdurb.setSecond(pick(800000)); - gdurb.setMonth(pick(20)); - - // Years - // Months - // Days - // Hours - // Minutes - // Seconds - // Fractions - if (minInclusive != null) { - if (gdurb.getYear() < minInclusive.getYear()) - gdurb.setYear(minInclusive.getYear()); - if (gdurb.getMonth() < minInclusive.getMonth()) - gdurb.setMonth(minInclusive.getMonth()); - if (gdurb.getDay() < minInclusive.getDay()) - gdurb.setDay(minInclusive.getDay()); - if (gdurb.getHour() < minInclusive.getHour()) - gdurb.setHour(minInclusive.getHour()); - if (gdurb.getMinute() < minInclusive.getMinute()) - gdurb.setMinute(minInclusive.getMinute()); - if (gdurb.getSecond() < minInclusive.getSecond()) - gdurb.setSecond(minInclusive.getSecond()); - if (gdurb.getFraction().compareTo(minInclusive.getFraction()) < 0) - gdurb.setFraction(minInclusive.getFraction()); - } - - if (maxInclusive != null) { - if (gdurb.getYear() > maxInclusive.getYear()) - gdurb.setYear(maxInclusive.getYear()); - if (gdurb.getMonth() > maxInclusive.getMonth()) - gdurb.setMonth(maxInclusive.getMonth()); - if (gdurb.getDay() > maxInclusive.getDay()) - gdurb.setDay(maxInclusive.getDay()); - if (gdurb.getHour() > maxInclusive.getHour()) - gdurb.setHour(maxInclusive.getHour()); - if (gdurb.getMinute() > maxInclusive.getMinute()) - gdurb.setMinute(maxInclusive.getMinute()); - if (gdurb.getSecond() > maxInclusive.getSecond()) - gdurb.setSecond(maxInclusive.getSecond()); - if (gdurb.getFraction().compareTo(maxInclusive.getFraction()) > 0) - gdurb.setFraction(maxInclusive.getFraction()); - } - - if (minExclusive != null) { - if (gdurb.getYear() <= minExclusive.getYear()) - gdurb.setYear(minExclusive.getYear() + 1); - if (gdurb.getMonth() <= minExclusive.getMonth()) - gdurb.setMonth(minExclusive.getMonth() + 1); - if (gdurb.getDay() <= minExclusive.getDay()) - gdurb.setDay(minExclusive.getDay() + 1); - if (gdurb.getHour() <= minExclusive.getHour()) - gdurb.setHour(minExclusive.getHour() + 1); - if (gdurb.getMinute() <= minExclusive.getMinute()) - gdurb.setMinute(minExclusive.getMinute() + 1); - if (gdurb.getSecond() <= minExclusive.getSecond()) - gdurb.setSecond(minExclusive.getSecond() + 1); - if (gdurb.getFraction().compareTo(minExclusive.getFraction()) <= 0) - gdurb.setFraction(minExclusive.getFraction().add(new BigDecimal(0.001))); - } - - if (maxExclusive != null) { - if (gdurb.getYear() > maxExclusive.getYear()) - gdurb.setYear(maxExclusive.getYear()); - if (gdurb.getMonth() > maxExclusive.getMonth()) - gdurb.setMonth(maxExclusive.getMonth()); - if (gdurb.getDay() > maxExclusive.getDay()) - gdurb.setDay(maxExclusive.getDay()); - if (gdurb.getHour() > maxExclusive.getHour()) - gdurb.setHour(maxExclusive.getHour()); - if (gdurb.getMinute() > maxExclusive.getMinute()) - gdurb.setMinute(maxExclusive.getMinute()); - if (gdurb.getSecond() > maxExclusive.getSecond()) - gdurb.setSecond(maxExclusive.getSecond()); - if (gdurb.getFraction().compareTo(maxExclusive.getFraction()) > 0) - gdurb.setFraction(maxExclusive.getFraction()); - } - - gdurb.normalize(); - return gdurb.toString(); - } - - private String formatDate(SchemaType sType) { - GDateBuilder gdateb = new GDateBuilder(new Date(1000L * pick(365 * 24 * 60 * 60) + (30L + pick(20)) * 365 * 24 * 60 * 60 * 1000)); - GDate min = null, max = null; - GDate temp; - - // Find the min and the max according to the type - switch (sType.getPrimitiveType().getBuiltinTypeCode()) { - case SchemaType.BTC_DATE_TIME: { - XmlDateTime x = (XmlDateTime) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlDateTime) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlDateTime) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlDateTime) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_TIME: { - XmlTime x = (XmlTime) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlTime) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlTime) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlTime) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_DATE: { - XmlDate x = (XmlDate) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlDate) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlDate) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlDate) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_G_YEAR_MONTH: { - XmlGYearMonth x = (XmlGYearMonth) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlGYearMonth) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlGYearMonth) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlGYearMonth) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_G_YEAR: { - XmlGYear x = (XmlGYear) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlGYear) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlGYear) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlGYear) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_G_MONTH_DAY: { - XmlGMonthDay x = (XmlGMonthDay) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlGMonthDay) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlGMonthDay) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlGMonthDay) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_G_DAY: { - XmlGDay x = (XmlGDay) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlGDay) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlGDay) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlGDay) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - case SchemaType.BTC_G_MONTH: { - XmlGMonth x = (XmlGMonth) sType.getFacet(SchemaType.FACET_MIN_INCLUSIVE); - if (x != null) - min = x.getGDateValue(); - x = (XmlGMonth) sType.getFacet(SchemaType.FACET_MIN_EXCLUSIVE); - if (x != null) - if (min == null || min.compareToGDate(x.getGDateValue()) <= 0) - min = x.getGDateValue(); - - x = (XmlGMonth) sType.getFacet(SchemaType.FACET_MAX_INCLUSIVE); - if (x != null) - max = x.getGDateValue(); - x = (XmlGMonth) sType.getFacet(SchemaType.FACET_MAX_EXCLUSIVE); - if (x != null) - if (max == null || max.compareToGDate(x.getGDateValue()) >= 0) - max = x.getGDateValue(); - break; - } - } - - if (min != null && max == null) { - if (min.compareToGDate(gdateb) >= 0) { - // Reset the date to min + (1-8) hours - Calendar c = gdateb.getCalendar(); - c.add(Calendar.HOUR_OF_DAY, pick(8)); - gdateb = new GDateBuilder(c); - } - } else if (min == null && max != null) { - if (max.compareToGDate(gdateb) <= 0) { - // Reset the date to max - (1-8) hours - Calendar c = gdateb.getCalendar(); - c.add(Calendar.HOUR_OF_DAY, 0 - pick(8)); - gdateb = new GDateBuilder(c); - } - } else if (min != null && max != null) { - if (min.compareToGDate(gdateb) >= 0 || max.compareToGDate(gdateb) <= 0) { - // Find a date between the two - Calendar c = min.getCalendar(); - Calendar cmax = max.getCalendar(); - c.add(Calendar.HOUR_OF_DAY, 1); - if (c.after(cmax)) { - c.add(Calendar.HOUR_OF_DAY, -1); - c.add(Calendar.MINUTE, 1); - if (c.after(cmax)) { - c.add(Calendar.MINUTE, -1); - c.add(Calendar.SECOND, 1); - if (c.after(cmax)) { - c.add(Calendar.SECOND, -1); - c.add(Calendar.MILLISECOND, 1); - if (c.after(cmax)) - c.add(Calendar.MILLISECOND, -1); - } - } - } - gdateb = new GDateBuilder(c); - } - } - - gdateb.setBuiltinTypeCode(sType.getPrimitiveType().getBuiltinTypeCode()); - if (pick(2) == 0) - gdateb.clearTimeZone(); - return gdateb.toString(); - } - - private SchemaType closestBuiltin(SchemaType sType) { - while (!sType.isBuiltinType()) - sType = sType.getBaseType(); - return sType; - } - - /** - * Cracks a combined QName of the form URL:localname - */ - public static QName crackQName(String qName) { - String ns; - String name; - - int index = qName.lastIndexOf(':'); - if (index >= 0) { - ns = qName.substring(0, index); - name = qName.substring(index + 1); - } else { - ns = ""; - name = qName; - } - - return new QName(ns, name); - } - - /** - * Cursor position: - * Before this call: - * ^ (cursor at the ^) - * After this call: - * <som text^ - */ - private void processParticle(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - int loop = determineMinMaxForSample(sp, xmlc); - - while (loop-- > 0) { - switch (sp.getParticleType()) { - case (SchemaParticle.ELEMENT): - processElement(sp, xmlc, mixed); - break; - case (SchemaParticle.SEQUENCE): - processSequence(sp, xmlc, mixed); - break; - case (SchemaParticle.CHOICE): - processChoice(sp, xmlc, mixed); - break; - case (SchemaParticle.ALL): - processAll(sp, xmlc, mixed); - break; - case (SchemaParticle.WILDCARD): - processWildCard(sp, xmlc, mixed); - break; - default: - // throw new Exception("No Match on Schema Particle Type: " + String.valueOf(sp.getParticleType())); - } - } - } - - private int determineMinMaxForSample(SchemaParticle sp, XmlCursor xmlc) { - int minOccurs = sp.getIntMinOccurs(); - int maxOccurs = sp.getIntMaxOccurs(); - - if (minOccurs == maxOccurs) - return minOccurs; - - int result = minOccurs; - if (result == 0 && _nElements < MAX_ELEMENTS) - result = 1; - - if (sp.getParticleType() != SchemaParticle.ELEMENT) - return result; - - // it probably only makes sense to put comments in front of individual elements that repeat - - if (sp.getMaxOccurs() == null) { - // xmlc.insertComment("The next " + getItemNameOrType(sp, xmlc) + " may be repeated " + minOccurs + " or more times"); - if (minOccurs == 0) - xmlc.insertComment("Zero or more repetitions:"); - else - xmlc.insertComment(minOccurs + " or more repetitions:"); - } else if (sp.getIntMaxOccurs() > 1) { - xmlc.insertComment(minOccurs + " to " + String.valueOf(sp.getMaxOccurs()) + " repetitions:"); - } else { - xmlc.insertComment("Optional:"); - } - return result; - } - - /* - Return a name for the element or the particle type to use in the comment for minoccurs, max occurs - */ - private String getItemNameOrType(SchemaParticle sp, XmlCursor xmlc) { - String elementOrTypeName = null; - if (sp.getParticleType() == SchemaParticle.ELEMENT) { - elementOrTypeName = "Element (" + sp.getName().getLocalPart() + ")"; - } else { - elementOrTypeName = printParticleType(sp.getParticleType()); - } - return elementOrTypeName; - } - - private void processElement(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - // cast as schema local element - SchemaLocalElement element = (SchemaLocalElement) sp; - /// ^ -> ^ - if (_soapEnc) - xmlc.insertElement(element.getName().getLocalPart()); // soap encoded? drop namespaces. - else - xmlc.insertElement(element.getName().getLocalPart(), element.getName().getNamespaceURI()); - _nElements++; - /// -> ^ - xmlc.toPrevToken(); - // -> stuff^ - createSampleForType(element.getType(), xmlc); - // -> stuff^ - xmlc.toNextToken(); - - } - - private void moveToken(int numToMove, XmlCursor xmlc) { - for (int i = 0; i < Math.abs(numToMove); i++) { - if (numToMove < 0) { - xmlc.toPrevToken(); - } else { - xmlc.toNextToken(); - } - } - } - - private static final String formatQName(XmlCursor xmlc, QName qName) { - XmlCursor parent = xmlc.newCursor(); - parent.toParent(); - String prefix = parent.prefixForNamespace(qName.getNamespaceURI()); - parent.dispose(); - String name; - if (prefix == null || prefix.length() == 0) - name = qName.getLocalPart(); - else - name = prefix + ":" + qName.getLocalPart(); - return name; - } - - private static final QName HREF = new QName("href"); - - private static final QName ID = new QName("id"); - - private static final QName XSI_TYPE = new QName("http://www.w3.org/2001/XMLSchema-instance", "type"); - - private static final QName ENC_ARRAYTYPE = new QName("http://schemas.xmlsoap.org/soap/encoding/", "arrayType"); - - private static final QName ENC_OFFSET = new QName("http://schemas.xmlsoap.org/soap/encoding/", "offset"); - - private static final Set SKIPPED_SOAP_ATTRS = new HashSet(Arrays.asList(new QName[] { HREF, ID, ENC_OFFSET })); - - private void processAttributes(SchemaType stype, XmlCursor xmlc) { - if (_soapEnc) { - QName typeName = stype.getName(); - if (typeName != null) { - xmlc.insertAttributeWithValue(XSI_TYPE, formatQName(xmlc, typeName)); - } - } - - SchemaProperty[] attrProps = stype.getAttributeProperties(); - for (int i = 0; i < attrProps.length; i++) { - SchemaProperty attr = attrProps[i]; - if (_soapEnc) { - if (SKIPPED_SOAP_ATTRS.contains(attr.getName())) - continue; - if (ENC_ARRAYTYPE.equals(attr.getName())) { - SOAPArrayType arrayType = ((SchemaWSDLArrayType) stype.getAttributeModel().getAttribute(attr.getName())).getWSDLArrayType(); - if (arrayType != null) - xmlc.insertAttributeWithValue(attr.getName(), formatQName(xmlc, arrayType.getQName()) + arrayType.soap11DimensionString()); - continue; - } - } - String defaultValue = attr.getDefaultText(); - xmlc.insertAttributeWithValue(attr.getName(), defaultValue == null ? sampleDataForSimpleType(attr.getType()) : defaultValue); - } - } - - private void processSequence(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - SchemaParticle[] spc = sp.getParticleChildren(); - for (int i = 0; i < spc.length; i++) { - /// maybestuff^ - processParticle(spc[i], xmlc, mixed); - //maybestuff...morestuff^ - if (mixed && i < spc.length - 1) { - if (isGenerate_sample_data()) { - xmlc.insertChars(pick(WORDS)); - } else { - xmlc.insertChars(""); - } - } - } - } - - private void processChoice(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - SchemaParticle[] spc = sp.getParticleChildren(); - xmlc.insertComment("You have a CHOICE of the next " + String.valueOf(spc.length) + " items at this level"); - for (int i = 0; i < spc.length; i++) { - processParticle(spc[i], xmlc, mixed); - } - } - - private void processAll(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - SchemaParticle[] spc = sp.getParticleChildren(); - // xmlc.insertComment("You may enter the following " + String.valueOf(spc.length) + " items in any order"); - for (int i = 0; i < spc.length; i++) { - processParticle(spc[i], xmlc, mixed); - if (mixed && i < spc.length - 1) - xmlc.insertChars(pick(WORDS)); - } - } - - private void processWildCard(SchemaParticle sp, XmlCursor xmlc, boolean mixed) { - xmlc.insertComment("You may enter ANY elements at this point"); - xmlc.insertElement("AnyElement"); - } - - /** - * This method will get the base type for the schema type - */ - - private static QName getClosestName(SchemaType sType) { - while (sType.getName() == null) - sType = sType.getBaseType(); - - return sType.getName(); - } - - private String printParticleType(int particleType) { - StringBuffer returnParticleType = new StringBuffer(); - returnParticleType.append("Schema Particle Type: "); - - switch (particleType) { - case SchemaParticle.ALL: - returnParticleType.append("ALL\n"); - break; - case SchemaParticle.CHOICE: - returnParticleType.append("CHOICE\n"); - break; - case SchemaParticle.ELEMENT: - returnParticleType.append("ELEMENT\n"); - break; - case SchemaParticle.SEQUENCE: - returnParticleType.append("SEQUENCE\n"); - break; - case SchemaParticle.WILDCARD: - returnParticleType.append("WILDCARD\n"); - break; - default: - returnParticleType.append("Schema Particle Type Unknown"); - break; - } - - return returnParticleType.toString(); - } - - private ArrayList _typeStack = new ArrayList(); - - public boolean isGenerate_sample_data() { - return generate_sample_data; - } - - public void setGenerate_sample_data(boolean generate_sample_data) { - this.generate_sample_data = generate_sample_data; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XBbasedXMLGenerator.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XBbasedXMLGenerator.java deleted file mode 100644 index 128d65cecd..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XBbasedXMLGenerator.java +++ /dev/null @@ -1,253 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import java.io.ByteArrayInputStream; -import java.io.InputStream; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Hashtable; -import java.util.Iterator; -import java.util.List; - -import javax.wsdl.Definition; -import javax.wsdl.WSDLException; -import javax.wsdl.extensions.schema.Schema; -import javax.wsdl.factory.WSDLFactory; -import javax.wsdl.xml.WSDLReader; -import javax.xml.namespace.QName; - -import org.apache.xmlbeans.SchemaGlobalElement; -import org.apache.xmlbeans.SchemaType; -import org.apache.xmlbeans.SchemaTypeSystem; -import org.apache.xmlbeans.XmlBeans; -import org.apache.xmlbeans.XmlException; -import org.apache.xmlbeans.XmlObject; -import org.apache.xmlbeans.XmlOptions; -import org.apache.xmlbeans.impl.xsd2inst.SchemaInstanceGenerator; -import org.xml.sax.InputSource; - -import com.ibm.wsdl.util.xml.DOM2Writer; - -public class XBbasedXMLGenerator extends SchemaInstanceGenerator implements XMLGenerator { - private XMLfromXSDConfiguration config = null; - - public static final String QNAME_SEPARATOR = "#"; - - public XBbasedXMLGenerator(XMLfromXSDConfiguration config) { - this.config = config; - // config.setXsdInputStream(getClass().getResource(conf).openStream()); - } - - public Hashtable generateXmlAll() throws Exception { - Hashtable xmlInstances = new Hashtable(); - TuscanySampleXmlUtil xmlUtil = new TuscanySampleXmlUtil(); - xmlUtil.setGenerate_sample_data(config.isGenerateSampleData()); - SchemaTypeSystem sts = processXSDSources(); - SchemaType elementType = null; - for (SchemaGlobalElement globalElement : sts.globalElements()) { - elementType = getRootElementSchemaType(sts, globalElement.getName().getNamespaceURI(), globalElement.getName().getLocalPart()); - xmlInstances.put(makeQName(globalElement.getName()), XmlObject.Factory.parse(xmlUtil.createSampleForType(elementType))); - } - - return xmlInstances; - } - - public String generateXMLAsString() throws Exception { - SchemaTypeSystem sts = processXSDSources(); - SchemaType rootElementType = getRootElementSchemaType(sts, config.getSchemaTypeNamespaceURI(), config.getSchemaTypeName()); - String result = ""; - if (rootElementType != null) { - TuscanySampleXmlUtil xmlUtil = new TuscanySampleXmlUtil(); - xmlUtil.setGenerate_sample_data(config.isGenerateSampleData()); - result = xmlUtil.createSampleForType(rootElementType); - } else { - System.out.println("Could not find a global element with name \"" + config.getRootElementLocalName() + "\""); - } - return result; - } - - public void generateXMLIntoOutputStream() throws Exception { - config.getXmlOutputStream().write(generateXMLAsString().getBytes()); - } - - public void generateXML() throws Exception { - SchemaTypeSystem sts = processXSDSources(); - - SchemaType rootElementType = getRootElementSchemaType(sts, config.getSchemaTypeNamespaceURI(), config.getSchemaTypeName()); - - if (rootElementType != null) { - TuscanySampleXmlUtil xmlUtil = new TuscanySampleXmlUtil(); - xmlUtil.setGenerate_sample_data(config.isGenerateSampleData()); - String result = xmlUtil.createSampleForType(rootElementType); - config.getXmlOutputStream().write(result.getBytes()); - // System.out.println(result); - } else { - System.out.println("Could not find a global element with name \"" + config.getRootElementLocalName() + "\""); - } - } - - protected SchemaType getRootElementSchemaType(SchemaTypeSystem sts, String schemaNamespace, String schemaTypeName) { - SchemaType schemaType = null; - - if (sts == null) { - System.out.println("No Schemas to process."); - } else { - // first check in the global types - SchemaType[] globalTypes = sts.globalTypes(); - for (int i = 0; i < globalTypes.length; i++) { - if (schemaNamespace.equals(globalTypes[i].getName().getNamespaceURI()) - && schemaTypeName.equals(globalTypes[i].getName().getLocalPart())) { - schemaType = globalTypes[i]; - break; - } - } - - // next check for anonymous types defined inline within elements - if (schemaType == null) { - SchemaType[] globalElems = sts.documentTypes(); - for (int i = 0; i < globalElems.length; i++) { - if (schemaNamespace.equals(globalElems[i].getDocumentElementName().getNamespaceURI()) - && schemaTypeName.equals(globalElems[i].getDocumentElementName().getLocalPart())) { - schemaType = globalElems[i]; - break; - } - } - } - } - return schemaType; - } - - public void generateXML(XMLfromXSDConfiguration config) throws Exception { - this.config = config; - generateXML(); - } - - public XMLfromXSDConfiguration getConfig() { - return config; - } - - public void setConfig(XMLfromXSDConfiguration config) { - this.config = config; - } - - private Definition readInTheWSDLFile(InputStream wsdlStream) throws WSDLException { - WSDLReader reader = WSDLFactory.newInstance().newWSDLReader(); - reader.setFeature("javax.wsdl.importDocuments", true); - - /* - * File file = new File(uri); String baseURI; - * - * if (uri.startsWith("http://")){ baseURI = uri; } else{ if(file.getParentFile() == null){ try { baseURI = new - * File(".").getCanonicalFile().toURI().toString(); } catch (IOException e) { throw new RuntimeException(e); } } else { baseURI = - * file.getParentFile().toURI().toString(); } } - */ - // Document doc; - InputSource inputSource; - try { - - // doc = XMLUtils.newDocument(wsdlStream); - inputSource = new InputSource(wsdlStream); - /* - * } catch (ParserConfigurationException e) { throw new WSDLException(WSDLException.PARSER_ERROR, "Parser Configuration Error", e); } - * catch (SAXException e) { throw new WSDLException(WSDLException.PARSER_ERROR, "Parser SAX Error", e); - */ - } catch (Exception e) { - throw new WSDLException(WSDLException.INVALID_WSDL, "IO Error", e); - } - - // return reader.readWSDL(config.getRootElementNamespaceURI(), doc); - return reader.readWSDL(config.getRootElementNamespaceURI(), inputSource); - } - - protected InputStream[] getXSDsFromWSDL(InputStream xsdInputStream) throws Exception { - Definition defn = readInTheWSDLFile(xsdInputStream); - List list = defn.getTypes().getExtensibilityElements(); - - InputStream[] xsdFragments = new InputStream[list.size()]; - - Iterator iterator = list.iterator(); - Schema schemaElement = null; - - for (int count = 0; count < list.size(); ++count) { - schemaElement = (Schema) iterator.next(); - // System.out.println(" *** - " + element.getElementType().getNamespaceURI()); - // System.out.println(" **** - " + element + " & " + element.getClass().getPackage().getName()); - // System.out.println(DOM2Writer.nodeToString(element.getElement())); - xsdFragments[count] = new ByteArrayInputStream(DOM2Writer.nodeToString(schemaElement.getElement()).getBytes()); - } - - return xsdFragments; - } - - protected SchemaTypeSystem processXSDSources() throws Exception { - SchemaTypeSystem sts = null; - if (config.getXsdFileName().endsWith(XSD_FILE)) { - sts = processXSDs(new InputStream[] { config.getXsdInputStream() }); - } else if (config.getXsdFileName().endsWith(WSDL_FILE)) { - sts = processXSDs(getXSDsFromWSDL(config.getXsdInputStream())); - } - return sts; - } - - protected SchemaTypeSystem processXSDs(InputStream[] inputStreams) { - List sdocs = new ArrayList(); - for (int i = 0; i < inputStreams.length; i++) { - try { - sdocs.add(XmlObject.Factory.parse(inputStreams[i], (new XmlOptions()).setLoadLineNumbers().setLoadMessageDigest())); - } catch (Exception e) { - System.err.println("Can not load schema file: " + inputStreams[i] + ": "); - e.printStackTrace(); - } - } - - XmlObject[] schemas = (XmlObject[]) sdocs.toArray(new XmlObject[sdocs.size()]); - - SchemaTypeSystem sts = null; - if (schemas.length > 0) { - Collection errors = new ArrayList(); - XmlOptions compileOptions = new XmlOptions(); - /* - * if (dl) compileOptions.setCompileDownloadUrls(); if (nopvr) compileOptions.setCompileNoPvrRule(); if (noupa) - * compileOptions.setCompileNoUpaRule(); - */ - try { - sts = XmlBeans.compileXsd(schemas, XmlBeans.getBuiltinTypeSystem(), compileOptions); - } catch (Exception e) { - if (errors.isEmpty() || !(e instanceof XmlException)) - e.printStackTrace(); - - System.out.println("Schema compilation errors: "); - for (Iterator i = errors.iterator(); i.hasNext();) - System.out.println(i.next()); - } - } - - return sts; - } - - private String makeQName(String nameSpace, String localName) { - return nameSpace + QNAME_SEPARATOR + localName; - } - - private String makeQName(QName qName) { - return qName.getNamespaceURI() + QNAME_SEPARATOR + qName.getLocalPart(); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGenerator.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGenerator.java deleted file mode 100644 index 15848158e6..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGenerator.java +++ /dev/null @@ -1,52 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import java.util.Hashtable; - -import org.apache.xmlbeans.XmlObject; - -/** - * This is the XMLGenerator Interface that will be implemented by various - * types of Generators (SDO based, XMLBeans based etc.) - * - */ -public interface XMLGenerator { - public static final int SDO_BASED = 1; - - public static final int XMLBEANS_BASED = 2; - - public static final String XSD_FILE = ".xsd"; - - public static final String WSDL_FILE = ".wsdl"; - - public void generateXML() throws Exception; - - public void generateXML(XMLfromXSDConfiguration config) throws Exception; - - public void generateXMLIntoOutputStream() throws Exception; - - public String generateXMLAsString() throws Exception; - - public Hashtable generateXmlAll() throws Exception; - - public XMLfromXSDConfiguration getConfig(); - - public void setConfig(XMLfromXSDConfiguration config); -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGeneratorFactory.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGeneratorFactory.java deleted file mode 100644 index e4075557e8..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLGeneratorFactory.java +++ /dev/null @@ -1,55 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -/** - * This is a factory for creating XML Generators. The types of XML Generators - * are enumerated in the XMLGenerator interface. - * - */ -public class XMLGeneratorFactory { - private static XMLGeneratorFactory factory = null; - - protected XMLGeneratorFactory() { - - } - - public static XMLGeneratorFactory getInstance() { - if (factory == null) { - factory = new XMLGeneratorFactory(); - } - return factory; - } - - public XMLGenerator createGenerator(int generatorType) { - XMLGenerator generator = null; - switch (generatorType) { - case XMLGenerator.SDO_BASED: { - // generator = new SDObasedXMLGenerator(new XMLfromXSDConfiguration()); - break; - } - case XMLGenerator.XMLBEANS_BASED: { - generator = new XBbasedXMLGenerator(new XMLfromXSDConfiguration()); - break; - } - } - - return generator; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDConfiguration.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDConfiguration.java deleted file mode 100644 index 76f6b711bd..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDConfiguration.java +++ /dev/null @@ -1,246 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import java.io.File; -import java.io.FileInputStream; -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; -import java.net.URL; - -/** - * This class encapsulates the configuration settings for the "XML From XSD" generation. - * Presently it contains settings like the XSD to be use, the schematype for which and - * xml instance is to be created, the destination for the output etc. All of these - * settings are used by the 'generator' classes during the genation of the xml instance. - * - */ -public class XMLfromXSDConfiguration implements CmdLineArgsHandler { - private static int fileCount = 0; - - public static final String DEFAULT_XML_OUTPUT_FILENAME = "XML_FROM_XSD_" + (++fileCount) + ".xml"; - - public static final String XSD_FILE_URL_OPTION = "xsd"; - - public static final String XML_OUTPUT_LOCATION_OPTION = "o"; - - public static final String XML_OUTPUT_FILENAME_OPTION = "of"; - - public static final String ROOT_ELEMENT_NAMESPACE_URI_OPTION = "rns"; - - public static final String ROOT_ELEMENT_LOCALNAME_OPTION = "rn"; - - public static final String SCHEMA_TYPE_NAME = "st"; - - public static final String SCHEMA_TYPE_NAMESPACE_URI = "stn"; - - public static final String GENERATE_SAMPLE_DATA = "sd"; - - protected String xmlOutputLocation = null; - - protected File xmlOutputDirectory = null; - - protected String xsdFileName = null; - - protected String xmlFileName = null; - - protected InputStream xsdInputStream = null; - - protected OutputStream xmlOutputStream = null; - - protected String rootElementNamespaceURI = null; - - protected String rootElementLocalName = null; - - protected String schemaTypeName = null; - - protected String schemaTypeNamespaceURI = null; - - protected boolean generateSampleData = false; - - private void handleXSDInputFileOption(String xsdFileUrl) throws Exception { - xsdFileName = xsdFileUrl; - // xsdInputStream = new FileInputStream(new File(xsdFileName)); - URL resourceUrl = Thread.currentThread().getContextClassLoader().getResource(xsdFileName); - if (resourceUrl != null) { - xsdInputStream = resourceUrl.openStream(); - } else { - File inFile = new File(xsdFileName); - xsdFileName = inFile.getName(); - xsdInputStream = new FileInputStream(inFile); - } - } - - private void handleXMLOutputLocationOption(String outputLocation) throws Exception { - xmlOutputLocation = outputLocation; - xmlOutputDirectory = new File(xmlOutputLocation); - if (!xmlOutputDirectory.exists()) { - xmlOutputDirectory.mkdirs(); - } else if (!xmlOutputDirectory.isDirectory()) { - throw new IllegalArgumentException("The input location for the xml output " + outputLocation + "is not a folder"); - } - } - - private void handleOutputFilenameOption(String outputFileName) throws Exception { - xmlFileName = outputFileName; - - // first create a file in the given location - File outputFile = new File(xmlOutputDirectory, xmlFileName); - - try { - if (!outputFile.exists()) { - outputFile.createNewFile(); - } - xmlOutputStream = new FileOutputStream(outputFile); - } catch (IOException e) { - throw new Exception(e); - } - } - - public void handleArgument(String optionFlag, String argValue) throws IllegalArgumentException { - try { - if (XSD_FILE_URL_OPTION.equalsIgnoreCase(optionFlag)) { - handleXSDInputFileOption(argValue); - } else if (XML_OUTPUT_LOCATION_OPTION.equalsIgnoreCase(optionFlag)) { - handleXMLOutputLocationOption(argValue); - } else if (XML_OUTPUT_FILENAME_OPTION.equalsIgnoreCase(optionFlag)) { - handleOutputFilenameOption(argValue); - } else if (ROOT_ELEMENT_NAMESPACE_URI_OPTION.equalsIgnoreCase(optionFlag)) { - setRootElementNamespaceURI(argValue); - } else if (ROOT_ELEMENT_LOCALNAME_OPTION.equalsIgnoreCase(optionFlag)) { - setRootElementLocalName(argValue); - } else if (SCHEMA_TYPE_NAME.equalsIgnoreCase(optionFlag)) { - setSchemaTypeName(argValue); - } else if (SCHEMA_TYPE_NAMESPACE_URI.equalsIgnoreCase(optionFlag)) { - setSchemaTypeNamespaceURI(argValue); - } else if (GENERATE_SAMPLE_DATA.equalsIgnoreCase(optionFlag)) { - setGenerateSampleData(true); - } - } catch (Exception e) { - throw new IllegalArgumentException("Exception due to - " + e); - } - } - - public String getRootElementLocalName() { - if (rootElementLocalName == null) { - rootElementLocalName = schemaTypeName.toLowerCase(); - } - return rootElementLocalName; - } - - public void setRootElementLocalName(String rootElementLocalName) { - this.rootElementLocalName = rootElementLocalName; - } - - public String getRootElementNamespaceURI() { - if (rootElementNamespaceURI == null) { - rootElementNamespaceURI = schemaTypeNamespaceURI; - } - return rootElementNamespaceURI; - } - - public void setRootElementNamespaceURI(String rootElementNamespaceURI) { - this.rootElementNamespaceURI = rootElementNamespaceURI; - } - - public String getXmlFileName() { - if (xmlFileName == null) { - xmlFileName = getXsdFileName() + ".xml"; - } - return xmlFileName; - } - - public void setXmlFileName(String xmlFileName) { - this.xmlFileName = xmlFileName; - } - - public File getXmlOutputLocation() { - return xmlOutputDirectory; - } - - public void setXmlOutputLocation(File xmlOutputLocation) { - this.xmlOutputDirectory = xmlOutputLocation; - } - - public OutputStream getXmlOutputStream() throws Exception { - if (xmlOutputStream == null) { - if (xmlOutputDirectory == null) { - handleXMLOutputLocationOption(System.getProperty("user.dir")); - } - handleOutputFilenameOption(getXmlFileName()); - } - return xmlOutputStream; - } - - public void setXmlOutputStream(OutputStream xmlOutputStream) { - this.xmlOutputStream = xmlOutputStream; - } - - public String getXsdFileName() { - return xsdFileName; - } - - public void setXsdFileName(String xsdFileName) throws Exception { - this.xsdFileName = xsdFileName; - handleXSDInputFileOption(xsdFileName); - } - - public InputStream getXsdInputStream() throws Exception { - if (xsdInputStream == null) { - throw new IllegalArgumentException("XSD Input Source not set....!"); - } - return xsdInputStream; - } - - public void setXsdInputStream(InputStream xsdInputStream) { - this.xsdInputStream = xsdInputStream; - } - - public String getSchemaTypeName() { - return schemaTypeName; - } - - public void setSchemaTypeName(String schemaTypeName) { - this.schemaTypeName = schemaTypeName; - } - - public String getSchemaTypeNamespaceURI() { - return schemaTypeNamespaceURI; - } - - public void setSchemaTypeNamespaceURI(String schemaTypeNamespaceURI) { - this.schemaTypeNamespaceURI = schemaTypeNamespaceURI; - } - - public void setXmlOutputLocation(String xmlOutputLocation) throws Exception { - this.xmlOutputLocation = xmlOutputLocation; - handleXMLOutputLocationOption(xmlOutputLocation); - } - - public boolean isGenerateSampleData() { - return generateSampleData; - } - - public void setGenerateSampleData(boolean generateSampleData) { - this.generateSampleData = generateSampleData; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGenerator.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGenerator.java deleted file mode 100644 index 357d4203fe..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGenerator.java +++ /dev/null @@ -1,82 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -/** - * This class provides a command line tooling functinality for creating an XML - * instance from an input XSD. - */ -public class XMLfromXSDGenerator { - public static int generatorType = XMLGenerator.XMLBEANS_BASED; - - /** - * @param args - */ - public static void main(String[] args) { - try { - new XMLfromXSDGenerator().generateXMLInstance(args); - } catch (Exception e) { - e.printStackTrace(); - System.out.println(getPrintUsageMessage()); - } - } - - public void generateXMLInstance(String args[]) throws Exception { - // create a configuration object to hold settings for this generation - XMLfromXSDConfiguration config = new XMLfromXSDConfiguration(); - - // create an argument processor to process the input arguments - CmdLineArgsProcessor argsProcessor = new CmdLineArgsProcessor(); - - // configure the args processor with the 'config' object that must be populated - // with values from the proecessed input arguments - argsProcessor.setArgsHandler(config); - - // set the usage message to be output by the args processor if input arguments are not proper - argsProcessor.setPrintUsageMessage(getPrintUsageMessage()); - - // start processing the arguments - argsProcessor.processArgs(args); - - // now that the configuration settings are populated from the input arguments - // instantiate the xmlfromsdogenerator with this config object - - XMLGenerator generator = new XMLGeneratorFactory().createGenerator(generatorType); - // XBbasedXMLGenerator generator = new XBbasedXMLGenerator(config); - - // generate the xml instance - generator.generateXML(config); - } - - protected static String getPrintUsageMessage() { - StringBuffer strBuffer = new StringBuffer(); - strBuffer.append("Usage arguments:\n"); - strBuffer.append(" [ -rns ]\n"); - strBuffer.append(" [ -rn ]\n"); - strBuffer.append(" [ -xsd ]\n"); - strBuffer.append(" [ -of ]\n"); - strBuffer.append(" [ -o ]\n"); - strBuffer.append(" [ -st ]\n"); - strBuffer.append(" [ -stn ]\n"); - strBuffer.append(" [ -sd (provide this flag if sample data is to be generated)\n"); - - return strBuffer.toString(); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceCreationException.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceCreationException.java deleted file mode 100644 index 140d3efdb4..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceCreationException.java +++ /dev/null @@ -1,34 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -/** - * The Exception wrapper class for encasulating exceptions that occur during xml instance creation - * - */ -public class XmlInstanceCreationException extends Exception { - - public XmlInstanceCreationException(String message) { - super(message); - } - - public XmlInstanceCreationException(Exception e) { - super(e); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistry.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistry.java deleted file mode 100644 index 15f0fcfb73..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistry.java +++ /dev/null @@ -1,31 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import java.util.Map; - -import org.apache.xmlbeans.XmlObject; - -/** - * Interface for system registry of xml instances - * - */ -public interface XmlInstanceRegistry { - public Map getXmlInstance(String wsdlPath) throws XmlInstanceCreationException; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistryImpl.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistryImpl.java deleted file mode 100644 index 73b7232eae..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XmlInstanceRegistryImpl.java +++ /dev/null @@ -1,68 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import java.util.Hashtable; -import java.util.Map; - -import org.apache.xmlbeans.XmlObject; -import org.osoa.sca.annotations.Init; -import org.osoa.sca.annotations.Scope; - -/** - * An implementation for the XMLInstnaceRegistry - * - */ -@Scope("MODULE") -public class XmlInstanceRegistryImpl implements XmlInstanceRegistry { - - private Hashtable> wsdlXmlInstances; - - private XMLGenerator xmlGenerator; - - public XmlInstanceRegistryImpl() { - wsdlXmlInstances = new Hashtable>(); - - XMLfromXSDConfiguration generationConfig = new XMLfromXSDConfiguration(); - xmlGenerator = XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.XMLBEANS_BASED); - xmlGenerator.setConfig(generationConfig); - } - - @Init(eager = true) - public void init() { - } - - /* (non-Javadoc) - * @see org.apache.tuscany.container.javascript.XmlInstanceRegistry#getXmlInstance(java.lang.String, java.lang.String, java.lang.String) - */ - public Map getXmlInstance(String wsdlPath) throws XmlInstanceCreationException { - Map xmlInstanceMap = null; - if ((xmlInstanceMap = wsdlXmlInstances.get(wsdlPath)) == null) { - try { - xmlGenerator.getConfig().setXsdFileName(wsdlPath); - xmlInstanceMap = xmlGenerator.generateXmlAll(); - wsdlXmlInstances.put(wsdlPath, xmlInstanceMap); - } catch (Exception e) { - throw new XmlInstanceCreationException(e); - } - } - return xmlInstanceMap; - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/default.scdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/default.scdl deleted file mode 100644 index beb51e4c82..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/default.scdl +++ /dev/null @@ -1,51 +0,0 @@ - - - - - - - org.apache.tuscany.sca.services.containers - javascript - 1.0-incubator-M2-SNAPSHOT - - - - - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/js.system.scdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/js.system.scdl deleted file mode 100644 index 914c53c10c..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/main/resources/META-INF/sca/js.system.scdl +++ /dev/null @@ -1,45 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldService.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldService.java deleted file mode 100644 index e0b1ab2303..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldService.java +++ /dev/null @@ -1,27 +0,0 @@ -/* - * 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 helloworld; - -import org.apache.axiom.om.OMElement; - -public interface HelloWorldService { - - String sayHello(String s); - OMElement sayE4XHello(OMElement xmlObject); -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldServiceImpl.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldServiceImpl.java deleted file mode 100644 index ac17e29eb0..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/helloworld/HelloWorldServiceImpl.java +++ /dev/null @@ -1,55 +0,0 @@ -/* - * 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 helloworld; - -import java.io.ByteArrayInputStream; - -import javax.xml.stream.XMLStreamReader; - -import org.apache.axiom.om.OMAbstractFactory; -import org.apache.axiom.om.OMElement; -import org.apache.axiom.om.impl.builder.StAXOMBuilder; -import org.apache.axiom.om.util.StAXUtils; - -public class HelloWorldServiceImpl implements HelloWorldService { - - public OMElement sayE4XHello(OMElement xmlObject) { - - String helloString = "" - + "Hello from Java Implementation to NoString"; - - try { - String inputValue = xmlObject.getFirstElement().getText(); - - XMLStreamReader xmlReader = StAXUtils.createXMLStreamReader(new ByteArrayInputStream(helloString.getBytes())); - - StAXOMBuilder staxOMBuilder = new StAXOMBuilder(OMAbstractFactory.getOMFactory(), xmlReader); - OMElement response = staxOMBuilder.getDocumentElement(); - response.getFirstElement().setText(response.getFirstElement().getText() + inputValue); - - return response; - } catch (Exception e) { - return null; - } - } - - public String sayHello(String s) { - return "Hello " + s; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoaderTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoaderTestCase.java deleted file mode 100644 index b7f081bb70..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/JavaScriptImplementationLoaderTestCase.java +++ /dev/null @@ -1,107 +0,0 @@ -/* - * 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.container.javascript; - -import javax.xml.stream.XMLStreamException; -import javax.xml.stream.XMLStreamReader; - -import org.apache.tuscany.spi.component.CompositeComponent; -import org.apache.tuscany.spi.deployer.DeploymentContext; -import org.apache.tuscany.spi.loader.LoaderException; -import org.apache.tuscany.spi.loader.LoaderRegistry; -import org.apache.tuscany.spi.loader.MissingResourceException; - -import junit.framework.TestCase; -import static org.easymock.EasyMock.expect; -import static org.easymock.classextension.EasyMock.createMock; -import static org.easymock.classextension.EasyMock.replay; -import static org.easymock.classextension.EasyMock.verify; - -/** - * Tests for JavaScriptImplementationLoader - */ -public class JavaScriptImplementationLoaderTestCase extends TestCase { - private CompositeComponent parent; - - private XMLStreamReader reader; - - private DeploymentContext deploymentContext; - - private ClassLoader classLoader; - - private LoaderRegistry registry; - - private JavaScriptImplementationLoader loader; - - public void testNoScriptAttribute() throws LoaderException, XMLStreamException { - expect(reader.getAttributeValue(null, "script")).andReturn(null); - replay(reader); - replay(deploymentContext); - - try { - loader.load(parent, reader, deploymentContext); - fail(); - } catch (MissingResourceException e) { - // ok - } - verify(reader); - verify(deploymentContext); - } - - public void testNoScriptPresent() throws LoaderException, XMLStreamException { - expect(reader.getAttributeValue(null, "script")).andReturn("foo.groovy"); - expect(deploymentContext.getClassLoader()).andReturn(classLoader); - - replay(reader); - replay(deploymentContext); - - JavaScriptImplementationLoader mockLoader = new JavaScriptImplementationLoader(registry) { - protected String loadSource(ClassLoader cl, String resource) throws LoaderException { - assertSame(classLoader, cl); - assertEquals("foo.groovy", resource); - throw new MissingResourceException(resource); - } - }; - try { - mockLoader.load(parent, reader, deploymentContext); - fail(); - } catch (MissingResourceException e) { - assertEquals("foo.groovy", e.getMessage()); - } - verify(reader); - verify(deploymentContext); - } - - public void testLoadScript() throws LoaderException { - String script = - loader.loadSource(getClass().getClassLoader(), "org/apache/tuscany/container/javascript/mock/test.js"); - assertEquals("//Test Script", script); - } - - protected void setUp() throws Exception { - super.setUp(); - registry = createMock(LoaderRegistry.class); - loader = new JavaScriptImplementationLoader(registry); - - parent = createMock(CompositeComponent.class); - reader = createMock(XMLStreamReader.class); - deploymentContext = createMock(DeploymentContext.class); - classLoader = createMock(ClassLoader.class); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/PropertyTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/PropertyTestCase.java deleted file mode 100644 index 7287d7833f..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/PropertyTestCase.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * 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.container.javascript; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import junit.framework.TestCase; - -import org.apache.tuscany.container.javascript.mock.Greeting; -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.core.component.scope.ModuleScopeContainer; -import org.apache.tuscany.spi.wire.WireService; -import org.apache.tuscany.test.ArtifactFactory; - -/** - * Tests for component properties - */ -public class PropertyTestCase extends TestCase { - - private static final String SCRIPT = "function greet(name){ return property; }"; - - private RhinoScript implClass; - - /** - * Tests injecting a simple property type on a Javascript implementation instance - */ - public void testPropertyInjection() throws Exception { - /*ModuleScopeContainer scope = new ModuleScopeContainer(null); - scope.start(); - List> services = new ArrayList>(); - services.add(Greeting.class); - Map properties = new HashMap(); - properties.put("property", "bar"); - WireService wireService = ArtifactFactory.createWireService(); - JavaScriptComponent context = new JavaScriptComponent("source", implClass, services, properties, null, scope, wireService, null); - scope.register(context); - Greeting greeting = context.getServiceInstance(); - assertEquals("bar", greeting.greet("foo")); - scope.stop();*/ - } - - protected void setUp() throws Exception { - super.setUp(); - implClass = new RhinoScript("test", SCRIPT); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/RhinoScriptIntrospectorTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/RhinoScriptIntrospectorTestCase.java deleted file mode 100644 index 3a51a8f619..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/RhinoScriptIntrospectorTestCase.java +++ /dev/null @@ -1,114 +0,0 @@ -/* - * 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.container.javascript; - -import java.io.IOException; -import java.net.URL; -import java.util.Map; -import javax.wsdl.WSDLException; -import javax.xml.namespace.QName; - -import org.apache.tuscany.spi.idl.InvalidServiceContractException; -import org.apache.tuscany.spi.idl.java.JavaServiceContract; -import org.apache.tuscany.spi.loader.MissingResourceException; -import org.apache.tuscany.spi.model.ComponentType; -import org.apache.tuscany.spi.model.ServiceContract; -import org.apache.tuscany.spi.model.ServiceDefinition; - -import helloworld.HelloWorldService; -import junit.framework.TestCase; -import org.apache.tuscany.container.javascript.rhino.RhinoSCAConfig; -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.core.idl.java.JavaInterfaceProcessorRegistryImpl; -import org.apache.tuscany.idl.wsdl.WSDLDefinitionRegistryImpl; -import org.apache.tuscany.idl.wsdl.WSDLServiceContract; -import org.apache.tuscany.idl.wsdl.XMLSchemaRegistryImpl; - -public class RhinoScriptIntrospectorTestCase extends TestCase { - - private static final WSDLDefinitionRegistryImpl.Monitor NULL_MONITOR = new WSDLDefinitionRegistryImpl.Monitor() { - public void readingWSDL(String namespace, URL location) { - } - - public void cachingDefinition(String namespace, URL location) { - } - }; - - public void testJavaInterface() throws MissingResourceException, InvalidServiceContractException { - RhinoScript rs = - new RhinoScript("javaInterfaceTest", "SCA = { javaInterface : 'helloworld.HelloWorldService',};", - null, getClass().getClassLoader()); - RhinoSCAConfig scaConfig = new RhinoSCAConfig(rs.getScriptScope()); - JavaScriptIntrospector introspector = - new JavaScriptIntrospector(null, new JavaInterfaceProcessorRegistryImpl()); - ComponentType comonentType = introspector.introspectScript(scaConfig, rs.getClassLoader()); - assertNotNull(comonentType); - Map services = comonentType.getServices(); - assertEquals(1, services.size()); - ServiceDefinition serviceDefinition = (ServiceDefinition) services.values().iterator().next(); - ServiceContract serviceContract = serviceDefinition.getServiceContract(); - assertTrue(serviceContract instanceof JavaServiceContract); - JavaServiceContract javaServiceContract = (JavaServiceContract) serviceContract; - assertEquals(HelloWorldService.class, javaServiceContract.getInterfaceClass()); - } - - public void testWSDLLocation() throws WSDLException { -// RhinoScript rs = new RhinoScript("wsdlLocation", -// "SCA = { wsdlLocation : 'src/test/resources/org/apache/tuscany/container/javascript/rhino/helloworld.wsdl',};", null, getClass() -// .getClassLoader()); -// RhinoSCAConfig scaConfig = new RhinoSCAConfig(rs.getScriptScope()); -// JavaScriptIntrospector introspector = new JavaScriptIntrospector(null); -// ComponentType comonentType = introspector.introspectScript(scaConfig, rs.getClassLoader()); -// assertNotNull(comonentType); -// Map services = comonentType.getServices(); -// assertEquals(1, services.size()); -// ServiceDefinition serviceDefinition = (ServiceDefinition) services.values().iterator().next(); -// ServiceContract serviceContract = serviceDefinition.getServiceContract(); -// assertTrue(serviceContract instanceof WSDLServiceContract); -// WSDLServiceContract wsdlServiceContract = (WSDLServiceContract) serviceContract; -// assertEquals(new QName("http://helloworld", "HelloWorld"), wsdlServiceContract.getPortType().getQName()); - } - - public void testWSDLPortType() throws WSDLException, IOException, MissingResourceException, - InvalidServiceContractException { - RhinoScript rs = new RhinoScript("wsdlPortType", - "SCA = { wsdlPortType : 'HelloWorld', wsdlNamespace : 'http://helloworld',};", null, - getClass().getClassLoader()); - RhinoSCAConfig scaConfig = new RhinoSCAConfig(rs.getScriptScope()); - - WSDLDefinitionRegistryImpl wsdlReg = new WSDLDefinitionRegistryImpl(); - wsdlReg.setSchemaRegistry(new XMLSchemaRegistryImpl()); - wsdlReg.setMonitor(NULL_MONITOR); - URL wsdlURL = - getClass().getClassLoader().getResource("org/apache/tuscany/container/javascript/rhino/helloworld.wsdl"); - wsdlReg.loadDefinition("http://helloworld", wsdlURL); - - JavaScriptIntrospector introspector = - new JavaScriptIntrospector(wsdlReg, new JavaInterfaceProcessorRegistryImpl()); - ComponentType comonentType = introspector.introspectScript(scaConfig, rs.getClassLoader()); - assertNotNull(comonentType); - Map services = comonentType.getServices(); - assertEquals(1, services.size()); - ServiceDefinition serviceDefinition = (ServiceDefinition) services.values().iterator().next(); - ServiceContract serviceContract = serviceDefinition.getServiceContract(); - assertTrue(serviceContract instanceof WSDLServiceContract); - WSDLServiceContract wsdlServiceContract = (WSDLServiceContract) serviceContract; - assertEquals(new QName("http://helloworld", "HelloWorld"), wsdlServiceContract.getPortType().getQName()); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/ScriptInvokeTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/ScriptInvokeTestCase.java deleted file mode 100644 index 94835591df..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/ScriptInvokeTestCase.java +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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.container.javascript; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; - -import junit.framework.TestCase; - -import org.apache.tuscany.container.javascript.mock.Greeting; -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.core.component.scope.ModuleScopeContainer; -import org.apache.tuscany.test.ArtifactFactory; - -/** - * Tests for invoker JavaScriptComponents - */ -public class ScriptInvokeTestCase extends TestCase { - - private static final String SCRIPT = "function greet(name) { return name }"; - - private RhinoScript rhinoScript; - - /** - * Tests the invocation of a Groovy "script" as opposed to a class - */ - public void testBasicScriptInvocation() throws Exception { -// ModuleScopeContainer scope = new ModuleScopeContainer(null); -// scope.start(); -// List> services = new ArrayList>(); -// services.add(Greeting.class); -// JavaScriptComponent context = new JavaScriptComponent("source", rhinoScript, services, new HashMap(), -// null, scope, ArtifactFactory.createWireService(), null); -// scope.register(context); -// Greeting object = (Greeting) context.getServiceInstance(); -// assertEquals("foo", object.greet("foo")); -// scope.stop(); - } - - protected void setUp() throws Exception { - super.setUp(); - rhinoScript = new RhinoScript("test", SCRIPT); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/WireTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/WireTestCase.java deleted file mode 100644 index 8bf7f8e74a..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/WireTestCase.java +++ /dev/null @@ -1,161 +0,0 @@ -/* - * 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.container.javascript; - -import static org.easymock.EasyMock.reportMatcher; - -import java.lang.reflect.Type; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; - -import junit.framework.TestCase; - -import org.apache.tuscany.container.javascript.mock.Greeting; -import org.apache.tuscany.container.javascript.rhino.RhinoScript; -import org.apache.tuscany.core.component.scope.ModuleScopeContainer; -import org.apache.tuscany.spi.model.Operation; -import org.apache.tuscany.spi.wire.InboundInvocationChain; -import org.apache.tuscany.spi.wire.InboundWire; -import org.apache.tuscany.spi.wire.Message; -import org.apache.tuscany.spi.wire.TargetInvoker; -import org.apache.tuscany.test.ArtifactFactory; -import org.easymock.IArgumentMatcher; - -/** - * Tests for JavaScript component wiring - */ -public class WireTestCase extends TestCase { - - private static final String SCRIPT = - " function setWire(ref){" + - " wire = ref;" + " }" + - " " + - " function greet(name){" + - " return wire.greet(name); " + - " }"; - - private static final String SCRIPT2 = - " function greet(name){" + - " return name; " + - " }"; - - private RhinoScript implClass1; - - private RhinoScript implClass2; - - /** - * Tests a basic invocation down a source wire - */ - public void testReferenceWireInvocation() throws Exception { -// ModuleScopeContainer scope = new ModuleScopeContainer(null); -// scope.start(); -// -// List> services = new ArrayList>(); -// services.add(Greeting.class); -// JavaScriptComponent context = new JavaScriptComponent("source", implClass1, services, properties, null, scope, -// ArtifactFactory.createWireService(), null); -// OutboundWire wire = ArtifactFactory.createOutboundWire("wire", Greeting.class); -// ArtifactFactory.terminateWire(wire); -// -// TargetInvoker invoker = createMock(TargetInvoker.class); -// expect(invoker.isCacheable()).andReturn(false); -// Message response = new MessageImpl(); -// response.setBody("foo"); -// expect(invoker.invoke(eqMessage())).andReturn(response); -// replay(invoker); -// -// for (OutboundInvocationChain chain : wire.getInvocationChains().values()) { -// chain.setTargetInvoker(invoker); -// } -// scope.register(context); -// context.addOutboundWire(wire); -// Greeting greeting = context.getServiceInstance(); -// assertEquals("foo", greeting.greet("foo")); -// verify(invoker); -// -// scope.stop(); - } - - // todo this could be generalized and moved to test module - public static Message eqMessage() { - reportMatcher(new IArgumentMatcher() { - public boolean matches(Object object) { - if (!(object instanceof Message)) { - return false; - } - final Message msg = (Message) object; - Object[] body = (Object[]) msg.getBody(); - return "foo".equals(body[0]); - } - - public void appendTo(StringBuffer stringBuffer) { - } - }); - return null; - } - - /** - * Tests a basic invocation to a target - */ - public void testTargetInvocation() throws Exception { - ModuleScopeContainer scope = new ModuleScopeContainer(null); - scope.start(); - List> services = new ArrayList>(); - services.add(Greeting.class); - JavaScriptComponent context = - new JavaScriptComponent("source", implClass2, new HashMap(), services, null, scope, - ArtifactFactory.createWireService(), null); - scope.register(context); - Operation operation = new Operation("greet", null, null, null, false, null); - TargetInvoker invoker = context.createTargetInvoker(null, operation); - assertEquals("foo", invoker.invokeTarget(new String[]{"foo"})); - scope.stop(); - } - - /** - * Tests a basic invocation down a target wire - */ - public void testTargetWireInvocation() throws Exception { - ModuleScopeContainer scope = new ModuleScopeContainer(null); - scope.start(); - List> services = new ArrayList>(); - services.add(Greeting.class); - JavaScriptComponent context = - new JavaScriptComponent("source", implClass2, new HashMap(), services, null, scope, - ArtifactFactory.createWireService(), null); - scope.register(context); - - InboundWire wire = ArtifactFactory.createInboundWire("Greeting", Greeting.class); - ArtifactFactory.terminateWire(wire); - for (InboundInvocationChain chain : wire.getInvocationChains().values()) { - chain.setTargetInvoker(context.createTargetInvoker(null, chain.getOperation())); - } - context.addInboundWire(wire); - Greeting greeting = (Greeting) context.getServiceInstance("Greeting"); - assertEquals("foo", greeting.greet("foo")); - scope.stop(); - } - - protected void setUp() throws Exception { - super.setUp(); - implClass1 = new RhinoScript("script1", SCRIPT); - implClass2 = new RhinoScript("script2", SCRIPT2); - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/HelloWorldTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/HelloWorldTestCase.java deleted file mode 100644 index 3db49618e2..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/HelloWorldTestCase.java +++ /dev/null @@ -1,104 +0,0 @@ -/* - * 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.container.javascript.function; - -import helloworld.HelloWorldService; - -import java.io.ByteArrayInputStream; -import java.net.URL; - -import javax.xml.stream.XMLStreamReader; - -import org.apache.axiom.om.OMAbstractFactory; -import org.apache.axiom.om.OMElement; -import org.apache.axiom.om.impl.builder.StAXOMBuilder; -import org.apache.axiom.om.util.StAXUtils; -import org.apache.tuscany.test.SCATestCase; -import org.osoa.sca.CompositeContext; -import org.osoa.sca.CurrentCompositeContext; - -/** - * This shows how to test the HelloWorld service component. - */ -public class HelloWorldTestCase extends SCATestCase { - - private CompositeContext context; - - protected void setUp() throws Exception { - URL base = getClass().getResource("/META-INF/sca/js.system.scdl"); - addExtension("JavaScriptContainer", new URL(base, "default.scdl")); - setApplicationSCDL(getClass().getResource("helloworld.scdl")); - super.setUp(); - - context = CurrentCompositeContext.getContext(); - } - - public void testHelloWorld() throws Exception { - HelloWorldService helloWorldService = context.locateService(HelloWorldService.class, "HelloWorldComponent"); - assertEquals(helloWorldService.sayHello("petra"), "Hello petra"); - } - - public void testIntrospectedHelloWorld() throws Exception { - HelloWorldService introspectableService = context.locateService(HelloWorldService.class, "IntrospectableHelloWorldComponent"); - assertEquals(introspectableService.sayHello("petra"), "Hello petra"); - } - - public void testE4XImplInvocation() throws Exception { - HelloWorldService e4xHelloWorldService = context.locateService(HelloWorldService.class, "HelloWorldComponentE4X"); - String xmlInput = " " + - "TuscanyWorld " + - ""; - - XMLStreamReader xmlReader = StAXUtils.createXMLStreamReader( - new ByteArrayInputStream(xmlInput.getBytes())); - StAXOMBuilder staxOMBuilder = new StAXOMBuilder(OMAbstractFactory.getOMFactory(), xmlReader); - Object response = e4xHelloWorldService.sayE4XHello(staxOMBuilder.getDocumentElement()); - assertNotNull(response); - assertTrue(response instanceof OMElement); - assertEquals("e4xHello TuscanyWorld", ((OMElement)response).getFirstElement().getText()); - //System.out.println(response); - } - - public void testE4XRefInvocation() throws Exception - { - HelloWorldService e4xHelloWorldService = context.locateService(HelloWorldService.class, "HelloWorldComponentE4X"); - - String initialInput = "JavaClient"; - String jsAddition = " thro e4x reference"; - String endSvcImplResponse = "Hello from Java Implementation to "; - - Object response = e4xHelloWorldService.sayHello(initialInput); - assertNotNull(response); - assertTrue(response instanceof String); - assertEquals(endSvcImplResponse + initialInput + jsAddition, response.toString()); - //System.out.println(response); - } - - public void testHelloWorldProperty() throws Exception { - HelloWorldService helloWorldService = context.locateService(HelloWorldService.class, "HelloWorldProperty"); - assertEquals(helloWorldService.sayHello("petra"), "Kia ora petra"); - System.out.println(helloWorldService.sayHello("petra")); - } - - public void testHelloWorldPropertyDefault() throws Exception { - HelloWorldService helloWorldService = context.locateService(HelloWorldService.class, "HelloWorldPropertyDefault"); - assertEquals(helloWorldService.sayHello("petra"), "Hi petra"); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/ScopeTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/ScopeTestCase.java deleted file mode 100644 index b823939e6c..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/function/ScopeTestCase.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * 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.container.javascript.function; - -import java.net.URL; - -import helloworld.HelloWorldService; - -import org.apache.tuscany.test.SCATestCase; -import org.osoa.sca.CompositeContext; -import org.osoa.sca.CurrentCompositeContext; - -/** - * This shows how to test the HelloWorld service component. - */ -public class ScopeTestCase extends SCATestCase { - - private CompositeContext context; - - protected void setUp() throws Exception { - URL base = getClass().getResource("/META-INF/sca/js.system.scdl"); - addExtension("JavaScriptContainer", new URL(base, "default.scdl")); - setApplicationSCDL(getClass().getResource("scopeTest.scdl")); - super.setUp(); - - context = CurrentCompositeContext.getContext(); - } - -// Composite scope not implemented in core yet -// public void testComposite() throws Exception { -// HelloWorldService composoteScopeService = context.locateService(HelloWorldService.class, "ComposoteScopeService"); -// assertEquals("1", composoteScopeService.sayHello("")); -// assertEquals("2", composoteScopeService.sayHello("")); -// } - - public void testStateless() throws Exception { - HelloWorldService statelessService = context.locateService(HelloWorldService.class, "StatelessComponent"); - assertEquals("1", statelessService.sayHello("")); - // stateless gives a new instance for each request - assertEquals("1", statelessService.sayHello("")); - } - -// Request scope not implemented in core yet -// public void testRequestState() throws Exception { -// HelloWorldService requestService = context.locateService(HelloWorldService.class, "RequestComponent"); -// assertEquals("1", requestService.sayHello("")); -// assertEquals("1", requestService.sayHello("")); -// } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/mock/Greeting.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/mock/Greeting.java deleted file mode 100644 index e300f73469..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/mock/Greeting.java +++ /dev/null @@ -1,26 +0,0 @@ -/* - * 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.container.javascript.mock; - -public interface Greeting { - - String setWire(Greeting ref); - - String greet(String name); -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/Foo.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/Foo.java deleted file mode 100644 index 397501a23b..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/Foo.java +++ /dev/null @@ -1,34 +0,0 @@ -/* - * 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.container.javascript.rhino; - -class Foo { - private String s; - - public Foo() { - } - - public String getS() { - return s; - } - - public void setS(String s) { - this.s = s; - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvokerTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvokerTestCase.java deleted file mode 100644 index dad61659f3..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoFunctionInvokerTestCase.java +++ /dev/null @@ -1,174 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.io.IOException; - -import junit.framework.TestCase; - -import org.apache.axiom.om.OMElement; -import org.apache.xmlbeans.XmlException; -import org.apache.xmlbeans.XmlObject; - -/** - * Tests for the RhinoFunctionInvoker - */ -public class RhinoFunctionInvokerTestCase extends TestCase { - - public RhinoFunctionInvokerTestCase() { - } - - protected void setUp() throws Exception { - super.setUp(); - } - - public void testNoArgsInvoke() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getPetra() {return 'petra';}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getPetra"); - assertNotNull(invoker); - assertEquals("petra", invoker.invoke(null)); - } - - public void testOneArgInvoke() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getS(s) {return s;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getS"); - assertNotNull(invoker); - assertEquals("petra", invoker.invoke(new Object[] { "petra" })); - } - - public void testMultiArgsInvoke() { - RhinoScript rhinoScript = new RhinoScript("foo", "function concat(x, y) {return x + y}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("concat"); - assertNotNull(invoker); - assertEquals("petrasue", invoker.invoke(new Object[] { "petra", "sue" })); - } - - public void testNoResponseInvoke() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getNull() {}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getNull"); - assertNotNull(invoker); - assertEquals(null, invoker.invoke(new Object[0])); - } - - public void testNullResponseInvoke() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getNull() {return null;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getNull"); - assertNotNull(invoker); - assertEquals(null, invoker.invoke(new Object[0])); - } - - public void testResponseTypeDefaultString() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getTrue() {return true;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getTrue"); - assertNotNull(invoker); - Object o = invoker.invoke(new Object[0]); - assertTrue(o instanceof String); - assertEquals("true", o); - } - - public void testResponseTypeBoolean() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getTrue() {return true;}"); - //rhinoScript.setResponseClass("getTrue", Boolean.class); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getTrue", Boolean.class); - assertNotNull(invoker); - assertTrue((Boolean) invoker.invoke(new Object[0])); - } - - public void testResponseTypeStringArray() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getAs() {var as = new Array(1);as[0]='petra';return as;}"); - //rhinoScript.setResponseClass("getAs", new String[0].getClass()); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getAs", new String[0].getClass()); - assertNotNull(invoker); - Object o = invoker.invoke(new Object[0]); - assertNotNull(o); - assertTrue(o.getClass().isArray()); - assertEquals("petra", ((Object[]) o)[0]); - } - - public void testResponseTypeBooleanArray() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getBs() {var bs = new Array(1);bs[0]=true;return bs;}"); - rhinoScript.setResponseClass("getBs", new Boolean[0].getClass()); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getBs", new Boolean[0].getClass()); - assertNotNull(invoker); - Object o = invoker.invoke(new Object[0]); - assertNotNull(o); - assertTrue(o.getClass().isArray()); - assertTrue(((Boolean[]) o)[0]); - } - - public void testRequestCustomType() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getFooS(foo) {return foo.getS();}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getFooS"); - assertNotNull(invoker); - - Foo foo = new Foo(); - foo.setS("petra"); - Object o = invoker.invoke(new Object[] { foo }); - assertEquals(foo.getS(), o); - } - - public void testResponseCustomType() { - RhinoScript rhinoScript = new RhinoScript("foo", - "importClass(Packages.org.apache.tuscany.container.javascript.rhino.Foo);function getFoo(s) {var foo = new Foo(); foo.setS(s);return foo;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getFoo"); - assertNotNull(invoker); - - Object o = invoker.invoke(new Object[] { "petra" }); - assertNotNull(o); - assertEquals("petra", ((Foo) o).getS()); - } - - public void testXMLRequest() throws XmlException, IOException { - RhinoScript rhinoScript = new RhinoScript("foo", "function isXML(x) {return 'xml' == (typeof x);}"); - //rhinoScript.setResponseClass("isXML", Boolean.class); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("isXML", Boolean.class); - assertNotNull(invoker); - - Object xml = XmlObject.Factory.parse(""); - assertTrue((Boolean) invoker.invoke(new Object[] { xml })); - - Object notXML = "notXML"; - assertFalse((Boolean) invoker.invoke(new Object[] { notXML })); - } - - public void testXMLResponse() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getXML(s) {return { s } ;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getXML"); - assertNotNull(invoker); - - Object xml = invoker.invoke(new Object[] { "petra" }); - assertNotNull(xml); - assertTrue(xml instanceof OMElement); - assertEquals("petra", ((OMElement) xml).toString()); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfigTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfigTestCase.java deleted file mode 100644 index cddaa9c46f..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoSCAConfigTestCase.java +++ /dev/null @@ -1,116 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import junit.framework.TestCase; - -import org.apache.tuscany.spi.model.Scope; - -public class RhinoSCAConfigTestCase extends TestCase { - - public void testJavaInteface() { - RhinoScript rs = new RhinoScript("javaInterface", "SCA = { javaInterface : 'Test' }"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals("Test", scaConfig.getJavaInterface()); - } - - public void testWSDLLocation() { - RhinoScript rs = new RhinoScript("wsdlLocation", "SCA = { wsdlLocation : 'Test' }"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals("Test", scaConfig.getWSDLLocation()); - } - - public void testWSDLNamespace() { - RhinoScript rs = new RhinoScript("wsdlNamespace", "SCA = { wsdlNamespace : 'Test' }"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals("Test", scaConfig.getWSDLNamespace()); - } - - public void testWSDLPortType() { - RhinoScript rs = new RhinoScript("wsdlPortType", "SCA = { wsdlPortType : 'Test' }"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals("Test", scaConfig.getWSDLPortType()); - } - - public void testScopeStateless() { - RhinoScript rs = new RhinoScript("testScopeStateless", "SCA = { scope : 'stateless', javaInterface : 'helloworld.HelloWorldService'}"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals(Scope.STATELESS, scaConfig.getScope()); - } - - public void testScopeComposite() { - RhinoScript rs = new RhinoScript("testScopeComposite", "SCA = { scope : 'composite', javaInterface : 'helloworld.HelloWorldService'}"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals(Scope.MODULE, scaConfig.getScope()); // TODO - } - - public void testScopeConversational() { - RhinoScript rs = new RhinoScript("testScopeConversational", "SCA = { scope : 'conversational', javaInterface : 'helloworld.HelloWorldService'}"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals(Scope.SESSION, scaConfig.getScope()); - } - - public void testScopeRequest() { - RhinoScript rs = new RhinoScript("testScopeRequest", "SCA = { scope : 'request', javaInterface : 'helloworld.HelloWorldService'}"); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(scaConfig.hasSCAConfig()); - assertEquals(Scope.REQUEST, scaConfig.getScope()); - } - - public void testBadScope() { - RhinoScript rs = new RhinoScript("testScopeStateless", "SCA = { scope : 'rubbish', javaInterface : 'helloworld.HelloWorldService'}"); - try { - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - fail("expecting bad scope exception: " + scaConfig); - } catch (IllegalArgumentException e) { - } - } - - public void testNoConfig() { - RhinoScript rs = new RhinoScript("javaInterface", ""); - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - assertTrue(!scaConfig.hasSCAConfig()); - } - - public void testNoService() { - RhinoScript rs = new RhinoScript("javaInterface", "SCA = {}"); - try { - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - fail("expecting no service exception: " + scaConfig); - } catch (IllegalArgumentException e) { - } - } - - public void testDupicateInteface() { - RhinoScript rs = new RhinoScript("javaInterface", "SCA = { javaInterface : 'Test', wsdlLocation : 'Test' }"); - try { - RhinoSCAConfig scaConfig = rs.getSCAConfig(); - fail("expecting multiple service exception: " + scaConfig); - } catch (IllegalArgumentException e) { - } - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstanceTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstanceTestCase.java deleted file mode 100644 index 76d6c7c49d..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptInstanceTestCase.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import junit.framework.TestCase; - -/** - * Tests for the RhinoScriptInstance - */ -public class RhinoScriptInstanceTestCase extends TestCase { - - public RhinoScriptInstanceTestCase() { - - } - - protected void setUp() throws Exception { - super.setUp(); - } - - public void testInvokeFunction() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getPetra() {return 'petra';}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - assertEquals("petra", instance.invokeFunction("getPetra", new Object[0])); - } - - public void testCreateRhinoFunctionInvoker() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getPetra() {return 'petra';}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - RhinoFunctionInvoker invoker = instance.createRhinoFunctionInvoker("getPetra"); - assertNotNull(invoker); - assertEquals("petra", invoker.invoke(new Object[0])); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptTestCase.java deleted file mode 100644 index ab684c39ce..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/rhino/RhinoScriptTestCase.java +++ /dev/null @@ -1,83 +0,0 @@ -/* - * 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.container.javascript.rhino; - -import java.util.HashMap; -import java.util.Map; - -import junit.framework.TestCase; - -/** - * Tests for the RhinoScript - */ -public class RhinoScriptTestCase extends TestCase { - - public RhinoScriptTestCase() { - - } - - protected void setUp() throws Exception { - super.setUp(); - } - - public void testSimpleConstructor() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getPetra() {return 'petra';}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - assertEquals("petra", instance.invokeFunction("getPetra", new Object[0])); - } - - public void testFullConstructor() { - ClassLoader cl = getClass().getClassLoader(); - Map contexts = new HashMap(); - contexts.put("name", "petra"); - RhinoScript rhinoScript = new RhinoScript("foo", "function getName() {return name;}", contexts, cl); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - assertEquals("petra", instance.invokeFunction("getName", new Object[0])); - } - - public void testCreateInstance() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getPetra() {return 'petra';}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - assertNotNull(instance); - } - - public void testCreateInstanceWithContext() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getName() {return name;}"); - Map contexts = new HashMap(); - contexts.put("name", "petra"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(contexts); - assertEquals("petra", instance.invokeFunction("getName", new Object[0])); - } - - public void testDefaultResponseType() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getX() {return 42;}"); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - assertEquals("42", instance.invokeFunction("getX", new Object[0])); - } - - public void testSetResponseType() { - RhinoScript rhinoScript = new RhinoScript("foo", "function getX() {return 42;}"); - rhinoScript.setResponseClass("getX", Integer.class); - RhinoScriptInstance instance = rhinoScript.createRhinoScriptInstance(); - Object x = instance.invokeFunction("getX", new Object[0], Integer.class); - assertTrue(x instanceof Integer); - assertEquals(new Integer(42), x); - } - -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGeneratorTestCase.java b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGeneratorTestCase.java deleted file mode 100644 index 15752bdaa1..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/java/org/apache/tuscany/container/javascript/utils/xmlfromxsd/XMLfromXSDGeneratorTestCase.java +++ /dev/null @@ -1,129 +0,0 @@ -/* - * 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.container.javascript.utils.xmlfromxsd; - -import junit.framework.TestCase; - -public class XMLfromXSDGeneratorTestCase extends TestCase { - - protected void setUp() throws Exception { - super.setUp(); - } - - protected void tearDown() throws Exception { - super.tearDown(); - } - - /*public void testXMLInstance_SDO_based_1() - { - String[] arguments = new String[] { "-xsd", "sequences.xsd", - "-st", "MixedQuote", - "-stn", "http://www.example.com/sequences", - "-o", "target/xmlFromxsd-source", - "-of", "sequences_sdo.xml" - }; - - XMLfromXSDGenerator.main(arguments); - //File file = new File("target/java2wsdl-source/CustomerValue.wsdl"); - //assertTrue(file.exists() && file.isFile()); - } - - public void testXMLInstance_SDO_based_2() - { - try - { - XMLfromXSDConfiguration config = new XMLfromXSDConfiguration(); - config.setXsdFileName("interopdoc.wsdl"); - config.setSchemaTypeName("ComplexDocument"); - config.setSchemaTypeNamespaceURI("http://soapinterop.org/"); - config.setXmlOutputLocation("target/xmlFromxsd-source"); - config.setXmlFileName("interopdoc_sdo.xml"); - - XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.SDO_BASED).generateXML(config); - //XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.XMLBEANS_BASED).generateXML(config); - } - catch ( Exception e ) - { - e.printStackTrace(); - } - } - - public void testXMLInstance_SDO_based_3() - { - try - { - XMLfromXSDConfiguration config = new XMLfromXSDConfiguration(); - config.setXsdFileName("helloworld.wsdl"); - //config.setSchemaTypeName("getGreetings"); - config.setSchemaTypeName("ComplexGreetings"); - config.setSchemaTypeNamespaceURI("http://helloworldaxis.samples.tuscany.apache.org"); - config.setXmlOutputLocation("target/xmlFromxsd-source"); - config.setXmlFileName("helloworld_sdo.xml"); - - XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.SDO_BASED).generateXML(config); - } - catch ( Exception e ) - { - e.printStackTrace(); - } - }*/ - - public void testXMLInstance_XB_based_1() { - String[] arguments = new String[] { "-xsd", "src/test/resources/sequences.xsd", "-st", "mixedStockQuote", "-stn", - "http://www.example.com/sequences", "-o", "target/xmlFromxsd-source", "-of", "sequences_xb.xml" }; - - XMLfromXSDGenerator.generatorType = XMLGenerator.XMLBEANS_BASED; - XMLfromXSDGenerator.main(arguments); - /* - * File file = new File("target/java2wsdl-source/CustomerValue.wsdl"); assertTrue(file.exists() && file.isFile()); - */ - } - - public void testXMLInstance_XB_based_2() { - try { - XMLfromXSDConfiguration config = new XMLfromXSDConfiguration(); - config.setXsdFileName("interopdoc.wsdl"); - config.setSchemaTypeName("ComplexDocument"); - config.setSchemaTypeNamespaceURI("http://soapinterop.org/"); - config.setXmlOutputLocation("target/xmlFromxsd-source"); - config.setXmlFileName("interopdoc_xb.xml"); - - XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.XMLBEANS_BASED).generateXML(config); - } catch (Exception e) { - e.printStackTrace(); - } - } - - public void testXMLInstance_XB_based_3() { - try { - XMLfromXSDConfiguration config = new XMLfromXSDConfiguration(); - config.setXsdFileName("org/apache/tuscany/container/javascript/rhino/helloworld.wsdl"); - // config.setXsdFileName("helloworld.wsdl"); - config.setSchemaTypeName("getGreetings"); - // config.setSchemaTypeName("ComplexGreetings"); - config.setSchemaTypeNamespaceURI("http://helloworld"); - config.setXmlOutputLocation("target/xmlFromxsd-source"); - config.setXmlFileName("helloworld_xb.xml"); - - XMLGeneratorFactory.getInstance().createGenerator(XMLGenerator.XMLBEANS_BASED).generateXML(config); - } catch (Exception e) { - e.printStackTrace(); - } - } -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/AccountService.wsdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/AccountService.wsdl deleted file mode 100644 index 2a56a3c496..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/AccountService.wsdl +++ /dev/null @@ -1,242 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/interopdoc.wsdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/interopdoc.wsdl deleted file mode 100644 index 820c26ca34..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/interopdoc.wsdl +++ /dev/null @@ -1,180 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.componentType b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.componentType deleted file mode 100644 index bd1e9445c1..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.componentType +++ /dev/null @@ -1,26 +0,0 @@ - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.js deleted file mode 100644 index 520153329e..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/HelloWorld.js +++ /dev/null @@ -1,21 +0,0 @@ -/* - * 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. - */ -function sayHello(s) { - return "Hello " + s; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/IntrospectableHelloWorld.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/IntrospectableHelloWorld.js deleted file mode 100644 index 2f6b7e0675..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/IntrospectableHelloWorld.js +++ /dev/null @@ -1,25 +0,0 @@ -/* - * 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. - */ -SCA = { - 'javaInterface' : 'helloworld.HelloWorldService' -} - -function sayHello(s) { - return "Hello " + s; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/compositeScope.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/compositeScope.js deleted file mode 100644 index 4684b89e66..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/compositeScope.js +++ /dev/null @@ -1,29 +0,0 @@ -/* - * 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. - */ -SCA = { - scope : 'composite', - javaInterface : 'helloworld.HelloWorldService' -} - -x = 0; - -function sayHello(s) { - x = x + 1; - return x; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.componentType b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.componentType deleted file mode 100644 index 8f2d906f58..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.componentType +++ /dev/null @@ -1,33 +0,0 @@ - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.js deleted file mode 100644 index 3e9c00fcb9..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/e4x.js +++ /dev/null @@ -1,45 +0,0 @@ -/* - * 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. - */ - -function sayE4XHello(xmlIn) { - - var greeting = "e4xHello " + xmlIn..*::name; - var xmlOut = getXmlObject("http://helloworld","getGreetingsResponse"); - - var ns = new Namespace("http://helloworld"); - xmlOut.ns::getGreetingsReturn = greeting; - - return xmlOut; -} - - - - function sayHello(name) { - //create XML Request Object - var xmlIn = getXmlObject("http://helloworld","getGreetings"); - var ns = new Namespace("http://helloworld"); - xmlIn.ns::name = name + " thro e4x reference"; - - //invoke service thro service reference and obtain XML Response - var xmlOut = extHelloWorldService.sayE4XHello(xmlIn); - - //extract the content of response XML and return as string - var greeting = "" + xmlOut..*::getGreetingsReturn; - return greeting; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/helloworld.scdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/helloworld.scdl deleted file mode 100644 index c3c4f5c669..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/helloworld.scdl +++ /dev/null @@ -1,50 +0,0 @@ - - - - - - - - - - - - - - - HelloWorldJavaReference - - - - - - - - - Kia ora - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.componentType b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.componentType deleted file mode 100644 index 8e46971ea3..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.componentType +++ /dev/null @@ -1,28 +0,0 @@ - - - - - - - - - Hi - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.js deleted file mode 100644 index 96e21d0c75..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/propertyTest.js +++ /dev/null @@ -1,21 +0,0 @@ -/* - * 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. - */ -function sayHello(s) { - return GREETING + ' ' + s; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/requestScope.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/requestScope.js deleted file mode 100644 index bf8f840b91..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/requestScope.js +++ /dev/null @@ -1,30 +0,0 @@ -/* - * 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. - */ - -SCA = { - scope : 'request', - javaInterface : 'helloworld.HelloWorldService' -} - -x = 0; - -function sayHello(s) { - x = x + 1; - return x; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/scopeTest.scdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/scopeTest.scdl deleted file mode 100644 index 3754d69da1..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/scopeTest.scdl +++ /dev/null @@ -1,37 +0,0 @@ - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/statelessScope.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/statelessScope.js deleted file mode 100644 index 21f5104859..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/function/statelessScope.js +++ /dev/null @@ -1,29 +0,0 @@ -/* - * 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. - */ -SCA = { - scope : 'stateless', - javaInterface : 'helloworld.HelloWorldService' -} - -x = 0; - -function sayHello(s) { - x = x + 1; - return x; -} diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/mock/test.js b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/mock/test.js deleted file mode 100644 index ef2694b475..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/mock/test.js +++ /dev/null @@ -1 +0,0 @@ -//Test Script \ No newline at end of file diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/rhino/helloworld.wsdl b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/rhino/helloworld.wsdl deleted file mode 100644 index 67067f044a..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/org/apache/tuscany/container/javascript/rhino/helloworld.wsdl +++ /dev/null @@ -1,78 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/sequences.xsd b/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/sequences.xsd deleted file mode 100644 index a565f3fa65..0000000000 --- a/branches/sca-java-M2/sca/services/containers/container.javascript/src/test/resources/sequences.xsd +++ /dev/null @@ -1,100 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -- cgit v1.2.3