01: /**
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: * See the License for the specific language governing permissions and
15: * limitations under the License.
16: */package org.apache.openejb.test.stateful;
17:
18: import org.apache.openejb.test.ApplicationException;
19: import org.apache.openejb.test.object.OperationsPolicy;
20:
21: import java.util.Properties;
22:
23: /**
24: *
25: * @author <a href="mailto:david.blevins@visi.com">David Blevins</a>
26: * @author <a href="mailto:Richard@Monson-Haefel.com">Richard Monson-Haefel</a>
27: */
28: public interface BasicStatefulBusinessRemote {
29:
30: /**
31: * Reverses the string passed in then returns it
32: *
33: * @return string
34: */
35: public String businessMethod(String text);
36:
37: public Object echo(Object object);
38:
39: /**
40: * Throws an ApplicationException when invoked
41: *
42: */
43: public void throwApplicationException() throws ApplicationException;
44:
45: /**
46: * Throws a java.lang.NullPointerException when invoked
47: * This is a system exception and should result in the
48: * destruction of the instance and invalidation of the
49: * remote reference.
50: *
51: */
52: public void throwSystemException_NullPointer();
53:
54: /**
55: * Returns a report of the bean's
56: * runtime permissions
57: *
58: * @return properties
59: */
60: public Properties getPermissionsReport();
61:
62: /**
63: * Returns a report of the allowed opperations
64: * for one of the bean's methods.
65: *
66: * @param methodName The method for which to get the allowed opperations report
67: * @return operations policy
68: */
69: public OperationsPolicy getAllowedOperationsReport(String methodName);
70:
71: /**
72: * Verify if we can invoke remove() on a stateful session bean as a business method
73: */
74: public Object remove();
75: }
|