[test] Move cctest/test-strtod to unittests/numbers/

... strtod-unittest.

Bug: v8:12781
Change-Id: I86c3a27a0197103c4ca4be111d55e60b98928758
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3675735
Reviewed-by: Leszek Swirski <leszeks@chromium.org>
Commit-Queue: 王澳 <wangao.james@bytedance.com>
Cr-Commit-Position: refs/heads/main@{#80801}
This commit is contained in:
jameslahm 2022-05-29 09:23:41 +08:00 committed by V8 LUCI CQ
parent e8186979f4
commit d1fbcecc1d
3 changed files with 18 additions and 17 deletions

View File

@ -229,7 +229,6 @@ v8_source_set("cctest_sources") {
"test-shared-strings.cc", "test-shared-strings.cc",
"test-smi-lexicographic-compare.cc", "test-smi-lexicographic-compare.cc",
"test-strings.cc", "test-strings.cc",
"test-strtod.cc",
"test-swiss-name-dictionary-csa.cc", "test-swiss-name-dictionary-csa.cc",
"test-swiss-name-dictionary-infra.cc", "test-swiss-name-dictionary-infra.cc",
"test-swiss-name-dictionary.cc", "test-swiss-name-dictionary.cc",

View File

@ -394,6 +394,7 @@ v8_source_set("unittests_sources") {
"logging/log-unittest.cc", "logging/log-unittest.cc",
"numbers/bigint-unittest.cc", "numbers/bigint-unittest.cc",
"numbers/conversions-unittest.cc", "numbers/conversions-unittest.cc",
"numbers/strtod-unittest.cc",
"objects/array-list-unittest.cc", "objects/array-list-unittest.cc",
"objects/concurrent-descriptor-array-unittest.cc", "objects/concurrent-descriptor-array-unittest.cc",
"objects/concurrent-feedback-vector-unittest.cc", "objects/concurrent-feedback-vector-unittest.cc",

View File

@ -25,25 +25,28 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include "src/base/numbers/strtod.h"
#include <stdlib.h> #include <stdlib.h>
#include "src/base/numbers/bignum.h" #include "src/base/numbers/bignum.h"
#include "src/base/numbers/diy-fp.h" #include "src/base/numbers/diy-fp.h"
#include "src/base/numbers/double.h" #include "src/base/numbers/double.h"
#include "src/base/numbers/strtod.h"
#include "src/base/utils/random-number-generator.h" #include "src/base/utils/random-number-generator.h"
#include "src/init/v8.h" #include "src/init/v8.h"
#include "test/cctest/cctest.h" #include "test/unittests/test-utils.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace v8 { namespace v8 {
namespace base { namespace base {
namespace test_strtod {
using StrtodTest = ::testing::Test;
static double StrtodChar(const char* str, int exponent) { static double StrtodChar(const char* str, int exponent) {
return Strtod(CStrVector(str), exponent); return Strtod(CStrVector(str), exponent);
} }
TEST(Strtod) { TEST_F(StrtodTest, Strtod) {
Vector<const char> vector; Vector<const char> vector;
vector = CStrVector("0"); vector = CStrVector("0");
@ -295,7 +298,8 @@ TEST(Strtod) {
"6640064319118728664842287477491068264828851624402189317" "6640064319118728664842287477491068264828851624402189317"
"2769161449825765517353755844373640588822904791244190695" "2769161449825765517353755844373640588822904791244190695"
"2998382932630754670573838138825217065450843010498555058" "2998382932630754670573838138825217065450843010498555058"
"88186560731", -1035)); "88186560731",
-1035));
// Boundary cases. Boundaries themselves should round to even. // Boundary cases. Boundaries themselves should round to even.
// //
@ -363,13 +367,12 @@ TEST(Strtod) {
"22321503775666622503982534335974568884423900265498198385" "22321503775666622503982534335974568884423900265498198385"
"48794829220689472168983109969836584681402285424333066033" "48794829220689472168983109969836584681402285424333066033"
"98508864458040010349339704275671864433837704860378616227" "98508864458040010349339704275671864433837704860378616227"
"71738545623065874679014086723327636718751", -1076)); "71738545623065874679014086723327636718751",
-1076));
} }
static int CompareBignumToDiyFp(const Bignum& bignum_digits, static int CompareBignumToDiyFp(const Bignum& bignum_digits,
int bignum_exponent, int bignum_exponent, DiyFp diy_fp) {
DiyFp diy_fp) {
Bignum bignum; Bignum bignum;
bignum.AssignBignum(bignum_digits); bignum.AssignBignum(bignum_digits);
Bignum other; Bignum other;
@ -411,10 +414,10 @@ static bool CheckDouble(Vector<const char> buffer, int exponent,
d.NormalizedBoundaries(&lower_boundary, &upper_boundary); d.NormalizedBoundaries(&lower_boundary, &upper_boundary);
if ((d.Significand() & 1) == 0) { if ((d.Significand() & 1) == 0) {
return CompareBignumToDiyFp(input_digits, exponent, lower_boundary) >= 0 && return CompareBignumToDiyFp(input_digits, exponent, lower_boundary) >= 0 &&
CompareBignumToDiyFp(input_digits, exponent, upper_boundary) <= 0; CompareBignumToDiyFp(input_digits, exponent, upper_boundary) <= 0;
} else { } else {
return CompareBignumToDiyFp(input_digits, exponent, lower_boundary) > 0 && return CompareBignumToDiyFp(input_digits, exponent, lower_boundary) > 0 &&
CompareBignumToDiyFp(input_digits, exponent, upper_boundary) < 0; CompareBignumToDiyFp(input_digits, exponent, upper_boundary) < 0;
} }
} }
@ -435,12 +438,11 @@ static uint32_t DeterministicRandom() {
return (hi << 16) + (lo & 0xFFFF); return (hi << 16) + (lo & 0xFFFF);
} }
static const int kBufferSize = 1024; static const int kBufferSize = 1024;
static const int kShortStrtodRandomCount = 2; static const int kShortStrtodRandomCount = 2;
static const int kLargeStrtodRandomCount = 2; static const int kLargeStrtodRandomCount = 2;
TEST(RandomStrtod) { TEST_F(StrtodTest, RandomStrtod) {
base::RandomNumberGenerator rng; base::RandomNumberGenerator rng;
char buffer[kBufferSize]; char buffer[kBufferSize];
for (int length = 1; length < 15; length++) { for (int length = 1; length < 15; length++) {
@ -449,7 +451,7 @@ TEST(RandomStrtod) {
for (int j = 0; j < length; ++j) { for (int j = 0; j < length; ++j) {
buffer[pos++] = rng.NextInt(10) + '0'; buffer[pos++] = rng.NextInt(10) + '0';
} }
int exponent = DeterministicRandom() % (25*2 + 1) - 25 - length; int exponent = DeterministicRandom() % (25 * 2 + 1) - 25 - length;
buffer[pos] = '\0'; buffer[pos] = '\0';
Vector<const char> vector(buffer, pos); Vector<const char> vector(buffer, pos);
double strtod_result = Strtod(vector, exponent); double strtod_result = Strtod(vector, exponent);
@ -462,7 +464,7 @@ TEST(RandomStrtod) {
for (int j = 0; j < length; ++j) { for (int j = 0; j < length; ++j) {
buffer[pos++] = rng.NextInt(10) + '0'; buffer[pos++] = rng.NextInt(10) + '0';
} }
int exponent = DeterministicRandom() % (308*2 + 1) - 308 - length; int exponent = DeterministicRandom() % (308 * 2 + 1) - 308 - length;
buffer[pos] = '\0'; buffer[pos] = '\0';
Vector<const char> vector(buffer, pos); Vector<const char> vector(buffer, pos);
double strtod_result = Strtod(vector, exponent); double strtod_result = Strtod(vector, exponent);
@ -471,6 +473,5 @@ TEST(RandomStrtod) {
} }
} }
} // namespace test_strtod
} // namespace base } // namespace base
} // namespace v8 } // namespace v8