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 15:42:13 UTC

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

Author: jbonofre
Date: Fri Sep 14 13:42:12 2012
New Revision: 1384783

URL: http://svn.apache.org/viewvc?rev=1384783&view=rev
Log:
[KARAF-1798] Add packages itest

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

Added: karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/PackagesTest.java
URL: http://svn.apache.org/viewvc/karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/PackagesTest.java?rev=1384783&view=auto
==============================================================================
--- karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/PackagesTest.java (added)
+++ karaf/branches/karaf-2.3.x/itests/src/test/java/org/apache/karaf/itests/PackagesTest.java Fri Sep 14 13:42:12 2012
@@ -0,0 +1,78 @@
+/*
+ * 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.openmbean.TabularData;
+import javax.management.remote.JMXConnector;
+
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertTrue;
+
+@RunWith(JUnit4TestRunner.class)
+@ExamReactorStrategy(AllConfinedStagedReactorFactory.class)
+public class PackagesTest extends KarafTestSupport {
+
+    @Test
+    public void exportsCommand() throws Exception {
+        String exportsOutput = executeCommand("packages:exports");
+        System.out.println(exportsOutput);
+        assertFalse(exportsOutput.isEmpty());
+    }
+
+    @Test
+    public void exportsViaMBean() throws Exception {
+        JMXConnector connector = null;
+        try {
+            connector = this.getJMXConnector();
+            MBeanServerConnection connection = connector.getMBeanServerConnection();
+            ObjectName name = new ObjectName("org.apache.karaf:type=packages,name=root");
+            TabularData exports = (TabularData) connection.invoke(name, "exportedPackages", new Object[]{ }, new String[]{ });
+            assertTrue(exports.size() > 0);
+        } finally {
+            if (connector != null)
+                connector.close();
+        }
+    }
+
+    @Test
+    public void importsCommand() throws Exception {
+        String importsOutput = executeCommand("packages:imports");
+        System.out.println(importsOutput);
+        assertFalse(importsOutput.isEmpty());
+    }
+
+    @Test
+    public void importsViaMBean() throws Exception {
+        JMXConnector connector = null;
+        try {
+            connector = this.getJMXConnector();
+            MBeanServerConnection connection = connector.getMBeanServerConnection();
+            ObjectName name = new ObjectName("org.apache.karaf:type=packages,name=root");
+            TabularData imports = (TabularData) connection.invoke(name, "importedPackages", new Object[]{ }, new String[]{ });
+            assertTrue(imports.size() > 0);
+        } finally {
+            if (connector != null)
+                connector.close();
+        }
+    }
+
+}