/* * This program is free software; you can redistribute it and/or modify it under the * terms of the GNU General Public License, version 2 as published by the Free Software * Foundation. * * You should have received a copy of the GNU General Public License along with this * program; if not, you can obtain a copy at http://www.gnu.org/licenses/gpl-2.0.html * or from the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU General Public License for more details. * * * Copyright 2008 Pentaho Corporation. All rights reserved. */ package org.pentaho.test.platform.engine.core; import java.math.BigDecimal; import org.pentaho.platform.api.engine.IAuditEntry; import org.pentaho.platform.engine.core.audit.AuditEntry; import org.pentaho.platform.engine.core.audit.AuditHelper; import org.pentaho.platform.engine.core.audit.MessageTypes; import org.pentaho.platform.engine.core.audit.NullAuditEntry; import org.pentaho.platform.engine.core.output.SimpleContentItem; import org.pentaho.platform.engine.core.system.PentahoSystem; import org.pentaho.platform.engine.core.system.StandaloneSession; import org.pentaho.platform.engine.core.system.objfac.StandaloneObjectFactory; import junit.framework.TestCase; @SuppressWarnings({"all"}) public class AuditEntryTest extends TestCase { public void testAuditEntry() throws Exception { StandaloneObjectFactory factory = new StandaloneObjectFactory(); PentahoSystem.setObjectFactory( factory ); String jobId = "testjobid"; String instId = "testinstid"; String objId = "testobjid"; String objType = "testobjtype"; String actor = "testactor"; String messageType = "testtype"; String messageName = "testname"; String messageTxtValue = MessageTypes.INSTANCE_END; BigDecimal messageNumValue = new BigDecimal(99); float duration = (float) 1.23; // this should not complain AuditEntry.auditJobDuration(jobId, instId, objId, objType, actor, messageType, messageName, messageTxtValue, duration); TestOutputHandler.contentItem = new SimpleContentItem(); factory.defineObject(IAuditEntry.class.getSimpleName(), TestAuditEntry.class.getName(), StandaloneObjectFactory.Scope.GLOBAL); // this should not complain AuditEntry.auditJobDuration(jobId, instId, objId, objType, actor, messageType, messageName, messageTxtValue, duration); TestAuditEntry entry = (TestAuditEntry) factory.get(IAuditEntry.class, null); assertEquals( jobId, entry.jobId ); assertEquals( "1.23", Double.toString( entry.duration ).substring(0,4) ); assertEquals( null, entry.messageNumValue ); assertEquals( messageType, entry.messageType ); assertEquals( messageName, entry.messageName ); assertEquals( messageTxtValue, entry.messageTxtValue ); AuditEntry.auditJobNumValue(jobId, instId, objId, objType, actor, messageType, messageName, messageNumValue); assertEquals( "0", Double.toString( entry.duration ).substring(0, 1) ); assertEquals( messageNumValue, entry.messageNumValue ); assertEquals( null, entry.messageTxtValue ); AuditEntry.auditJobTxtValue(jobId, instId, objId, objType, actor, messageType, messageName, messageTxtValue); assertEquals( "0", Double.toString( entry.duration ).substring(0, 1) ); assertEquals( null, entry.messageNumValue ); assertEquals( messageTxtValue, entry.messageTxtValue ); new MessageTypes(); new AuditHelper(); new AuditEntry(); } public void testAuditHelper() throws Exception { StandaloneSession session = new StandaloneSession( "testuser"); String messageType = "testtype"; String messageName = "testname"; String messageTxtValue = "testtext"; BigDecimal messageNumValue = new BigDecimal(99); float duration = (float) 1.23; AuditHelper.audit(null, session, messageType, messageName, messageTxtValue, duration, null); TestAuditEntry entry = (TestAuditEntry) PentahoSystem.get(IAuditEntry.class, null); assertEquals( "", entry.instId ); assertEquals( "", entry.jobId ); assertEquals( "testuser", entry.actor ); assertEquals( messageTxtValue, entry.messageTxtValue ); } public void testNullAuditEntry() { IAuditEntry auditEntry = new NullAuditEntry(); // this should not fail, even with all nulls as inputs auditEntry.auditAll(null, null, null, null, null, null, null, null, null, 0.0); } }