Skip to content

Commit

Permalink
Improve tests for MovingAverage, #15
Browse files Browse the repository at this point in the history
  • Loading branch information
safris committed Jun 9, 2020
1 parent b220567 commit d7f5ac4
Showing 1 changed file with 33 additions and 16 deletions.
49 changes: 33 additions & 16 deletions src/test/java/org/libj/math/MovingAverageTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,23 +21,40 @@
import org.junit.Test;

public class MovingAverageTest {
@Test
public void testMovingAverage() {
final double[] vals = {1, 2, 4, 1, 2, 3, 7};
final double[] averages = {
1.0,
1.5,
2.3333333333333335,
2.0,
2.0,
2.1666666666666665,
2.857142857142857
};

final MovingAverage movingAverage = new MovingAverage();
private static final double epsilon = 0.0001;
private static final double[] vals = {1, 2, 4, 1, 2, 3, 7};
private static final double[] averages = {
1.0,
1.5,
2.3333333333333335,
2.0,
2.0,
2.1666666666666665,
2.857142857142857
};

private static void add(final MovingAverage a, final int i) {
a.add(vals[i]);
assertEquals(averages[i], a.doubleValue(), epsilon);
}

private static void test(final MovingAverage a, final MovingAverage b) {
for (int i = 0; i < vals.length; ++i) {
movingAverage.add(vals[i]);
assertEquals(averages[i], movingAverage.doubleValue(), 0.0001d);
add(a, i);
add(b, i);
assertEquals(a.byteValue(), b.byteValue());
assertEquals(a.shortValue(), b.shortValue());
assertEquals(a.intValue(), b.intValue());
assertEquals(a.longValue(), b.longValue());
assertEquals(a.floatValue(), b.floatValue(), epsilon);
assertEquals(a.toString(), b.toString());
}

assertEquals(vals.length, a.getCount());
}

@Test
public void testMovingAverage() {
test(new MovingAverage(), new MovingAverage(0));
}
}

0 comments on commit d7f5ac4

Please sign in to comment.