diff --git a/src/hdmf/utils.py b/src/hdmf/utils.py index d85eb5c8c..e6ee0f66d 100644 --- a/src/hdmf/utils.py +++ b/src/hdmf/utils.py @@ -184,6 +184,11 @@ def __fmt_str_quotes(x): return str(x) +def __shape_error_message(argname, valshape, allowable_shapes): + allowable_shapes_str = str(allowable_shapes).replace("None", ":") + return f"incorrect shape for {argname}: got {valshape}, and expected {allowable_shapes_str}" + + def __parse_args(validator, args, kwargs, enforce_type=True, enforce_shape=True, allow_extra=False, # noqa: C901 allow_positional=AllowPositional.ALLOWED): """ @@ -300,8 +305,7 @@ def __parse_args(validator, args, kwargs, enforce_type=True, enforce_shape=True, argval = getattr(argval, argname) valshape = get_data_shape(argval) if valshape is not None and not __shape_okay_multi(argval, arg['shape']): - fmt_val = (argname, valshape, arg['shape']) - value_errors.append("incorrect shape for '%s' (got '%s', expected '%s')" % fmt_val) + value_errors.append(__shape_error_message(argname, valshape, arg['shape'])) if 'enum' in arg: err = __check_enum(argval, arg) if err: @@ -357,8 +361,7 @@ def __parse_args(validator, args, kwargs, enforce_type=True, enforce_shape=True, argval = getattr(argval, argname) valshape = get_data_shape(argval) if valshape is not None and not __shape_okay_multi(argval, arg['shape']): - fmt_val = (argname, valshape, arg['shape']) - value_errors.append("incorrect shape for '%s' (got '%s', expected '%s')" % fmt_val) + value_errors.append(__shape_error_message(argname, valshape, arg['shape'])) if 'enum' in arg and argval is not None: err = __check_enum(argval, arg) if err: diff --git a/tests/unit/utils_test/test_docval.py b/tests/unit/utils_test/test_docval.py index d0ea934f7..4731e8d3d 100644 --- a/tests/unit/utils_test/test_docval.py +++ b/tests/unit/utils_test/test_docval.py @@ -859,7 +859,7 @@ def test_shape_invalid_unpack(self): # shape after an object is initialized obj2.arg3 = [10, 20, 30] - err_msg = "MyChainClass.__init__: incorrect shape for 'arg3' (got '(3,)', expected '(None, 2)')" + err_msg = "MyChainClass.__init__: incorrect shape for arg3: got (3,), and expected (:, 2)" with self.assertRaisesWith(ValueError, err_msg): MyChainClass(self.obj1, obj2, [[100, 200]]) @@ -896,7 +896,7 @@ def test_shape_invalid_unpack_default(self): # shape after an object is initialized obj2.arg4 = [10, 20, 30] - err_msg = "MyChainClass.__init__: incorrect shape for 'arg4' (got '(3,)', expected '(None, 2)')" + err_msg = "MyChainClass.__init__: incorrect shape for arg4: got (3,), and expected (:, 2)" with self.assertRaisesWith(ValueError, err_msg): MyChainClass(self.obj1, [[100, 200], [300, 400], [500, 600]], arg4=obj2)