]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
GH-94808: Cover `PyOS_mystrnicmp` and `PyOS_mystricmp` (gh-102469)
authorArtem Mukhin <ortem00@gmail.com>
Wed, 22 Mar 2023 11:35:27 +0000 (12:35 +0100)
committerGitHub <noreply@github.com>
Wed, 22 Mar 2023 11:35:27 +0000 (20:35 +0900)
Modules/Setup.stdlib.in
Modules/_testcapi/parts.h
Modules/_testcapi/pyos.c [new file with mode: 0644]
Modules/_testcapimodule.c
PCbuild/_testcapi.vcxproj
PCbuild/_testcapi.vcxproj.filters

index b12290d436cbeb53c2f93030804fedbe329c8ad7..fe1b9f8f5380c18394f126954bf4c95efbf9b9f2 100644 (file)
 @MODULE__XXTESTFUZZ_TRUE@_xxtestfuzz _xxtestfuzz/_xxtestfuzz.c _xxtestfuzz/fuzzer.c
 @MODULE__TESTBUFFER_TRUE@_testbuffer _testbuffer.c
 @MODULE__TESTINTERNALCAPI_TRUE@_testinternalcapi _testinternalcapi.c
-@MODULE__TESTCAPI_TRUE@_testcapi _testcapimodule.c _testcapi/vectorcall.c _testcapi/vectorcall_limited.c _testcapi/heaptype.c _testcapi/unicode.c _testcapi/getargs.c _testcapi/pytime.c _testcapi/datetime.c _testcapi/docstring.c _testcapi/mem.c _testcapi/watchers.c _testcapi/long.c _testcapi/float.c _testcapi/structmember.c _testcapi/exceptions.c _testcapi/code.c
+@MODULE__TESTCAPI_TRUE@_testcapi _testcapimodule.c _testcapi/vectorcall.c _testcapi/vectorcall_limited.c _testcapi/heaptype.c _testcapi/unicode.c _testcapi/getargs.c _testcapi/pytime.c _testcapi/datetime.c _testcapi/docstring.c _testcapi/mem.c _testcapi/watchers.c _testcapi/long.c _testcapi/float.c _testcapi/structmember.c _testcapi/exceptions.c _testcapi/code.c _testcapi/pyos.c
 @MODULE__TESTCLINIC_TRUE@_testclinic _testclinic.c
 
 # Some testing modules MUST be built as shared libraries.
index c8f31dc8e39faec28a62f2edd4052b43d1cdddaa..60ec81dad2ba9efe6049b086f267cc945da842a3 100644 (file)
@@ -38,6 +38,7 @@ int _PyTestCapi_Init_Float(PyObject *module);
 int _PyTestCapi_Init_Structmember(PyObject *module);
 int _PyTestCapi_Init_Exceptions(PyObject *module);
 int _PyTestCapi_Init_Code(PyObject *module);
+int _PyTestCapi_Init_PyOS(PyObject *module);
 
 #ifdef LIMITED_API_AVAILABLE
 int _PyTestCapi_Init_VectorcallLimited(PyObject *module);
