Author: bimargulies
Date: Sun Apr 22 18:48:15 2012
New Revision: 1328931

URL: http://svn.apache.org/viewvc?rev=1328931&view=rev
Log:
[MCHANGES-262] Using custom issue types mapping (MCHANGES-245) throws a 
llegalArgumentException

Added:
    
maven/plugins/trunk/maven-changes-plugin/src/test/java/org/apache/maven/plugin/issues/IssueManagementSystemTest.java
Modified:
    
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/changes/IssueType.java
    
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/issues/AbstractIssueManagementSystem.java

Modified: 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/changes/IssueType.java
URL: 
http://svn.apache.org/viewvc/maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/changes/IssueType.java?rev=1328931&r1=1328930&r2=1328931&view=diff
==============================================================================
--- 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/changes/IssueType.java
 (original)
+++ 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/changes/IssueType.java
 Sun Apr 22 18:48:15 2012
@@ -45,6 +45,15 @@ public enum IssueType
 
     public static IssueType lookupByKey( String key )
     {
-        return IssueType.valueOf( key.toUpperCase() );
+        IssueType type;
+        try
+        {
+            type = IssueType.valueOf( key.toUpperCase() );
+        }
+        catch ( IllegalArgumentException e )
+        {
+            type = null;
+        }
+        return type;
     }
 }

Modified: 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/issues/AbstractIssueManagementSystem.java
URL: 
http://svn.apache.org/viewvc/maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/issues/AbstractIssueManagementSystem.java?rev=1328931&r1=1328930&r2=1328931&view=diff
==============================================================================
--- 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/issues/AbstractIssueManagementSystem.java
 (original)
+++ 
maven/plugins/trunk/maven-changes-plugin/src/main/java/org/apache/maven/plugin/issues/AbstractIssueManagementSystem.java
 Sun Apr 22 18:48:15 2012
@@ -66,12 +66,12 @@ public abstract class AbstractIssueManag
     {
         for ( Map.Entry<String, String> me : issueTypes.entrySet() )
         {
-            IssueType type = IssueType.lookupByKey( me.getValue() );
+            IssueType type = IssueType.lookupByKey( me.getKey() );
             if ( type == null )
             {
-                throw new MojoExecutionException( "Invalid issue action " + 
me.getValue() );
+                throw new MojoExecutionException( "Invalid issue action " + 
me.getKey() );
             }
-            String imsTypes = me.getKey();
+            String imsTypes = me.getValue();
             String[] imsTypeArray = imsTypes.split( "," );
             for ( String imsType : imsTypeArray ) 
             {

Added: 
maven/plugins/trunk/maven-changes-plugin/src/test/java/org/apache/maven/plugin/issues/IssueManagementSystemTest.java
URL: 
http://svn.apache.org/viewvc/maven/plugins/trunk/maven-changes-plugin/src/test/java/org/apache/maven/plugin/issues/IssueManagementSystemTest.java?rev=1328931&view=auto
==============================================================================
--- 
maven/plugins/trunk/maven-changes-plugin/src/test/java/org/apache/maven/plugin/issues/IssueManagementSystemTest.java
 (added)
+++ 
maven/plugins/trunk/maven-changes-plugin/src/test/java/org/apache/maven/plugin/issues/IssueManagementSystemTest.java
 Sun Apr 22 18:48:15 2012
@@ -0,0 +1,90 @@
+package org.apache.maven.plugin.issues;
+
+/*
+ * 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.
+ */
+
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.maven.plugin.MojoExecutionException;
+
+import junit.framework.TestCase;
+
+/**
+ * @author Alan Parkinson
+ * @since 2.7
+ */
+public class IssueManagementSystemTest
+    extends TestCase
+{
+
+    private MockIssueManagementSystem ims;
+
+    private class MockIssueManagementSystem
+        extends AbstractIssueManagementSystem
+    {
+
+        @Override
+        public String getName()
+        {
+            return "Mock IMS";
+        }
+
+    }
+
+    @Override
+    protected void setUp()
+        throws Exception
+    {
+        ims = new MockIssueManagementSystem();
+    }
+
+    public void testApplyingValidCustomIssueTypes()
+    {
+        Map<String, String> issueTypes = new HashMap<String, String>();
+        issueTypes.put( "add", "Story,Epic" );
+        issueTypes.put( "fix", "Defect" );
+        issueTypes.put( "update", "Improvement" );
+
+        try
+        {
+            ims.applyConfiguration( issueTypes );
+        }
+        catch ( MojoExecutionException e )
+        {
+            fail();
+        }
+    }
+
+    public void testApplyingInvalidCustomIssueTypes()
+    {
+        Map<String, String> issueTypes = new HashMap<String, String>();
+        issueTypes.put( "new", "Story,Epic" );
+
+        try
+        {
+            ims.applyConfiguration( issueTypes );
+            fail( "Exception not thrown for invalid group name" );
+        }
+        catch ( MojoExecutionException e )
+        {
+
+        }
+    }
+}


Reply via email to