blob: 12bb09608205858db79e64b84cffe2d07c974db4 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007, 2012 IBM Corporation and others 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: IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.equinox.log.test;
import junit.framework.TestCase;
import org.eclipse.osgi.tests.OSGiTestsActivator;
import org.osgi.framework.ServiceReference;
import org.osgi.service.log.*;
public class LogServiceTest extends TestCase {
private LogService log;
private ServiceReference logReference;
private LogReaderService reader;
private ServiceReference readerReference;
private TestListener listener;
public LogServiceTest(String name) {
super(name);
}
protected void setUp() throws Exception {
logReference = OSGiTestsActivator.getContext().getServiceReference(LogService.class.getName());
readerReference = OSGiTestsActivator.getContext().getServiceReference(LogReaderService.class.getName());
log = (LogService) OSGiTestsActivator.getContext().getService(logReference);
reader = (LogReaderService) OSGiTestsActivator.getContext().getService(readerReference);
listener = new TestListener();
reader.addLogListener(listener);
}
protected void tearDown() throws Exception {
reader.removeLogListener(listener);
OSGiTestsActivator.getContext().ungetService(logReference);
OSGiTestsActivator.getContext().ungetService(readerReference);
}
public void testLogDebug() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_DEBUG, "debug"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == LogService.LOG_DEBUG);
}
public void testLogError() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_ERROR, "error"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == LogService.LOG_ERROR);
}
public void testLogInfo() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_INFO, "info"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == LogService.LOG_INFO);
}
public void testLogWarning() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_WARNING, "warning"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == LogService.LOG_WARNING);
}
public void testLogZeroLevel() throws Exception {
synchronized (listener) {
log.log(0, "zero"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == 0);
}
public void testLogNegativeLevel() throws Exception {
synchronized (listener) {
log.log(-1, "negative"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getLevel() == -1);
}
public void testLogMessage() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_INFO, "message"); //$NON-NLS-1$
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getMessage().equals("message")); //$NON-NLS-1$
}
public void testLogNullMessage() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_INFO, null);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getMessage() == null);
}
public void testLogThrowable() throws Exception {
Throwable t = new Throwable("throwable"); //$NON-NLS-1$
synchronized (listener) {
log.log(LogService.LOG_INFO, null, t);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getException().getMessage().equals(t.getMessage()));
}
public void testLogNullThrowable() throws Exception {
synchronized (listener) {
log.log(LogService.LOG_INFO, null, null);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getException() == null);
}
public void testLogServiceReference() throws Exception {
synchronized (listener) {
log.log(logReference, LogService.LOG_INFO, null);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getServiceReference().equals(logReference));
}
public void testNullLogServiceReference() throws Exception {
synchronized (listener) {
log.log(null, LogService.LOG_INFO, null);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getServiceReference() == null);
}
public void testLogServiceReferenceWithNullThrowable() throws Exception {
synchronized (listener) {
log.log(logReference, LogService.LOG_INFO, null, null);
listener.waitForLogEntry();
}
assertTrue(listener.getEntryX().getServiceReference().equals(logReference));
}
public void testLogNull1() throws Exception {
synchronized (listener) {
log.log(0, null);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == 0);
assertTrue(entry.getMessage() == null);
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == null);
}
public void testLogNull2() throws Exception {
synchronized (listener) {
log.log(0, null, null);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == 0);
assertTrue(entry.getMessage() == null);
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == null);
}
public void testLogNull3() throws Exception {
synchronized (listener) {
log.log(null, 0, null);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == 0);
assertTrue(entry.getMessage() == null);
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == null);
}
public void testLogNull4() throws Exception {
synchronized (listener) {
log.log(null, 0, null, null);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == 0);
assertTrue(entry.getMessage() == null);
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == null);
}
public void testLogFull1() throws Exception {
String message = "test"; //$NON-NLS-1$
synchronized (listener) {
log.log(LogService.LOG_INFO, message);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == LogService.LOG_INFO);
assertTrue(entry.getMessage().equals(message));
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == null);
}
public void testLogFull2() throws Exception {
String message = "test"; //$NON-NLS-1$
Throwable t = new Throwable("test"); //$NON-NLS-1$
synchronized (listener) {
log.log(LogService.LOG_INFO, message, t);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == LogService.LOG_INFO);
assertTrue(entry.getMessage().equals(message));
assertTrue(entry.getException().getMessage().equals(t.getMessage()));
assertTrue(entry.getServiceReference() == null);
}
public void testLogFull3() throws Exception {
String message = "test"; //$NON-NLS-1$
synchronized (listener) {
log.log(logReference, LogService.LOG_INFO, message);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == LogService.LOG_INFO);
assertTrue(entry.getMessage().equals(message));
assertTrue(entry.getException() == null);
assertTrue(entry.getServiceReference() == logReference);
}
public void testLogFull4() throws Exception {
String message = "test"; //$NON-NLS-1$
Throwable t = new Throwable("test"); //$NON-NLS-1$
synchronized (listener) {
log.log(logReference, LogService.LOG_INFO, message, t);
listener.waitForLogEntry();
}
LogEntry entry = listener.getEntryX();
assertTrue(entry.getLevel() == LogService.LOG_INFO);
assertTrue(entry.getMessage().equals(message));
assertTrue(entry.getException().getMessage().equals(t.getMessage()));
assertTrue(entry.getServiceReference() == logReference);
}
}