forked from jboss-developer/jboss-eap-quickstarts
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Code complete for cdi-portable-extension pom, template readme, beans.xml files missed by IntelliJ Adding openshift profile README done
- Loading branch information
1 parent
f06f4b4
commit 34db925
Showing
13 changed files
with
766 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
CDI Portable Extension: An example of a Portable Extension and some of the APIs / SPIs of CDI | ||
====================================================== | ||
Author: Jason Porter | ||
Level: Intermediate | ||
Technologies: CDI | ||
Summary: Creating a basic CDI extension to provide injection of fields from an XML file. | ||
|
||
What is it? | ||
----------- | ||
|
||
This project demonstrates a simple CDI Portable Extension and some of the SPI classes used | ||
to complete that task. | ||
|
||
It contains very simple domain model classes, an extension class, the service registration file | ||
for that extension and an Arquillian test to verify the extension is working correctly. | ||
|
||
It does not contain any user interface, the tests must be run to verify everything is working | ||
correctly. | ||
|
||
System requirements | ||
------------------- | ||
|
||
All you need to build this project is Java 6.0 (Java SDK 1.6) or better, Maven 3.0 or better. | ||
|
||
The application this project produces is designed to be run on JBoss Enterprise Application Platform 6 or JBoss AS 7. | ||
|
||
|
||
Configure Maven | ||
--------------- | ||
|
||
Contributor: You can copy or link to the Maven configuration information in the README file in the root folder of the quickstarts. For example: | ||
|
||
If you have not yet done so, you must [Configure Maven](../README.md#mavenconfiguration) before testing the quickstarts. | ||
|
||
Start JBoss Enterprise Application Platform 6 or JBoss AS 7 with the Web Profile | ||
------------------------- | ||
|
||
1. Open a command line and navigate to the root of the JBoss server directory. | ||
2. The following shows the command line to start the server with the web profile: | ||
|
||
For Linux: JBOSS_HOME/bin/standalone.sh | ||
For Windows: JBOSS_HOME\bin\standalone.bat | ||
|
||
|
||
Run the Arquillian Tests | ||
------------------------- | ||
|
||
This quickstart provides Arquillian tests. By default, these tests are configured to be skipped as Arquillian tests require the use of a container. | ||
|
||
_NOTE: The following commands assume you have configured your Maven user settings. If you have not, you must include Maven setting arguments on the command line. See [Run the Arquillian Tests](../README.md#arquilliantests) for complete instructions and additional options._ | ||
|
||
1. Make sure you have started the JBoss Server as described above. | ||
2. Open a command line and navigate to the root directory of this quickstart. | ||
3. Type the following command to run the test goal with the following profile activated: | ||
|
||
mvn clean test -Parq-jbossas-remote | ||
|
||
|
||
Run tests from JBDS | ||
----------------------- | ||
|
||
To be able to run the tests from JBDS, first set the active Maven profile in project properties to be either 'arq-jbossas-managed' for running on | ||
managed server or 'arq-jbossas-remote' for running on remote server. | ||
|
||
To run the tests, right click on the project or individual classes and select Run As --> JUnit Test in the context menu. | ||
|
||
|
||
Investigate the Console Output | ||
---------------------------- | ||
|
||
|
||
### Maven | ||
|
||
Maven prints summary of performed tests into the console: | ||
|
||
------------------------------------------------------- | ||
T E S T S | ||
------------------------------------------------------- | ||
Running org.jboss.as.quickstart.cdi.extension.test.CreatureExtensionTest | ||
log4j:WARN No appenders could be found for logger (org.jboss.logging). | ||
log4j:WARN Please initialize the log4j system properly. | ||
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 2.87 sec | ||
|
||
Results : | ||
|
||
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0 | ||
|
||
|
||
### Server log | ||
|
||
There are two logging statements done when the tests are run: | ||
|
||
#### Example | ||
|
||
15:07:13,145 INFO [org.jboss.as.server.deployment] (MSC service thread 1-5) JBAS015876: Starting deployment of "test.war" | ||
15:07:13,267 INFO [org.jboss.weld.deployer] (MSC service thread 1-1) JBAS016002: Processing weld deployment test.war | ||
15:07:13,283 INFO [org.jboss.weld.deployer] (MSC service thread 1-7) JBAS016005: Starting Services for CDI deployment: test.war | ||
15:07:13,290 INFO [org.jboss.weld.deployer] (MSC service thread 1-3) JBAS016008: Starting weld service for deployment test.war | ||
15:07:13,338 INFO [org.jboss.as.quickstart.cdi.extension.CreatureExtension] (MSC service thread 1-3) Setting up injection target for class org.jboss.as.quickstart.cdi.extension.model.Monster | ||
15:07:13,343 INFO [org.jboss.as.quickstart.cdi.extension.CreatureExtension] (MSC service thread 1-3) Setting up injection target for class org.jboss.as.quickstart.cdi.extension.model.NonPlayerCharacter | ||
15:07:13,377 INFO [org.jboss.web] (MSC service thread 1-1) JBAS018210: Registering web context: /test | ||
15:07:13,495 INFO [org.jboss.as.server] (management-handler-thread - 5) JBAS018559: Deployed "test.war" | ||
15:07:13,922 INFO [org.jboss.weld.deployer] (MSC service thread 1-8) JBAS016009: Stopping weld service for deployment test.war | ||
15:07:13,932 INFO [org.jboss.as.server.deployment] (MSC service thread 1-7) JBAS015877: Stopped deployment test.war in 16ms | ||
15:07:14,039 INFO [org.jboss.as.repository] (management-handler-thread - 6) JBAS014901: Content removed from location /home/jporter/java_libraries/jboss-as/build/target/jboss-as-7.1.1.Final/standalone/data/content/4d/40e4e277a16327b45b62954d70d91bbf3fcf42/content | ||
15:07:14,040 INFO [org.jboss.as.server] (management-handler-thread - 6) JBAS018558: Undeployed "test.war" | ||
|
||
The two statements to look for are these: | ||
|
||
15:07:13,338 INFO [org.jboss.as.quickstart.cdi.extension.CreatureExtension] (MSC service thread 1-3) Setting up injection target for class org.jboss.as.quickstart.cdi.extension.model.Monster | ||
15:07:13,343 INFO [org.jboss.as.quickstart.cdi.extension.CreatureExtension] (MSC service thread 1-3) Setting up injection target for class org.jboss.as.quickstart.cdi.extension.model.NonPlayerCharacter | ||
|
||
Run the Quickstart in JBoss Developer Studio or Eclipse | ||
------------------------------------- | ||
You can also start the server and deploy the quickstarts from Eclipse using JBoss tools. For more information, see [Use JBoss Developer Studio or Eclipse to Run the Quickstarts](../README.md#useeclipse) | ||
|
||
|
||
Debug the Application | ||
------------------------------------ | ||
|
||
If you want to debug the source code or look at the Javadocs of any library in the project, run either of the following commands to pull them into your local repository. The IDE should then detect them. | ||
|
||
mvn dependency:sources | ||
mvn dependency:resolve -Dclassifier=javadoc |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,197 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<!-- JBoss, Home of Professional Open Source Copyright 2012, Red Hat, Inc. | ||
and/or its affiliates, and individual contributors by the @authors tag. See | ||
the copyright.txt in the distribution for a full listing of individual contributors. | ||
Licensed 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. --> | ||
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" | ||
xmlns="http://maven.apache.org/POM/4.0.0" | ||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> | ||
<modelVersion>4.0.0</modelVersion> | ||
|
||
<groupId>org.jboss.as.quickstarts</groupId> | ||
<artifactId>jboss-as-cdi-portable-extension</artifactId> | ||
<version>7.1.2-SNAPSHOT</version> | ||
<packaging>war</packaging> | ||
<name>JBoss AS Quickstarts: CDI Portable Extension</name> | ||
<description>CDI Portable Extension: An example of a Portable Extension and some of the APIs / SPIs of CDI</description> | ||
|
||
<url>http://jboss.org/jbossas</url> | ||
<licenses> | ||
<license> | ||
<name>Apache License, Version 2.0</name> | ||
<distribution>repo</distribution> | ||
<url>http://www.apache.org/licenses/LICENSE-2.0.html</url> | ||
</license> | ||
</licenses> | ||
|
||
<properties> | ||
<!-- Explicitly declaring the source encoding eliminates the following message: | ||
[WARNING] Using platform encoding (UTF-8 actually) to copy filtered | ||
resources, i.e. build is platform dependent! --> | ||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> | ||
<jboss.bom.version>1.0.0.Final</jboss.bom.version> | ||
</properties> | ||
|
||
<dependencyManagement> | ||
<dependencies> | ||
<!-- Define the version of JBoss' Java EE 6 APIs we want to import. | ||
Any dependencies from org.jboss.spec will have their version defined by this BOM | ||
JBoss distributes a complete set of Java EE 6 APIs including | ||
a Bill of Materials (BOM). A BOM specifies the versions of a "stack" (or | ||
a collection) of artifacts. We use this here so that we always get the correct | ||
versions of artifacts. Here we use the jboss-javaee-6.0 stack (you can | ||
read this as the JBoss stack of the Java EE 6 APIs). You can actually | ||
use this stack with any version of JBoss AS that implements Java EE 6, not | ||
just JBoss AS 7! --> | ||
<dependency> | ||
<groupId>org.jboss.bom</groupId> | ||
<artifactId>jboss-javaee-6.0-with-tools</artifactId> | ||
<version>${jboss.bom.version}</version> | ||
<type>pom</type> | ||
<scope>import</scope> | ||
</dependency> | ||
</dependencies> | ||
</dependencyManagement> | ||
|
||
<dependencies> | ||
<!-- Import the CDI API, we use provided scope as the API is included in JBoss AS 7 --> | ||
<dependency> | ||
<groupId>javax.enterprise</groupId> | ||
<artifactId>cdi-api</artifactId> | ||
<scope>provided</scope> | ||
</dependency> | ||
|
||
<!-- Import the Common Annotations API (JSR-250), we use provided scope as the API is included in JBoss AS 7 --> | ||
<dependency> | ||
<groupId>org.jboss.spec.javax.annotation</groupId> | ||
<artifactId>jboss-annotations-api_1.1_spec</artifactId> | ||
<scope>provided</scope> | ||
</dependency> | ||
|
||
<!-- Testing dependencies and arquillian --> | ||
<dependency> | ||
<groupId>junit</groupId> | ||
<artifactId>junit</artifactId> | ||
<scope>test</scope> | ||
</dependency> | ||
<dependency> | ||
<groupId>org.jboss.arquillian.junit</groupId> | ||
<artifactId>arquillian-junit-container</artifactId> | ||
<scope>test</scope> | ||
</dependency> | ||
<dependency> | ||
<groupId>org.jboss.arquillian.protocol</groupId> | ||
<artifactId>arquillian-protocol-servlet</artifactId> | ||
</dependency> | ||
</dependencies> | ||
<build> | ||
<finalName>${project.artifactId}</finalName> | ||
<plugins> | ||
<plugin> | ||
<artifactId>maven-war-plugin</artifactId> | ||
<version>2.1.1</version> | ||
<configuration> | ||
<!-- Java EE 6 doesn't require web.xml, Maven needs to catch up! --> | ||
<failOnMissingWebXml>false</failOnMissingWebXml> | ||
</configuration> | ||
</plugin> | ||
<!-- JBoss AS plugin to deploy war --> | ||
<plugin> | ||
<groupId>org.jboss.as.plugins</groupId> | ||
<artifactId>jboss-as-maven-plugin</artifactId> | ||
<version>7.1.1.Final</version> | ||
</plugin> | ||
<!-- Compiler plugin enforces Java 1.6 compatibility and activates annotation processors --> | ||
<plugin> | ||
<artifactId>maven-compiler-plugin</artifactId> | ||
<version>2.3.2</version> | ||
<configuration> | ||
<source>1.6</source> | ||
<target>1.6</target> | ||
</configuration> | ||
</plugin> | ||
</plugins> | ||
</build> | ||
<profiles> | ||
<profile> | ||
<!-- The default profile skips all tests, though you can tune it to run just unit tests based on a custom pattern | ||
Separate profiles are provided for running all tests, including Arquillian tests that execute in the | ||
specified container | ||
--> | ||
<id>default</id> | ||
<activation> | ||
<activeByDefault>true</activeByDefault> | ||
</activation> | ||
<build> | ||
<plugins> | ||
<plugin> | ||
<artifactId>maven-surefire-plugin</artifactId> | ||
<configuration> | ||
<skip>true</skip> | ||
</configuration> | ||
</plugin> | ||
<!-- The JBoss AS plugin deploys your war to a local JBoss AS container --> | ||
<!-- To use, set the JBOSS_HOME environment variable and run: mvn package jboss-as:deploy --> | ||
<plugin> | ||
<groupId>org.jboss.as.plugins</groupId> | ||
<artifactId>jboss-as-maven-plugin</artifactId> | ||
</plugin> | ||
</plugins> | ||
</build> | ||
</profile> | ||
|
||
<profile> | ||
|
||
<!-- An optional Arquillian testing profile that executes tests in your JBoss AS instance --> | ||
<!-- This profile will start a new JBoss AS instance, and execute the test, shutting it down when done --> | ||
<!-- Run with: mvn clean test -Parq-jbossas-managed --> | ||
<id>arq-jbossas-managed</id> | ||
<dependencies> | ||
<dependency> | ||
<groupId>org.jboss.as</groupId> | ||
<artifactId>jboss-as-arquillian-container-managed</artifactId> | ||
<scope>test</scope> | ||
</dependency> | ||
</dependencies> | ||
</profile> | ||
|
||
<profile> | ||
<!-- An optional Arquillian testing profile that executes tests in a remote JBoss AS instance --> | ||
<!-- Run with: mvn clean test -Parq-jbossas-remote --> | ||
<id>arq-jbossas-remote</id> | ||
<dependencies> | ||
<dependency> | ||
<groupId>org.jboss.as</groupId> | ||
<artifactId>jboss-as-arquillian-container-remote</artifactId> | ||
<scope>test</scope> | ||
</dependency> | ||
</dependencies> | ||
</profile> | ||
<profile> | ||
<!-- When built in OpenShift the 'openshift' profile will be used when invoking mvn. --> | ||
<!-- Use this profile for any OpenShift specific customization your app will need. --> | ||
<!-- By default that is to put the resulting archive into the 'deployments' folder. --> | ||
<!-- http://maven.apache.org/guides/mini/guide-building-for-different-environments.html --> | ||
<id>openshift</id> | ||
<build> | ||
<plugins> | ||
<plugin> | ||
<artifactId>maven-war-plugin</artifactId> | ||
<version>2.1.1</version> | ||
<configuration> | ||
<outputDirectory>deployments</outputDirectory> | ||
<warName>ROOT</warName> | ||
</configuration> | ||
</plugin> | ||
</plugins> | ||
</build> | ||
</profile> | ||
</profiles> | ||
</project> |
69 changes: 69 additions & 0 deletions
69
...able-extension/src/main/java/org/jboss/as/quickstart/cdi/extension/CreatureExtension.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
/* | ||
* JBoss, Home of Professional Open Source | ||
* Copyright 2012, Red Hat, Inc., and individual contributors | ||
* by the @authors tag. See the copyright.txt in the distribution for a | ||
* full listing of individual contributors. | ||
* | ||
* Licensed 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.jboss.as.quickstart.cdi.extension; | ||
|
||
import java.io.IOException; | ||
import java.io.InputStream; | ||
import java.util.logging.Logger; | ||
|
||
import javax.enterprise.event.Observes; | ||
import javax.enterprise.inject.spi.Extension; | ||
import javax.enterprise.inject.spi.ProcessInjectionTarget; | ||
import javax.xml.parsers.DocumentBuilder; | ||
import javax.xml.parsers.DocumentBuilderFactory; | ||
import javax.xml.parsers.ParserConfigurationException; | ||
|
||
import org.jboss.as.quickstart.cdi.extension.model.Creature; | ||
import org.w3c.dom.Document; | ||
import org.w3c.dom.Element; | ||
import org.xml.sax.SAXException; | ||
|
||
/** | ||
* A simple CDI Portable Extension to "inject" values from XML into the instances of a bean. | ||
*/ | ||
public class CreatureExtension implements Extension { | ||
private static Document document; | ||
private final Logger log = Logger.getLogger(CreatureExtension.class.getName()); | ||
|
||
static { | ||
try { | ||
InputStream creatureDefs = CreatureExtension.class.getClassLoader().getResourceAsStream("creatures.xml"); | ||
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); | ||
DocumentBuilder builder = factory.newDocumentBuilder(); | ||
document = builder.parse(creatureDefs); | ||
} catch (ParserConfigurationException e) { | ||
throw new RuntimeException("Error building xml parser, aborting", e); | ||
} catch (SAXException e) { | ||
throw new RuntimeException("SAX exception while parsing xml file", e); | ||
} catch (IOException e) { | ||
throw new RuntimeException("Error reading or parsing xml file", e); | ||
} | ||
} | ||
|
||
/** | ||
* Observer to a CDI lifecycle event to correctly setup the XML backed "injection. | ||
* @param pit CDI lifecycle callback payload | ||
* @param <X> Type of the Injection to observe | ||
*/ | ||
<X extends Creature> void processInjectionTarget(@Observes ProcessInjectionTarget<X> pit) { | ||
Class<? extends Creature> klass = pit.getAnnotatedType().getJavaClass(); | ||
log.info("Setting up injection target for " + klass); | ||
final Element entry = (Element) document.getElementsByTagName(klass.getSimpleName().toLowerCase()).item(0); | ||
pit.setInjectionTarget(new XmlBackedWrappedInjectionTarget<X>(pit.getInjectionTarget(), entry)); | ||
} | ||
} |
Oops, something went wrong.