diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-01-13 20:06:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-01-13 20:06:56 +0000 | 
| commit | 7fed546d1996271dabc7cf71d4d033125c4da4ee (patch) | |
| tree | 2b6dc7dcb4a6380cb331aded15f5a81c0038e194 /unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp | |
| parent | 9e6d35490a6542f9c97607f93c2ef8ca8e03cbcc (diff) | |
Notes
Diffstat (limited to 'unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp')
| -rw-r--r-- | unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp | 21 | 
1 files changed, 21 insertions, 0 deletions
| diff --git a/unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp b/unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp index 5c6925179c6a..605f0233e876 100644 --- a/unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp +++ b/unittests/ScriptInterpreter/Python/PythonDataObjectsTests.cpp @@ -203,6 +203,27 @@ TEST_F(PythonDataObjectsTest, TestPythonInteger)      EXPECT_EQ(7, constructed_int.GetInteger());  } +TEST_F(PythonDataObjectsTest, TestPythonBytes) +{ +    static const char *test_bytes = "PythonDataObjectsTest::TestPythonBytes"; +    PyObject *py_bytes = PyBytes_FromString(test_bytes); +    EXPECT_TRUE(PythonBytes::Check(py_bytes)); +    PythonBytes python_bytes(PyRefType::Owned, py_bytes); +    EXPECT_EQ(PyObjectType::Bytes, python_bytes.GetObjectType()); + +#if PY_MAJOR_VERSION < 3 +    EXPECT_TRUE(PythonString::Check(py_bytes)); +    EXPECT_EQ(PyObjectType::String, python_bytes.GetObjectType()); +#else +    EXPECT_FALSE(PythonString::Check(py_bytes)); +    EXPECT_NE(PyObjectType::String, python_bytes.GetObjectType()); +#endif + +    llvm::ArrayRef<uint8_t> bytes = python_bytes.GetBytes(); +    EXPECT_EQ(bytes.size(), strlen(test_bytes)); +    EXPECT_EQ(0, ::memcmp(bytes.data(), test_bytes, bytes.size())); +} +  TEST_F(PythonDataObjectsTest, TestPythonString)  {      // Test that strings behave correctly when wrapped by a PythonString. | 
