From ef9ea880f5af96378820d81bb873c13d17ae3095 Mon Sep 17 00:00:00 2001 From: James Saryerwinnie Date: Wed, 5 Mar 2014 17:34:34 -0800 Subject: [PATCH] Fix regression when parsing number types in shorthand We can't call strip() until we know that the object is a string. This is a regression introduced in the last CLI release. --- awscli/argprocess.py | 4 +-- tests/unit/rds/test_describe_db_log_files.py | 27 ++++++++++++++++++++ 2 files changed, 29 insertions(+), 2 deletions(-) create mode 100644 tests/unit/rds/test_describe_db_log_files.py diff --git a/awscli/argprocess.py b/awscli/argprocess.py index eed1148e892b..b8b59ec78449 100644 --- a/awscli/argprocess.py +++ b/awscli/argprocess.py @@ -162,8 +162,8 @@ def get_parse_method_for_param(self, param, value=None): if isinstance(value, list): check_val = value[0] else: - check_val = value.strip() - if isinstance(check_val, six.string_types) and check_val.startswith( + check_val = value + if isinstance(check_val, six.string_types) and check_val.strip().startswith( ('[', '{')): LOG.debug("Param %s looks like JSON, not considered for " "param shorthand.", param.py_name) diff --git a/tests/unit/rds/test_describe_db_log_files.py b/tests/unit/rds/test_describe_db_log_files.py new file mode 100644 index 000000000000..824a3a5eb973 --- /dev/null +++ b/tests/unit/rds/test_describe_db_log_files.py @@ -0,0 +1,27 @@ +#!/usr/bin/env python +# 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 tests.unit import BaseAWSCommandParamsTest + + +class TestDescribeDBLogFiles(BaseAWSCommandParamsTest): + maxDiff = None + prefix = 'rds describe-db-log-files ' + + def test_add_option(self): + args = ('--file-last-written 10 ' + '--db-instance-identifier foo') + cmdline = self.prefix + args + result = {'DBInstanceIdentifier': 'foo', + 'FileLastWritten': '10'} + self.assert_params_for_cmd(cmdline, result)