Author: rmannibucau
Date: Mon Jul 16 10:23:14 2012
New Revision: 1361964
URL: http://svn.apache.org/viewvc?rev=1361964&view=rev
Log:
OPENEJB-1870 server side event sample
Added:
openejb/trunk/openejb/examples/server-events/
openejb/trunk/openejb/examples/server-events/pom.xml
openejb/trunk/openejb/examples/server-events/src/
openejb/trunk/openejb/examples/server-events/src/main/
openejb/trunk/openejb/examples/server-events/src/main/java/
openejb/trunk/openejb/examples/server-events/src/main/java/org/
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/AutoDiscoveredListener.java
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/MyListener.java
openejb/trunk/openejb/examples/server-events/src/main/resources/
openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/
openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/org.apache.openejb.extension
openejb/trunk/openejb/examples/server-events/src/test/
openejb/trunk/openejb/examples/server-events/src/test/java/
openejb/trunk/openejb/examples/server-events/src/test/java/org/
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/ListenerTest.java
openejb/trunk/openejb/examples/server-events/src/test/resources/
openejb/trunk/openejb/examples/server-events/src/test/resources/META-INF/
openejb/trunk/openejb/examples/server-events/src/test/resources/META-INF/ejb-jar.xml
openejb/trunk/openejb/examples/server-events/src/test/resources/arquillian.xml
Modified:
openejb/trunk/openejb/examples/pom.xml
Modified: openejb/trunk/openejb/examples/pom.xml
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/pom.xml?rev=1361964&r1=1361963&r2=1361964&view=diff
==============================================================================
--- openejb/trunk/openejb/examples/pom.xml (original)
+++ openejb/trunk/openejb/examples/pom.xml Mon Jul 16 10:23:14 2012
@@ -90,6 +90,7 @@
<module>schedule-expression</module>
<module>schedule-methods-meta</module>
<module>schedule-methods</module>
+ <module>server-events</module>
<module>simple-cdi-interceptor</module>
<module>simple-cmp2</module>
<module>simple-mdb-and-cdi</module>
Added: openejb/trunk/openejb/examples/server-events/pom.xml
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/pom.xml?rev=1361964&view=auto
==============================================================================
--- openejb/trunk/openejb/examples/server-events/pom.xml (added)
+++ openejb/trunk/openejb/examples/server-events/pom.xml Mon Jul 16 10:23:14
2012
@@ -0,0 +1,104 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+
+ 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.
+-->
+
+<!-- $Rev: 1346534 $ $Date: 2012-06-05 20:57:54 +0200 (mar. 05 juin 2012) $ -->
+
+<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/maven-v4_0_0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+
+ <groupId>org.superbiz</groupId>
+ <artifactId>server-events</artifactId>
+ <packaging>jar</packaging>
+ <version>1.1-SNAPSHOT</version>
+ <name>OpenEJB :: Examples :: Server Events</name>
+
+ <properties>
+ <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+ </properties>
+
+ <build>
+ <defaultGoal>install</defaultGoal>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <version>2.4</version>
+ <configuration>
+ <source>1.6</source>
+ <target>1.6</target>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+
+ <repositories>
+ <repository>
+ <id>apache-m2-snapshot</id>
+ <name>Apache Snapshot Repository</name>
+ <url>http://repository.apache.org/snapshots</url>
+ </repository>
+ </repositories>
+
+ <dependencies>
+ <dependency>
+ <groupId>org.apache.openejb</groupId>
+ <artifactId>javaee-api</artifactId>
+ <version>6.0-4</version>
+ <scope>provided</scope>
+ </dependency>
+ <!--
+ The <scope>provided</scope> since that's OpenEJB dependent.
+ -->
+ <dependency>
+ <groupId>org.apache.openejb</groupId>
+ <artifactId>openejb-core</artifactId>
+ <version>4.1.0-SNAPSHOT</version>
+ <scope>provided</scope>
+ </dependency>
+
+ <!-- test libs -->
+ <dependency>
+ <groupId>junit</groupId>
+ <artifactId>junit</artifactId>
+ <version>4.10</version>
+ <scope>test</scope>
+ </dependency>
+ <dependency>
+ <groupId>org.apache.openejb</groupId>
+ <artifactId>arquillian-openejb-embedded-4</artifactId>
+ <version>4.1.0-SNAPSHOT</version>
+ <scope>test</scope>
+ </dependency>
+ </dependencies>
+ <!--
+ This section allows you to configure where to publish libraries for sharing.
+ It is not required and may be deleted. For more information see:
+ http://maven.apache.org/plugins/maven-deploy-plugin/
+ -->
+ <distributionManagement>
+ <repository>
+ <id>localhost</id>
+ <url>file://${basedir}/target/repo/</url>
+ </repository>
+ <snapshotRepository>
+ <id>localhost</id>
+ <url>file://${basedir}/target/snapshot-repo/</url>
+ </snapshotRepository>
+ </distributionManagement>
+</project>
\ No newline at end of file
Added:
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/AutoDiscoveredListener.java
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/AutoDiscoveredListener.java?rev=1361964&view=auto
==============================================================================
---
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/AutoDiscoveredListener.java
(added)
+++
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/AutoDiscoveredListener.java
Mon Jul 16 10:23:14 2012
@@ -0,0 +1,16 @@
+package org.superbiz.event;
+
+import
org.apache.openejb.assembler.classic.event.AssemblerAfterApplicationCreated;
+import org.apache.openejb.observer.Observes;
+
+public class AutoDiscoveredListener {
+ private static String appName;
+
+ public void appCreated(@Observes final AssemblerAfterApplicationCreated
appCreatedEvent) {
+ appName = appCreatedEvent.getApp().appId;
+ }
+
+ public static String getAppName() {
+ return appName;
+ }
+}
Added:
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/MyListener.java
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/MyListener.java?rev=1361964&view=auto
==============================================================================
---
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/MyListener.java
(added)
+++
openejb/trunk/openejb/examples/server-events/src/main/java/org/superbiz/event/MyListener.java
Mon Jul 16 10:23:14 2012
@@ -0,0 +1,26 @@
+package org.superbiz.event;
+
+import org.apache.openejb.observer.Observes;
+
+import java.util.logging.Logger;
+
+/**
+ * registered as service in openejb.xml, tomee.xml, resources.xml or openejb
system properties:
+ *
+ * listener = new://Service?type=org.superbiz.event.MyListener
+ * listener.logAllEvent = true
+ */
+public class MyListener {
+ private static final Logger LOGGER =
Logger.getLogger(MyListener.class.getName());
+
+ private boolean logAllEvent = false;
+
+ public void global(@Observes final Object event) {
+ LOGGER.info(">>> an event occured -> " + event.toString());
+ }
+
+ // configurable
+ public void setLogAllEvent(boolean logAllEvent) {
+ this.logAllEvent = logAllEvent;
+ }
+}
Added:
openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/org.apache.openejb.extension
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/org.apache.openejb.extension?rev=1361964&view=auto
==============================================================================
---
openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/org.apache.openejb.extension
(added)
+++
openejb/trunk/openejb/examples/server-events/src/main/resources/META-INF/org.apache.openejb.extension
Mon Jul 16 10:23:14 2012
@@ -0,0 +1 @@
+org.superbiz.event.AutoDiscoveredListener
Added:
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/ListenerTest.java
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/ListenerTest.java?rev=1361964&view=auto
==============================================================================
---
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/ListenerTest.java
(added)
+++
openejb/trunk/openejb/examples/server-events/src/test/java/org/superbiz/event/ListenerTest.java
Mon Jul 16 10:23:14 2012
@@ -0,0 +1,27 @@
+package org.superbiz.event;
+
+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.StringAsset;
+import org.jboss.shrinkwrap.api.spec.JavaArchive;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import static org.junit.Assert.assertEquals;
+
+@RunWith(Arquillian.class)
+public class ListenerTest {
+ @Deployment
+ public static JavaArchive jar() {
+ return ShrinkWrap.create(JavaArchive.class, "listener-test.jar")
+ .addClasses(MyListener.class, AutoDiscoveredListener.class)
+ .addAsManifestResource(new
StringAsset(AutoDiscoveredListener.class.getName()),
ArchivePaths.create("org.apache.openejb.extension"));
+ }
+
+ @Test
+ public void check() {
+ assertEquals("listener-test", AutoDiscoveredListener.getAppName());
+ }
+}
Added:
openejb/trunk/openejb/examples/server-events/src/test/resources/META-INF/ejb-jar.xml
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/test/resources/META-INF/ejb-jar.xml?rev=1361964&view=auto
==============================================================================
(empty)
Added:
openejb/trunk/openejb/examples/server-events/src/test/resources/arquillian.xml
URL:
http://svn.apache.org/viewvc/openejb/trunk/openejb/examples/server-events/src/test/resources/arquillian.xml?rev=1361964&view=auto
==============================================================================
---
openejb/trunk/openejb/examples/server-events/src/test/resources/arquillian.xml
(added)
+++
openejb/trunk/openejb/examples/server-events/src/test/resources/arquillian.xml
Mon Jul 16 10:23:14 2012
@@ -0,0 +1,30 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<!--
+
+ 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.
+-->
+<arquillian
+ xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://jboss.org/schema/arquillian
http://jboss.org/schema/arquillian/arquillian_1_0.xsd">
+ <container qualifier="openejb" default="true">
+ <configuration>
+ <property name="properties">
+ listener = new://Service?type=org.superbiz.event.MyListener
+ listener.logAllEvent = true
+ </property>
+ </configuration>
+ </container>
+</arquillian>