io.prestosql.tests.hive.TestComments Maven / Gradle / Ivy
/*
* 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 io.prestosql.tests.hive;
import io.prestosql.tempto.AfterTestWithContext;
import io.prestosql.tempto.BeforeTestWithContext;
import io.prestosql.tempto.ProductTest;
import io.prestosql.tempto.query.QueryResult;
import org.testng.annotations.Test;
import static io.prestosql.tempto.query.QueryExecutor.query;
import static io.prestosql.tests.TestGroups.COMMENT;
import static java.lang.String.format;
import static org.testng.Assert.assertEquals;
public class TestComments
extends ProductTest
{
private static final String COMMENT_TABLE_NAME = "comment_test";
private static final String COMMENT_COLUMN_NAME = "comment_column_test";
@BeforeTestWithContext
@AfterTestWithContext
public void dropTestTable()
{
query("DROP TABLE IF EXISTS " + COMMENT_TABLE_NAME);
query("DROP TABLE IF EXISTS " + COMMENT_COLUMN_NAME);
}
@Test(groups = COMMENT)
public void testCommentTable()
{
String createTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint\n" +
")\n" +
"COMMENT 'old comment'\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_TABLE_NAME);
query(createTableSql);
QueryResult actualResult = query("SHOW CREATE TABLE " + COMMENT_TABLE_NAME);
assertEquals(actualResult.row(0).get(0), createTableSql);
String commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint\n" +
")\n" +
"COMMENT 'new comment'\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_TABLE_NAME);
query(format("COMMENT ON TABLE %s IS 'new comment'", COMMENT_TABLE_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_TABLE_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint\n" +
")\n" +
"COMMENT ''\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_TABLE_NAME);
query(format("COMMENT ON TABLE %s IS ''", COMMENT_TABLE_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_TABLE_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint\n" +
")\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_TABLE_NAME);
query(format("COMMENT ON TABLE %s IS NULL", COMMENT_TABLE_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_TABLE_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
}
@Test(groups = COMMENT)
public void testCommentColumn()
{
String createTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint COMMENT 'test comment',\n" +
" c2 bigint COMMENT '',\n" +
" c3 bigint\n" +
")\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_COLUMN_NAME);
query(createTableSql);
QueryResult actualResult = query("SHOW CREATE TABLE " + COMMENT_COLUMN_NAME);
assertEquals(actualResult.row(0).get(0), createTableSql);
String commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint COMMENT 'new comment',\n" +
" c2 bigint COMMENT '',\n" +
" c3 bigint\n" +
")\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_COLUMN_NAME);
query(format("COMMENT ON COLUMN %s.c1 IS 'new comment'", COMMENT_COLUMN_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_COLUMN_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint COMMENT '',\n" +
" c2 bigint COMMENT '',\n" +
" c3 bigint\n" +
")\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_COLUMN_NAME);
query(format("COMMENT ON COLUMN %s.c1 IS ''", COMMENT_COLUMN_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_COLUMN_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
commentedCreateTableSql = format("" +
"CREATE TABLE hive.default.%s (\n" +
" c1 bigint,\n" +
" c2 bigint COMMENT '',\n" +
" c3 bigint\n" +
")\n" +
"WITH (\n" +
" format = 'RCBINARY'\n" +
")",
COMMENT_COLUMN_NAME);
query(format("COMMENT ON COLUMN %s.c1 IS NULL", COMMENT_COLUMN_NAME));
actualResult = query("SHOW CREATE TABLE " + COMMENT_COLUMN_NAME);
assertEquals(actualResult.row(0).get(0), commentedCreateTableSql);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy