93 lines
3.6 KiB
Python
93 lines
3.6 KiB
Python
# Copyright (c) 2017 EasyStack Inc.
|
|
#
|
|
# 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.
|
|
|
|
import mock
|
|
|
|
from sahara.plugins import base as pb
|
|
from sahara.plugins import exceptions as ex
|
|
from sahara_plugin_vanilla.plugins.vanilla.hadoop2 import edp_engine
|
|
from sahara_plugin_vanilla.tests.unit import base as sahara_base
|
|
|
|
|
|
class EdpOozieEngineTest(sahara_base.SaharaTestCase):
|
|
|
|
engine_path = 'sahara.plugins.edp.'
|
|
|
|
def setUp(self):
|
|
super(EdpOozieEngineTest, self).setUp()
|
|
self.cluster = mock.Mock()
|
|
self.override_config("plugins", ["vanilla"])
|
|
pb.setup_plugins()
|
|
with mock.patch('sahara.plugins.edp.get_plugin',
|
|
return_value='test_plugins'):
|
|
self.engine = edp_engine.EdpOozieEngine(self.cluster)
|
|
|
|
def test_get_hdfs_user(self):
|
|
self.assertEqual(self.engine.get_hdfs_user(), 'hadoop')
|
|
|
|
def test_get_name_node_uri(self):
|
|
cluster = {'info': {
|
|
'HDFS': {
|
|
'NameNode': 'test_url'}}}
|
|
ret = self.engine.get_name_node_uri(cluster)
|
|
self.assertEqual(ret, 'test_url')
|
|
|
|
def test_get_oozie_server_uri(self):
|
|
cluster = {'info': {
|
|
'JobFlow': {
|
|
'Oozie': 'test_url'}}}
|
|
ret = self.engine.get_oozie_server_uri(cluster)
|
|
self.assertEqual(ret, 'test_url/oozie/')
|
|
|
|
@mock.patch('sahara_plugin_vanilla.plugins.vanilla.utils.get_oozie')
|
|
def test_get_oozie_server(self, get_oozie):
|
|
get_oozie.return_value = 'bingo'
|
|
ret = self.engine.get_oozie_server(self.cluster)
|
|
get_oozie.assert_called_once_with(self.cluster)
|
|
self.assertEqual(ret, 'bingo')
|
|
|
|
@mock.patch(engine_path + 'PluginsOozieJobEngine.validate_job_execution')
|
|
@mock.patch('sahara.plugins.utils.get_instances_count')
|
|
def test_validate_job_execution(self,
|
|
get_instances_count,
|
|
validate_job_execution):
|
|
job = mock.Mock()
|
|
data = mock.Mock()
|
|
get_instances_count.return_value = 0
|
|
self.assertRaises(ex.InvalidComponentCountException,
|
|
self.engine.validate_job_execution,
|
|
self.cluster, job, data)
|
|
|
|
get_instances_count.return_value = 1
|
|
self.engine.validate_job_execution(self.cluster, job, data)
|
|
validate_job_execution.assert_called_once_with(self.cluster,
|
|
job, data)
|
|
|
|
@mock.patch('sahara.plugins.edp.create_dir_hadoop2')
|
|
def test_create_hdfs_dir(self, create_dir_hadoop2):
|
|
self.engine.get_hdfs_user = mock.Mock(return_value='test_user')
|
|
remote = mock.Mock()
|
|
dir_name = mock.Mock()
|
|
self.engine.create_hdfs_dir(remote, dir_name)
|
|
create_dir_hadoop2.assert_called_once_with(remote, dir_name,
|
|
'test_user')
|
|
|
|
def test_get_resource_manager_uri(self):
|
|
cluster = {'info': {
|
|
'YARN': {
|
|
'ResourceManager': 'test_url'}}}
|
|
ret = self.engine.get_resource_manager_uri(cluster)
|
|
self.assertEqual(ret, 'test_url')
|