Coverage Report - org.apache.maven.plugin.ear.EarModuleFactory
 
Classes in this File Line Coverage Branch Coverage Complexity
EarModuleFactory
0%
0/40
0%
0/22
8.667
 
 1  
 package org.apache.maven.plugin.ear;
 2  
 
 3  
 /*
 4  
  * Licensed to the Apache Software Foundation (ASF) under one
 5  
  * or more contributor license agreements.  See the NOTICE file
 6  
  * distributed with this work for additional information
 7  
  * regarding copyright ownership.  The ASF licenses this file
 8  
  * to you under the Apache License, Version 2.0 (the
 9  
  * "License"); you may not use this file except in compliance
 10  
  * with the License.  You may obtain a copy of the License at
 11  
  *
 12  
  *  http://www.apache.org/licenses/LICENSE-2.0
 13  
  *
 14  
  * Unless required by applicable law or agreed to in writing,
 15  
  * software distributed under the License is distributed on an
 16  
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 17  
  * KIND, either express or implied.  See the License for the
 18  
  * specific language governing permissions and limitations
 19  
  * under the License.
 20  
  */
 21  
 
 22  
 import org.apache.maven.artifact.Artifact;
 23  
 import org.apache.maven.plugin.ear.util.ArtifactTypeMappingService;
 24  
 import org.apache.maven.plugin.ear.util.JavaEEVersion;
 25  
 
 26  
 import java.util.ArrayList;
 27  
 import java.util.Collections;
 28  
 import java.util.List;
 29  
 
 30  
 /**
 31  
  * Builds an {@link EarModule} based on an <tt>Artifact</tt>.
 32  
  *
 33  
  * @author <a href="snicoll@apache.org">Stephane Nicoll</a>
 34  
  * @version $Id: EarModuleFactory.java 1050900 2010-12-19 17:10:52Z snicoll $
 35  
  */
 36  0
 public final class EarModuleFactory
 37  
 {
 38  
     public final static List standardArtifactTypes;
 39  
 
 40  
     static
 41  
     {
 42  0
         List temp = new ArrayList();
 43  0
         temp.add( "jar" );
 44  0
         temp.add( "ejb" );
 45  0
         temp.add( "ejb3" );
 46  0
         temp.add( "par" );
 47  0
         temp.add( "ejb-client" );
 48  0
         temp.add( "rar" );
 49  0
         temp.add( "war" );
 50  0
         temp.add( "sar" );
 51  0
         temp.add( "wsr" );
 52  0
         temp.add( "har" );
 53  0
         standardArtifactTypes = Collections.unmodifiableList( temp );
 54  0
     }
 55  
 
 56  
     /**
 57  
      * Creates a new {@link EarModule} based on the
 58  
      * specified {@link Artifact} and the specified
 59  
      * execution configuration.
 60  
      *
 61  
      * @param artifact                the artifact
 62  
      * @param javaEEVersion           the javaEE version to use
 63  
      * @param defaultLibBundleDir     the default bundle dir for {@link org.apache.maven.plugin.ear.JarModule}
 64  
      * @param includeInApplicationXml should {@link org.apache.maven.plugin.ear.JarModule} be included in application Xml
 65  
      * @param typeMappingService      The artifact type mapping service
 66  
      * @return an ear module for this artifact
 67  
      * @throws UnknownArtifactTypeException if the artifact is not handled
 68  
      */
 69  
     public static EarModule newEarModule( Artifact artifact, JavaEEVersion javaEEVersion, String defaultLibBundleDir,
 70  
                                           Boolean includeInApplicationXml,
 71  
                                           ArtifactTypeMappingService typeMappingService )
 72  
         throws UnknownArtifactTypeException
 73  
     {
 74  
         // Get the standard artifact type based on default config and user-defined mapping(s)
 75  0
         final String artifactType = typeMappingService.getStandardType( artifact.getType() );
 76  
 
 77  0
         if ( "jar".equals( artifactType ) )
 78  
         {
 79  0
             return new JarModule( artifact, defaultLibBundleDir, includeInApplicationXml );
 80  
         }
 81  0
         else if ( "ejb".equals( artifactType ) )
 82  
         {
 83  0
             return new EjbModule( artifact );
 84  
         }
 85  0
         else if ( "ejb3".equals( artifactType ) )
 86  
         {
 87  0
             return new Ejb3Module( artifact );
 88  
         }
 89  0
         else if ( "par".equals( artifactType ) )
 90  
         {
 91  0
             return new ParModule( artifact );
 92  
         }
 93  0
         else if ( "ejb-client".equals( artifactType ) )
 94  
         {
 95  
             // Somewhat weird way to tackle the problem described in MEAR-85
 96  0
             if ( javaEEVersion.le( JavaEEVersion.OneDotFour ) )
 97  
             {
 98  0
                 return new EjbClientModule( artifact, null );
 99  
             }
 100  
             else
 101  
             {
 102  0
                 return new EjbClientModule( artifact, defaultLibBundleDir );
 103  
             }
 104  
         }
 105  0
         else if ( "rar".equals( artifactType ) )
 106  
         {
 107  0
             return new RarModule( artifact );
 108  
         }
 109  0
         else if ( "war".equals( artifactType ) )
 110  
         {
 111  0
             return new WebModule( artifact );
 112  
         }
 113  0
         else if ( "sar".equals( artifactType ) )
 114  
         {
 115  0
             return new SarModule( artifact );
 116  
         }
 117  0
         else if ( "wsr".equals( artifactType ) )
 118  
         {
 119  0
             return new WsrModule( artifact );
 120  
         }
 121  0
         else if ( "har".equals( artifactType ) )
 122  
         {
 123  0
             return new HarModule( artifact );
 124  
         }
 125  
         else
 126  
         {
 127  0
             throw new IllegalStateException( "Could not handle artifact type[" + artifactType + "]" );
 128  
         }
 129  
     }
 130  
 
 131  
     /**
 132  
      * Returns a list of standard artifact types.
 133  
      *
 134  
      * @return the standard artifact types
 135  
      */
 136  
     public static List getStandardArtifactTypes()
 137  
     {
 138  0
         return standardArtifactTypes;
 139  
     }
 140  
 
 141  
     /**
 142  
      * Specify whether the specified type is standard artifact
 143  
      * type.
 144  
      *
 145  
      * @param type the type to check
 146  
      * @return true if the specified type is a standard artifact type
 147  
      */
 148  
     public static boolean isStandardArtifactType( final String type )
 149  
     {
 150  0
         return standardArtifactTypes.contains( type );
 151  
     }
 152  
 
 153  
 }