mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-25 23:06:10 +01:00
Remove StringRef::isNullTerminated and StringRef::c_str
Both of them were fundamentally unsafe to use and shouldn't be used at all.
This commit is contained in:
parent
e50e10ef8f
commit
f1d7a10e06
@ -5,7 +5,6 @@
|
|||||||
// https://www.boost.org/LICENSE_1_0.txt)
|
// https://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
// SPDX-License-Identifier: BSL-1.0
|
||||||
#include <catch2/internal/catch_enforce.hpp>
|
|
||||||
#include <catch2/internal/catch_stringref.hpp>
|
#include <catch2/internal/catch_stringref.hpp>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
@ -18,11 +17,6 @@ namespace Catch {
|
|||||||
: StringRef( rawChars, static_cast<StringRef::size_type>(std::strlen(rawChars) ) )
|
: StringRef( rawChars, static_cast<StringRef::size_type>(std::strlen(rawChars) ) )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
auto StringRef::c_str() const -> char const* {
|
|
||||||
CATCH_ENFORCE(isNullTerminated(), "Called StringRef::c_str() on a non-null-terminated instance");
|
|
||||||
return m_start;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto StringRef::operator == ( StringRef const& other ) const noexcept -> bool {
|
auto StringRef::operator == ( StringRef const& other ) const noexcept -> bool {
|
||||||
return m_size == other.m_size
|
return m_size == other.m_size
|
||||||
&& (std::memcmp( m_start, other.m_start, m_size ) == 0);
|
&& (std::memcmp( m_start, other.m_start, m_size ) == 0);
|
||||||
|
@ -69,10 +69,6 @@ namespace Catch {
|
|||||||
return m_size;
|
return m_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the current start pointer. If the StringRef is not
|
|
||||||
// null-terminated, throws std::domain_exception
|
|
||||||
auto c_str() const -> char const*;
|
|
||||||
|
|
||||||
public: // substrings and searches
|
public: // substrings and searches
|
||||||
// Returns a substring of [start, start + length).
|
// Returns a substring of [start, start + length).
|
||||||
// If start + length > size(), then the substring is [start, start + size()).
|
// If start + length > size(), then the substring is [start, start + size()).
|
||||||
@ -91,10 +87,6 @@ namespace Catch {
|
|||||||
return m_start;
|
return m_start;
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr auto isNullTerminated() const noexcept -> bool {
|
|
||||||
return m_start[m_size] == '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
public: // iterators
|
public: // iterators
|
||||||
constexpr const_iterator begin() const { return m_start; }
|
constexpr const_iterator begin() const { return m_start; }
|
||||||
constexpr const_iterator end() const { return m_start + m_size; }
|
constexpr const_iterator end() const { return m_start + m_size; }
|
||||||
|
@ -1481,29 +1481,23 @@ Matchers.tests.cpp:<line number>: passed: testStringForMatching(), EndsWith("sub
|
|||||||
Matchers.tests.cpp:<line number>: passed: testStringForMatching(), EndsWith(" SuBsTrInG", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" ends with: " substring" (case insensitive)
|
Matchers.tests.cpp:<line number>: passed: testStringForMatching(), EndsWith(" SuBsTrInG", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" ends with: " substring" (case insensitive)
|
||||||
String.tests.cpp:<line number>: passed: empty.empty() for: true
|
String.tests.cpp:<line number>: passed: empty.empty() for: true
|
||||||
String.tests.cpp:<line number>: passed: empty.size() == 0 for: 0 == 0
|
String.tests.cpp:<line number>: passed: empty.size() == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: empty.isNullTerminated() for: true
|
String.tests.cpp:<line number>: passed: std::strcmp( empty.data(), "" ) == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: std::strcmp( empty.c_str(), "" ) == 0 for: 0 == 0
|
|
||||||
String.tests.cpp:<line number>: passed: s.empty() == false for: false == false
|
String.tests.cpp:<line number>: passed: s.empty() == false for: false == false
|
||||||
String.tests.cpp:<line number>: passed: s.size() == 5 for: 5 == 5
|
String.tests.cpp:<line number>: passed: s.size() == 5 for: 5 == 5
|
||||||
String.tests.cpp:<line number>: passed: s.isNullTerminated() for: true
|
|
||||||
String.tests.cpp:<line number>: passed: std::strcmp( rawChars, "hello" ) == 0 for: 0 == 0
|
String.tests.cpp:<line number>: passed: std::strcmp( rawChars, "hello" ) == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: s.c_str()
|
|
||||||
String.tests.cpp:<line number>: passed: s.c_str() == rawChars for: "hello" == "hello"
|
|
||||||
String.tests.cpp:<line number>: passed: s.data() == rawChars for: "hello" == "hello"
|
String.tests.cpp:<line number>: passed: s.data() == rawChars for: "hello" == "hello"
|
||||||
String.tests.cpp:<line number>: passed: original == "original"
|
String.tests.cpp:<line number>: passed: original == "original"
|
||||||
String.tests.cpp:<line number>: passed: !(original.isNullTerminated()) for: !false
|
|
||||||
String.tests.cpp:<line number>: passed: original.c_str()
|
|
||||||
String.tests.cpp:<line number>: passed: original.data()
|
String.tests.cpp:<line number>: passed: original.data()
|
||||||
String.tests.cpp:<line number>: passed: ss.empty() == false for: false == false
|
String.tests.cpp:<line number>: passed: ss.empty() == false for: false == false
|
||||||
String.tests.cpp:<line number>: passed: ss.size() == 5 for: 5 == 5
|
String.tests.cpp:<line number>: passed: ss.size() == 5 for: 5 == 5
|
||||||
String.tests.cpp:<line number>: passed: std::strncmp( ss.data(), "hello", 5 ) == 0 for: 0 == 0
|
String.tests.cpp:<line number>: passed: std::strncmp( ss.data(), "hello", 5 ) == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: ss == "hello" for: hello == "hello"
|
String.tests.cpp:<line number>: passed: ss == "hello" for: hello == "hello"
|
||||||
String.tests.cpp:<line number>: passed: ss.size() == 6 for: 6 == 6
|
String.tests.cpp:<line number>: passed: ss.size() == 6 for: 6 == 6
|
||||||
String.tests.cpp:<line number>: passed: std::strcmp( ss.c_str(), "world!" ) == 0 for: 0 == 0
|
String.tests.cpp:<line number>: passed: std::strcmp( ss.data(), "world!" ) == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: s.data() == s2.data() for: "hello world!" == "hello world!"
|
String.tests.cpp:<line number>: passed: s.data() == s2.data() for: "hello world!" == "hello world!"
|
||||||
String.tests.cpp:<line number>: passed: s.data() == ss.data() for: "hello world!" == "hello world!"
|
String.tests.cpp:<line number>: passed: s.data() == ss.data() for: "hello world!" == "hello world!"
|
||||||
String.tests.cpp:<line number>: passed: s.substr(s.size() + 1, 123).empty() for: true
|
String.tests.cpp:<line number>: passed: s.substr(s.size() + 1, 123).empty() for: true
|
||||||
String.tests.cpp:<line number>: passed: std::strcmp(ss.c_str(), "world!") == 0 for: 0 == 0
|
String.tests.cpp:<line number>: passed: std::strcmp(ss.data(), "world!") == 0 for: 0 == 0
|
||||||
String.tests.cpp:<line number>: passed: s.substr(1'000'000, 1).empty() for: true
|
String.tests.cpp:<line number>: passed: s.substr(1'000'000, 1).empty() for: true
|
||||||
String.tests.cpp:<line number>: passed: reinterpret_cast<char*>(buffer1) != reinterpret_cast<char*>(buffer2) for: "Hello" != "Hello"
|
String.tests.cpp:<line number>: passed: reinterpret_cast<char*>(buffer1) != reinterpret_cast<char*>(buffer2) for: "Hello" != "Hello"
|
||||||
String.tests.cpp:<line number>: passed: left == right for: Hello == Hello
|
String.tests.cpp:<line number>: passed: left == right for: Hello == Hello
|
||||||
@ -1525,7 +1519,6 @@ String.tests.cpp:<line number>: passed: together == "abrakadabra" for: "abrakada
|
|||||||
String.tests.cpp:<line number>: passed: with 1 message: 'empty.size() == 0'
|
String.tests.cpp:<line number>: passed: with 1 message: 'empty.size() == 0'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'empty.begin() == empty.end()'
|
String.tests.cpp:<line number>: passed: with 1 message: 'empty.begin() == empty.end()'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.size() == 3'
|
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.size() == 3'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.isNullTerminated()'
|
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.data() == abc'
|
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.data() == abc'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.begin() == abc'
|
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.begin() == abc'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.begin() != stringref.end()'
|
String.tests.cpp:<line number>: passed: with 1 message: 'stringref.begin() != stringref.end()'
|
||||||
@ -1535,14 +1528,10 @@ String.tests.cpp:<line number>: passed: with 1 message: 'stringref[1] == 'b''
|
|||||||
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.size() == 2'
|
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.size() == 2'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.data() == abc'
|
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.data() == abc'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.begin() != shortened.end()'
|
String.tests.cpp:<line number>: passed: with 1 message: 'shortened.begin() != shortened.end()'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: '!(shortened.isNullTerminated())'
|
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: '!(shortened.substr(1, 3).isNullTerminated())'
|
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: '!(sr1.empty())'
|
String.tests.cpp:<line number>: passed: with 1 message: '!(sr1.empty())'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'sr1.size() == 3'
|
String.tests.cpp:<line number>: passed: with 1 message: 'sr1.size() == 3'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'sr1.isNullTerminated()'
|
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'sr2.empty()'
|
String.tests.cpp:<line number>: passed: with 1 message: 'sr2.empty()'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'sr2.size() == 0'
|
String.tests.cpp:<line number>: passed: with 1 message: 'sr2.size() == 0'
|
||||||
String.tests.cpp:<line number>: passed: with 1 message: 'sr2.isNullTerminated()'
|
|
||||||
ToStringChrono.tests.cpp:<line number>: passed: minute == seconds for: 1 m == 60 s
|
ToStringChrono.tests.cpp:<line number>: passed: minute == seconds for: 1 m == 60 s
|
||||||
ToStringChrono.tests.cpp:<line number>: passed: hour != seconds for: 1 h != 60 s
|
ToStringChrono.tests.cpp:<line number>: passed: hour != seconds for: 1 h != 60 s
|
||||||
ToStringChrono.tests.cpp:<line number>: passed: micro != milli for: 1 us != 1 ms
|
ToStringChrono.tests.cpp:<line number>: passed: micro != milli for: 1 us != 1 ms
|
||||||
|
@ -1381,5 +1381,5 @@ due to unexpected exception with message:
|
|||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
test cases: 356 | 282 passed | 70 failed | 4 failed as expected
|
test cases: 356 | 282 passed | 70 failed | 4 failed as expected
|
||||||
assertions: 2088 | 1936 passed | 131 failed | 21 failed as expected
|
assertions: 2077 | 1925 passed | 131 failed | 21 failed as expected
|
||||||
|
|
||||||
|
@ -10494,12 +10494,7 @@ with expansion:
|
|||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( empty.isNullTerminated() )
|
REQUIRE( std::strcmp( empty.data(), "" ) == 0 )
|
||||||
with expansion:
|
|
||||||
true
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE( std::strcmp( empty.c_str(), "" ) == 0 )
|
|
||||||
with expansion:
|
with expansion:
|
||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
@ -10520,24 +10515,11 @@ String.tests.cpp:<line number>: PASSED:
|
|||||||
with expansion:
|
with expansion:
|
||||||
5 == 5
|
5 == 5
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE( s.isNullTerminated() )
|
|
||||||
with expansion:
|
|
||||||
true
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( std::strcmp( rawChars, "hello" ) == 0 )
|
REQUIRE( std::strcmp( rawChars, "hello" ) == 0 )
|
||||||
with expansion:
|
with expansion:
|
||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE_NOTHROW( s.c_str() )
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE( s.c_str() == rawChars )
|
|
||||||
with expansion:
|
|
||||||
"hello" == "hello"
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( s.data() == rawChars )
|
REQUIRE( s.data() == rawChars )
|
||||||
with expansion:
|
with expansion:
|
||||||
@ -10553,14 +10535,6 @@ String.tests.cpp:<line number>
|
|||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( original == "original" )
|
REQUIRE( original == "original" )
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE_FALSE( original.isNullTerminated() )
|
|
||||||
with expansion:
|
|
||||||
!false
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
REQUIRE_THROWS( original.c_str() )
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE_NOTHROW( original.data() )
|
REQUIRE_NOTHROW( original.data() )
|
||||||
|
|
||||||
@ -10606,7 +10580,7 @@ with expansion:
|
|||||||
6 == 6
|
6 == 6
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( std::strcmp( ss.c_str(), "world!" ) == 0 )
|
REQUIRE( std::strcmp( ss.data(), "world!" ) == 0 )
|
||||||
with expansion:
|
with expansion:
|
||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
@ -10658,7 +10632,7 @@ String.tests.cpp:<line number>
|
|||||||
...............................................................................
|
...............................................................................
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
REQUIRE( std::strcmp(ss.c_str(), "world!") == 0 )
|
REQUIRE( std::strcmp(ss.data(), "world!") == 0 )
|
||||||
with expansion:
|
with expansion:
|
||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
@ -10832,10 +10806,6 @@ String.tests.cpp:<line number>: PASSED:
|
|||||||
with message:
|
with message:
|
||||||
stringref.size() == 3
|
stringref.size() == 3
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
with message:
|
|
||||||
stringref.isNullTerminated()
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
with message:
|
with message:
|
||||||
stringref.data() == abc
|
stringref.data() == abc
|
||||||
@ -10872,14 +10842,6 @@ String.tests.cpp:<line number>: PASSED:
|
|||||||
with message:
|
with message:
|
||||||
shortened.begin() != shortened.end()
|
shortened.begin() != shortened.end()
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
with message:
|
|
||||||
!(shortened.isNullTerminated())
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
with message:
|
|
||||||
!(shortened.substr(1, 3).isNullTerminated())
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
StringRef at compilation time
|
StringRef at compilation time
|
||||||
UDL construction
|
UDL construction
|
||||||
@ -10895,10 +10857,6 @@ String.tests.cpp:<line number>: PASSED:
|
|||||||
with message:
|
with message:
|
||||||
sr1.size() == 3
|
sr1.size() == 3
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
with message:
|
|
||||||
sr1.isNullTerminated()
|
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
String.tests.cpp:<line number>: PASSED:
|
||||||
with message:
|
with message:
|
||||||
sr2.empty()
|
sr2.empty()
|
||||||
@ -10907,10 +10865,6 @@ String.tests.cpp:<line number>: PASSED:
|
|||||||
with message:
|
with message:
|
||||||
sr2.size() == 0
|
sr2.size() == 0
|
||||||
|
|
||||||
String.tests.cpp:<line number>: PASSED:
|
|
||||||
with message:
|
|
||||||
sr2.isNullTerminated()
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
Stringifying std::chrono::duration helpers
|
Stringifying std::chrono::duration helpers
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
@ -16769,5 +16723,5 @@ Misc.tests.cpp:<line number>: PASSED:
|
|||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
test cases: 356 | 266 passed | 86 failed | 4 failed as expected
|
test cases: 356 | 266 passed | 86 failed | 4 failed as expected
|
||||||
assertions: 2105 | 1936 passed | 148 failed | 21 failed as expected
|
assertions: 2094 | 1925 passed | 148 failed | 21 failed as expected
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<testsuitesloose text artifact
|
<testsuitesloose text artifact
|
||||||
>
|
>
|
||||||
<testsuite name="<exe-name>" errors="17" failures="132" tests="2106" hostname="tbd" time="{duration}" timestamp="{iso8601-timestamp}">
|
<testsuite name="<exe-name>" errors="17" failures="132" tests="2095" hostname="tbd" time="{duration}" timestamp="{iso8601-timestamp}">
|
||||||
<properties>
|
<properties>
|
||||||
<property name="filters" value="~[!nonportable]~[!benchmark]~[approvals] *"/>
|
<property name="filters" value="~[!nonportable]~[!benchmark]~[approvals] *"/>
|
||||||
<property name="random-seed" value="1"/>
|
<property name="random-seed" value="1"/>
|
||||||
|
@ -2646,30 +2646,18 @@ ok {test-number} - empty.empty() for: true
|
|||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - empty.size() == 0 for: 0 == 0
|
ok {test-number} - empty.size() == 0 for: 0 == 0
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - empty.isNullTerminated() for: true
|
ok {test-number} - std::strcmp( empty.data(), "" ) == 0 for: 0 == 0
|
||||||
# StringRef
|
|
||||||
ok {test-number} - std::strcmp( empty.c_str(), "" ) == 0 for: 0 == 0
|
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.empty() == false for: false == false
|
ok {test-number} - s.empty() == false for: false == false
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.size() == 5 for: 5 == 5
|
ok {test-number} - s.size() == 5 for: 5 == 5
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.isNullTerminated() for: true
|
|
||||||
# StringRef
|
|
||||||
ok {test-number} - std::strcmp( rawChars, "hello" ) == 0 for: 0 == 0
|
ok {test-number} - std::strcmp( rawChars, "hello" ) == 0 for: 0 == 0
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.c_str()
|
|
||||||
# StringRef
|
|
||||||
ok {test-number} - s.c_str() == rawChars for: "hello" == "hello"
|
|
||||||
# StringRef
|
|
||||||
ok {test-number} - s.data() == rawChars for: "hello" == "hello"
|
ok {test-number} - s.data() == rawChars for: "hello" == "hello"
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - original == "original"
|
ok {test-number} - original == "original"
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - !(original.isNullTerminated()) for: !false
|
|
||||||
# StringRef
|
|
||||||
ok {test-number} - original.c_str()
|
|
||||||
# StringRef
|
|
||||||
ok {test-number} - original.data()
|
ok {test-number} - original.data()
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - ss.empty() == false for: false == false
|
ok {test-number} - ss.empty() == false for: false == false
|
||||||
@ -2682,7 +2670,7 @@ ok {test-number} - ss == "hello" for: hello == "hello"
|
|||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - ss.size() == 6 for: 6 == 6
|
ok {test-number} - ss.size() == 6 for: 6 == 6
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - std::strcmp( ss.c_str(), "world!" ) == 0 for: 0 == 0
|
ok {test-number} - std::strcmp( ss.data(), "world!" ) == 0 for: 0 == 0
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.data() == s2.data() for: "hello world!" == "hello world!"
|
ok {test-number} - s.data() == s2.data() for: "hello world!" == "hello world!"
|
||||||
# StringRef
|
# StringRef
|
||||||
@ -2690,7 +2678,7 @@ ok {test-number} - s.data() == ss.data() for: "hello world!" == "hello world!"
|
|||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.substr(s.size() + 1, 123).empty() for: true
|
ok {test-number} - s.substr(s.size() + 1, 123).empty() for: true
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - std::strcmp(ss.c_str(), "world!") == 0 for: 0 == 0
|
ok {test-number} - std::strcmp(ss.data(), "world!") == 0 for: 0 == 0
|
||||||
# StringRef
|
# StringRef
|
||||||
ok {test-number} - s.substr(1'000'000, 1).empty() for: true
|
ok {test-number} - s.substr(1'000'000, 1).empty() for: true
|
||||||
# StringRef
|
# StringRef
|
||||||
@ -2730,8 +2718,6 @@ ok {test-number} - with 1 message: 'empty.begin() == empty.end()'
|
|||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'stringref.size() == 3'
|
ok {test-number} - with 1 message: 'stringref.size() == 3'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'stringref.isNullTerminated()'
|
|
||||||
# StringRef at compilation time
|
|
||||||
ok {test-number} - with 1 message: 'stringref.data() == abc'
|
ok {test-number} - with 1 message: 'stringref.data() == abc'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'stringref.begin() == abc'
|
ok {test-number} - with 1 message: 'stringref.begin() == abc'
|
||||||
@ -2750,21 +2736,13 @@ ok {test-number} - with 1 message: 'shortened.data() == abc'
|
|||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'shortened.begin() != shortened.end()'
|
ok {test-number} - with 1 message: 'shortened.begin() != shortened.end()'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: '!(shortened.isNullTerminated())'
|
|
||||||
# StringRef at compilation time
|
|
||||||
ok {test-number} - with 1 message: '!(shortened.substr(1, 3).isNullTerminated())'
|
|
||||||
# StringRef at compilation time
|
|
||||||
ok {test-number} - with 1 message: '!(sr1.empty())'
|
ok {test-number} - with 1 message: '!(sr1.empty())'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'sr1.size() == 3'
|
ok {test-number} - with 1 message: 'sr1.size() == 3'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'sr1.isNullTerminated()'
|
|
||||||
# StringRef at compilation time
|
|
||||||
ok {test-number} - with 1 message: 'sr2.empty()'
|
ok {test-number} - with 1 message: 'sr2.empty()'
|
||||||
# StringRef at compilation time
|
# StringRef at compilation time
|
||||||
ok {test-number} - with 1 message: 'sr2.size() == 0'
|
ok {test-number} - with 1 message: 'sr2.size() == 0'
|
||||||
# StringRef at compilation time
|
|
||||||
ok {test-number} - with 1 message: 'sr2.isNullTerminated()'
|
|
||||||
# Stringifying std::chrono::duration helpers
|
# Stringifying std::chrono::duration helpers
|
||||||
ok {test-number} - minute == seconds for: 1 m == 60 s
|
ok {test-number} - minute == seconds for: 1 m == 60 s
|
||||||
# Stringifying std::chrono::duration helpers
|
# Stringifying std::chrono::duration helpers
|
||||||
@ -4202,5 +4180,5 @@ ok {test-number} - q3 == 23. for: 23.0 == 23.0
|
|||||||
ok {test-number} -
|
ok {test-number} -
|
||||||
# xmlentitycheck
|
# xmlentitycheck
|
||||||
ok {test-number} -
|
ok {test-number} -
|
||||||
1..2105
|
1..2094
|
||||||
|
|
||||||
|
@ -12536,21 +12536,13 @@ Message from section two
|
|||||||
</Expression>
|
</Expression>
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
empty.isNullTerminated()
|
std::strcmp( empty.data(), "" ) == 0
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
true
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
std::strcmp( empty.c_str(), "" ) == 0
|
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
0 == 0
|
0 == 0
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<OverallResults successes="4" failures="0" expectedFailures="0"/>
|
<OverallResults successes="3" failures="0" expectedFailures="0"/>
|
||||||
</Section>
|
</Section>
|
||||||
<Section name="From string literal" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="From string literal" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
@ -12569,14 +12561,6 @@ Message from section two
|
|||||||
5 == 5
|
5 == 5
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
s.isNullTerminated()
|
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
true
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
std::strcmp( rawChars, "hello" ) == 0
|
std::strcmp( rawChars, "hello" ) == 0
|
||||||
@ -12585,22 +12569,6 @@ Message from section two
|
|||||||
0 == 0
|
0 == 0
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<Expression success="true" type="REQUIRE_NOTHROW" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
s.c_str()
|
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
s.c_str()
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
s.c_str() == rawChars
|
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
"hello" == "hello"
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
s.data() == rawChars
|
s.data() == rawChars
|
||||||
@ -12609,7 +12577,7 @@ Message from section two
|
|||||||
"hello" == "hello"
|
"hello" == "hello"
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<OverallResults successes="7" failures="0" expectedFailures="0"/>
|
<OverallResults successes="4" failures="0" expectedFailures="0"/>
|
||||||
</Section>
|
</Section>
|
||||||
<Section name="From sub-string" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="From sub-string" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
@ -12620,22 +12588,6 @@ Message from section two
|
|||||||
original == "original"
|
original == "original"
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<Expression success="true" type="REQUIRE_FALSE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
!(original.isNullTerminated())
|
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
!false
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE_THROWS" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
|
||||||
<Original>
|
|
||||||
original.c_str()
|
|
||||||
</Original>
|
|
||||||
<Expanded>
|
|
||||||
original.c_str()
|
|
||||||
</Expanded>
|
|
||||||
</Expression>
|
|
||||||
<Expression success="true" type="REQUIRE_NOTHROW" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE_NOTHROW" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
original.data()
|
original.data()
|
||||||
@ -12644,7 +12596,7 @@ Message from section two
|
|||||||
original.data()
|
original.data()
|
||||||
</Expanded>
|
</Expanded>
|
||||||
</Expression>
|
</Expression>
|
||||||
<OverallResults successes="4" failures="0" expectedFailures="0"/>
|
<OverallResults successes="2" failures="0" expectedFailures="0"/>
|
||||||
</Section>
|
</Section>
|
||||||
<Section name="Substrings" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="Substrings" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Section name="zero-based substring" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="zero-based substring" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
@ -12696,7 +12648,7 @@ Message from section two
|
|||||||
</Expression>
|
</Expression>
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
std::strcmp( ss.c_str(), "world!" ) == 0
|
std::strcmp( ss.data(), "world!" ) == 0
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
0 == 0
|
0 == 0
|
||||||
@ -12752,7 +12704,7 @@ Message from section two
|
|||||||
<Section name="Substring off the end are trimmed" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="Substring off the end are trimmed" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
std::strcmp(ss.c_str(), "world!") == 0
|
std::strcmp(ss.data(), "world!") == 0
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
0 == 0
|
0 == 0
|
||||||
@ -12941,10 +12893,10 @@ Message from section two
|
|||||||
</TestCase>
|
</TestCase>
|
||||||
<TestCase name="StringRef at compilation time" tags="[constexpr][StringRef][Strings]" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<TestCase name="StringRef at compilation time" tags="[constexpr][StringRef][Strings]" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<Section name="Simple constructors" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="Simple constructors" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<OverallResults successes="15" failures="0" expectedFailures="0"/>
|
<OverallResults successes="12" failures="0" expectedFailures="0"/>
|
||||||
</Section>
|
</Section>
|
||||||
<Section name="UDL construction" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
<Section name="UDL construction" filename="tests/<exe-name>/IntrospectiveTests/String.tests.cpp" >
|
||||||
<OverallResults successes="6" failures="0" expectedFailures="0"/>
|
<OverallResults successes="4" failures="0" expectedFailures="0"/>
|
||||||
</Section>
|
</Section>
|
||||||
<OverallResult success="true"/>
|
<OverallResult success="true"/>
|
||||||
</TestCase>
|
</TestCase>
|
||||||
@ -19715,9 +19667,9 @@ loose text artifact
|
|||||||
</Section>
|
</Section>
|
||||||
<OverallResult success="true"/>
|
<OverallResult success="true"/>
|
||||||
</TestCase>
|
</TestCase>
|
||||||
<OverallResults successes="1936" failures="149" expectedFailures="21"/>
|
<OverallResults successes="1925" failures="149" expectedFailures="21"/>
|
||||||
<OverallResultsCases successes="266" failures="86" expectedFailures="4"/>
|
<OverallResultsCases successes="266" failures="86" expectedFailures="4"/>
|
||||||
</Group>
|
</Group>
|
||||||
<OverallResults successes="1936" failures="148" expectedFailures="21"/>
|
<OverallResults successes="1925" failures="148" expectedFailures="21"/>
|
||||||
<OverallResultsCases successes="266" failures="86" expectedFailures="4"/>
|
<OverallResultsCases successes="266" failures="86" expectedFailures="4"/>
|
||||||
</Catch>
|
</Catch>
|
||||||
|
@ -10,29 +10,23 @@ TEST_CASE( "StringRef", "[Strings][StringRef]" ) {
|
|||||||
StringRef empty;
|
StringRef empty;
|
||||||
REQUIRE( empty.empty() );
|
REQUIRE( empty.empty() );
|
||||||
REQUIRE( empty.size() == 0 );
|
REQUIRE( empty.size() == 0 );
|
||||||
REQUIRE( empty.isNullTerminated() );
|
REQUIRE( std::strcmp( empty.data(), "" ) == 0 );
|
||||||
REQUIRE( std::strcmp( empty.c_str(), "" ) == 0 );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "From string literal" ) {
|
SECTION( "From string literal" ) {
|
||||||
StringRef s = "hello";
|
StringRef s = "hello";
|
||||||
REQUIRE( s.empty() == false );
|
REQUIRE( s.empty() == false );
|
||||||
REQUIRE( s.size() == 5 );
|
REQUIRE( s.size() == 5 );
|
||||||
REQUIRE( s.isNullTerminated() );
|
|
||||||
|
|
||||||
auto rawChars = s.data();
|
auto rawChars = s.data();
|
||||||
REQUIRE( std::strcmp( rawChars, "hello" ) == 0 );
|
REQUIRE( std::strcmp( rawChars, "hello" ) == 0 );
|
||||||
|
|
||||||
REQUIRE_NOTHROW(s.c_str());
|
|
||||||
REQUIRE(s.c_str() == rawChars);
|
|
||||||
REQUIRE(s.data() == rawChars);
|
REQUIRE(s.data() == rawChars);
|
||||||
}
|
}
|
||||||
SECTION( "From sub-string" ) {
|
SECTION( "From sub-string" ) {
|
||||||
StringRef original = StringRef( "original string" ).substr(0, 8);
|
StringRef original = StringRef( "original string" ).substr(0, 8);
|
||||||
REQUIRE( original == "original" );
|
REQUIRE( original == "original" );
|
||||||
|
|
||||||
REQUIRE_FALSE(original.isNullTerminated());
|
|
||||||
REQUIRE_THROWS(original.c_str());
|
|
||||||
REQUIRE_NOTHROW(original.data());
|
REQUIRE_NOTHROW(original.data());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,7 +45,7 @@ TEST_CASE( "StringRef", "[Strings][StringRef]" ) {
|
|||||||
SECTION( "non-zero-based substring") {
|
SECTION( "non-zero-based substring") {
|
||||||
ss = s.substr( 6, 6 );
|
ss = s.substr( 6, 6 );
|
||||||
REQUIRE( ss.size() == 6 );
|
REQUIRE( ss.size() == 6 );
|
||||||
REQUIRE( std::strcmp( ss.c_str(), "world!" ) == 0 );
|
REQUIRE( std::strcmp( ss.data(), "world!" ) == 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Pointer values of full refs should match" ) {
|
SECTION( "Pointer values of full refs should match" ) {
|
||||||
@ -69,7 +63,7 @@ TEST_CASE( "StringRef", "[Strings][StringRef]" ) {
|
|||||||
|
|
||||||
SECTION("Substring off the end are trimmed") {
|
SECTION("Substring off the end are trimmed") {
|
||||||
ss = s.substr(6, 123);
|
ss = s.substr(6, 123);
|
||||||
REQUIRE(std::strcmp(ss.c_str(), "world!") == 0);
|
REQUIRE(std::strcmp(ss.data(), "world!") == 0);
|
||||||
}
|
}
|
||||||
SECTION("substring start after the end is empty") {
|
SECTION("substring start after the end is empty") {
|
||||||
REQUIRE(s.substr(1'000'000, 1).empty());
|
REQUIRE(s.substr(1'000'000, 1).empty());
|
||||||
@ -147,7 +141,6 @@ TEST_CASE("StringRef at compilation time", "[Strings][StringRef][constexpr]") {
|
|||||||
|
|
||||||
constexpr StringRef stringref(abc, 3);
|
constexpr StringRef stringref(abc, 3);
|
||||||
STATIC_REQUIRE(stringref.size() == 3);
|
STATIC_REQUIRE(stringref.size() == 3);
|
||||||
STATIC_REQUIRE(stringref.isNullTerminated());
|
|
||||||
STATIC_REQUIRE(stringref.data() == abc);
|
STATIC_REQUIRE(stringref.data() == abc);
|
||||||
STATIC_REQUIRE(stringref.begin() == abc);
|
STATIC_REQUIRE(stringref.begin() == abc);
|
||||||
STATIC_REQUIRE(stringref.begin() != stringref.end());
|
STATIC_REQUIRE(stringref.begin() != stringref.end());
|
||||||
@ -160,19 +153,15 @@ TEST_CASE("StringRef at compilation time", "[Strings][StringRef][constexpr]") {
|
|||||||
STATIC_REQUIRE(shortened.size() == 2);
|
STATIC_REQUIRE(shortened.size() == 2);
|
||||||
STATIC_REQUIRE(shortened.data() == abc);
|
STATIC_REQUIRE(shortened.data() == abc);
|
||||||
STATIC_REQUIRE(shortened.begin() != shortened.end());
|
STATIC_REQUIRE(shortened.begin() != shortened.end());
|
||||||
STATIC_REQUIRE_FALSE(shortened.isNullTerminated());
|
|
||||||
STATIC_REQUIRE_FALSE(shortened.substr(1, 3).isNullTerminated());
|
|
||||||
}
|
}
|
||||||
SECTION("UDL construction") {
|
SECTION("UDL construction") {
|
||||||
constexpr auto sr1 = "abc"_catch_sr;
|
constexpr auto sr1 = "abc"_catch_sr;
|
||||||
STATIC_REQUIRE_FALSE(sr1.empty());
|
STATIC_REQUIRE_FALSE(sr1.empty());
|
||||||
STATIC_REQUIRE(sr1.size() == 3);
|
STATIC_REQUIRE(sr1.size() == 3);
|
||||||
STATIC_REQUIRE(sr1.isNullTerminated());
|
|
||||||
|
|
||||||
using Catch::operator"" _sr;
|
using Catch::operator"" _sr;
|
||||||
constexpr auto sr2 = ""_sr;
|
constexpr auto sr2 = ""_sr;
|
||||||
STATIC_REQUIRE(sr2.empty());
|
STATIC_REQUIRE(sr2.empty());
|
||||||
STATIC_REQUIRE(sr2.size() == 0);
|
STATIC_REQUIRE(sr2.size() == 0);
|
||||||
STATIC_REQUIRE(sr2.isNullTerminated());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user