/*
* Copyright 2014, Stratio.
*
* 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 com.stratio.deep.jdbc.extractor;
import com.mysql.jdbc.Driver;
import com.stratio.deep.commons.config.ExtractorConfig;
import com.stratio.deep.commons.entity.Cells;
import com.stratio.deep.commons.extractor.utils.ExtractorConstants;
import com.stratio.deep.jdbc.config.JdbcConfigFactory;
import com.stratio.deep.jdbc.config.JdbcDeepJobConfig;
import com.stratio.deep.jdbc.reader.JdbcReader;
import com.stratio.deep.jdbc.writer.JdbcWriter;
import org.apache.spark.Partition;
import org.apache.spark.rdd.JdbcPartition;
import org.mockito.Mockito;
import org.mockito.internal.util.reflection.Whitebox;
import org.powermock.api.mockito.PowerMockito;
import org.testng.annotations.Test;
import java.util.HashMap;
import java.util.Map;
import static org.mockito.Mockito.*;
import static org.testng.Assert.assertEquals;
/**
* Created by mariomgal on 12/12/14.
*/
@Test(groups = { "UnitTests" })
public class JdbcNativeExtractorTest {
private static final String HOST = "localhost";
private static final int PORT = 3306;
private static final String DRIVER_CLASS = "com.mysql.jdbc.Driver";
private static final String DATABASE = "database";
private static final String TABLE = "table";
private static final int NUM_PARTITIONS = 1;
private JdbcReader jdbcReader = PowerMockito.mock(JdbcReader.class);
private JdbcWriter jdbcWriter = PowerMockito.mock(JdbcWriter.class);
@Test
public void testPartitions() {
JdbcNativeExtractor extractor = createJdbcNativeExtractor();
Partition [] partitions = extractor.getPartitions(createJdbcDeepJobConfig());
assertEquals(partitions.length, NUM_PARTITIONS);
JdbcPartition partition0 = (JdbcPartition)partitions[0];
assertEquals(partition0.index(), 0);
assertEquals(partition0.lower(), 0);
assertEquals(partition0.upper(), Integer.MAX_VALUE - 1);
}
@Test
public void testHasNext() throws Exception {
JdbcNativeExtractor extractor = createJdbcNativeExtractor();
extractor.hasNext();
verify(jdbcReader, times(1)).hasNext();
}
@Test
public void testSaveRdd() throws Exception {
JdbcNativeExtractor extractor = createJdbcNativeExtractor();
doReturn(new HashMap()).when(extractor).transformElement(any(Object.class));
extractor.saveRDD(new Object());
verify(jdbcWriter, times(1)).save(any(Map.class));
}
@Test
public void testClose() throws Exception {
JdbcNativeExtractor extractor = createJdbcNativeExtractor();
extractor.close();
verify(jdbcWriter, times(1)).close();
verify(jdbcReader, times(1)).close();
}
private JdbcNativeExtractor createJdbcNativeExtractor() {
JdbcNativeExtractor extractor = PowerMockito.mock(JdbcNativeExtractor.class, Mockito.CALLS_REAL_METHODS);
Whitebox.setInternalState(extractor, "jdbcDeepJobConfig", new JdbcDeepJobConfig<>(Cells.class));
Whitebox.setInternalState(extractor, "jdbcReader", jdbcReader);
Whitebox.setInternalState(extractor, "jdbcWriter", jdbcWriter);
return extractor;
}
private JdbcDeepJobConfig createJdbcDeepJobConfig() {
JdbcDeepJobConfig result = JdbcConfigFactory.createJdbc();
ExtractorConfig config = new ExtractorConfig();
config.putValue(ExtractorConstants.HOST, HOST);
config.putValue(ExtractorConstants.PORT, PORT);
config.putValue(ExtractorConstants.JDBC_DRIVER_CLASS, DRIVER_CLASS);
config.putValue(ExtractorConstants.CATALOG, DATABASE);
config.putValue(ExtractorConstants.TABLE, TABLE);
result.initialize(config);
return result;
}
}