KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > openejb > test > entity > bmp > BmpRemoteIntfcTests


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: BmpRemoteIntfcTests.java 1096 2004-03-26 21:41:16Z dblevins $
44  */

45 package org.openejb.test.entity.bmp;
46
47
48 /**
49  * [5] Should be run as the fifth test suite of the BasicBmpTestClients
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 BmpRemoteIntfcTests extends BasicBmpTestClient{
55
56     public BmpRemoteIntfcTests(){
57         super("RemoteIntfc.");
58     }
59
60     protected void setUp() throws Exception JavaDoc{
61         super.setUp();
62         Object JavaDoc obj = initialContext.lookup("client/tests/entity/bmp/BasicBmpHome");
63         ejbHome = (BasicBmpHome)javax.rmi.PortableRemoteObject.narrow( obj, BasicBmpHome.class);
64         ejbObject = ejbHome.create("Forth Bean");
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      * Throw an application exception and make sure the exception
81      * reaches the bean nicely.
82      */

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

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

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

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