[
https://jira.codehaus.org/browse/MNG-4770?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Michael Osipov updated MNG-4770:
--------------------------------
Affects Version/s: (was: 2.2.x (to be reviewed))
> WSDL dependencies should not be transitive
> ------------------------------------------
>
> Key: MNG-4770
> URL: https://jira.codehaus.org/browse/MNG-4770
> Project: Maven 2 & 3
> Issue Type: Bug
> Components: Dependencies
> Reporter: Ove Gram Nipen
> Assignee: Benjamin Bentmann
>
> Some web service frameworks, such as CXF, lets you deploy wsdl artifacts in
> the maven repository. When another project (the client) depends on a wsdl
> artifact, the client should not receive the dependencies of the web service
> project transitively, since the web service is isolated.
> It is not possible to work around the problem by declaring the dependencies
> of the web service project as optional, since this leads to missing jar files
> in the web service's {{WEB-INF/lib}}.
> More specifically:
> Say you have a service called {{HelloService}}, defined in its own pom:
> {code}
> <project>
> <groupId>com.example</groupId>
> <artifactId>HelloService</artifactId>
> <version>1.0</version>
> <packaging>war</packaging>
> <dependencies>
> <dependency>
> <dependency>
> <groupId>org.springframework</groupId>
> <artifactId>spring-core</artifactId>
> <version>2.5.6</version>
> </dependency>
> ...
> </project>
> {code}
> {{HelloService}} uses the {{cxf-java2ws-plugin}}, which generates a wsdl file
> and installs it in the maven repository during {{mvn install}}.
> You then have a client project called {{HelloConsumer}}, defined in its own
> pom:
> {code}
> <project>
> <groupId>org.something</groupId>
> <artifactId>HelloConsumer</artifactId>
> <packaging>war</packaging>
> <dependencies>
> <dependency>
> <groupId>com.example</groupId>
> <artifactId>HelloService</artifactId>
> <version>1.0</version>
> <type>wsdl</type>
> </dependency>
> ...
> </project>
> {code}
> {{HelloConsumer}} would then use the {{maven-dependency-plugin}} together
> with the {{cxf-codegen-plugin}} to copy the wsdl locally and generate the
> necessary web service stubs.
> If you then do {{mvn dependency:tree}} on {{HelloConsumer}}, you would expect
> to see only {{HelloService}}, not spring, because {{HelloService}} and
> {{HelloConsumer}} are isolated from each other by the web service transport
> layer, most often http. *However, maven currently includes spring
> transitively*, which is wrong.
--
This message was sent by Atlassian JIRA
(v6.1.6#6162)