From f7a487b80939dbf83fae0e401fafe6673624eef8 Mon Sep 17 00:00:00 2001 From: Alex Gaynor Date: Thu, 13 Oct 2022 21:14:44 -0400 Subject: [PATCH] Use a TypeError, rather than a ValueError, when refusing to treat a str as a Vec This is far more consistent with how these exceptions are usually used --- newsfragments/2685.changed.md | 1 + pytests/tests/test_sequence.py | 2 +- src/types/sequence.rs | 4 ++-- 3 files changed, 4 insertions(+), 3 deletions(-) create mode 100644 newsfragments/2685.changed.md diff --git a/newsfragments/2685.changed.md b/newsfragments/2685.changed.md new file mode 100644 index 00000000000..8e498fe167b --- /dev/null +++ b/newsfragments/2685.changed.md @@ -0,0 +1 @@ +Use a TypeError, rather than a ValueError, when refusing to treat a str as a Vec diff --git a/pytests/tests/test_sequence.py b/pytests/tests/test_sequence.py index d0328146922..91aac50ac72 100644 --- a/pytests/tests/test_sequence.py +++ b/pytests/tests/test_sequence.py @@ -17,7 +17,7 @@ def test_vec_from_bytes(): def test_vec_from_str(): - with pytest.raises(ValueError): + with pytest.raises(TypeError): sequence.vec_to_vec_pystring("123") diff --git a/src/types/sequence.rs b/src/types/sequence.rs index 422a2db2e10..9fa4010c732 100644 --- a/src/types/sequence.rs +++ b/src/types/sequence.rs @@ -1,6 +1,6 @@ // Copyright (c) 2017-present PyO3 Project and Contributors use crate::err::{self, PyDowncastError, PyErr, PyResult}; -use crate::exceptions::PyValueError; +use crate::exceptions::PyTypeError; use crate::inspect::types::TypeInfo; use crate::internal_tricks::get_ssize_index; use crate::once_cell::GILOnceCell; @@ -285,7 +285,7 @@ where { fn extract(obj: &'a PyAny) -> PyResult { if let Ok(true) = obj.is_instance_of::() { - return Err(PyValueError::new_err("Can't extract `str` to `Vec`")); + return Err(PyTypeError::new_err("Can't extract `str` to `Vec`")); } extract_sequence(obj) }