|
Line 0
a/Source/WebKit/chromium/tests/DecimalTest.cpp_sec1
|
|
|
1 |
/* |
| 2 |
* Copyright (C) 2012 Google Inc. All rights reserved. |
| 3 |
* |
| 4 |
* Redistribution and use in source and binary forms, with or without |
| 5 |
* modification, are permitted provided that the following conditions are |
| 6 |
* met: |
| 7 |
* |
| 8 |
* * Redistributions of source code must retain the above copyright |
| 9 |
* notice, this list of conditions and the following disclaimer. |
| 10 |
* * Redistributions in binary form must reproduce the above |
| 11 |
* copyright notice, this list of conditions and the following disclaimer |
| 12 |
* in the documentation and/or other materials provided with the |
| 13 |
* distribution. |
| 14 |
* * Neither the name of Google Inc. nor the names of its |
| 15 |
* contributors may be used to endorse or promote products derived from |
| 16 |
* this software without specific prior written permission. |
| 17 |
* |
| 18 |
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| 19 |
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| 20 |
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| 21 |
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| 22 |
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| 23 |
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| 24 |
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 25 |
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 26 |
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 27 |
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 28 |
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 29 |
*/ |
| 30 |
|
| 31 |
#include "config.h" |
| 32 |
#include "Decimal.h" |
| 33 |
|
| 34 |
#include <gtest/gtest.h> |
| 35 |
#include <wtf/MathExtras.h> |
| 36 |
#include <wtf/text/CString.h> |
| 37 |
|
| 38 |
namespace WebCore { |
| 39 |
|
| 40 |
std::ostream& operator<<(std::ostream& os, const Decimal& decimal) |
| 41 |
{ |
| 42 |
Decimal::EncodedData data = decimal.value(); |
| 43 |
return os |
| 44 |
<< "encode(" << String::number(data.coefficient()).ascii().data() |
| 45 |
<< ", " << String::number(data.exponent()).ascii().data() |
| 46 |
<< ", " << (data.sign() == Decimal::Negative ? "Negative" : "Positive") |
| 47 |
<< ")=" << decimal.toString().ascii().data(); |
| 48 |
} |
| 49 |
|
| 50 |
} // namespace WebCore |
| 51 |
|
| 52 |
using namespace WebCore; |
| 53 |
|
| 54 |
// Simulate WebCore/html/StepRange |
| 55 |
class DecimalStepRange { |
| 56 |
public: |
| 57 |
Decimal maximum; |
| 58 |
Decimal minimum; |
| 59 |
Decimal step; |
| 60 |
|
| 61 |
DecimalStepRange(const Decimal& minimum, const Decimal& maximum, const Decimal& step) |
| 62 |
: maximum(maximum) |
| 63 |
, minimum(minimum) |
| 64 |
, step(step) |
| 65 |
{ |
| 66 |
} |
| 67 |
|
| 68 |
Decimal clampValue(Decimal value) const |
| 69 |
{ |
| 70 |
const Decimal result = minimum + ((value - minimum) / step).round() * step; |
| 71 |
ASSERT(result.isFinite()); |
| 72 |
return result > maximum ? result - step : result; |
| 73 |
} |
| 74 |
}; |
| 75 |
|
| 76 |
class DecimalTest : public ::testing::Test { |
| 77 |
protected: |
| 78 |
typedef Decimal::Sign Sign; |
| 79 |
protected: static const Sign Positive = Decimal::Positive; |
| 80 |
protected: static const Sign Negative = Decimal::Negative; |
| 81 |
|
| 82 |
Decimal encode(uint64_t coefficient, int exponent, Sign sign) |
| 83 |
{ |
| 84 |
return Decimal(sign, exponent, coefficient); |
| 85 |
} |
| 86 |
|
| 87 |
protected: Decimal fromString(const String& string) |
| 88 |
{ |
| 89 |
return Decimal::fromString(string); |
| 90 |
} |
| 91 |
|
| 92 |
protected: String stepDown(const String& minimum, const String& maximum, const String& step, const String& valueString, int numberOfStepTimes) |
| 93 |
{ |
| 94 |
DecimalStepRange stepRange(fromString(minimum), fromString(maximum), fromString(step)); |
| 95 |
Decimal value = fromString(valueString); |
| 96 |
for (int i = 0; i < numberOfStepTimes; ++i) { |
| 97 |
value -= stepRange.step; |
| 98 |
value = stepRange.clampValue(value); |
| 99 |
} |
| 100 |
return value.toString(); |
| 101 |
} |
| 102 |
|
| 103 |
protected: String stepUp(const String& minimum, const String& maximum, const String& step, const String& valueString, int numberOfStepTimes) |
| 104 |
{ |
| 105 |
DecimalStepRange stepRange(fromString(minimum), fromString(maximum), fromString(step)); |
| 106 |
Decimal value = fromString(valueString); |
| 107 |
for (int i = 0; i < numberOfStepTimes; ++i) { |
| 108 |
value += stepRange.step; |
| 109 |
value = stepRange.clampValue(value); |
| 110 |
} |
| 111 |
return value.toString(); |
| 112 |
} |
| 113 |
}; |
| 114 |
|
| 115 |
TEST_F(DecimalTest, Abs) |
| 116 |
{ |
| 117 |
EXPECT_EQ(encode(0, 0, Positive), encode(0, 0, Positive).abs()); |
| 118 |
EXPECT_EQ(encode(0, 0, Positive), encode(0, 0, Negative).abs()); |
| 119 |
|
| 120 |
EXPECT_EQ(encode(0, 10, Positive), encode(0, 10, Positive).abs()); |
| 121 |
EXPECT_EQ(encode(0, 10, Positive), encode(0, 10, Negative).abs()); |
| 122 |
|
| 123 |
EXPECT_EQ(encode(0, -10, Positive), encode(0, -10, Positive).abs()); |
| 124 |
EXPECT_EQ(encode(0, -10, Positive), encode(0, -10, Negative).abs()); |
| 125 |
|
| 126 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, 0, Positive).abs()); |
| 127 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, 0, Negative).abs()); |
| 128 |
|
| 129 |
EXPECT_EQ(encode(1, 10, Positive), encode(1, 10, Positive).abs()); |
| 130 |
EXPECT_EQ(encode(1, 10, Positive), encode(1, 10, Negative).abs()); |
| 131 |
|
| 132 |
EXPECT_EQ(encode(1, -10, Positive), encode(1, -10, Positive).abs()); |
| 133 |
EXPECT_EQ(encode(1, -10, Positive), encode(1, -10, Negative).abs()); |
| 134 |
} |
| 135 |
|
| 136 |
TEST_F(DecimalTest, Ceiling) |
| 137 |
{ |
| 138 |
EXPECT_EQ(Decimal(1), Decimal(1).ceiling()); |
| 139 |
EXPECT_EQ(Decimal(2), encode(11, -1, Positive).ceiling()); |
| 140 |
EXPECT_EQ(Decimal(2), encode(13, -1, Positive).ceiling()); |
| 141 |
EXPECT_EQ(Decimal(2), encode(15, -1, Positive).ceiling()); |
| 142 |
EXPECT_EQ(Decimal(2), encode(19, -1, Positive).ceiling()); |
| 143 |
|
| 144 |
EXPECT_EQ(Decimal(-1), Decimal(-1).ceiling()); |
| 145 |
EXPECT_EQ(Decimal(-1), encode(11, -1, Negative).ceiling()); |
| 146 |
EXPECT_EQ(Decimal(-1), encode(13, -1, Negative).ceiling()); |
| 147 |
EXPECT_EQ(Decimal(-1), encode(15, -1, Negative).ceiling()); |
| 148 |
EXPECT_EQ(Decimal(-1), encode(19, -1, Negative).ceiling()); |
| 149 |
} |
| 150 |
|
| 151 |
TEST_F(DecimalTest, EncodedData) |
| 152 |
{ |
| 153 |
EXPECT_EQ(encode(0, 0, Positive), encode(0, 0, Positive)); |
| 154 |
EXPECT_EQ(encode(0, 0, Negative), encode(0, 0, Negative)); |
| 155 |
EXPECT_EQ(Decimal(1), Decimal(1)); |
| 156 |
EXPECT_EQ(encode(1, 0, Negative), encode(1, 0, Negative)); |
| 157 |
EXPECT_EQ(Decimal::infinity(Positive), encode(1, 2000, Positive)); |
| 158 |
EXPECT_EQ(Decimal::zero(Positive), encode(1, -2000, Positive)); |
| 159 |
} |
| 160 |
|
| 161 |
TEST_F(DecimalTest, Floor) |
| 162 |
{ |
| 163 |
EXPECT_EQ(Decimal(1), Decimal(1).floor()); |
| 164 |
EXPECT_EQ(Decimal(1), encode(11, -1, Positive).floor()); |
| 165 |
EXPECT_EQ(Decimal(1), encode(13, -1, Positive).floor()); |
| 166 |
EXPECT_EQ(Decimal(1), encode(15, -1, Positive).floor()); |
| 167 |
EXPECT_EQ(Decimal(1), encode(19, -1, Positive).floor()); |
| 168 |
|
| 169 |
EXPECT_EQ(Decimal(-1), Decimal(-1).floor()); |
| 170 |
EXPECT_EQ(Decimal(-2), encode(11, -1, Negative).floor()); |
| 171 |
EXPECT_EQ(Decimal(-2), encode(13, -1, Negative).floor()); |
| 172 |
EXPECT_EQ(Decimal(-2), encode(15, -1, Negative).floor()); |
| 173 |
EXPECT_EQ(Decimal(-2), encode(19, -1, Negative).floor()); |
| 174 |
} |
| 175 |
|
| 176 |
TEST_F(DecimalTest, FromInt32) |
| 177 |
{ |
| 178 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(0)); |
| 179 |
EXPECT_EQ(Decimal(1), Decimal(1)); |
| 180 |
EXPECT_EQ(encode(1, 0, Negative), Decimal(-1)); |
| 181 |
EXPECT_EQ(encode(100, 0, Positive), Decimal(100)); |
| 182 |
EXPECT_EQ(encode(100, 0, Negative), Decimal(-100)); |
| 183 |
EXPECT_EQ(encode(0x7FFFFFFF, 0, Positive), Decimal(INT_MAX)); |
| 184 |
EXPECT_EQ(encode(0x80000000u, 0, Negative), Decimal(INT_MIN)); |
| 185 |
} |
| 186 |
|
| 187 |
TEST_F(DecimalTest, FromString) |
| 188 |
{ |
| 189 |
EXPECT_EQ(encode(0, 0, Positive), fromString("0")); |
| 190 |
EXPECT_EQ(encode(0, 0, Negative), fromString("-0")); |
| 191 |
EXPECT_EQ(Decimal(1), fromString("1")); |
| 192 |
EXPECT_EQ(encode(1, 0, Negative), fromString("-1")); |
| 193 |
EXPECT_EQ(Decimal(1), fromString("01")); |
| 194 |
EXPECT_EQ(encode(3, 0, Positive), fromString("+3")); |
| 195 |
EXPECT_EQ(encode(0, 3, Positive), fromString("0E3")); |
| 196 |
EXPECT_EQ(encode(5, -1, Positive), fromString(".5")); |
| 197 |
EXPECT_EQ(encode(100, 0, Positive), fromString("100")); |
| 198 |
EXPECT_EQ(encode(100, 0, Negative), fromString("-100")); |
| 199 |
EXPECT_EQ(encode(123, -2, Positive), fromString("1.23")); |
| 200 |
EXPECT_EQ(encode(123, -2, Negative), fromString("-1.23")); |
| 201 |
EXPECT_EQ(encode(123, 8, Positive), fromString("1.23E10")); |
| 202 |
EXPECT_EQ(encode(123, 8, Negative), fromString("-1.23E10")); |
| 203 |
EXPECT_EQ(encode(123, 8, Positive), fromString("1.23E+10")); |
| 204 |
EXPECT_EQ(encode(123, 8, Negative), fromString("-1.23E+10")); |
| 205 |
EXPECT_EQ(encode(123, -12, Positive), fromString("1.23E-10")); |
| 206 |
EXPECT_EQ(encode(123, -12, Negative), fromString("-1.23E-10")); |
| 207 |
EXPECT_EQ(encode(5, -7, Positive), fromString("0.0000005")); |
| 208 |
EXPECT_EQ(encode(123, -3, Positive), fromString("0.123")); |
| 209 |
EXPECT_EQ(encode(0, -2, Positive), fromString("00.00")); |
| 210 |
EXPECT_EQ(encode(1, 2, Positive), fromString("1E2")); |
| 211 |
EXPECT_EQ(Decimal::infinity(Positive), fromString("1E20000")); |
| 212 |
EXPECT_EQ(Decimal::zero(Positive), fromString("1E-20000")); |
| 213 |
EXPECT_EQ(encode(1000, 1023, Positive), fromString("1E1026")); |
| 214 |
EXPECT_EQ(Decimal::zero(Positive), fromString("1E-1026")); |
| 215 |
EXPECT_EQ(Decimal::infinity(Positive), fromString("1234567890E1036")); |
| 216 |
|
| 217 |
// 2^1024 |
| 218 |
const uint64_t leadingDigitsOf2PowerOf1024 = UINT64_C(17976931348623159); |
| 219 |
EXPECT_EQ(encode(leadingDigitsOf2PowerOf1024, 292, Positive), fromString("179769313486231590772930519078902473361797697894230657273430081157732675805500963132708477322407536021120113879871393357658789768814416622492847430639474124377767893424865485276302219601246094119453082952085005768838150682342462881473913110540827237163350510684586298239947245938479716304835356329624224137216")); |
| 220 |
} |
| 221 |
|
| 222 |
// These strings are look like proper number, but we don't accept them. |
| 223 |
TEST_F(DecimalTest, FromStringLikeNumber) |
| 224 |
{ |
| 225 |
EXPECT_EQ(Decimal::nan(), fromString(" 123 ")); |
| 226 |
EXPECT_EQ(Decimal::nan(), fromString("1,234")); |
| 227 |
EXPECT_EQ(Decimal::nan(), fromString("INF")); |
| 228 |
} |
| 229 |
|
| 230 |
TEST_F(DecimalTest, fromStringTruncated) |
| 231 |
{ |
| 232 |
EXPECT_EQ(Decimal::nan(), fromString("x")); |
| 233 |
EXPECT_EQ(Decimal::nan(), fromString("0.")); |
| 234 |
EXPECT_EQ(Decimal::nan(), fromString("1x")); |
| 235 |
|
| 236 |
EXPECT_EQ(Decimal::nan(), fromString("1Ex")); |
| 237 |
EXPECT_EQ(Decimal::nan(), fromString("1E2x")); |
| 238 |
EXPECT_EQ(Decimal::nan(), fromString("1E+x")); |
| 239 |
} |
| 240 |
|
| 241 |
TEST_F(DecimalTest, Predicates) |
| 242 |
{ |
| 243 |
EXPECT_TRUE(Decimal::zero(Positive).isFinite()); |
| 244 |
EXPECT_TRUE(Decimal::zero(Positive).isPositive()); |
| 245 |
EXPECT_FALSE(Decimal::zero(Positive).isNegative()); |
| 246 |
EXPECT_FALSE(Decimal::zero(Positive).isSpecial()); |
| 247 |
EXPECT_TRUE(Decimal::zero(Positive).isZero()); |
| 248 |
|
| 249 |
EXPECT_TRUE(Decimal::zero(Negative).isFinite()); |
| 250 |
EXPECT_FALSE(Decimal::zero(Negative).isPositive()); |
| 251 |
EXPECT_TRUE(Decimal::zero(Negative).isNegative()); |
| 252 |
EXPECT_FALSE(Decimal::zero(Negative).isSpecial()); |
| 253 |
EXPECT_TRUE(Decimal::zero(Negative).isZero()); |
| 254 |
|
| 255 |
EXPECT_TRUE(Decimal(123).isFinite()); |
| 256 |
EXPECT_TRUE(Decimal(123).isPositive()); |
| 257 |
EXPECT_FALSE(Decimal(123).isNegative()); |
| 258 |
EXPECT_FALSE(Decimal(123).isSpecial()); |
| 259 |
EXPECT_FALSE(Decimal(123).isZero()); |
| 260 |
|
| 261 |
EXPECT_TRUE(Decimal(-123).isFinite()); |
| 262 |
EXPECT_FALSE(Decimal(-123).isPositive()); |
| 263 |
EXPECT_TRUE(Decimal(-123).isNegative()); |
| 264 |
EXPECT_FALSE(Decimal(-123).isSpecial()); |
| 265 |
EXPECT_FALSE(Decimal(-123).isZero()); |
| 266 |
} |
| 267 |
|
| 268 |
TEST_F(DecimalTest, PredicatesSpecialValues) |
| 269 |
{ |
| 270 |
EXPECT_FALSE(Decimal::infinity(Positive).isFinite()); |
| 271 |
EXPECT_TRUE(Decimal::infinity(Positive).isPositive()); |
| 272 |
EXPECT_FALSE(Decimal::infinity(Positive).isNegative()); |
| 273 |
EXPECT_TRUE(Decimal::infinity(Positive).isSpecial()); |
| 274 |
EXPECT_FALSE(Decimal::infinity(Positive).isZero()); |
| 275 |
|
| 276 |
EXPECT_FALSE(Decimal::infinity(Negative).isFinite()); |
| 277 |
EXPECT_FALSE(Decimal::infinity(Negative).isPositive()); |
| 278 |
EXPECT_TRUE(Decimal::infinity(Negative).isNegative()); |
| 279 |
EXPECT_TRUE(Decimal::infinity(Negative).isSpecial()); |
| 280 |
EXPECT_FALSE(Decimal::infinity(Negative).isZero()); |
| 281 |
|
| 282 |
EXPECT_FALSE(Decimal::nan().isFinite()); |
| 283 |
EXPECT_TRUE(Decimal::nan().isSpecial()); |
| 284 |
EXPECT_FALSE(Decimal::nan().isZero()); |
| 285 |
} |
| 286 |
|
| 287 |
TEST_F(DecimalTest, OpAdd) |
| 288 |
{ |
| 289 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(0) + Decimal(0)); |
| 290 |
EXPECT_EQ(Decimal(1), Decimal(2) + Decimal(-1)); |
| 291 |
EXPECT_EQ(Decimal(1), Decimal(-1) + Decimal(2)); |
| 292 |
EXPECT_EQ(encode(100, 0, Positive), Decimal(99) + Decimal(1)); |
| 293 |
EXPECT_EQ(encode(100, 0, Negative), Decimal(-50) + Decimal(-50)); |
| 294 |
EXPECT_EQ(encode(1000000000000000, 35, Positive), encode(1, 50, Positive) + Decimal(1)); |
| 295 |
EXPECT_EQ(encode(1000000000000000, 35, Positive), Decimal(1) + encode(1, 50, Positive)); |
| 296 |
EXPECT_EQ(encode(10000000001, 0, Positive), encode(1, 10, Positive) + Decimal(1)); |
| 297 |
EXPECT_EQ(encode(10000000001, 0, Positive), Decimal(1) + encode(1, 10, Positive)); |
| 298 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, -1022, Positive) + encode(1, 0, Positive)); |
| 299 |
EXPECT_EQ(encode(2, -1022, Positive), encode(1, -1022, Positive) + encode(1, -1022, Positive)); |
| 300 |
} |
| 301 |
|
| 302 |
TEST_F(DecimalTest, OpAddBigE) |
| 303 |
{ |
| 304 |
EXPECT_EQ(encode(1, 1022, Positive), encode(1, 1022, Positive) + encode(1, 0, Positive)); |
| 305 |
EXPECT_EQ(encode(2, 1022, Positive), encode(1, 1022, Positive) + encode(1, 1022, Positive)); |
| 306 |
EXPECT_EQ(Decimal::infinity(Positive), encode(uint64_t(-1), 1022, Positive) + encode(1, 0, Positive)); |
| 307 |
} |
| 308 |
|
| 309 |
TEST_F(DecimalTest, OpAddSmallE) |
| 310 |
{ |
| 311 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, -1022, Positive) + encode(1, 0, Positive)); |
| 312 |
EXPECT_EQ(encode(2, -1022, Positive), encode(1, -1022, Positive) + encode(1, -1022, Positive)); |
| 313 |
} |
| 314 |
|
| 315 |
TEST_F(DecimalTest, OpAddSpecialValues) |
| 316 |
{ |
| 317 |
const Decimal Infinity(Decimal::infinity(Positive)); |
| 318 |
const Decimal MinusInfinity(Decimal::infinity(Negative)); |
| 319 |
const Decimal NaN(Decimal::nan()); |
| 320 |
const Decimal Ten(10); |
| 321 |
|
| 322 |
EXPECT_EQ(Infinity, Infinity + Infinity); |
| 323 |
EXPECT_EQ(NaN, Infinity + MinusInfinity); |
| 324 |
EXPECT_EQ(NaN, MinusInfinity + Infinity); |
| 325 |
EXPECT_EQ(MinusInfinity, MinusInfinity + MinusInfinity); |
| 326 |
|
| 327 |
EXPECT_EQ(Infinity, Infinity + Ten); |
| 328 |
EXPECT_EQ(Infinity, Ten + Infinity); |
| 329 |
EXPECT_EQ(MinusInfinity, MinusInfinity + Ten); |
| 330 |
EXPECT_EQ(MinusInfinity, Ten + MinusInfinity); |
| 331 |
|
| 332 |
EXPECT_EQ(NaN, NaN + NaN); |
| 333 |
EXPECT_EQ(NaN, NaN + Ten); |
| 334 |
EXPECT_EQ(NaN, Ten + NaN); |
| 335 |
} |
| 336 |
|
| 337 |
TEST_F(DecimalTest, OpCompare) |
| 338 |
{ |
| 339 |
EXPECT_TRUE(Decimal(0) == Decimal(0)); |
| 340 |
EXPECT_TRUE(Decimal(0) != Decimal(1)); |
| 341 |
EXPECT_TRUE(Decimal(0) < Decimal(1)); |
| 342 |
EXPECT_TRUE(Decimal(0) <= Decimal(0)); |
| 343 |
EXPECT_TRUE(Decimal(0) > Decimal(-1)); |
| 344 |
EXPECT_TRUE(Decimal(0) >= Decimal(0)); |
| 345 |
|
| 346 |
EXPECT_FALSE(Decimal(1) == Decimal(2)); |
| 347 |
EXPECT_FALSE(Decimal(1) != Decimal(1)); |
| 348 |
EXPECT_FALSE(Decimal(1) < Decimal(0)); |
| 349 |
EXPECT_FALSE(Decimal(1) <= Decimal(0)); |
| 350 |
EXPECT_FALSE(Decimal(1) > Decimal(2)); |
| 351 |
EXPECT_FALSE(Decimal(1) >= Decimal(2)); |
| 352 |
} |
| 353 |
|
| 354 |
TEST_F(DecimalTest, OpCompareSpecialValues) |
| 355 |
{ |
| 356 |
EXPECT_TRUE(Decimal(1) < Decimal::infinity(Positive)); |
| 357 |
EXPECT_TRUE(Decimal(1) > Decimal::infinity(Negative)); |
| 358 |
} |
| 359 |
|
| 360 |
TEST_F(DecimalTest, OpDiv) |
| 361 |
{ |
| 362 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(0) / Decimal(1)); |
| 363 |
EXPECT_EQ(encode(2, 0, Negative), Decimal(2) / Decimal(-1)); |
| 364 |
EXPECT_EQ(encode(5, -1, Negative), Decimal(-1) / Decimal(2)); |
| 365 |
EXPECT_EQ(encode(99, 0, Positive), Decimal(99) / Decimal(1)); |
| 366 |
EXPECT_EQ(Decimal(1), Decimal(-50) / Decimal(-50)); |
| 367 |
EXPECT_EQ(encode(3333333333333333, -16, Positive), Decimal(1) / Decimal(3)); |
| 368 |
EXPECT_EQ(encode(12345678901234, -1, Positive), encode(12345678901234, 0, Positive) / Decimal(10)); |
| 369 |
} |
| 370 |
|
| 371 |
TEST_F(DecimalTest, OpDivBigE) |
| 372 |
{ |
| 373 |
EXPECT_EQ(encode(1, 1022, Positive), encode(1, 1022, Positive) / encode(1, 0, Positive)); |
| 374 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, 1022, Positive) / encode(1, 1022, Positive)); |
| 375 |
} |
| 376 |
|
| 377 |
TEST_F(DecimalTest, OpDivSmallE) |
| 378 |
{ |
| 379 |
EXPECT_EQ(encode(1, -1022, Positive), encode(1, -1022, Positive) / encode(1, 0, Positive)); |
| 380 |
EXPECT_EQ(encode(1, 0, Positive), encode(1, -1022, Positive) / encode(1, -1022, Positive)); |
| 381 |
} |
| 382 |
|
| 383 |
TEST_F(DecimalTest, OpDivSpecialValues) |
| 384 |
{ |
| 385 |
const Decimal Infinity(Decimal::infinity(Positive)); |
| 386 |
const Decimal MinusInfinity(Decimal::infinity(Negative)); |
| 387 |
const Decimal NaN(Decimal::nan()); |
| 388 |
const Decimal Zero(Decimal::zero(Positive)); |
| 389 |
const Decimal MinusZero(Decimal::zero(Negative)); |
| 390 |
const Decimal Ten(10); |
| 391 |
const Decimal MinusTen(-10); |
| 392 |
|
| 393 |
EXPECT_EQ(NaN, Zero / Zero); |
| 394 |
EXPECT_EQ(NaN, Zero / MinusZero); |
| 395 |
EXPECT_EQ(NaN, MinusZero / Zero); |
| 396 |
EXPECT_EQ(NaN, MinusZero / MinusZero); |
| 397 |
|
| 398 |
EXPECT_EQ(Infinity, Ten / Zero); |
| 399 |
EXPECT_EQ(MinusInfinity, Ten / MinusZero); |
| 400 |
EXPECT_EQ(MinusInfinity, MinusTen / Zero); |
| 401 |
EXPECT_EQ(Infinity, MinusTen / MinusZero); |
| 402 |
|
| 403 |
EXPECT_EQ(Infinity, Infinity / Zero); |
| 404 |
EXPECT_EQ(MinusInfinity, Infinity / MinusZero); |
| 405 |
EXPECT_EQ(MinusInfinity, MinusInfinity / Zero); |
| 406 |
EXPECT_EQ(Infinity, MinusInfinity / MinusZero); |
| 407 |
|
| 408 |
EXPECT_EQ(NaN, Infinity / Infinity); |
| 409 |
EXPECT_EQ(NaN, Infinity / MinusInfinity); |
| 410 |
EXPECT_EQ(NaN, MinusInfinity / Infinity); |
| 411 |
EXPECT_EQ(NaN, MinusInfinity / MinusInfinity); |
| 412 |
|
| 413 |
EXPECT_EQ(Zero, Ten / Infinity); |
| 414 |
EXPECT_EQ(MinusZero, Ten / MinusInfinity); |
| 415 |
EXPECT_EQ(MinusZero, MinusTen / Infinity); |
| 416 |
EXPECT_EQ(Zero, MinusTen / MinusInfinity); |
| 417 |
|
| 418 |
EXPECT_EQ(NaN, NaN / NaN); |
| 419 |
EXPECT_EQ(NaN, NaN / Ten); |
| 420 |
EXPECT_EQ(NaN, Ten / NaN); |
| 421 |
} |
| 422 |
|
| 423 |
TEST_F(DecimalTest, OpMul) |
| 424 |
{ |
| 425 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(0) * Decimal(0)); |
| 426 |
EXPECT_EQ(encode(2, 0, Negative), Decimal(2) * Decimal(-1)); |
| 427 |
EXPECT_EQ(encode(2, 0, Negative), Decimal(-1) * Decimal(2)); |
| 428 |
EXPECT_EQ(encode(99, 0, Positive), Decimal(99) * Decimal(1)); |
| 429 |
EXPECT_EQ(encode(2500, 0, Positive), Decimal(-50) * Decimal(-50)); |
| 430 |
} |
| 431 |
|
| 432 |
TEST_F(DecimalTest, OpMulBigE) |
| 433 |
{ |
| 434 |
EXPECT_EQ(encode(1, 1022, Positive), encode(1, 1022, Positive) * encode(1, 0, Positive)); |
| 435 |
EXPECT_EQ(Decimal::infinity(Positive), encode(1, 1022, Positive) * encode(1, 1022, Positive)); |
| 436 |
} |
| 437 |
|
| 438 |
TEST_F(DecimalTest, OpMulSmallE) |
| 439 |
{ |
| 440 |
EXPECT_EQ(encode(1, -1022, Positive), encode(1, -1022, Positive) * encode(1, 0, Positive)); |
| 441 |
EXPECT_EQ(encode(0, 0, Positive), encode(1, -1022, Positive) * encode(1, -1022, Positive)); |
| 442 |
} |
| 443 |
|
| 444 |
TEST_F(DecimalTest, OpMulSpecialValues) |
| 445 |
{ |
| 446 |
const Decimal Infinity(Decimal::infinity(Positive)); |
| 447 |
const Decimal MinusInfinity(Decimal::infinity(Negative)); |
| 448 |
const Decimal NaN(Decimal::nan()); |
| 449 |
const Decimal Ten(10); |
| 450 |
const Decimal MinusTen(-10); |
| 451 |
const Decimal Zero(Decimal::zero(Positive)); |
| 452 |
const Decimal MinusZero(Decimal::zero(Negative)); |
| 453 |
|
| 454 |
EXPECT_EQ(Infinity, Infinity * Infinity); |
| 455 |
EXPECT_EQ(MinusInfinity, Infinity * MinusInfinity); |
| 456 |
EXPECT_EQ(MinusInfinity, MinusInfinity * Infinity); |
| 457 |
EXPECT_EQ(Infinity, MinusInfinity * MinusInfinity); |
| 458 |
|
| 459 |
EXPECT_EQ(NaN, Infinity * Zero); |
| 460 |
EXPECT_EQ(NaN, Zero * MinusInfinity); |
| 461 |
EXPECT_EQ(NaN, MinusInfinity * Zero); |
| 462 |
EXPECT_EQ(NaN, MinusInfinity * Zero); |
| 463 |
|
| 464 |
EXPECT_EQ(NaN, Infinity * MinusZero); |
| 465 |
EXPECT_EQ(NaN, MinusZero * MinusInfinity); |
| 466 |
EXPECT_EQ(NaN, MinusInfinity * MinusZero); |
| 467 |
EXPECT_EQ(NaN, MinusInfinity * MinusZero); |
| 468 |
|
| 469 |
EXPECT_EQ(Infinity, Infinity * Ten); |
| 470 |
EXPECT_EQ(Infinity, Ten * Infinity); |
| 471 |
EXPECT_EQ(MinusInfinity, MinusInfinity * Ten); |
| 472 |
EXPECT_EQ(MinusInfinity, Ten * MinusInfinity); |
| 473 |
|
| 474 |
EXPECT_EQ(MinusInfinity, Infinity * MinusTen); |
| 475 |
EXPECT_EQ(MinusInfinity, MinusTen * Infinity); |
| 476 |
EXPECT_EQ(Infinity, MinusInfinity * MinusTen); |
| 477 |
EXPECT_EQ(Infinity, MinusTen * MinusInfinity); |
| 478 |
|
| 479 |
EXPECT_EQ(NaN, NaN * NaN); |
| 480 |
EXPECT_EQ(NaN, NaN * Ten); |
| 481 |
EXPECT_EQ(NaN, Ten * NaN); |
| 482 |
} |
| 483 |
|
| 484 |
TEST_F(DecimalTest, OpSub) |
| 485 |
{ |
| 486 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(0) - Decimal(0)); |
| 487 |
EXPECT_EQ(encode(3, 0, Positive), Decimal(2) - Decimal(-1)); |
| 488 |
EXPECT_EQ(encode(3, 0, Negative), Decimal(-1) - Decimal(2)); |
| 489 |
EXPECT_EQ(encode(98, 0, Positive), Decimal(99) - Decimal(1)); |
| 490 |
EXPECT_EQ(encode(0, 0, Positive), Decimal(-50) - Decimal(-50)); |
| 491 |
EXPECT_EQ(encode(1000000000000000, 35, Positive), encode(1, 50, Positive) - Decimal(1)); |
| 492 |
EXPECT_EQ(encode(1000000000000000, 35, Negative), Decimal(1) - encode(1, 50, Positive)); |
| 493 |
} |
| 494 |
|
| 495 |
TEST_F(DecimalTest, OpSubBigE) |
| 496 |
{ |
| 497 |
EXPECT_EQ(encode(1, 1022, Positive), encode(1, 1022, Positive) - encode(1, 0, Positive)); |
| 498 |
EXPECT_EQ(encode(0, 0, Positive), encode(1, 1022, Positive) - encode(1, 1022, Positive)); |
| 499 |
} |
| 500 |
|
| 501 |
TEST_F(DecimalTest, OpSubSmallE) |
| 502 |
{ |
| 503 |
EXPECT_EQ(encode(UINT64_C(10000000000000000), -16, Negative), encode(1, -1022, Positive) - encode(1, 0, Positive)); |
| 504 |
EXPECT_EQ(encode(0, 0, Positive), encode(1, -1022, Positive) - encode(1, -1022, Positive)); |
| 505 |
} |
| 506 |
|
| 507 |
TEST_F(DecimalTest, OpSubSpecialValues) |
| 508 |
{ |
| 509 |
const Decimal Infinity(Decimal::infinity(Positive)); |
| 510 |
const Decimal MinusInfinity(Decimal::infinity(Negative)); |
| 511 |
const Decimal NaN(Decimal::nan()); |
| 512 |
const Decimal Ten(10); |
| 513 |
|
| 514 |
EXPECT_EQ(NaN, Infinity - Infinity); |
| 515 |
EXPECT_EQ(Infinity, Infinity - MinusInfinity); |
| 516 |
EXPECT_EQ(MinusInfinity, MinusInfinity - Infinity); |
| 517 |
EXPECT_EQ(NaN, MinusInfinity - MinusInfinity); |
| 518 |
|
| 519 |
EXPECT_EQ(Infinity, Infinity - Ten); |
| 520 |
EXPECT_EQ(MinusInfinity, Ten - Infinity); |
| 521 |
EXPECT_EQ(MinusInfinity, MinusInfinity - Ten); |
| 522 |
EXPECT_EQ(Infinity, Ten - MinusInfinity); |
| 523 |
|
| 524 |
EXPECT_EQ(NaN, NaN - NaN); |
| 525 |
EXPECT_EQ(NaN, NaN - Ten); |
| 526 |
EXPECT_EQ(NaN, Ten - NaN); |
| 527 |
} |
| 528 |
|
| 529 |
TEST_F(DecimalTest, Properties) |
| 530 |
{ |
| 531 |
EXPECT_TRUE(Decimal(0).isFinite()); |
| 532 |
EXPECT_FALSE(Decimal(0).isSpecial()); |
| 533 |
} |
| 534 |
|
| 535 |
TEST_F(DecimalTest, PropertiesSpecial) |
| 536 |
{ |
| 537 |
EXPECT_TRUE(Decimal::infinity(Positive).isSpecial()); |
| 538 |
EXPECT_FALSE(Decimal::infinity(Positive).isFinite()); |
| 539 |
|
| 540 |
EXPECT_TRUE(Decimal::infinity(Negative).isSpecial()); |
| 541 |
EXPECT_FALSE(Decimal::infinity(Negative).isFinite()); |
| 542 |
|
| 543 |
EXPECT_TRUE(Decimal::nan().isSpecial()); |
| 544 |
EXPECT_FALSE(Decimal::nan().isFinite()); |
| 545 |
} |
| 546 |
|
| 547 |
// LayoutTests/fast/forms/number/number-stepup-stepdown-from-renderer |
| 548 |
TEST_F(DecimalTest, RealWorldExampleNumberStepUpStepDownFromRenderer) |
| 549 |
{ |
| 550 |
EXPECT_EQ(String("10"), stepDown("0", "100", "10", "19", 1)); |
| 551 |
EXPECT_EQ(String("90"), stepUp("0", "99", "10", "89", 1)); |
| 552 |
EXPECT_EQ(String("1"), stepUp("0", "1", "0.33333333333333333", "0", 3)); // step=1/3 |
| 553 |
EXPECT_EQ(String("0.01"), stepUp("0", "0.01", "0.0033333333333333333", "0", 3)); // step=1/300 |
| 554 |
EXPECT_EQ(String("1"), stepUp("0", "1", "0.003921568627450980", "0", 255)); // step=1/255 |
| 555 |
EXPECT_EQ(String("1"), stepUp("0", "1", "0.1", "0", 10)); |
| 556 |
} |
| 557 |
|
| 558 |
TEST_F(DecimalTest, RealWorldExampleNumberStepUpStepDownFromRendererRounding) |
| 559 |
{ |
| 560 |
EXPECT_EQ(String("5.015"), stepUp("0", "100", "0.005", "5.005", 2)); |
| 561 |
EXPECT_EQ(String("5.06"), stepUp("0", "100", "0.005", "5.005", 11)); |
| 562 |
EXPECT_EQ(String("5.065"), stepUp("0", "100", "0.005", "5.005", 12)); |
| 563 |
|
| 564 |
EXPECT_EQ(String("5.015"), stepUp("4", "9", "0.005", "5.005", 2)); |
| 565 |
EXPECT_EQ(String("5.06"), stepUp("4", "9", "0.005", "5.005", 11)); |
| 566 |
EXPECT_EQ(String("5.065"), stepUp("4", "9", "0.005", "5.005", 12)); |
| 567 |
} |
| 568 |
|
| 569 |
TEST_F(DecimalTest, RealWorldExampleRangeStepUpStepDown) |
| 570 |
{ |
| 571 |
EXPECT_EQ(String("1e+38"), stepUp("0", "1E38", "1", "1E38", 9)); |
| 572 |
EXPECT_EQ(String("1e+38"), stepDown("0", "1E38", "1", "1E38", 9)); |
| 573 |
} |
| 574 |
|
| 575 |
TEST_F(DecimalTest, Remainder) |
| 576 |
{ |
| 577 |
EXPECT_EQ(encode(9, -1, Negative), encode(21, -1, Positive).remainder(3)); |
| 578 |
EXPECT_EQ(Decimal(1), Decimal(10).remainder(3)); |
| 579 |
EXPECT_EQ(encode(1, 0, Negative), Decimal(-10).remainder(3)); |
| 580 |
EXPECT_EQ(encode(2, -1, Positive), encode(102, -1, Positive).remainder(1)); |
| 581 |
EXPECT_EQ(encode(1, -1, Positive), Decimal(10).remainder(encode(3, -1, Positive))); |
| 582 |
EXPECT_EQ(encode(3, -1, Negative), encode(36, -1, Positive).remainder(encode(13, -1, Positive))); |
| 583 |
} |
| 584 |
|
| 585 |
TEST_F(DecimalTest, RemainderSpecialValues) |
| 586 |
{ |
| 587 |
EXPECT_EQ(Decimal::infinity(Positive), Decimal::infinity(Positive).remainder(1)); |
| 588 |
EXPECT_EQ(Decimal::nan(), Decimal::nan().remainder(1)); |
| 589 |
} |
| 590 |
|
| 591 |
TEST_F(DecimalTest, Round) |
| 592 |
{ |
| 593 |
EXPECT_EQ(Decimal(1), (Decimal(9) / Decimal(10)).round()); |
| 594 |
EXPECT_EQ(Decimal(25), (Decimal(5) / fromString("0.200")).round()); |
| 595 |
EXPECT_EQ(Decimal(3), (Decimal(5) / Decimal(2)).round()); |
| 596 |
EXPECT_EQ(Decimal(1), (Decimal(2) / Decimal(3)).round()); |
| 597 |
EXPECT_EQ(Decimal(3), (Decimal(10) / Decimal(3)).round()); |
| 598 |
EXPECT_EQ(Decimal(3), (Decimal(1) / fromString("0.3")).round()); |
| 599 |
EXPECT_EQ(Decimal(10), (Decimal(1) / fromString("0.1")).round()); |
| 600 |
EXPECT_EQ(Decimal(5), (Decimal(1) / fromString("0.2")).round()); |
| 601 |
EXPECT_EQ(Decimal(10), (fromString("10.2") / 1).round()); |
| 602 |
} |
| 603 |
|
| 604 |
TEST_F(DecimalTest, RoundSepcialValues) |
| 605 |
{ |
| 606 |
EXPECT_EQ(Decimal::infinity(Positive), Decimal::infinity(Positive).round()); |
| 607 |
EXPECT_EQ(Decimal::nan(), Decimal::nan().round()); |
| 608 |
} |
| 609 |
|
| 610 |
TEST_F(DecimalTest, ToStringSpecial) |
| 611 |
{ |
| 612 |
EXPECT_EQ(String("Infinity"), Decimal::infinity(Positive).toString()); |
| 613 |
EXPECT_EQ(String("-Infinity"), Decimal::infinity(Negative).toString()); |
| 614 |
EXPECT_EQ(String("NaN"), Decimal::nan().toString()); |
| 615 |
} |