blob: 5e9208b59cf5140c9ffef04fde33719e3c1ed69d [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.phoenix.end2end;
import static org.apache.phoenix.util.PhoenixRuntime.TENANT_ID_ATTRIB;
import java.sql.SQLException;
import org.apache.phoenix.query.BaseTest;
import org.junit.Before;
public abstract class BaseTenantSpecificTablesIT extends ParallelStatsEnabledIT {
protected String TENANT_ID;
protected String TENANT_TYPE_ID = "abc";
protected String PHOENIX_JDBC_TENANT_SPECIFIC_URL;
protected String TENANT_ID2;
protected String PHOENIX_JDBC_TENANT_SPECIFIC_URL2;
protected String PARENT_TABLE_NAME;
protected String PARENT_TABLE_DDL;
protected String TENANT_TABLE_NAME;
protected String TENANT_TABLE_DDL;
protected String PARENT_TABLE_NAME_NO_TENANT_TYPE_ID;
protected String PARENT_TABLE_DDL_NO_TENANT_TYPE_ID;
protected String TENANT_TABLE_NAME_NO_TENANT_TYPE_ID;
protected String TENANT_TABLE_DDL_NO_TENANT_TYPE_ID;
@Before
public void createTables() throws SQLException {
TENANT_ID = "T_" + BaseTest.generateUniqueName();
TENANT_ID2 = "T_" + BaseTest.generateUniqueName();
PHOENIX_JDBC_TENANT_SPECIFIC_URL = getUrl() + ';' + TENANT_ID_ATTRIB + '=' + TENANT_ID;
PHOENIX_JDBC_TENANT_SPECIFIC_URL2 = getUrl() + ';' + TENANT_ID_ATTRIB + '=' + TENANT_ID2;
PARENT_TABLE_NAME = "P_" + BaseTest.generateUniqueName();
TENANT_TABLE_NAME = "V_" + BaseTest.generateUniqueName();
PARENT_TABLE_NAME_NO_TENANT_TYPE_ID = "P_" + BaseTest.generateUniqueName();
TENANT_TABLE_NAME_NO_TENANT_TYPE_ID = "V_" + BaseTest.generateUniqueName();
PARENT_TABLE_DDL = "CREATE TABLE " + PARENT_TABLE_NAME + " ( \n" +
" \"user\" VARCHAR ,\n" +
" tenant_id VARCHAR NOT NULL,\n" +
" tenant_type_id VARCHAR(3) NOT NULL, \n" +
" id INTEGER NOT NULL\n" +
" CONSTRAINT pk PRIMARY KEY (tenant_id, tenant_type_id, id)) MULTI_TENANT=true, IMMUTABLE_ROWS=true";
TENANT_TABLE_DDL = "CREATE VIEW " + TENANT_TABLE_NAME + " ( \n" +
" tenant_col VARCHAR) AS SELECT *\n" +
" FROM " + PARENT_TABLE_NAME + " WHERE tenant_type_id= '" + TENANT_TYPE_ID + "'";
PARENT_TABLE_DDL_NO_TENANT_TYPE_ID = "CREATE TABLE " + PARENT_TABLE_NAME_NO_TENANT_TYPE_ID + " ( \n" +
" \"user\" VARCHAR ,\n" +
" tenant_id VARCHAR NOT NULL,\n" +
" id INTEGER NOT NULL,\n" +
" CONSTRAINT pk PRIMARY KEY (tenant_id, id)) MULTI_TENANT=true, IMMUTABLE_ROWS=true";
TENANT_TABLE_DDL_NO_TENANT_TYPE_ID = "CREATE VIEW " + TENANT_TABLE_NAME_NO_TENANT_TYPE_ID + " ( \n" +
" tenant_col VARCHAR) AS SELECT *\n" +
" FROM " + PARENT_TABLE_NAME_NO_TENANT_TYPE_ID;
createTestTable(getUrl(), PARENT_TABLE_DDL);
createTestTable(getUrl(), PARENT_TABLE_DDL_NO_TENANT_TYPE_ID);
createTestTable(PHOENIX_JDBC_TENANT_SPECIFIC_URL, TENANT_TABLE_DDL);
createTestTable(PHOENIX_JDBC_TENANT_SPECIFIC_URL, TENANT_TABLE_DDL_NO_TENANT_TYPE_ID);
}
}