/* * JBoss, Home of Professional Open Source. * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. Some portions may be licensed * to Red Hat, Inc. under one or more contributor license agreements. * * This library 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 2.1 of the License, or (at your option) any later version. * * This library 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 this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. */ package org.teiid.dqp.message; import java.math.BigInteger; import java.util.ArrayList; import java.util.List; import junit.framework.TestCase; import org.teiid.client.ResultsMessage; import org.teiid.client.metadata.ParameterInfo; import org.teiid.client.plan.PlanNode; import org.teiid.core.types.DataTypeManager; import org.teiid.core.util.UnitTestUtil; @SuppressWarnings("nls") public class TestResultsMessage extends TestCase { /** * Constructor for TestResultsMessage. * @param name */ public TestResultsMessage(String name) { super(name); } public static ResultsMessage example() { ResultsMessage message = new ResultsMessage(); message.setColumnNames(new String[] {"A", "B", "C", "D"}); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ message.setDataTypes(new String[] {DataTypeManager.DefaultDataTypes.BIG_INTEGER, DataTypeManager.DefaultDataTypes.BIG_INTEGER, DataTypeManager.DefaultDataTypes.BIG_INTEGER, DataTypeManager.DefaultDataTypes.BIG_INTEGER}); message.setFinalRow(200); message.setFirstRow(1); message.setLastRow(100); List parameters = new ArrayList(); parameters.add(new ParameterInfo(ParameterInfo.IN, 0)); parameters.add(new ParameterInfo(ParameterInfo.RESULT_SET, 5)); message.setParameters(parameters); PlanNode planDescs = new PlanNode("test"); planDescs.addProperty("key1", "val1"); //$NON-NLS-1$ //$NON-NLS-2$ planDescs.addProperty("key2", "val2"); //$NON-NLS-1$ //$NON-NLS-2$ planDescs.addProperty("key3", "val3"); //$NON-NLS-1$ //$NON-NLS-2$ planDescs.addProperty("key4", "val4"); //$NON-NLS-1$ //$NON-NLS-2$ message.setPlanDescription(planDescs); List results = new ArrayList(); results.add(new BigInteger("100")); //$NON-NLS-1$ results.add(new BigInteger("200")); //$NON-NLS-1$ results.add(new BigInteger("300")); //$NON-NLS-1$ results.add(new BigInteger("400")); //$NON-NLS-1$ message.setResults(new List[] {results}); List warnings = new ArrayList(); warnings.add(new Exception("warning1")); //$NON-NLS-1$ warnings.add(new Exception("warning2")); //$NON-NLS-1$ message.setWarnings(warnings); return message; } public void testSerialize() throws Exception { ResultsMessage message = example(); ResultsMessage copy = UnitTestUtil.helpSerialize(message); assertNotNull(copy.getColumnNames()); assertEquals(4, copy.getColumnNames().length); assertEquals("A", copy.getColumnNames()[0]); //$NON-NLS-1$ assertEquals("B", copy.getColumnNames()[1]); //$NON-NLS-1$ assertEquals("C", copy.getColumnNames()[2]); //$NON-NLS-1$ assertEquals("D", copy.getColumnNames()[3]); //$NON-NLS-1$ assertNotNull(copy.getDataTypes()); assertEquals(4, copy.getDataTypes().length); assertEquals(DataTypeManager.DefaultDataTypes.BIG_INTEGER, copy.getDataTypes()[0]); assertEquals(DataTypeManager.DefaultDataTypes.BIG_INTEGER, copy.getDataTypes()[1]); assertEquals(DataTypeManager.DefaultDataTypes.BIG_INTEGER, copy.getDataTypes()[2]); assertEquals(DataTypeManager.DefaultDataTypes.BIG_INTEGER, copy.getDataTypes()[3]); assertEquals(200, copy.getFinalRow()); assertEquals(1, copy.getFirstRow()); assertEquals(100, copy.getLastRow()); assertNotNull(copy.getParameters()); assertEquals(2, copy.getParameters().size()); ParameterInfo info1 = (ParameterInfo) copy.getParameters().get(0); assertEquals(ParameterInfo.IN, info1.getType()); assertEquals(0, info1.getNumColumns()); ParameterInfo info2 = (ParameterInfo) copy.getParameters().get(1); assertEquals(ParameterInfo.RESULT_SET, info2.getType()); assertEquals(5, info2.getNumColumns()); assertNotNull(copy.getPlanDescription()); assertEquals(4, copy.getPlanDescription().getProperties().size()); List<? extends List<?>> results = copy.getResultsList(); assertNotNull(results); assertEquals(1, results.size()); assertNotNull(results.get(0)); assertEquals(4, results.get(0).size()); assertEquals(new BigInteger("100"), copy.getResultsList().get(0).get(0)); //$NON-NLS-1$ assertEquals(new BigInteger("200"), copy.getResultsList().get(0).get(1)); //$NON-NLS-1$ assertEquals(new BigInteger("300"), copy.getResultsList().get(0).get(2)); //$NON-NLS-1$ assertEquals(new BigInteger("400"), copy.getResultsList().get(0).get(3)); //$NON-NLS-1$ assertNotNull(copy.getWarnings()); assertEquals(2, copy.getWarnings().size()); assertEquals(Exception.class, copy.getWarnings().get(0).getClass()); assertEquals("warning1", ((Exception)copy.getWarnings().get(0)).getMessage()); //$NON-NLS-1$ assertEquals(Exception.class, copy.getWarnings().get(1).getClass()); assertEquals("warning2", ((Exception)copy.getWarnings().get(1)).getMessage()); //$NON-NLS-1$ } public void testDelayedDeserialization() throws Exception { ResultsMessage message = example(); message.setDelayDeserialization(true); ResultsMessage copy = UnitTestUtil.helpSerialize(message); assertNull(copy.getResultsList()); copy.processResults(); assertNotNull(copy.getResultsList()); } }