/*! ******************************************************************************
*
* Pentaho Data Integration
*
* Copyright (C) 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.synchronizeaftermerge;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertEquals;
import org.junit.Before;
import org.junit.Test;
import org.pentaho.di.core.exception.KettleException;
import org.pentaho.di.core.injection.BaseMetadataInjectionTest;
public class SynchronizeAfterMergeMetaInjectionTest extends BaseMetadataInjectionTest<SynchronizeAfterMergeMeta> {
@Before
public void setup() {
super.setup( new SynchronizeAfterMergeMeta() );
}
@Test
public void test() throws Exception {
check( "SHEMA_NAME", new StringGetter() {
@Override
public String get() {
return meta.getSchemaName();
}
} );
check( "TABLE_NAME", new StringGetter() {
@Override
public String get() {
return meta.getTableName();
}
} );
check( "TABLE_FIELD", new StringGetter() {
@Override
public String get() {
return meta.getKeyLookup()[0];
}
} );
check( "STREAM_FIELD1", new StringGetter() {
@Override
public String get() {
return meta.getKeyStream()[0];
}
} );
check( "STREAM_FIELD2", new StringGetter() {
@Override
public String get() {
return meta.getKeyStream2()[0];
}
} );
check( "COMPARATOR", new StringGetter() {
@Override
public String get() {
return meta.getKeyCondition()[0];
}
} );
check( "UPDATE_TABLE_FIELD", new StringGetter() {
@Override
public String get() {
return meta.getUpdateLookup()[0];
}
} );
check( "STREAM_FIELD", new StringGetter() {
@Override
public String get() {
return meta.getUpdateStream()[0];
}
} );
check( "UPDATE", new BooleanGetter() {
@Override
public boolean get() {
return meta.getUpdate()[0];
}
} );
check( "COMMIT_SIZE", new IntGetter() {
@Override
public int get() {
return meta.getCommitSize();
}
} );
check( "TABLE_NAME_IN_FIELD", new BooleanGetter() {
@Override
public boolean get() {
return meta.istablenameInField();
}
} );
check( "TABLE_NAME_FIELD", new StringGetter() {
@Override
public String get() {
return meta.gettablenameField();
}
} );
check( "OPERATION_ORDER_FIELD", new StringGetter() {
@Override
public String get() {
return meta.getOperationOrderField();
}
} );
check( "USE_BATCH_UPDATE", new BooleanGetter() {
@Override
public boolean get() {
return meta.useBatchUpdate();
}
} );
check( "PERFORM_LOOKUP", new BooleanGetter() {
@Override
public boolean get() {
return meta.isPerformLookup();
}
} );
check( "ORDER_INSERT", new StringGetter() {
@Override
public String get() {
return meta.getOrderInsert();
}
} );
check( "ORDER_UPDATE", new StringGetter() {
@Override
public String get() {
return meta.getOrderUpdate();
}
} );
check( "ORDER_DELETE", new StringGetter() {
@Override
public String get() {
return meta.getOrderDelete();
}
} );
check( "CONNECTION_NAME", new StringGetter() {
public String get() {
return "My Connection";
}
}, "My Connection" );
}
@Test
public void getXML() throws KettleException {
skipProperties( "CONNECTION_NAME", "TABLE_NAME", "STREAM_FIELD2", "PERFORM_LOOKUP", "COMPARATOR",
"OPERATION_ORDER_FIELD", "ORDER_DELETE", "SHEMA_NAME", "TABLE_NAME_IN_FIELD", "ORDER_UPDATE", "ORDER_INSERT",
"USE_BATCH_UPDATE", "STREAM_FIELD", "TABLE_FIELD", "COMMIT_SIZE", "TABLE_NAME_FIELD" );
meta.setDefault();
check( "STREAM_FIELD1", new StringGetter() {
@Override
public String get() {
return meta.getKeyStream()[0];
}
} );
check( "UPDATE_TABLE_FIELD", new StringGetter() {
@Override
public String get() {
return meta.getUpdateLookup()[0];
}
} );
check( "UPDATE", new BooleanGetter() {
@Override
public boolean get() {
return meta.getUpdate()[0];
}
} );
meta.getXML();
String[] actualKeyLookup = meta.getKeyLookup();
assertNotNull( actualKeyLookup );
assertEquals( 1, actualKeyLookup.length );
String[] actualKeyCondition = meta.getKeyCondition();
assertNotNull( actualKeyCondition );
assertEquals( 1, actualKeyCondition.length );
String[] actualKeyStream2 = meta.getKeyCondition();
assertNotNull( actualKeyStream2 );
assertEquals( 1, actualKeyStream2.length );
String[] actualUpdateStream = meta.getUpdateStream();
assertNotNull( actualUpdateStream );
assertEquals( 1, actualUpdateStream.length );
}
private void skipProperties( String... propertyName ) {
for ( String property : propertyName ) {
skipPropertyTest( property );
}
}
}