/*
* Copyright (C) 2012-2015 DataStax Inc.
*
* 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.datastax.driver.core.schemabuilder;
import com.datastax.driver.core.DataType;
import org.testng.annotations.Test;
import static com.datastax.driver.core.schemabuilder.SchemaBuilder.*;
import static org.assertj.core.api.Assertions.assertThat;
public class CreateTypeTest {
@Test(groups = "unit")
public void should_create_UDT() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addColumn("col2", DataType.bigint());
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"col2 bigint)");
}
@Test(groups = "unit")
public void should_create_UDT_if_not_exists() throws Exception {
//When
SchemaStatement statement = createType("myType")
.ifNotExists()
.addColumn("col1", DataType.text())
.addColumn("col2", DataType.bigint());
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE IF NOT EXISTS myType(\n\t\t" +
"col1 text,\n\t\t" +
"col2 bigint)");
}
@Test(groups = "unit")
public void should_create_simple_UDT_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTColumn("my_udt", frozen("address"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt frozen<address>)");
}
@Test(groups = "unit")
public void should_create_list_UDT_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTListColumn("my_udt", frozen("address"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt list<frozen<address>>)");
}
@Test(groups = "unit")
public void should_create_set_UDT_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTSetColumn("my_udt", frozen("address"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt set<frozen<address>>)");
}
@Test(groups = "unit")
public void should_create_key_UDT_map_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTMapColumn("my_udt", frozen("address"), DataType.text());
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt map<frozen<address>, text>)");
}
@Test(groups = "unit")
public void should_create_value_UDT_map_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTMapColumn("my_udt", DataType.cint(), frozen("address"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt map<int, frozen<address>>)");
}
@Test(groups = "unit")
public void should_create_key_value_UDT_map_column() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTMapColumn("my_udt", frozen("coords"), frozen("address"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt map<frozen<coords>, frozen<address>>)");
}
@Test(groups = "unit")
public void should_create_column_with_manual_type() throws Exception {
//When
SchemaStatement statement = createType("ks", "myType")
.addColumn("col1", DataType.text())
.addUDTColumn("my_udt", udtLiteral("frozen<address>"));
//Then
assertThat(statement.getQueryString()).isEqualTo("\n\tCREATE TYPE ks.myType(\n\t\t" +
"col1 text,\n\t\t" +
"my_udt frozen<address>)");
}
}