diff options
Diffstat (limited to 'sca-java-1.x/trunk/modules')
-rw-r--r-- | sca-java-1.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/impl/NodeImpl.java | 42 |
1 files changed, 21 insertions, 21 deletions
diff --git a/sca-java-1.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/impl/NodeImpl.java b/sca-java-1.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/impl/NodeImpl.java index 4a93993560..0f110f0584 100644 --- a/sca-java-1.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/impl/NodeImpl.java +++ b/sca-java-1.x/trunk/modules/node-impl/src/main/java/org/apache/tuscany/sca/node/impl/NodeImpl.java @@ -140,7 +140,7 @@ public class NodeImpl implements SCANode, SCAClient { configuration.getComposite().setURI(compositeURL.toString()); // Configure the node - configureNode(configuration); + configureNode(configuration, null); } catch (ServiceRuntimeException e) { throw e; @@ -162,7 +162,7 @@ public class NodeImpl implements SCANode, SCAClient { initRuntime(); ConfiguredNodeImplementation config = findNodeConfiguration(null, null); - configureNode(config); + configureNode(config, null); } catch (ServiceRuntimeException e) { throw e; } catch (Throwable e) { @@ -197,7 +197,7 @@ public class NodeImpl implements SCANode, SCAClient { initRuntime(); ConfiguredNodeImplementation config = findNodeConfiguration(compositeURI, classLoader); - configureNode(config); + configureNode(config, null); } catch (ServiceRuntimeException e) { throw e; } catch (Throwable e) { @@ -378,7 +378,7 @@ public class NodeImpl implements SCANode, SCAClient { } // Configure the node - configureNode(configuration); + configureNode(configuration, null); } catch (ServiceRuntimeException e) { throw e; @@ -420,20 +420,7 @@ public class NodeImpl implements SCANode, SCAClient { modelFactories.getFactory(NodeImplementationFactory.class); configuration = nodeImplementationFactory.createConfiguredNodeImplementation(); - // Read the composite model - StAXArtifactProcessor<Composite> compositeProcessor = artifactProcessors.getProcessor(Composite.class); - // URL compositeURL = new URL(compositeURI); - logger.log(Level.INFO, "Loading composite: " + compositeURI); - - CompositeDocumentProcessor compositeDocProcessor = - (CompositeDocumentProcessor)documentProcessors.getProcessor(Composite.class); - composite = - compositeDocProcessor.read(URI.create(compositeURI), new ByteArrayInputStream(compositeContent - .getBytes("UTF-8"))); - - analyzeProblems(); - - configuration.setComposite(composite); + // Defer reading the composite content until the contributions have been loaded (TUSCANY-3569) // Create contribution models ContributionFactory contributionFactory = modelFactories.getFactory(ContributionFactory.class); @@ -444,7 +431,7 @@ public class NodeImpl implements SCANode, SCAClient { } // Configure the node - configureNode(configuration); + configureNode(configuration, compositeContent); } catch (ServiceRuntimeException e) { throw e; @@ -503,7 +490,7 @@ public class NodeImpl implements SCANode, SCAClient { return URI.create(uri); } - private void configureNode(ConfiguredNodeImplementation configuration) throws Exception { + private void configureNode(ConfiguredNodeImplementation configuration, String compositeContent) throws Exception { // Find if any contribution JARs already available locally on the classpath Map<String, URL> localContributions = localContributions(); @@ -539,7 +526,20 @@ public class NodeImpl implements SCANode, SCAClient { } composite = configuration.getComposite(); - + + // Read the composite content after the contributions have been loaded, so that the + // policySet definitions provided by the contributions are available (TUSCANY-3569) + if (composite == null && compositeContent != null) { + logger.log(Level.INFO, "Loading composite: " + configurationName); + CompositeDocumentProcessor compositeDocProcessor = + (CompositeDocumentProcessor)documentProcessors.getProcessor(Composite.class); + composite = + compositeDocProcessor.read(URI.create(configurationName), new ByteArrayInputStream(compositeContent + .getBytes("UTF-8"))); + analyzeProblems(); + configuration.setComposite(composite); + } + if(composite != null && composite.isUnresolved()) { ContributionFactory contributionFactory = modelFactories.getFactory(ContributionFactory.class); Artifact compositeFile = contributionFactory.createArtifact(); |