/*! ****************************************************************************** * * Pentaho Data Integration * * Copyright (C) 2002-2016 by Pentaho : http://www.pentaho.com * ******************************************************************************* * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ******************************************************************************/ package org.pentaho.di.trans.steps.uniquerows; import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import org.junit.Test; import org.pentaho.di.core.exception.KettleException; import org.pentaho.di.trans.steps.loadsave.LoadSaveTester; import org.pentaho.di.trans.steps.loadsave.validator.ArrayLoadSaveValidator; import org.pentaho.di.trans.steps.loadsave.validator.BooleanLoadSaveValidator; import org.pentaho.di.trans.steps.loadsave.validator.FieldLoadSaveValidator; import org.pentaho.di.trans.steps.loadsave.validator.PrimitiveBooleanArrayLoadSaveValidator; import org.pentaho.di.trans.steps.loadsave.validator.StringLoadSaveValidator; public class UniqueRowsMetaTest { @Test public void testRoundTrip() throws KettleException { List<String> attributes = Arrays.asList( "count_rows", "count_field", "reject_duplicate_row", "error_description", "name", "case_insensitive" ); Map<String, String> getterMap = new HashMap<String, String>(); getterMap.put( "count_rows", "isCountRows" ); getterMap.put( "count_field", "getCountField" ); getterMap.put( "reject_duplicate_row", "isRejectDuplicateRow" ); getterMap.put( "error_description", "getErrorDescription" ); getterMap.put( "name", "getCompareFields" ); getterMap.put( "case_insensitive", "getCaseInsensitive" ); Map<String, String> setterMap = new HashMap<String, String>(); setterMap.put( "count_rows", "setCountRows" ); setterMap.put( "count_field", "setCountField" ); setterMap.put( "reject_duplicate_row", "setRejectDuplicateRow" ); setterMap.put( "error_description", "setErrorDescription" ); setterMap.put( "name", "setCompareFields" ); setterMap.put( "case_insensitive", "setCaseInsensitive" ); Map<String, FieldLoadSaveValidator<?>> fieldLoadSaveValidatorAttributeMap = new HashMap<String, FieldLoadSaveValidator<?>>(); //Arrays need to be consistent length FieldLoadSaveValidator<String[]> stringArrayLoadSaveValidator = new ArrayLoadSaveValidator<String>( new StringLoadSaveValidator(), 25 ); FieldLoadSaveValidator<boolean[]> booleanArrayLoadSaveValidator = new PrimitiveBooleanArrayLoadSaveValidator( new BooleanLoadSaveValidator(), 25 ); fieldLoadSaveValidatorAttributeMap.put( "name", stringArrayLoadSaveValidator ); fieldLoadSaveValidatorAttributeMap.put( "case_insensitive", booleanArrayLoadSaveValidator ); LoadSaveTester loadSaveTester = new LoadSaveTester( UniqueRowsMeta.class, attributes, getterMap, setterMap, fieldLoadSaveValidatorAttributeMap, new HashMap<String, FieldLoadSaveValidator<?>>() ); loadSaveTester.testSerialization(); } }