You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@karaf.apache.org by jb...@apache.org on 2012/09/14 14:23:59 UTC

svn commit: r1384738 - /karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java

Author: jbonofre
Date: Fri Sep 14 12:23:59 2012
New Revision: 1384738

URL: http://svn.apache.org/viewvc?rev=1384738&view=rev
Log:
[KARAF-1798] Add config itests

Added:
    karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java

Added: karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java?rev=1384738&view=auto
==============================================================================
--- karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java (added)
+++ karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/ConfigTest.java Fri Sep 14 12:23:59 2012
@@ -0,0 +1,64 @@
+/*
+ * 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.apache.karaf.itests;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.ops4j.pax.exam.junit.ExamReactorStrategy;
+import org.ops4j.pax.exam.junit.JUnit4TestRunner;
+import org.ops4j.pax.exam.spi.reactors.AllConfinedStagedReactorFactory;
+
+import javax.management.MBeanServerConnection;
+import javax.management.ObjectName;
+import javax.management.remote.JMXConnector;
+
+import java.util.List;
+import java.util.Map;
+
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+
+@RunWith(JUnit4TestRunner.class)
+@ExamReactorStrategy(AllConfinedStagedReactorFactory.class)
+public class ConfigTest extends KarafTestSupport {
+
+    @Test
+    public void listCommand() throws Exception {
+        String configListOutput = executeCommand("config:list");
+        System.out.println(configListOutput);
+        assertFalse(configListOutput.isEmpty());
+        configListOutput = executeCommand("config:list \"(service.pid=org.apache.karaf.features)\"");
+        System.out.println(configListOutput);
+        assertFalse(configListOutput.isEmpty());
+    }
+
+    @Test
+    public void listViaMBean() throws Exception {
+        JMXConnector connector = null;
+        try {
+            connector = this.getJMXConnector();
+            MBeanServerConnection connection = connector.getMBeanServerConnection();
+            ObjectName name = new ObjectName("org.apache.karaf:type=config,name=root");
+            List<String> configs = (List<String>) connection.invoke(name, "list", new Object[]{ }, new String[]{ });
+            assertTrue(configs.size() > 0);
+            assertTrue(configs.contains("org.apache.karaf.features"));
+            Map<String, String> properties = (Map<String, String>) connection.invoke(name, "proplist", new Object[]{ "org.apache.karaf.features" }, new String[]{ "java.lang.String" });
+            assertTrue(properties.keySet().size() > 0);
+        } finally {
+            if (connector != null)
+                connector.close();
+        }
+    }
+
+}