/* * 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 org.testng.annotations.Test; import static com.datastax.driver.core.schemabuilder.SchemaBuilder.*; import static org.assertj.core.api.Assertions.assertThat; public class DropTest { @Test(groups = "unit") public void should_drop_table() throws Exception { //When SchemaStatement statement = dropTable("test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TABLE test"); } @Test(groups = "unit") public void should_drop_table_with_keyspace() throws Exception { //When SchemaStatement statement = dropTable("ks", "test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TABLE ks.test"); } @Test(groups = "unit") public void should_drop_table_with_keyspace_if_exists() throws Exception { //When SchemaStatement statement = dropTable("ks", "test").ifExists(); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TABLE IF EXISTS ks.test"); } @Test(groups = "unit") public void should_drop_type() throws Exception { //When SchemaStatement statement = dropType("test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TYPE test"); } @Test(groups = "unit") public void should_drop_type_with_keyspace() throws Exception { //When SchemaStatement statement = dropType("ks", "test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TYPE ks.test"); } @Test(groups = "unit") public void should_drop_type_with_keyspace_if_exists() throws Exception { //When SchemaStatement statement = dropType("ks", "test").ifExists(); //Then assertThat(statement.getQueryString()).isEqualTo("DROP TYPE IF EXISTS ks.test"); } @Test(groups = "unit") public void should_drop_index() throws Exception { //When SchemaStatement statement = dropIndex("test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP INDEX test"); } @Test(groups = "unit") public void should_drop_index_with_keyspace() throws Exception { //When SchemaStatement statement = dropIndex("ks", "test"); //Then assertThat(statement.getQueryString()).isEqualTo("DROP INDEX ks.test"); } @Test(groups = "unit") public void should_drop_index_with_keyspace_if_exists() throws Exception { //When SchemaStatement statement = dropIndex("ks", "test").ifExists(); //Then assertThat(statement.getQueryString()).isEqualTo("DROP INDEX IF EXISTS ks.test"); } @Test(groups = "unit", expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp = "The keyspace name 'add' is not allowed because it is a reserved keyword") public void should_fail_if_keyspace_name_is_a_reserved_keyword() throws Exception { dropTable("add", "test").getQueryString(); } @Test(groups = "unit", expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp = "The table name 'add' is not allowed because it is a reserved keyword") public void should_fail_if_table_name_is_a_reserved_keyword() throws Exception { dropTable("add").getQueryString(); } }