/*!
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.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 Lesser General Public License for more details.
*
* Copyright (c) 2002-2013 Pentaho Corporation.. All rights reserved.
*/
package org.pentaho.reporting.engine.classic.core.function;
import junit.framework.Assert;
import org.pentaho.reporting.engine.classic.core.event.ReportEvent;
import org.pentaho.reporting.libraries.base.util.DebugLog;
public class ValidateFunctionResultExpression extends AbstractFunction {
private boolean failHard;
private int currentDataItem;
private String crosstabFilterGroup;
public ValidateFunctionResultExpression() {
}
public ValidateFunctionResultExpression( final String name, final boolean failHard,
final String validateCrosstabFilter ) {
setName( name );
this.crosstabFilterGroup = validateCrosstabFilter;
this.failHard = failHard;
}
public String getCrosstabFilterGroup() {
return crosstabFilterGroup;
}
public void setCrosstabFilterGroup( final String crosstabFilterGroup ) {
this.crosstabFilterGroup = crosstabFilterGroup;
}
public boolean isFailHard() {
return failHard;
}
public void setFailHard( final boolean failHard ) {
this.failHard = failHard;
}
public Object getValue() {
return null;
}
public void summaryRowSelection( final ReportEvent event ) {
if ( FunctionUtilities.isDefinedGroup( getCrosstabFilterGroup(), event ) ) {
final String targetName = getName().substring( 1 );
final Object expressionValue = getDataRow().get( targetName );
final Object tableModelValue = getDataRow().get( "validate-" + targetName );
currentDataItem = event.getState().getCurrentDataItem();
if ( !equalNumeric( expressionValue, tableModelValue ) ) {
if ( failHard ) {
DebugLog.log( "*" + currentDataItem + "! " + expressionValue + " - " + tableModelValue );
Assert.assertEquals( tableModelValue, expressionValue );
} else {
DebugLog.log( "*" + currentDataItem + "! " + expressionValue + " - " + tableModelValue );
}
}
}
}
public void itemsAdvanced( final ReportEvent event ) {
final String targetName = getName().substring( 1 );
final Object expressionValue = getDataRow().get( targetName );
final Object tableModelValue = getDataRow().get( "validate-" + targetName );
currentDataItem = event.getState().getCurrentDataItem();
long sequenceCounter = event.getState().getCrosstabColumnSequenceCounter( 3 );
if ( !failHard ) {
DebugLog.log( currentDataItem + ":" + sequenceCounter + "# " + expressionValue + " - " + tableModelValue );
}
if ( !equalNumeric( expressionValue, tableModelValue ) ) {
if ( failHard ) {
// DebugLog.log(currentDataItem + "! " + expressionValue + " - " + tableModelValue);
Assert.assertEquals( tableModelValue, expressionValue );
} else {
// DebugLog.log(currentDataItem + "! " + expressionValue + " - " + tableModelValue);
}
}
}
private boolean equalNumeric( final Object o1, final Object o2 ) {
if ( o1 instanceof Number == false ) {
return false;
}
if ( o2 instanceof Number == false ) {
return false;
}
final Number n1 = (Number) o1;
final Number n2 = (Number) o2;
return Math.abs( n1.doubleValue() - n2.doubleValue() ) < 0.0000005;
}
}