/** * Copyright (C) 2014 Stratio (http://stratio.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 com.stratio.ingestion.sink.cassandra; import static org.fest.assertions.Assertions.assertThat; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.verifyNoMoreInteractions; import static org.mockito.Mockito.verifyZeroInteractions; import static org.mockito.Mockito.when; import java.net.InetAddress; import java.net.UnknownHostException; import java.nio.ByteBuffer; import java.util.Set; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ExpectedException; import com.datastax.driver.core.Cluster; import com.datastax.driver.core.DataType; import com.datastax.driver.core.KeyspaceMetadata; import com.datastax.driver.core.Metadata; import com.datastax.driver.core.Session; import com.datastax.driver.core.TableMetadata; import com.datastax.driver.core.exceptions.InvalidTypeException; import com.google.common.collect.ImmutableSet; public class TestCassandraUtils { final Set<DataType> textualTypes = ImmutableSet.of( DataType.ascii(), DataType.text(), DataType.varchar() ); @Rule public ExpectedException thrown = ExpectedException.none(); @Test public void executeCqlScriptNull() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, null); verifyZeroInteractions(session); } @Test public void executeCqlScriptEmpty() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, ""); verifyZeroInteractions(session); } @Test public void executeCqlScriptWhitespaceOnly() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, " "); verifyZeroInteractions(session); } @Test public void executeCqlScriptOneStatement() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, " MY STATEMENT;"); verify(session).execute("MY STATEMENT"); verifyNoMoreInteractions(session); } @Test public void executeCqlScriptTwoStatements() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, "MY STATEMENT;\n\nOTHER STATEMENT;"); verify(session).execute("MY STATEMENT"); verify(session).execute("OTHER STATEMENT"); verifyNoMoreInteractions(session); } @Test public void executeCqlScriptTwoStatementsNoFinalSemicolon() { final Session session = mock(Session.class); CassandraUtils.executeCqlScript(session, "MY STATEMENT;\n\nOTHER STATEMENT"); verify(session).execute("MY STATEMENT"); verify(session).execute("OTHER STATEMENT"); verifyNoMoreInteractions(session); } @Test(expected = NullPointerException.class) public void getTableMetadataOnNullSession() { CassandraUtils.getTableMetadata(null, "keyspace", "table"); } @Test(expected = NullPointerException.class) public void getTableMetadataOnNullKeyspace() { CassandraUtils.getTableMetadata(mock(Session.class), null, "table"); } @Test(expected = NullPointerException.class) public void getTableMetadataOnNullTable() { CassandraUtils.getTableMetadata(mock(Session.class), "keyspace", null); } @Test public void getTableMetadataOnUnexistentKeyspace() { // session.getCluster().getMetadata().getKeyspace(keyspace); final Session session = mock(Session.class); final Cluster cluster = mock(Cluster.class); final Metadata metadata = mock(Metadata.class); when(session.getCluster()).thenReturn(cluster); when(cluster.getMetadata()).thenReturn(metadata); when(metadata.getKeyspace("keyspace")).thenReturn(null); thrown.expect(IllegalStateException.class); thrown.expectMessage("Keyspace keyspace does not exist"); CassandraUtils.getTableMetadata(session, "keyspace", "table"); } @Test public void getTableMetadataOnUnexistentTable() { final Session session = mock(Session.class); final Cluster cluster = mock(Cluster.class); final Metadata metadata = mock(Metadata.class); final KeyspaceMetadata keyspaceMetadata = mock(KeyspaceMetadata.class); when(session.getCluster()).thenReturn(cluster); when(cluster.getMetadata()).thenReturn(metadata); when(metadata.getKeyspace("keyspace")).thenReturn(keyspaceMetadata); when(keyspaceMetadata.getTable("table")).thenReturn(null); thrown.expect(IllegalStateException.class); thrown.expectMessage("Table keyspace.table does not exist"); CassandraUtils.getTableMetadata(session, "keyspace", "table"); } @Test public void getTableMetadata() { final Session session = mock(Session.class); final Cluster cluster = mock(Cluster.class); final Metadata metadata = mock(Metadata.class); final KeyspaceMetadata keyspaceMetadata = mock(KeyspaceMetadata.class); final TableMetadata tableMetadata = mock(TableMetadata.class); when(session.getCluster()).thenReturn(cluster); when(cluster.getMetadata()).thenReturn(metadata); when(metadata.getKeyspace("keyspace")).thenReturn(keyspaceMetadata); when(keyspaceMetadata.getTable("table")).thenReturn(tableMetadata); assertThat(CassandraUtils.getTableMetadata(session, "keyspace", "table")).isNotNull(); } @Test public void parseValueNull() { for (final DataType dataType : DataType.allPrimitiveTypes()) { assertThat(CassandraUtils.parseValue(dataType, null)).isNull(); } } @Test public void parseValueText() { for (final DataType dataType : textualTypes) { assertThat(CassandraUtils.parseValue(dataType, "unquoted_text")) .isEqualTo("unquoted_text"); assertThat(CassandraUtils.parseValue(dataType, "'quoted_text'")) .isEqualTo("'quoted_text'"); assertThat(CassandraUtils.parseValue(dataType, "'unescaped_'quoted_text'")) .isEqualTo("'unescaped_'quoted_text'"); } } @Test public void parseInet() throws UnknownHostException { assertThat(CassandraUtils.parseValue(DataType.inet(), "127.0.0.1")) .isEqualTo(InetAddress.getByName("127.0.0.1")); } @Test public void parseSpacedInt() throws UnknownHostException { assertThat(CassandraUtils.parseValue(DataType.cint(), " 1 2 ")) .isEqualTo(12); } @Test public void parseQuotedInetFails() throws UnknownHostException { thrown.expect(InvalidTypeException.class); thrown.expectMessage("Cannot parse inet value"); CassandraUtils.parseValue(DataType.inet(), "'127.0.0.1'"); } @Test public void parseBlob() { final ByteBuffer buffer = ByteBuffer.allocate(2); buffer.put(new byte[] { (byte) 0xF1, 0x56 }); buffer.flip(); assertThat(CassandraUtils.parseValue(DataType.blob(), "0xF156")) .isEqualTo(buffer); } }