# Copyright 2014 Amazon.com, Inc. or its affiliates. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"). You # may not use this file except in compliance with the License. A copy of # the License is located at # # http://aws.amazon.com/apache2.0/ # # or in the "license" file accompanying this file. This file 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. from awscli.testutils import mock from tests.unit.customizations.emr import EMRBaseAWSCommandParamsTest as \ BaseAWSCommandParamsTest from copy import deepcopy class TestRestoreFromHBaseBackup(BaseAWSCommandParamsTest): prefix = 'emr restore-from-hbase-backup' steps = [{ 'HadoopJarStep': { 'Args': [ 'emr.hbase.backup.Main', '--restore', '--backup-dir', 's3://abc/' ], 'Jar': '/home/hadoop/lib/hbase.jar' }, 'Name': 'Restore HBase', 'ActionOnFailure': 'CANCEL_AND_WAIT' }] def test_restore_from_hbase_backup(self): args = ' --cluster-id j-ABCD --dir s3://abc/' cmdline = self.prefix + args result = {'JobFlowId': 'j-ABCD', 'Steps': self.steps} self.assert_params_for_cmd(cmdline, result) def test_restore_from_hbase_backup_version(self): args = ' --cluster-id j-ABCD --dir s3://abc/ --backup-version DEF' cmdline = self.prefix + args steps = deepcopy(self.steps) steps[0]['HadoopJarStep']['Args'].append('--backup-version') steps[0]['HadoopJarStep']['Args'].append('DEF') result = {'JobFlowId': 'j-ABCD', 'Steps': steps} self.assert_params_for_cmd(cmdline, result) @mock.patch('awscli.customizations.emr.' 'emrutils.get_release_label') def test_unsupported_command_on_release_based_cluster_error( self, grl_patch): grl_patch.return_value = 'emr-4.0' args = ' --cluster-id j-ABCD --dir s3://abc/' cmdline = self.prefix + args expected_error_msg = ("\naws: error: restore-from-hbase-backup" " is not supported with 'emr-4.0' release.\n") result = self.run_cmd(cmdline, 255) self.assertEqual(result[1], expected_error_msg) if __name__ == "__main__": unittest.main()