// ============================================================================ // // Copyright (C) 2006-2016 Talend Inc. - www.talend.com // // This source code is available under agreement available at // %InstallDIR%\features\org.talend.rcp.branding.%PRODUCTNAME%\%PRODUCTNAME%license.txt // // You should have received a copy of the agreement // along with this program; if not, write to Talend SA // 9 rue Pages 92150 Suresnes, France // // ============================================================================ package org.talend.dataquality.statistics.numeric.summary; import static org.junit.Assert.assertEquals; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.talend.dataquality.statistics.type.DataTypeEnum; public class VarianceValueAnalyzerTest { @Before public void setUp() throws Exception { } @After public void tearDown() throws Exception { } @Test public void testAnalyzeStringArray() { SummaryAnalyzer analyzer = new SummaryAnalyzer(new DataTypeEnum[] { DataTypeEnum.DOUBLE }); // 1. assert case of all double values. String[] pureDouble = new String[] { "20", "0.3", "3", "4.5", "8" }; analyzer.init(); for (String strValue : pureDouble) { analyzer.analyze(strValue); } analyzer.end(); assertEquals(59.2, analyzer.getResult().get(0).getVariance(), 0.055); // 2. assert variance is small give same data. pureDouble = new String[] { "8", "8", "8", "8", "8" }; analyzer.init(); for (String strValue : pureDouble) { analyzer.analyze(strValue); } analyzer.end(); assertEquals(0, analyzer.getResult().get(0).getVariance(), 0.055); // 3. assert with values contain a str analyzer.init(); String[] strValues = new String[] { "20", "0.3", "3", "4.5", "8", "a str" }; for (String strValue : strValues) { analyzer.analyze(strValue); } analyzer.end(); assertEquals(59.2, analyzer.getResult().get(0).getVariance(), 0.055); } }