diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2013-03-25 16:24:48 +0100 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2013-03-25 17:33:29 +0100 |
commit | 40dcf2d713e67ef4d8c68a6df98954f1f0b783db (patch) | |
tree | 664e26d5a76f837cff2d31d0f026482e1ee7afb4 | |
parent | bd60d41176da540b01d7583cfe00637431967f39 (diff) |
Add test case for toInt overflow detection
Change-Id: I1c5b66888baac8aa1bc99c06579e0ef3638a4877
-rw-r--r-- | sal/CppunitTest_sal_rtl_strings.mk | 1 | ||||
-rw-r--r-- | sal/inc/rtl/string.hxx | 9 | ||||
-rw-r--r-- | sal/inc/rtl/ustring.hxx | 9 | ||||
-rw-r--r-- | sal/qa/rtl/strings/test_strings_toint.cxx | 65 |
4 files changed, 78 insertions, 6 deletions
diff --git a/sal/CppunitTest_sal_rtl_strings.mk b/sal/CppunitTest_sal_rtl_strings.mk index 222cedf17f49..1d56ecd06c7d 100644 --- a/sal/CppunitTest_sal_rtl_strings.mk +++ b/sal/CppunitTest_sal_rtl_strings.mk @@ -38,6 +38,7 @@ $(eval $(call gb_CppunitTest_add_exception_objects,sal_rtl_strings,\ sal/qa/rtl/strings/test_oustring_noadditional \ sal/qa/rtl/strings/test_oustring_startswith \ sal/qa/rtl/strings/test_oustring_stringliterals \ + sal/qa/rtl/strings/test_strings_toint \ sal/qa/rtl/strings/test_strings_valuex \ )) diff --git a/sal/inc/rtl/string.hxx b/sal/inc/rtl/string.hxx index 01ee46477f34..f6cec59dc04e 100644 --- a/sal/inc/rtl/string.hxx +++ b/sal/inc/rtl/string.hxx @@ -1349,7 +1349,8 @@ public: @param radix the radix (between 2 and 36) @return the int32 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. */ sal_Int32 toInt32( sal_Int16 radix = 10 ) const SAL_THROW(()) { @@ -1363,7 +1364,8 @@ public: @param radix the radix (between 2 and 36) @return the int64 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. */ sal_Int64 toInt64( sal_Int16 radix = 10 ) const SAL_THROW(()) { @@ -1377,7 +1379,8 @@ public: @param radix the radix (between 2 and 36) @return the uint64 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. @since LibreOffice 4.1 */ diff --git a/sal/inc/rtl/ustring.hxx b/sal/inc/rtl/ustring.hxx index 2afd95cc62f0..768f5521303d 100644 --- a/sal/inc/rtl/ustring.hxx +++ b/sal/inc/rtl/ustring.hxx @@ -1828,7 +1828,8 @@ public: @param radix the radix (between 2 and 36) @return the int32 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. */ sal_Int32 toInt32( sal_Int16 radix = 10 ) const SAL_THROW(()) { @@ -1842,7 +1843,8 @@ public: @param radix the radix (between 2 and 36) @return the int64 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. */ sal_Int64 toInt64( sal_Int16 radix = 10 ) const SAL_THROW(()) { @@ -1856,7 +1858,8 @@ public: @param radix the radix (between 2 and 36) @return the uint64 represented from this string. - 0 if this string represents no number. + 0 if this string represents no number or one of too large + magnitude. @since LibreOffice 4.1 */ diff --git a/sal/qa/rtl/strings/test_strings_toint.cxx b/sal/qa/rtl/strings/test_strings_toint.cxx new file mode 100644 index 000000000000..4a4f549e4495 --- /dev/null +++ b/sal/qa/rtl/strings/test_strings_toint.cxx @@ -0,0 +1,65 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This file is part of the LibreOffice project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ + +#include "sal/config.h" + +#include "cppunit/TestAssert.h" +#include "cppunit/TestFixture.h" +#include "cppunit/extensions/HelperMacros.h" +#include "rtl/string.hxx" +#include "rtl/ustring.hxx" +#include "sal/types.h" + +namespace { + +template< typename T > class Test: public CppUnit::TestFixture { +private: + CPPUNIT_TEST_SUITE(Test); + CPPUNIT_TEST(testToInt32Overflow); + CPPUNIT_TEST(testToInt64Overflow); + CPPUNIT_TEST(testToUInt64Overflow); + CPPUNIT_TEST_SUITE_END(); + + void testToInt32Overflow() { + CPPUNIT_ASSERT_EQUAL(sal_Int32(0), T("-2147483649").toInt32()); + CPPUNIT_ASSERT_EQUAL(SAL_MIN_INT32, T("-2147483648").toInt32()); + CPPUNIT_ASSERT_EQUAL(SAL_MIN_INT32 + 1, T("-2147483647").toInt32()); + CPPUNIT_ASSERT_EQUAL(SAL_MAX_INT32 - 1, T("2147483646").toInt32()); + CPPUNIT_ASSERT_EQUAL(SAL_MAX_INT32, T("2147483647").toInt32()); + CPPUNIT_ASSERT_EQUAL(sal_Int32(0), T("2147483648").toInt32()); + } + + void testToInt64Overflow() { + CPPUNIT_ASSERT_EQUAL(sal_Int64(0), T("-9223372036854775809").toInt64()); + CPPUNIT_ASSERT_EQUAL( + SAL_MIN_INT64, T("-9223372036854775808").toInt64()); + CPPUNIT_ASSERT_EQUAL( + SAL_MIN_INT64 + 1, T("-9223372036854775807").toInt64()); + CPPUNIT_ASSERT_EQUAL( + SAL_MAX_INT64 - 1, T("9223372036854775806").toInt64()); + CPPUNIT_ASSERT_EQUAL(SAL_MAX_INT64, T("9223372036854775807").toInt64()); + CPPUNIT_ASSERT_EQUAL(sal_Int64(0), T("9223372036854775808").toInt64()); + } + + void testToUInt64Overflow() { + CPPUNIT_ASSERT_EQUAL( + SAL_MAX_UINT64 - 1, T("18446744073709551614").toUInt64()); + CPPUNIT_ASSERT_EQUAL( + SAL_MAX_UINT64, T("18446744073709551615").toUInt64()); + CPPUNIT_ASSERT_EQUAL( + sal_uInt64(0), T("18446744073709551616").toUInt64()); + } +}; + +CPPUNIT_TEST_SUITE_REGISTRATION(Test< rtl::OString >); +CPPUNIT_TEST_SUITE_REGISTRATION(Test< rtl::OUString >); + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |