blob: 2d487a964aaccf1a2ca9c27fb8a30f8fa6bfe2b4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.apache.carbondata.cluster.sdv.generated
import org.apache.spark.sql.Row
import org.apache.spark.sql.common.util._
import org.scalatest.BeforeAndAfterAll
/**
* Test Class for ShowLoadsTestCase to verify all scenerios
*/
class ShowLoadsTestCase extends QueryTest with BeforeAndAfterAll {
//Verify failure/success/Partial status in show segments.
test("DataLoadManagement001_197", Include) {
sql(
s"""drop TABLE if exists ShowSegment_196""".stripMargin).collect
sql(s"""CREATE TABLE ShowSegment_196 (CUST_ID int,CUST_NAME String,ACTIVE_EMUI_VERSION string,DOB timestamp, DOJ timestamp, BIGINT_COLUMN1 bigint,BIGINT_COLUMN2 bigint,DECIMAL_COLUMN1 decimal(30,10),Double_COLUMN1 double,DECIMAL_COLUMN2 decimal(36,10), Double_COLUMN2 double,INTEGER_COLUMN1 int) STORED AS carbondata TBLPROPERTIES('table_blocksize'='1')""").collect
sql(s"""LOAD DATA INPATH '$resourcesPath/Data/InsertData/join1.csv' into table ShowSegment_196 OPTIONS('DELIMITER'=',' , 'QUOTECHAR'='"','BAD_RECORDS_ACTION'='FORCE','FILEHEADER'='CUST_ID,CUST_NAME,ACTIVE_EMUI_VERSION,DOB,DOJ,BIGINT_COLUMN1,BIGINT_COLUMN2,DECIMAL_COLUMN1,Double_COLUMN1,DECIMAL_COLUMN2,Double_COLUMN2,INTEGER_COLUMN1')""").collect
sql(s"""LOAD DATA INPATH '$resourcesPath/Data/InsertData/join1.csv' into table ShowSegment_196 OPTIONS('DELIMITER'=',' , 'QUOTECHAR'='"','BAD_RECORDS_ACTION'='FORCE','FILEHEADER'='CUST_ID,CUST_NAME,ACTIVE_EMUI_VERSION,DOB,DOJ,BIGINT_COLUMN1,BIGINT_COLUMN2,DECIMAL_COLUMN1,Double_COLUMN1,DECIMAL_COLUMN2,Double_COLUMN2,INTEGER_COLUMN1')""").collect
val df = sql(s"""show segments for table ShowSegment_196""").collect()
// validating headers
val header = df(0).schema
assert(header(0).name.equalsIgnoreCase("SegmentSequenceId"))
assert(header(1).name.equalsIgnoreCase("Status"))
assert(header(2).name.equalsIgnoreCase("Load Start Time"))
assert(header(3).name.equalsIgnoreCase("Load End Time"))
assert(header(4).name.equalsIgnoreCase("Merged To"))
assert(header(5).name.equalsIgnoreCase("File Format"))
val col = df.map {
row => Row(row.getString(0), row.getString(1), row.getString(4))
}.toSeq
assert(col.equals(Seq(Row("1", "Success", "NA"),
Row("0", "Success", "NA"))))
sql(s"""drop table ShowSegment_196""").collect
}
//Verify show segment commands with database name.
test("DataLoadManagement001_196", Include) {
sql(s"""drop TABLE if exists Database_ShowSegment_196""").collect
sql(s"""CREATE TABLE Database_ShowSegment_196 (CUST_ID int,CUST_NAME String,ACTIVE_EMUI_VERSION string,DOB timestamp, DOJ timestamp, BIGINT_COLUMN1 bigint,BIGINT_COLUMN2 bigint,DECIMAL_COLUMN1 decimal(30,10),Double_COLUMN1 double,DECIMAL_COLUMN2 decimal(36,10), Double_COLUMN2 double,INTEGER_COLUMN1 int) STORED AS carbondata TBLPROPERTIES('table_blocksize'='1')""").collect
sql(s"""LOAD DATA INPATH '$resourcesPath/Data/InsertData/join1.csv' into table Database_ShowSegment_196 OPTIONS('DELIMITER'=',' , 'QUOTECHAR'='"','BAD_RECORDS_ACTION'='FORCE','FILEHEADER'='CUST_ID,CUST_NAME,ACTIVE_EMUI_VERSION,DOB,DOJ,BIGINT_COLUMN1,BIGINT_COLUMN2,DECIMAL_COLUMN1,Double_COLUMN1,DECIMAL_COLUMN2,Double_COLUMN2,INTEGER_COLUMN1')""").collect
val df = sql(s"""show segments for table default.Database_ShowSegment_196""").collect()
val col = df.map {
row => Row(row.getString(0), row.getString(1), row.getString(4))
}.toSeq
assert(col.equals(Seq(Row("0", "Success", "NA"))))
sql(s"""drop table Database_ShowSegment_196""").collect
}
//Show Segments failing if table name not in same case
test("DataLoadManagement001_830", Include) {
sql(s"""drop TABLE if exists Case_ShowSegment_196""").collect
sql(s"""CREATE TABLE Case_ShowSegment_196 (CUST_ID int,CUST_NAME String,ACTIVE_EMUI_VERSION string,DOB timestamp, DOJ timestamp, BIGINT_COLUMN1 bigint,BIGINT_COLUMN2 bigint,DECIMAL_COLUMN1 decimal(30,10),Double_COLUMN1 double,DECIMAL_COLUMN2 decimal(36,10), Double_COLUMN2 double,INTEGER_COLUMN1 int) STORED AS carbondata TBLPROPERTIES('table_blocksize'='1')""").collect
val df = sql(s"""show segments for table CASE_ShowSegment_196""").collect()
val col = df.map {
row => Row(row.getString(0), row.getString(1), row.getString(4))
}.toSeq
assert(col.equals(Seq()))
sql(s"""drop table Case_ShowSegment_196""").collect
}
}