/*
* 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.entities;
import static org.easymock.EasyMock.verify;
import static org.junit.Assert.assertArrayEquals;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
import java.beans.PropertyChangeListener;
import java.util.HashMap;
import java.util.Map;
import org.drugis.addis.ExampleData;
import org.drugis.common.JUnitUtil;
import org.junit.Before;
import org.junit.Test;
public class FrequencyMeasurementTest {
private PopulationCharacteristic d_cv;
private FrequencyMeasurement d_meas;
@Before
public void setUp() {
d_cv = ExampleData.buildGenderVariable();
d_meas = new FrequencyMeasurement(d_cv);
}
private String getCat(PopulationCharacteristic cv, int i) {
return ((CategoricalVariableType) cv.getVariableType()).getCategories().get(i);
}
@Test
public void testGetSampleSize() {
d_meas.setFrequency(getCat(d_cv, 0), 5);
assertEquals(null, d_meas.getSampleSize());
d_meas.setFrequency(getCat(d_cv, 1), 3);
assertEquals(new Integer(8), d_meas.getSampleSize());
}
@Test
public void testSetFrequency() {
d_meas.setFrequency(getCat(d_cv, 0), 5);
assertEquals(new Integer(5), d_meas.getFrequency(getCat(d_cv, 0)));
}
@Test
public void testSetFrequencyFires() {
d_meas.setFrequency(getCat(d_cv, 0), 5);
Map<String, Integer> map = new HashMap<String, Integer>(d_meas.getFrequencies());
Map<String, Integer> newMap = new HashMap<String, Integer>(d_meas.getFrequencies());
newMap.put("Male", 25);
PropertyChangeListener l = JUnitUtil.mockListener(d_meas, FrequencyMeasurement.PROPERTY_FREQUENCIES,
map, newMap);
d_meas.addPropertyChangeListener(l);
d_meas.setFrequency(getCat(d_cv, 0), 25);
verify(l);
}
@Test(expected=IllegalArgumentException.class)
public void testGetFrequencyThrows() {
d_meas.getFrequency("illegalCat");
}
@Test(expected=IllegalArgumentException.class)
public void testSetFrequencyThrows() {
d_meas.setFrequency("illegalCat", 0);
}
@Test
public void testIsOfType() {
assertTrue(d_meas.isOfType(new CategoricalVariableType()));
assertFalse(d_meas.isOfType(new RateVariableType()));
assertFalse(d_meas.isOfType(new ContinuousVariableType()));
}
@Test
public void testToString() {
d_meas.setFrequency(getCat(d_cv, 0), 25);
d_meas.setFrequency(getCat(d_cv, 1), 50);
String expected = "Male = 25 / Female = 50";
assertEquals(expected, d_meas.toString());
}
@Test
public void testDeepCopy() {
d_meas.setFrequency(getCat(d_cv, 0), 25);
FrequencyMeasurement m = d_meas.clone();
assertArrayEquals(d_meas.getCategories(), m.getCategories());
assertEquals(new Integer(25), m.getFrequency(getCat(d_cv, 0)));
assertEquals(null, m.getFrequency(getCat(d_cv, 1)));
d_meas.setFrequency(getCat(d_cv, 0), 50);
assertEquals(new Integer(25), m.getFrequency(getCat(d_cv, 0)));
}
@Test
public void testEquals() {
FrequencyMeasurement m = d_meas.clone();
d_meas.setFrequency(getCat(d_cv, 0), 25);
d_meas.setFrequency(getCat(d_cv, 1), 50);
assertFalse(d_meas.equals(m));
m = d_meas.clone();
assertEquals(d_meas, m);
assertFalse(d_meas.equals(null));
assertFalse(d_meas.equals(""));
}
@Test
public void testGetCategories() {
assertArrayEquals(((CategoricalVariableType) d_cv.getVariableType()).getCategories().toArray(), d_meas.getCategories());
}
@Test
public void testAdd() {
FrequencyMeasurement m = d_meas.clone();
d_meas.setFrequency(getCat(d_cv, 0), 25);
d_meas.setFrequency(getCat(d_cv, 1), 20);
m.add(d_meas);
assertEquals(null, m.getFrequency(getCat(d_cv, 0)));
assertEquals(null, m.getFrequency(getCat(d_cv, 1)));
m = d_meas.clone();
m.add(d_meas);
assertEquals(new Integer(50), m.getFrequency(getCat(d_cv, 0)));
assertEquals(new Integer(40), m.getFrequency(getCat(d_cv, 1)));
}
@Test
public void testClone() {
d_meas.setFrequency(getCat(d_cv, 0), 25);
d_meas.setFrequency(getCat(d_cv, 1), 20);
assertEquals(d_meas, d_meas.clone());
assertFalse(d_meas == d_meas.clone());
}
}