mirror of
https://github.com/python/cpython.git
synced 2025-01-22 08:25:42 +08:00
Issue #15770: Check invalid arguments in test function. Patch by Victor Stinner.
This commit is contained in:
parent
f21587e3a8
commit
66e63170d9
@ -1212,6 +1212,8 @@ class TestBufferProtocol(unittest.TestCase):
|
||||
self.assertRaises(TypeError, get_contiguous, nd, PyBUF_READ, 961)
|
||||
self.assertRaises(UnicodeEncodeError, get_contiguous, nd, PyBUF_READ,
|
||||
'\u2007')
|
||||
self.assertRaises(ValueError, get_contiguous, nd, PyBUF_READ, 'Z')
|
||||
self.assertRaises(ValueError, get_contiguous, nd, 255, 'A')
|
||||
|
||||
# cmp_contig()
|
||||
nd = ndarray([1], shape=[1])
|
||||
|
@ -2362,6 +2362,13 @@ get_ascii_order(PyObject *order)
|
||||
|
||||
ord = PyBytes_AS_STRING(ascii_order)[0];
|
||||
Py_DECREF(ascii_order);
|
||||
|
||||
if (ord != 'C' && ord != 'F' && ord != 'A') {
|
||||
PyErr_SetString(PyExc_ValueError,
|
||||
"invalid order, must be C, F or A");
|
||||
return CHAR_MAX;
|
||||
}
|
||||
|
||||
return ord;
|
||||
}
|
||||
|
||||
@ -2384,16 +2391,21 @@ get_contiguous(PyObject *self, PyObject *args)
|
||||
"buffertype must be PyBUF_READ or PyBUF_WRITE");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
type = PyLong_AsLong(buffertype);
|
||||
if (type == -1 && PyErr_Occurred()) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
ord = get_ascii_order(order);
|
||||
if (ord == CHAR_MAX) {
|
||||
if (type != PyBUF_READ && type != PyBUF_WRITE) {
|
||||
PyErr_SetString(PyExc_ValueError,
|
||||
"invalid buffer type");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
ord = get_ascii_order(order);
|
||||
if (ord == CHAR_MAX)
|
||||
return NULL;
|
||||
|
||||
return PyMemoryView_GetContiguous(obj, (int)type, ord);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user