Author: ffang
Date: Tue Aug 14 06:20:20 2012
New Revision: 1372740

URL: http://svn.apache.org/viewvc?rev=1372740&view=rev
Log:
[KARAF-1066]make features xml parser more forgiving

Added:
    
karaf/trunk/features/core/src/test/resources/org/apache/karaf/features/repo2.xml
Modified:
    
karaf/trunk/features/core/src/main/java/org/apache/karaf/features/internal/RepositoryImpl.java
    
karaf/trunk/features/core/src/test/java/org/apache/karaf/features/RepositoryTest.java

Modified: 
karaf/trunk/features/core/src/main/java/org/apache/karaf/features/internal/RepositoryImpl.java
URL: 
http://svn.apache.org/viewvc/karaf/trunk/features/core/src/main/java/org/apache/karaf/features/internal/RepositoryImpl.java?rev=1372740&r1=1372739&r2=1372740&view=diff
==============================================================================
--- 
karaf/trunk/features/core/src/main/java/org/apache/karaf/features/internal/RepositoryImpl.java
 (original)
+++ 
karaf/trunk/features/core/src/main/java/org/apache/karaf/features/internal/RepositoryImpl.java
 Tue Aug 14 06:20:20 2012
@@ -69,7 +69,9 @@ public class RepositoryImpl implements R
         load();
         URI[] result = new URI[features.getRepository().size()];
         for (int i = 0; i < features.getRepository().size(); i++) {
-            result[i] = URI.create(features.getRepository().get(i));
+            String uri = features.getRepository().get(i);
+            uri = uri.trim();
+            result[i] = URI.create(uri);
         }
         return result;
     }

Modified: 
karaf/trunk/features/core/src/test/java/org/apache/karaf/features/RepositoryTest.java
URL: 
http://svn.apache.org/viewvc/karaf/trunk/features/core/src/test/java/org/apache/karaf/features/RepositoryTest.java?rev=1372740&r1=1372739&r2=1372740&view=diff
==============================================================================
--- 
karaf/trunk/features/core/src/test/java/org/apache/karaf/features/RepositoryTest.java
 (original)
+++ 
karaf/trunk/features/core/src/test/java/org/apache/karaf/features/RepositoryTest.java
 Tue Aug 14 06:20:20 2012
@@ -65,6 +65,48 @@ public class RepositoryTest extends Test
         assertEquals(true, 
features[2].getConfigurationFiles().get(0).isOverride());
         assertEquals("cfloc", 
features[2].getConfigurationFiles().get(0).getLocation());
     }
+
+    public void testLoadFormattedRepo() throws Exception {
+        RepositoryImpl r = new 
RepositoryImpl(getClass().getResource("repo2.xml").toURI());
+        // Check repo
+        URI[] repos = r.getRepositories();
+        assertNotNull(repos);
+        assertEquals(1, repos.length);
+        assertEquals(URI.create("urn:r1"), repos[0]);
+        // Check features
+        Feature[] features = r.getFeatures();
+        assertNotNull(features);
+        assertEquals(3, features.length);
+        assertNotNull(features[0]);
+        assertEquals("f1", features[0].getName());
+        assertNotNull(features[0].getConfigurations());
+        assertEquals(1, features[0].getConfigurations().size());
+        assertNotNull(features[0].getConfigurations().get("c1"));
+        assertEquals(1, features[0].getConfigurations().get("c1").size());
+        assertEquals("v", features[0].getConfigurations().get("c1").get("k"));
+        assertNotNull(features[0].getDependencies());
+        assertEquals(0, features[0].getDependencies().size());
+        assertNotNull(features[0].getBundles());
+        assertEquals(2, features[0].getBundles().size());
+        assertEquals("b1", features[0].getBundles().get(0).getLocation());
+        assertEquals("b2", features[0].getBundles().get(1).getLocation());
+        assertNotNull(features[1]);
+        assertEquals("f2", features[1].getName());
+        assertNotNull(features[1].getConfigurations());
+        assertEquals(0, features[1].getConfigurations().size());
+        assertNotNull(features[1].getDependencies());
+        assertEquals(1, features[1].getDependencies().size());
+        assertEquals("f1" + 
org.apache.karaf.features.internal.model.Feature.SPLIT_FOR_NAME_AND_VERSION + 
org.apache.karaf.features.internal.model.Feature.DEFAULT_VERSION, 
features[1].getDependencies().get(0).toString());
+        assertNotNull(features[1].getBundles());
+        assertEquals(1, features[1].getBundles().size());
+        assertEquals("b3", features[1].getBundles().get(0).getLocation());
+        assertEquals("f3", features[2].getName());
+        assertNotNull(features[2].getConfigurationFiles());
+        assertEquals(1, features[2].getConfigurationFiles().size());
+        assertEquals("cf1", 
features[2].getConfigurationFiles().get(0).getFinalname());
+        assertEquals(true, 
features[2].getConfigurationFiles().get(0).isOverride());
+        assertEquals("cfloc", 
features[2].getConfigurationFiles().get(0).getLocation());
+    }
     
     public void testShowWrongUriInException() throws Exception {
         String uri = 
"src/test/resources/org/apache/karaf/shell/features/repo1.xml";

Added: 
karaf/trunk/features/core/src/test/resources/org/apache/karaf/features/repo2.xml
URL: 
http://svn.apache.org/viewvc/karaf/trunk/features/core/src/test/resources/org/apache/karaf/features/repo2.xml?rev=1372740&view=auto
==============================================================================
--- 
karaf/trunk/features/core/src/test/resources/org/apache/karaf/features/repo2.xml
 (added)
+++ 
karaf/trunk/features/core/src/test/resources/org/apache/karaf/features/repo2.xml
 Tue Aug 14 06:20:20 2012
@@ -0,0 +1,37 @@
+<?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.
+-->
+<features name="test" xmlns="http://karaf.apache.org/xmlns/features/v1.0.0";>
+    <repository>
+        urn:r1
+    </repository>
+    <feature name="f1" region="foo">
+        <config name="c1">
+            k=v
+        </config>
+        <bundle>b1</bundle>
+        <bundle>b2</bundle>
+    </feature>
+    <feature name="f2">
+        <feature>f1</feature>
+        <bundle>b3</bundle>
+    </feature>
+    <feature name="f3">
+       <configfile finalname="cf1" override="true">cfloc</configfile>
+       <bundle>b4</bundle> 
+    </feature>
+</features>


Reply via email to