/* * Copyright 2016-2017 the original author or authors. * * 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.springframework.cassandra.core.cql.generator; import static org.junit.Assume.*; import static org.springframework.cassandra.core.cql.generator.AlterUserTypeCqlGenerator.*; import org.junit.Before; import org.junit.Test; import org.springframework.cassandra.core.keyspace.AlterUserTypeSpecification; import org.springframework.cassandra.test.integration.AbstractKeyspaceCreatingIntegrationTest; import org.springframework.cassandra.test.integration.support.CassandraVersion; import org.springframework.data.util.Version; import com.datastax.driver.core.DataType; /** * Integration tests for {@link AlterUserTypeCqlGenerator}. * * @author Mark Paluch */ public class AlterUserTypeCqlGeneratorIntegrationTests extends AbstractKeyspaceCreatingIntegrationTest { static final Version CASSANDRA_3_10 = Version.parse("3.10"); Version cassandraVersion; @Before public void setUp() throws Exception { cassandraVersion = CassandraVersion.get(session); session.execute("DROP TYPE IF EXISTS address;"); session.execute("CREATE TYPE address (zip text, state text);"); } @Test // DATACASS-172 public void alterTypeShouldAddField() { AlterUserTypeSpecification spec = AlterUserTypeSpecification.alterType("address")// .add("street", DataType.varchar()); session.execute(toCql(spec)); } @Test // DATACASS-172, DATACASS-429 public void alterTypeShouldAlterField() { assumeTrue(cassandraVersion.isLessThan(CASSANDRA_3_10)); AlterUserTypeSpecification spec = AlterUserTypeSpecification.alterType("address")// .alter("zip", DataType.varchar()); session.execute(toCql(spec)); } @Test // DATACASS-172 public void alterTypeShouldRenameField() { AlterUserTypeSpecification spec = AlterUserTypeSpecification.alterType("address")// .rename("zip", "zap"); session.execute(toCql(spec)); } @Test // DATACASS-172 public void alterTypeShouldRenameFields() { AlterUserTypeSpecification spec = AlterUserTypeSpecification.alterType("address")// .rename("zip", "zap") // .rename("state", "county"); session.execute(toCql(spec)); } @Test(expected = IllegalArgumentException.class) // DATACASS-172 public void generationFailsIfNameIsNotSet() { toCql(AlterUserTypeSpecification.alterType()); } @Test(expected = IllegalArgumentException.class) // DATACASS-172 public void generationFailsWithoutFields() { toCql(AlterUserTypeSpecification.alterType().name("hello")); } }