Author: rmannibucau
Date: Fri Nov  9 15:51:29 2012
New Revision: 1407503

URL: http://svn.apache.org/viewvc?rev=1407503&view=rev
Log:
support WEB-INF/classes/META-INF/beans.xml in arquillian embedded adapter

Added:
    
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/test/java/org/apache/openejb/arquillian/openejb/WARArquillianTest.java
Modified:
    
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/main/java/org/apache/openejb/arquillian/openejb/OpenEJBArchiveProcessor.java

Modified: 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/main/java/org/apache/openejb/arquillian/openejb/OpenEJBArchiveProcessor.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/main/java/org/apache/openejb/arquillian/openejb/OpenEJBArchiveProcessor.java?rev=1407503&r1=1407502&r2=1407503&view=diff
==============================================================================
--- 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/main/java/org/apache/openejb/arquillian/openejb/OpenEJBArchiveProcessor.java
 (original)
+++ 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/main/java/org/apache/openejb/arquillian/openejb/OpenEJBArchiveProcessor.java
 Fri Nov  9 15:51:29 2012
@@ -42,7 +42,6 @@ import org.jboss.shrinkwrap.api.asset.As
 import org.jboss.shrinkwrap.api.asset.ClassLoaderAsset;
 import org.jboss.shrinkwrap.api.asset.FileAsset;
 import org.jboss.shrinkwrap.api.asset.UrlAsset;
-import org.jboss.shrinkwrap.api.classloader.ShrinkWrapClassLoader;
 import org.jboss.shrinkwrap.api.spec.WebArchive;
 import org.jboss.shrinkwrap.impl.base.filter.IncludeRegExpPaths;
 
@@ -162,7 +161,10 @@ public class OpenEJBArchiveProcessor {
         appModule.getEjbModules().add(ejbModule);
 
         {
-            final Node beansXml = archive.get(prefix.concat(BEANS_XML));
+            Node beansXml = archive.get(prefix.concat(BEANS_XML));
+            if (beansXml == null && WEB_INF.equals(prefix)) {
+                beansXml = 
archive.get(WEB_INF_CLASSES.concat(META_INF).concat(BEANS_XML));
+            }
             if (beansXml != null) {
                 ejbModule.getAltDDs().put(BEANS_XML, new 
AssetSource(beansXml.getAsset()));
             }
@@ -170,8 +172,8 @@ public class OpenEJBArchiveProcessor {
 
         {
             Node persistenceXml = archive.get(prefix.concat(PERSISTENCE_XML));
-            if (persistenceXml == null && prefix.startsWith("WEB-INF")) { // 
particular case
-                persistenceXml = 
archive.get(prefix.concat("classes/META-INF/").concat(PERSISTENCE_XML));
+            if (persistenceXml == null && WEB_INF.equals(prefix)) {
+                persistenceXml = 
archive.get(WEB_INF_CLASSES.concat(META_INF).concat(PERSISTENCE_XML));
             }
             if (persistenceXml != null) {
                 final Asset asset = persistenceXml.getAsset();

Added: 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/test/java/org/apache/openejb/arquillian/openejb/WARArquillianTest.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/test/java/org/apache/openejb/arquillian/openejb/WARArquillianTest.java?rev=1407503&view=auto
==============================================================================
--- 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/test/java/org/apache/openejb/arquillian/openejb/WARArquillianTest.java
 (added)
+++ 
openejb/trunk/openejb/arquillian/arquillian-openejb-embedded-4/src/test/java/org/apache/openejb/arquillian/openejb/WARArquillianTest.java
 Fri Nov  9 15:51:29 2012
@@ -0,0 +1,57 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.openejb.arquillian.openejb;
+
+import org.apache.openejb.loader.SystemInstance;
+import org.jboss.arquillian.container.test.api.Deployment;
+import org.jboss.arquillian.junit.Arquillian;
+import org.jboss.shrinkwrap.api.ArchivePaths;
+import org.jboss.shrinkwrap.api.ShrinkWrap;
+import org.jboss.shrinkwrap.api.asset.EmptyAsset;
+import org.jboss.shrinkwrap.api.spec.WebArchive;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import javax.inject.Inject;
+
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertTrue;
+
+@RunWith(Arquillian.class)
+public class WARArquillianTest {
+    @Inject
+    private ABean bean;
+
+    @Deployment
+    public static WebArchive archive() {
+        return ShrinkWrap.create(WebArchive.class, 
WARArquillianTest.class.getSimpleName().concat(".war"))
+                    .addClasses(ABean.class)
+                    .addAsWebInfResource(EmptyAsset.INSTANCE, 
ArchivePaths.create("classes/META-INF/beans.xml"));
+    }
+
+    @Test
+    public void checkItIsStarted() {
+        assertTrue(SystemInstance.isInitialized());
+    }
+
+    @Test
+    public void checkInjections() {
+        assertNotNull(bean);
+    }
+
+    public static class ABean {}
+}


Reply via email to