KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > openejb > test > stateless > StatelessRemoteIntfcTests


1 /**
2  * Redistribution and use of this software and associated documentation
3  * ("Software"), with or without modification, are permitted provided
4  * that the following conditions are met:
5  *
6  * 1. Redistributions of source code must retain copyright
7  * statements and notices. Redistributions must also contain a
8  * copy of this document.
9  *
10  * 2. Redistributions in binary form must reproduce the
11  * above copyright notice, this list of conditions and the
12  * following disclaimer in the documentation and/or other
13  * materials provided with the distribution.
14  *
15  * 3. The name "Exolab" must not be used to endorse or promote
16  * products derived from this Software without prior written
17  * permission of Exoffice Technologies. For written permission,
18  * please contact info@exolab.org.
19  *
20  * 4. Products derived from this Software may not be called "Exolab"
21  * nor may "Exolab" appear in their names without prior written
22  * permission of Exoffice Technologies. Exolab is a registered
23  * trademark of Exoffice Technologies.
24  *
25  * 5. Due credit should be given to the Exolab Project
26  * (http://www.exolab.org/).
27  *
28  * THIS SOFTWARE IS PROVIDED BY EXOFFICE TECHNOLOGIES AND CONTRIBUTORS
29  * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT
30  * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
31  * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
32  * EXOFFICE TECHNOLOGIES OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
33  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
35  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
36  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
37  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
38  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
39  * OF THE POSSIBILITY OF SUCH DAMAGE.
40  *
41  * Copyright 1999 (C) Exoffice Technologies Inc. All Rights Reserved.
42  *
43  * $Id: StatelessRemoteIntfcTests.java 1096 2004-03-26 21:41:16Z dblevins $
44  */

45 package org.openejb.test.stateless;
46
47
48 /**
49  * [5] Should be run as the fifth test suite of the BasicStatelessTestClients
50  *
51  * @author <a HREF="mailto:david.blevins@visi.com">David Blevins</a>
52  * @author <a HREF="mailto:Richard@Monson-Haefel.com">Richard Monson-Haefel</a>
53  */

54 public class StatelessRemoteIntfcTests extends BasicStatelessTestClient{
55
56     public StatelessRemoteIntfcTests(){
57         super("RemoteIntfc.");
58     }
59
60     protected void setUp() throws Exception JavaDoc{
61         super.setUp();
62         Object JavaDoc obj = initialContext.lookup("client/tests/stateless/BasicStatelessHome");
63         ejbHome = (BasicStatelessHome)javax.rmi.PortableRemoteObject.narrow( obj, BasicStatelessHome.class);
64         ejbObject = ejbHome.create();
65     }
66     
67     //=================================
68
// Test remote interface methods
69
//
70
public void test01_businessMethod(){
71         try{
72             String JavaDoc expected = "Success";
73             String JavaDoc actual = ejbObject.businessMethod("sseccuS");
74             assertEquals(expected, actual);
75         } catch (Exception JavaDoc e){
76             fail("Received Exception "+e.getClass()+ " : "+e.getMessage());
77         }
78     }
79
80     /**
81      * Throw an application exception and make sure the exception
82      * reaches the bean nicely.
83      */

84     public void test02_throwApplicationException(){
85         try{
86             ejbObject.throwApplicationException();
87         } catch (org.openejb.test.ApplicationException e){
88             //Good. This is the correct behaviour
89
return;
90         } catch (Throwable JavaDoc e){
91             fail("Received Exception "+e.getClass()+ " : "+e.getMessage());
92         }
93         fail("An ApplicationException should have been thrown.");
94     }
95     
96     /**
97      * After an application exception we should still be able to
98      * use our bean
99      */

100     public void test03_invokeAfterApplicationException(){
101         try{
102         String JavaDoc expected = "Success";
103         String JavaDoc actual = ejbObject.businessMethod("sseccuS");
104         assertEquals(expected, actual);
105         } catch (Throwable JavaDoc e){
106             fail("Received Exception "+e.getClass()+ " : "+e.getMessage());
107         }
108     }
109
110     public void test04_throwSystemException(){
111         try{
112             ejbObject.throwSystemException_NullPointer();
113         } catch (java.rmi.RemoteException JavaDoc e){
114             //Good, so far.
115
Throwable JavaDoc n = e.detail;
116             assertNotNull("Nested exception should not be is null", n );
117             assertTrue("Nested exception should be an instance of NullPointerException, but exception is "+n.getClass().getName(), (n instanceof NullPointerException JavaDoc));
118             return;
119         } catch (Throwable JavaDoc e){
120             fail("Received Exception "+e.getClass()+ " : "+e.getMessage());
121         }
122         fail("A NullPointerException should have been thrown.");
123     }
124     
125     /**
126      * After a system exception the intance should be garbage collected
127      * and the remote reference should be invalidated.
128      *
129      * This one seems to fail. we should double-check the spec on this.
130      */

131     public void TODO_test05_invokeAfterSystemException(){
132         try{
133         ejbObject.businessMethod("This refernce is invalid");
134         fail("A java.rmi.NoSuchObjectException should have been thrown.");
135         } catch (java.rmi.NoSuchObjectException JavaDoc e){
136             // Good.
137
} catch (Throwable JavaDoc e){
138             fail("Received Exception "+e.getClass()+ " : "+e.getMessage());
139         }
140     }
141     //
142
// Test remote interface methods
143
//=================================
144

145     protected void tearDown() throws Exception JavaDoc {
146         super.tearDown();
147     }
148 }
149
Popular Tags