/* * This file is part of ADDIS (Aggregate Data Drug Information System). * ADDIS is distributed from http://drugis.org/. * Copyright © 2009 Gert van Valkenhoef, Tommi Tervonen. * Copyright © 2010 Gert van Valkenhoef, Tommi Tervonen, Tijs Zwinkels, * Maarten Jacobs, Hanno Koeslag, Florin Schimbinschi, Ahmad Kamal, Daniel * Reid. * Copyright © 2011 Gert van Valkenhoef, Ahmad Kamal, Daniel Reid, Florin * Schimbinschi. * Copyright © 2012 Gert van Valkenhoef, Daniel Reid, Joël Kuiper, Wouter * Reckman. * Copyright © 2013 Gert van Valkenhoef, Joël Kuiper. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * 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. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.drugis.addis.presentation; import static org.easymock.EasyMock.verify; import static org.junit.Assert.assertEquals; import java.beans.PropertyChangeListener; import org.drugis.common.JUnitUtil; import org.junit.Before; import org.junit.Test; import com.jgoodies.binding.value.ValueModel; import fi.smaa.jsmaa.model.ScaleCriterion; public class RiskScalePresentationTest { private ScaleCriterion d_criterion; private RiskScalePresentation d_pm; @Before public void setUp() { d_criterion = new ScaleCriterion("criterion", true); d_criterion.setScale(new fi.smaa.jsmaa.model.Interval(0.12, 0.34)); d_pm = new RiskScalePresentation(d_criterion); } @Test public void testRiskModelShouldGiveCorrectValue() { Object actual = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_RISK).getValue(); Object expected = RiskScalePresentation.convertInterval(d_criterion.getScale()); assertEquals(expected, actual); } @Test public void testRiskModelShouldFireOnScaleChange() { ValueModel model = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_RISK); fi.smaa.jsmaa.model.Interval interval = new fi.smaa.jsmaa.model.Interval(0.8, 0.99); Object expected = RiskScalePresentation.convertInterval(interval); assertValueModelFires(model, interval, expected); } @Test public void testRiskDifferenceModelShouldGiveCorrectValue() { Object actual = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_RISK_DIFFERENCE).getValue(); Object expected = d_criterion.getScale().getEnd() - d_criterion.getScale().getStart(); assertEquals(expected, actual); } @Test public void testRiskDifferenceModelShouldFireOnScaleChange() { ValueModel model = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_RISK_DIFFERENCE); fi.smaa.jsmaa.model.Interval interval = new fi.smaa.jsmaa.model.Interval(0.8, 0.99); Object expected = interval.getEnd() - interval.getStart(); assertValueModelFires(model, interval, expected); } @Test public void testNNTModelShouldGiveCorrectValue() { Object actual = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_NNT).getValue(); Object expected = 1D / (d_criterion.getScale().getEnd() - d_criterion.getScale().getStart()); assertEquals(expected, actual); } @Test public void testNNTModelShouldFireOnScaleChange() { ValueModel model = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_NNT); fi.smaa.jsmaa.model.Interval interval = new fi.smaa.jsmaa.model.Interval(0.8, 0.99); Object expected = 1D / (interval.getEnd() - interval.getStart()); assertValueModelFires(model, interval, expected); } @Test public void testNNTLabelModelShouldGiveCorrectValue() { Object actual = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_NNT_LABEL).getValue(); Object expected = "NNT"; assertEquals(expected, actual); } @Test public void testNNTLabelModelShouldFireOnScaleChange() { ValueModel model = d_pm.getModel(OddsRatioScalePresentation.PROPERTY_NNT_LABEL); Object expected = "NNH"; PropertyChangeListener mock = JUnitUtil.mockListener(model, "value", null, expected); model.addValueChangeListener(mock); d_criterion.setAscending(false); assertEquals(expected, model.getValue()); verify(mock); } private void assertValueModelFires(ValueModel model, fi.smaa.jsmaa.model.Interval interval, Object expected) { PropertyChangeListener mock = JUnitUtil.mockListener(model, "value", null, expected); model.addValueChangeListener(mock); d_criterion.setScale(interval); assertEquals(expected, model.getValue()); verify(mock); } }