[jboss-cvs] JBossAS SVN: r82755 - in projects/metadata/trunk/src: test/java/org/jboss/test/metadata/jbmeta165/unit and 1 other directory.
jboss-cvs-commits at lists.jboss.org
jboss-cvs-commits at lists.jboss.org
Sun Jan 11 05:01:24 EST 2009
Author: ALRubinger
Date: 2009-01-11 05:01:23 -0500 (Sun, 11 Jan 2009)
New Revision: 82755
Added:
projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossServicePolicyDecorator.java
Modified:
projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossSessionPolicyDecorator.java
projects/metadata/trunk/src/test/java/org/jboss/test/metadata/jbmeta165/unit/ServiceBeanWrappedInPolicyDecoratorTestCase.java
Log:
[JBMETA-165] Provide a JBossServicePolicyDecorator to delegate @Service bean operations to underlying metadata
Added: projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossServicePolicyDecorator.java
===================================================================
--- projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossServicePolicyDecorator.java (rev 0)
+++ projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossServicePolicyDecorator.java 2009-01-11 10:01:23 UTC (rev 82755)
@@ -0,0 +1,86 @@
+/*
+ * JBoss, Home of Professional Open Source.
+ * Copyright 2008, Red Hat Middleware LLC, and individual contributors
+ * as indicated by the @author tags. See the copyright.txt file in the
+ * distribution for a full listing of individual contributors.
+ *
+ * This is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Lesser General Public License as
+ * published by the Free Software Foundation; either version 2.1 of
+ * the License, or (at your option) any later version.
+ *
+ * This software is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this software; if not, write to the Free
+ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
+ */
+package org.jboss.metadata.ejb.jboss.jndipolicy.plugins;
+
+import org.jboss.metadata.ejb.jboss.JBossEnterpriseBeanMetaData;
+import org.jboss.metadata.ejb.jboss.JBossServiceBeanMetaData;
+import org.jboss.metadata.ejb.jboss.jndipolicy.spi.DefaultJndiBindingPolicy;
+
+/**
+ * JBossServicePolicyDecorator
+ *
+ * @author <a href="mailto:andrew.rubinger at jboss.org">ALR</a>
+ * @version $Revision: $
+ */
+public class JBossServicePolicyDecorator extends JBossSessionPolicyDecorator<JBossServiceBeanMetaData>
+{
+
+ private static final long serialVersionUID = 1L;
+
+ public JBossServicePolicyDecorator(JBossServiceBeanMetaData delegate, DefaultJndiBindingPolicy jndiPolicy)
+ {
+ super(delegate, jndiPolicy);
+ }
+
+ @Override
+ public String getManagement()
+ {
+ return this.getDelegate().getManagement();
+ }
+
+ @Override
+ public String getObjectName()
+ {
+ return this.getDelegate().getObjectName();
+ }
+
+ @Override
+ public String getXmbean()
+ {
+ return this.getDelegate().getXmbean();
+ }
+
+ @Override
+ public void merge(JBossEnterpriseBeanMetaData overrideEjb, JBossEnterpriseBeanMetaData originalEjb)
+ {
+ this.getDelegate().merge(overrideEjb, originalEjb);
+ }
+
+ @Override
+ public void setManagement(String management)
+ {
+ this.getDelegate().setManagement(management);
+ }
+
+ @Override
+ public void setObjectName(String objectName)
+ {
+ this.getDelegate().setObjectName(objectName);
+ }
+
+ @Override
+ public void setXmbean(String xmBean)
+ {
+ this.getDelegate().setXmbean(xmBean);
+ }
+
+}
Modified: projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossSessionPolicyDecorator.java
===================================================================
--- projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossSessionPolicyDecorator.java 2009-01-11 09:57:51 UTC (rev 82754)
+++ projects/metadata/trunk/src/main/java/org/jboss/metadata/ejb/jboss/jndipolicy/plugins/JBossSessionPolicyDecorator.java 2009-01-11 10:01:23 UTC (rev 82755)
@@ -108,17 +108,18 @@
* @author <a href="mailto:andrew.rubinger at jboss.org">ALR</a>
* @version $Revision: $
*/
-public class JBossSessionPolicyDecorator extends JBossServiceBeanMetaData implements ResolveableJndiNameJbossSessionBeanMetadata
+public class JBossSessionPolicyDecorator<T extends JBossSessionBeanMetaData> extends JBossServiceBeanMetaData implements ResolveableJndiNameJbossSessionBeanMetadata
{
private static final long serialVersionUID = 1L;
private static final Logger log = Logger.getLogger(JBossSessionPolicyDecorator.class);
- private JBossSessionBeanMetaData delegate;
+ private T delegate;
private DefaultJndiBindingPolicy jndiPolicy;
- public JBossSessionPolicyDecorator(JBossSessionBeanMetaData delegate, DefaultJndiBindingPolicy jndiPolicy)
+ @SuppressWarnings("unchecked")
+ public JBossSessionPolicyDecorator(T delegate, DefaultJndiBindingPolicy jndiPolicy)
{
assert delegate != null : "delegate is null";
assert jndiPolicy != null : this.getClass().getSimpleName() + " requires a specified "
@@ -127,8 +128,8 @@
// Disallow double-wrapping
if(delegate instanceof JBossSessionPolicyDecorator)
{
- JBossSessionPolicyDecorator d =(JBossSessionPolicyDecorator)delegate;
- delegate = d.delegate;
+ JBossSessionPolicyDecorator<T> d =(JBossSessionPolicyDecorator<T>)delegate;
+ delegate = d.getDelegate();
}
this.delegate = delegate;
@@ -206,6 +207,11 @@
{
this.jndiPolicy = policy;
}
+
+ public T getDelegate()
+ {
+ return delegate;
+ }
/**
* Returns the resolved JNDI Name for the specified
@@ -1418,4 +1424,56 @@
{
delegate.setTransactionType(transactionType);
}
+
+ /*
+ * Unsupported Operations Beyond This Point
+ *
+ * JBMETA-165
+ *
+ * For these instead use JBossServicePolicyDecorator
+ */
+
+ private static final String ERROR_MESSAGE_SERVICE_NOT_SUPPORTED = "Instead use " + JBossServicePolicyDecorator.class.getSimpleName();
+
+ @Override
+ public String getManagement()
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public String getObjectName()
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public String getXmbean()
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public void merge(JBossEnterpriseBeanMetaData overrideEjb, JBossEnterpriseBeanMetaData originalEjb)
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public void setManagement(String management)
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public void setObjectName(String objectName)
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
+
+ @Override
+ public void setXmbean(String xmBean)
+ {
+ throw new UnsupportedOperationException(ERROR_MESSAGE_SERVICE_NOT_SUPPORTED);
+ }
}
Modified: projects/metadata/trunk/src/test/java/org/jboss/test/metadata/jbmeta165/unit/ServiceBeanWrappedInPolicyDecoratorTestCase.java
===================================================================
--- projects/metadata/trunk/src/test/java/org/jboss/test/metadata/jbmeta165/unit/ServiceBeanWrappedInPolicyDecoratorTestCase.java 2009-01-11 09:57:51 UTC (rev 82754)
+++ projects/metadata/trunk/src/test/java/org/jboss/test/metadata/jbmeta165/unit/ServiceBeanWrappedInPolicyDecoratorTestCase.java 2009-01-11 10:01:23 UTC (rev 82755)
@@ -35,7 +35,7 @@
import org.jboss.metadata.ejb.jboss.JBossEnterpriseBeanMetaData;
import org.jboss.metadata.ejb.jboss.JBossServiceBeanMetaData;
import org.jboss.metadata.ejb.jboss.jndipolicy.plugins.BasicJndiBindingPolicy;
-import org.jboss.metadata.ejb.jboss.jndipolicy.plugins.JBossSessionPolicyDecorator;
+import org.jboss.metadata.ejb.jboss.jndipolicy.plugins.JBossServicePolicyDecorator;
import org.jboss.test.metadata.jbmeta165.ServiceWithFullMetadataBean;
import org.junit.AfterClass;
import org.junit.BeforeClass;
@@ -192,21 +192,7 @@
// Wrap and set
JBossServiceBeanMetaData service = (JBossServiceBeanMetaData) bean;
- JBossServiceBeanMetaData policyWrapped = new JBossSessionPolicyDecorator(service, new BasicJndiBindingPolicy());
-
- //TODO this line above
-
- /*
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
+ JBossServiceBeanMetaData policyWrapped = new JBossServicePolicyDecorator(service, new BasicJndiBindingPolicy());
serviceBean = policyWrapped;
// Log
More information about the jboss-cvs-commits
mailing list