diff --git a/Modules/_testcapi/pyos.c b/Modules/_testcapi/pyos.c
new file mode 100644 (file)
index 0000000..63140e9
--- /dev/null
@@ -0,0 +1,60 @@
+#include "parts.h"
+
+
+static PyObject *
+test_PyOS_mystrnicmp(PyObject *self, PyObject *Py_UNUSED(ignored))
+{
+    assert(PyOS_mystrnicmp("", "", 0) == 0);
+    assert(PyOS_mystrnicmp("", "", 1) == 0);
+
+    assert(PyOS_mystrnicmp("insert", "ins", 3) == 0);
+    assert(PyOS_mystrnicmp("ins", "insert", 3) == 0);
+    assert(PyOS_mystrnicmp("insect", "insert", 3) == 0);
+
+    assert(PyOS_mystrnicmp("insert", "insert", 6) == 0);
+    assert(PyOS_mystrnicmp("Insert", "insert", 6) == 0);
+    assert(PyOS_mystrnicmp("INSERT", "insert", 6) == 0);
+    assert(PyOS_mystrnicmp("insert", "insert", 10) == 0);
+
+    assert(PyOS_mystrnicmp("invert", "insert", 6) == ('v' - 's'));
+    assert(PyOS_mystrnicmp("insert", "invert", 6) == ('s' - 'v'));
+    assert(PyOS_mystrnicmp("insert", "ins\0rt", 6) == 'e');
+
+    // GH-21845
+    assert(PyOS_mystrnicmp("insert\0a", "insert\0b", 8) == 0);
+
+    Py_RETURN_NONE;
+}
+
+static PyObject *
+test_PyOS_mystricmp(PyObject *self, PyObject *Py_UNUSED(ignored))
+{
+    assert(PyOS_mystricmp("", "") == 0);
+    assert(PyOS_mystricmp("insert", "insert") == 0);
+    assert(PyOS_mystricmp("Insert", "insert") == 0);
+    assert(PyOS_mystricmp("INSERT", "insert") == 0);
+    assert(PyOS_mystricmp("insert", "ins") == 'e');
+    assert(PyOS_mystricmp("ins", "insert") == -'e');
+
+    // GH-21845
+    assert(PyOS_mystricmp("insert", "ins\0rt") == 'e');
+    assert(PyOS_mystricmp("invert", "insert") == ('v' - 's'));
+
+    Py_RETURN_NONE;
+}
+
+static PyMethodDef test_methods[] = {
+    {"test_PyOS_mystrnicmp", test_PyOS_mystrnicmp, METH_NOARGS, NULL},
+    {"test_PyOS_mystricmp", test_PyOS_mystricmp, METH_NOARGS, NULL},
+    {NULL},
+};
+
+int
+_PyTestCapi_Init_PyOS(PyObject *mod)
+{
+    if (PyModule_AddFunctions(mod, test_methods) < 0) {
+        return -1;
+    }
+
+    return 0;
+}
index e2ebab5c5b48497c7c0bbb2afeffbfcf9be11918..3d9a2aeeb7cfd5c8a78ef93f6145c4741f3d99d2 100644 (file)
@@ -4154,6 +4154,9 @@ PyInit__testcapi(void)
     if (_PyTestCapi_Init_Code(m) < 0) {
         return NULL;
     }
+    if (_PyTestCapi_Init_PyOS(m) < 0) {
+        return NULL;
+    }
 
 #ifndef LIMITED_API_AVAILABLE
     PyModule_AddObjectRef(m, "LIMITED_API_AVAILABLE", Py_False);
index 4cc184bfc1ac829791156a2eb12c242e8172c932..439cd687fda61ddf389e2eab5171fe0540b2f69d 100644 (file)
     <ClCompile Include="..\Modules\_testcapi\structmember.c" />
     <ClCompile Include="..\Modules\_testcapi\exceptions.c" />
     <ClCompile Include="..\Modules\_testcapi\code.c" />
+    <ClCompile Include="..\Modules\_testcapi\pyos.c" />
   </ItemGroup>
   <ItemGroup>
     <ResourceCompile Include="..\PC\python_nt.rc" />
index fbdaf04ce37cb14d43ce268c1c8b9a3ed8dbf1a9..0e42e4982c21ff7c5a39326e7f3fd01b8007d8a1 100644 (file)
@@ -57,6 +57,9 @@
     <ClCompile Include="..\Modules\_testcapi\code.c">
       <Filter>Source Files</Filter>
     </ClCompile>
+    <ClCompile Include="..\Modules\_testcapi\pyos.c">
+      <Filter>Source Files</Filter>
+    </ClCompile>
   </ItemGroup>
   <ItemGroup>
     <ResourceCompile Include="..\PC\python_nt.rc">