blob: 5a695e941993c12be9f43c33c3c08e230d6d2630 [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.hadoop.hive.ql.metadata;
import java.io.IOException;
import java.net.ServerSocket;
import org.apache.hadoop.hive.conf.HiveConf;
import org.apache.hadoop.hive.metastore.MetaStoreTestUtils;
import org.apache.hadoop.hive.ql.session.SessionState;
import org.apache.hadoop.util.StringUtils;
import org.junit.After;
import org.junit.Before;
import org.junit.BeforeClass;
/**
*
* TestHiveRemote.
*
* Tests using the Hive metadata class to make calls to a remote metastore
*/
public class TestHiveRemote extends TestHive {
/**
* Start a remote metastore and initialize a Hive object pointing at it.
*/
@BeforeClass
public static void setUp() throws Exception {
hiveConf = new HiveConf(TestHiveRemote.class);
hiveConf.setVar(HiveConf.ConfVars.HIVE_AUTHORIZATION_MANAGER,
"org.apache.hadoop.hive.ql.security.authorization.plugin.sqlstd.SQLStdHiveAuthorizerFactory");
MetaStoreTestUtils.startMetaStoreWithRetry(hiveConf);
}
@Before
public void before() throws Exception {
SessionState.start(hiveConf);
try {
hm = Hive.get(hiveConf);
} catch (Exception e) {
System.err.println(StringUtils.stringifyException(e));
System.err
.println("Unable to initialize Hive Metastore using configuration: \n "
+ hiveConf);
throw e;
}
}
@After
public void after() throws IOException {
SessionState.get().close();
hm.close(false);
}
/**
* Cannot control trash in remote metastore, so skip this test
*/
@Override
public void testDropTableTrash() {
}
/**
* Finds a free port.
*
* @return a free port
* @throws IOException
*/
private String findFreePort() throws IOException {
ServerSocket socket= new ServerSocket(0);
int port = socket.getLocalPort();
socket.close();
return String.valueOf(port);
}
}