Skip to main content

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [List Home]
RE: [wtp-dev] Seeking approval for 105335 - Axis on Tomcat 4.1 doesnot work

+1

 


From: wtp-dev-bounces@xxxxxxxxxxx [mailto:wtp-dev-bounces@xxxxxxxxxxx] On Behalf Of Chris Brealey
Sent: Wednesday, July 27, 2005 2:00 PM
To: General discussion of project-wide or architectural issues.
Subject: Re: [wtp-dev] Seeking approval for 105335 - Axis on Tomcat 4.1 doesnot work

 


Further to Kathy's note, we are continuing to test our fix to 105335 on the Windows, Linux SuSE and Linux Red Hat and so far meeting with success. However, at this very late stage, I would like to encourage the community out there to also help test this patch. If you are willing and able, please try applying the patch* attached to 105335, then try running some basic Axis 1.2.1 Web service scenarios against Tomcat - especially Tomcat 4.1 - to help verify that the problem reported in 105335 is indeed fixed.

If, by 10pm EDT, there are no dissenting votes on the patch, and if we have approval from the PMC, I will commit and release it.

* There are two patches in 105335: (1) A source file patch for those with the SDK image and (2) A replacement jar for those running the binary image.

Thanks all,
Cheers - CB.

Chris Brealey
Senior Advisory Technical Manager, Rational Java Web Services, IBM Canada Ltd.
D3-275, D3/ENX/8200/MKM, 8200 Warden Avenue, Markham, Ontario, Canada, L6G 1C7
cbrealey@xxxxxxxxxx, 905.413.6038, tieline:969.6038, fax:905.413.4920


Kathy Chan/Toronto/IBM@IBMCA
Sent by: wtp-dev-bounces@xxxxxxxxxxx

07/27/2005 02:45 PM

Please respond to
"General discussion of project-wide or architectural issues."

To

wtp-dev@xxxxxxxxxxx, wtp-pmc@xxxxxxxxxxx

cc

 

Subject

[wtp-dev] Seeking approval for 105335 - Axis on Tomcat 4.1 does not        work

 

 

 





WTP PMC,

As per defect approval rules for 0.7, I would like to request approval for
defect 105335.

The defect fix is implemented and tested and I have reviewed it with Chris Brealey.


Defect
105335:

Starting with WTP0.7RC2 driver (after switching to Axis 1.2.1), creating bottom-up Web service using Axis runtime on Tomcat 4.1 does not work. You'll run into the following exception:

Unable to create WSDL from Java
NoClassDefFoundError: javax/activiation/DataHandler

After you hit this error, if you try to go thru a BU-Java scenario with Axis on
Tomcat 5.0, it will fail with a similar exception. Bottom line is, once you hit
this error, that's it, you can no longer create botton-up Web service. You need to
restart Eclipse WTP.


This problem does not occur with Tomcat 5.0.  Things will continue to work until you do a Axis on Tomcat 4.1
scenario.


We isolated the problem due to classloading behaviour in Axis 1.2.1 (please see the defect for more detail).  I'll be opening an Axis defect for this.  In the meanwhile, we workaround the problem by not passing in mail.jar and activation.jar in the classpath variable we pass to Axis

Java2WSDLAxisAnt.

 

I've verified that this change only affect the classpath variable used to set the classpath for Axis Java2WSDLAxisAnt.

I've tested this fix with Tomcat 4.0, 4.1, 5.0 and 5.5 and the Web services scenarios work fine.

Please discuss, vote, or feel free to ask any further follow up questions.
The development contact is Kathy Chan, kathy@xxxxxxxxxx.


Kathy Chan
Rational Studio Java Web Services, IBM Toronto Lab
D3-354, D3/R8V/8200/MKM, 8200 Warden Avenue, Markham, Ontario, Canada, L6G 1C7
kathy@xxxxxxxxxx, (905) 413-3022, tieline: 969-6038, fax: (905) 413-4920


----- Forwarded by Kathy Chan/Toronto/IBM on 27/07/2005 02:32 PM -----

Chris Brealey/Toronto/IBM@IBMCA
Sent by: wtp-dev-bounces@xxxxxxxxxxx

27/07/2005 01:27 PM

Please respond to
"General discussion of project-wide or architectural issues."

To

wtp-dev@xxxxxxxxxxx

cc

 

Subject

[wtp-dev] Fw: [Bug 105335] Axis on Tomcat 4.1 does not work

 

 

 






A heads up: Bug 105335 opened by Jeff represents a critical issue between Axis 1.2.1 and Tomcat 4.1. We will have to fix this somehow before releasing WTP 0.7. We are working on this and are hopeful of making a cheap and tactical fix as described by Jeff in the bug. Worst case is we revert to Axis 1.1.


Cheers - CB.

Chris Brealey
Senior Advisory Technical Manager, Rational Java Web Services, IBM Canada Ltd.
D3-275, D3/ENX/8200/MKM, 8200 Warden Avenue, Markham, Ontario, Canada, L6G 1C7
cbrealey@xxxxxxxxxx, 905.413.6038, tieline:969.6038, fax:905.413.4920

----- Forwarded by Chris Brealey/Toronto/IBM on 07/27/2005 01:21 PM -----

bugzilla-daemon@xxxxxxxxxxx

07/27/2005 12:48 PM

 

To

Chris Brealey/Toronto/IBM@IBMCA

cc

 

Subject

[Bug 105335] Axis on Tomcat 4.1 does not work



 

 






https://bugs.eclipse.org/bugs/show_bug.cgi?id=105335





------- Additional Comments From jeffliu@xxxxxxxxxx  2005-07-27 12:48 -------
The problem is that when the WS wizard invokes the Java2WSDLAxisAnt task, the
task itself will construct an AntClassLoader around the classpath that the WS
wizard passes into the task.

In a Tomcat 4.1 scenario, the classpath contains activation.jar and mail.jar,
whereas, in a Tomcat 5.0 scenario, the classpath does NOT contain the two jars.

After the AntClassLoader is constructed, Axis will CACHE this classloader in a
class call ClassUtils. Later on, when the TypeMappingRegistry is initialized,
the TypeMappingRegistry will determine whether type mapping for attachment is
needed. The way this is determined is by calling:

ClassUtils.forName("javax.activiation.DataHandler");

Of course this returns true because ClassUtils uses the CACHED AntClassLoader,
which has activation.jar and mail.jar on its classpath. So the
TypeMappingRegistry will go ahead and initialize the type mapping for
attachment. However, in the attachment type mapping's initialization method, it
does a:

Class.forName("javax.activiation.DataHandler");

instead of a:

ClassUtils.forName("javax.activiation.DataHandler");

Since Class.forName("...") will go to the Eclipse class loader, which does not
have activation.jar and mail.jar on its classpath. A NoClassDefFoundError is
being thrown. This exception propagates back to the WS wizard and the wizard
throws up an error dialog. IMHO, this is a bug in Axis. However, we are the one
that need to workaround it.....



------- You are receiving this mail because: -------
You are the assignee for the bug, or are watching the assignee._______________________________________________
wtp-dev mailing list
wtp-dev@xxxxxxxxxxx
https://dev.eclipse.org/mailman/listinfo/wtp-dev_______________________________________________
wtp-dev mailing list
wtp-dev@xxxxxxxxxxx
https://dev.eclipse.org/mailman/listinfo/wtp-dev


Back to the top