blob: 6b1a71ce88536977ac56e09ce8f8ba71e291216a [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2008, 2010 VMware Inc.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* VMware Inc. - initial contribution
*******************************************************************************/
package org.eclipse.virgo.medic.dump.test;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import java.io.File;
import java.io.IOException;
import java.util.Arrays;
import java.util.Dictionary;
import java.util.Hashtable;
import java.util.List;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceReference;
import org.osgi.service.cm.Configuration;
import org.osgi.service.cm.ConfigurationAdmin;
import org.slf4j.LoggerFactory;
import org.eclipse.virgo.medic.dump.DumpGenerator;
import org.eclipse.virgo.test.framework.OsgiTestRunner;
import org.eclipse.virgo.test.framework.TestFrameworkUtils;
// Medic integration tests do not run in the Eclipse IDE.
@RunWith(OsgiTestRunner.class)
public class DumpIntegrationTests {
private final BundleContext bundleContext = TestFrameworkUtils.getBundleContextForTestClass(getClass());
@Before
public void deleteDumps() {
File dumpsDir = new File("build", "dumps");
if (dumpsDir.exists()) {
deleteRecursively(dumpsDir);
}
}
private static void deleteRecursively(File file) {
if (file.isDirectory()) {
File[] files = file.listFiles();
if (files != null) {
for (File fileInDir : files) {
deleteRecursively(fileInDir);
}
}
}
assertTrue(file.delete());
}
@SuppressWarnings("unchecked")
@Test
public void dumpGeneratorAvailableFromServiceRegistry() {
ServiceReference<DumpGenerator> serviceReference = (ServiceReference<DumpGenerator>)this.bundleContext.getServiceReference(DumpGenerator.class.getName());
assertNotNull(serviceReference);
}
@Test
public void dumpDirectoryConfiguration() throws IOException, InterruptedException {
Configuration configuration = getConfiguration("org.eclipse.virgo.medic");
assertNotNull(configuration);
Dictionary<String, String> properties = new Hashtable<String, String>();
properties.put("dump.root.directory", "build/dumps/1");
configuration.update(properties);
Thread.sleep(2000);
ServiceReference<?> serviceReference = this.bundleContext.getServiceReference(DumpGenerator.class.getName());
DumpGenerator dumpGenerator = (DumpGenerator)this.bundleContext.getService(serviceReference);
dumpGenerator.generateDump("bleurgh");
File file = new File("build/dumps/1");
assertTrue(file.exists());
assertNotNull(file.list());
assertEquals(1, file.list().length);
assertDumpContributionsNumberOf(file.listFiles()[0], 3);
assertDumpContributionsEssential(file.listFiles()[0], "summary.txt", "thread.txt");
assertDumpContributionsAllowable(file.listFiles()[0], "heap.out.hprof", "heap.err", "summary.txt", "thread.txt");
properties.put("dump.root.directory", "build/dumps/2");
configuration.update(properties);
Thread.sleep(2000);
dumpGenerator.generateDump("bleurgh");
file = new File("build/dumps/2");
assertTrue(file.exists());
assertNotNull(file.list());
assertEquals(1, file.list().length);
assertDumpContributionsNumberOf(file.listFiles()[0], 3);
assertDumpContributionsEssential(file.listFiles()[0], "summary.txt", "thread.txt");
assertDumpContributionsAllowable(file.listFiles()[0], "heap.out.hprof", "heap.err.hprof", "summary.txt", "thread.txt");
}
@Test
public void exclusionConfiguration() throws IOException, InterruptedException {
Configuration configuration = getConfiguration("org.eclipse.virgo.medic");
assertNotNull(configuration);
Dictionary<String, String> properties = new Hashtable<String, String>();
properties.put("dump.root.directory", "build/dumps/1");
properties.put("dump.exclusions.bleurgh", "heap");
configuration.update(properties);
Thread.sleep(2000);
ServiceReference<?> serviceReference = this.bundleContext.getServiceReference(DumpGenerator.class.getName());
DumpGenerator dumpGenerator = (DumpGenerator)this.bundleContext.getService(serviceReference);
dumpGenerator.generateDump("bleurgh");
File file = new File("build/dumps/1");
assertTrue(file.exists());
assertNotNull(file.list());
assertEquals(1, file.list().length);
assertDumpContributionsNumberOf(file.listFiles()[0], 2);
assertDumpContributionsEssential(file.listFiles()[0], "summary.txt", "thread.txt");
}
@Test
@SuppressWarnings("unchecked")
public void logDumpEnabled() throws IOException, InterruptedException {
Configuration configuration = getConfiguration("org.eclipse.virgo.medic");
assertNotNull(configuration);
Dictionary<String, String> properties = new Hashtable<String, String>();
properties.put("dump.root.directory", "build/dumps/1");
properties.put("log.dump.level", "ERROR");
configuration.update(properties);
Thread.sleep(2000);
LoggerFactory.getLogger(getClass()).info("Test");
ServiceReference<DumpGenerator> serviceReference = (ServiceReference<DumpGenerator>)this.bundleContext.getServiceReference(DumpGenerator.class.getName());
DumpGenerator dumpGenerator = (DumpGenerator)this.bundleContext.getService(serviceReference);
dumpGenerator.generateDump("bleurgh");
File file = new File("build/dumps/1");
assertTrue(file.exists());
assertNotNull(file.list());
assertEquals(1, file.list().length);
assertDumpContributionsNumberOf(file.listFiles()[0], 3);
assertDumpContributionsEssential(file.listFiles()[0], "summary.txt", "thread.txt");
assertDumpContributionsAllowable(file.listFiles()[0], "heap.out.hprof", "heap.err.hprof", "summary.txt", "thread.txt");
}
private Configuration getConfiguration(String pid) throws IOException {
ConfigurationAdmin configurationAdmin = getConfigurationAdmin();
assertNotNull(configurationAdmin);
return configurationAdmin.getConfiguration(pid);
}
@SuppressWarnings("unchecked")
private ConfigurationAdmin getConfigurationAdmin() {
ServiceReference<ConfigurationAdmin> serviceReference = (ServiceReference<ConfigurationAdmin>)this.bundleContext.getServiceReference(ConfigurationAdmin.class.getName());
assertNotNull(serviceReference);
return (ConfigurationAdmin) this.bundleContext.getService(serviceReference);
}
private static void assertDumpContributionsNumberOf(File dumpDirectory, int numberAllowed) {
assertTrue("No dump directory found or not a directory.", dumpDirectory.exists() && dumpDirectory.isDirectory());
File[] files = dumpDirectory.listFiles();
assertEquals("Found '" + Arrays.toString(files) + " which is not the right number of files.", numberAllowed, files.length);
}
private static void assertDumpContributionsEssential(File dumpDirectory, String... contributions) {
assertTrue("No dump directory found or not a directory.", dumpDirectory.exists() && dumpDirectory.isDirectory());
List<String> dumpDirectoryList = Arrays.asList(dumpDirectory.list());
for (String fileName : contributions) {
assertTrue("The file " + fileName + " was not contributed", dumpDirectoryList.contains(fileName));
}
}
private static void assertDumpContributionsAllowable(File dumpDirectory, String... contributions) {
assertTrue("No dump directory found or not a directory.", dumpDirectory.exists() && dumpDirectory.isDirectory());
List<String> contributionsList = Arrays.asList(contributions);
for (String fileName : dumpDirectory.list()) {
assertTrue("The file " + fileName + " was not expected", contributionsList.contains(fileName));
}
}
}