/*
* This file is part of the GeoLatte project.
*
* GeoLatte is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* GeoLatte 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.
*
* You should have received a copy of the GNU Lesser General Public License
* along with GeoLatte. If not, see <http://www.gnu.org/licenses/>.
*
* Copyright (C) 2010 - 2010 and Ownership of code is shared by:
* Qmino bvba - Romeinsestraat 18 - 3001 Heverlee (http://www.qmino.com)
* Geovise bvba - Generaal Eisenhowerlei 9 - 2140 Antwerpen (http://www.geovise.com)
*/
package org.geolatte.common.expressions;
import org.jmock.Expectations;
import org.jmock.Mockery;
import org.jmock.integration.junit4.JUnit4Mockery;
import org.jmock.lib.legacy.ClassImposteriser;
import org.junit.After;
import org.junit.Before;
/**
* <p>
* This is the parent class for number comparison tests. It defines an number of common mocks.
* </p>
* <p>
* <i>Creation-Date</i>: 25-May-2010<br>
* <i>Creation-Time</i>: 16:53:19<br>
* </p>
*
* @author Bert Vanhooff
* @author <a href="http://www.qmino.com">Qmino bvba</a>
* @since SDK1.5
*/
public abstract class AbstractNumberComparisonTest {
private final int HIGHNUMBER = 5;
private final int LOWNUMBER = 1;
// Set Imposteriser to enable mocking classes (otherwise, only interfaces can be mocked)
protected Mockery context = new JUnit4Mockery() {
{setImposteriser(ClassImposteriser.INSTANCE);}
};
@SuppressWarnings("unchecked")
protected final NumberExpression highNumberExpression = (NumberExpression)context.mock(NumberExpression.class, "HighNumber");
@SuppressWarnings("unchecked")
protected final NumberExpression lowNumberExpression = (NumberExpression)context.mock(NumberExpression.class, "LowNumber");
protected Object theObjectToEvaluate = new Object();
@Before
public void setUp() throws Exception {
// Set return values for mocked highNumberExpression
context.checking(new Expectations() {
{allowing(highNumberExpression).evaluate(with(theObjectToEvaluate)); will(returnValue(HIGHNUMBER)); // Evaluate always returns HIGHNUMBER
allowing(highNumberExpression).compareTo(with(theObjectToEvaluate), with(HIGHNUMBER)); will(returnValue(0)); // Compare to itself (equal) returns 0
allowing(highNumberExpression).compareTo(with(theObjectToEvaluate), with(LOWNUMBER)); will(returnValue(1));} // Compare to a lower number returns 1
});
// Set return values for mocked lowNumberExpression
context.checking(new Expectations() {
{allowing(lowNumberExpression).evaluate(with(theObjectToEvaluate)); will(returnValue(LOWNUMBER)); // Evaluate always returns LOWNUMBER
allowing(lowNumberExpression).compareTo(with(theObjectToEvaluate), with(LOWNUMBER)); will(returnValue(0)); // Compare to itself (equal) returns 0
allowing(lowNumberExpression).compareTo(with(theObjectToEvaluate), with(HIGHNUMBER)); will(returnValue(-1));} // Compare to a higher number returns -1
});
}
@After
public void tearDown() throws Exception {
}
}