Index: tests/compiler/dart2js_extra/round_constant_folding_test.dart |
diff --git a/tests/compiler/dart2js_extra/round_constant_folding_test.dart b/tests/compiler/dart2js_extra/round_constant_folding_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..cd2ad5a22127b50378f17ff7a60bd8acdf3cbe27 |
--- /dev/null |
+++ b/tests/compiler/dart2js_extra/round_constant_folding_test.dart |
@@ -0,0 +1,167 @@ |
+// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file |
+// for details. All rights reserved. Use of this source code is governed by a |
+// BSD-style license that can be found in the LICENSE file. |
+ |
+import 'package:expect/expect.dart'; |
+ |
+const double PD1 = 0.0; |
+const double PD2 = double.MIN_POSITIVE; |
+const double PD3 = 2.0 * double.MIN_POSITIVE; |
+const double PD4 = 1.18e-38; |
+const double PD5 = 1.18e-38 * 2; |
+const double PD6 = 0.49999999999999994; |
+const double PD7 = 0.5; |
+const double PD8 = 0.9999999999999999; |
+const double PD9 = 1.0; |
+const double PD10 = 1.000000000000001; |
+const double PD11 = double.MAX_FINITE; |
+ |
+const double ND1 = -PD1; |
+const double ND2 = -PD2; |
+const double ND3 = -PD3; |
+const double ND4 = -PD4; |
+const double ND5 = -PD5; |
+const double ND6 = -PD6; |
+const double ND7 = -PD7; |
+const double ND8 = -PD8; |
+const double ND9 = -PD9; |
+const double ND10 = -PD10; |
+const double ND11 = -PD11; |
+ |
+const X1 = double.INFINITY; |
+const X2 = double.NEGATIVE_INFINITY; |
+const X3 = double.NAN; |
+ |
+// The following numbers are on the border of 52 bits. |
+// For example: 4503599627370499 + 0.5 => 4503599627370500. |
+const PQ1 = 4503599627370496.0; |
+const PQ2 = 4503599627370497.0; |
+const PQ3 = 4503599627370498.0; |
+const PQ4 = 4503599627370499.0; |
+const PQ5 = 9007199254740991.0; |
+const PQ6 = 9007199254740992.0; |
+ |
+const NQ1 = -PQ1; |
+const NQ2 = -PQ2; |
+const NQ3 = -PQ3; |
+const NQ4 = -PQ4; |
+const NQ5 = -PQ5; |
+const NQ6 = -PQ6; |
+ |
+const int PI1 = 0; |
+const int PI2 = 1; |
+const int PI3 = 0x1234; |
+const int PI4 = 0x12345678; |
+const int PI5 = 0x123456789AB; |
+const int PI6 = 0x123456789ABCDEF; |
+const int PI7 = 0x123456789ABCDEF0123456789ABCDEF0123456789ABCDEF; |
+ |
+const int NI1 = 0-PI1; |
+const int NI2 = -PI2; |
+const int NI3 = -PI3; |
+const int NI4 = -PI4; |
+const int NI5 = -PI5; |
+const int NI6 = -PI6; |
+const int NI7 = -PI7; |
+ |
+ |
+/// Ensures that the behaviour of `action()` is the same as `value.round()`. |
+@NoInline() // To ensure 'value.round()' has a non-constant receiver. |
+check(value, action) { |
+ var result1, result2; |
+ try { |
+ result1 = value.round(); |
+ } catch (e) { |
+ result1 = e; |
+ } |
+ |
+ try { |
+ result2 = action(); |
+ } catch (e) { |
+ result2 = e; |
+ } |
+ |
+ Expect.equals(result1.runtimeType, result2.runtimeType); |
+ if (result1 is num) { |
+ Expect.equals(result1, result2); |
+ Expect.equals(result1 is int, result2 is int); |
+ } else { |
+ Expect.equals(result1.runtimeType, result2.runtimeType); |
+ Expect.isTrue(result1 is Error); |
+ } |
+} |
+ |
+@NoInline() |
+void unusedCall(num x) { |
+ x.round(); // This call should not be removed since it might throw. |
+} |
+ |
+main() { |
+ check(PD1, () => PD1.round()); |
+ check(PD2, () => PD2.round()); |
+ check(PD3, () => PD3.round()); |
+ check(PD4, () => PD4.round()); |
+ check(PD5, () => PD5.round()); |
+ check(PD6, () => PD6.round()); |
+ check(PD7, () => PD7.round()); |
+ check(PD8, () => PD8.round()); |
+ check(PD9, () => PD9.round()); |
+ check(PD10, () => PD10.round()); |
+ check(PD11, () => PD11.round()); |
+ |
+ check(ND1, () => ND1.round()); |
+ check(ND2, () => ND2.round()); |
+ check(ND3, () => ND3.round()); |
+ check(ND4, () => ND4.round()); |
+ check(ND5, () => ND5.round()); |
+ check(ND6, () => ND6.round()); |
+ check(ND7, () => ND7.round()); |
+ check(ND8, () => ND8.round()); |
+ check(ND9, () => ND9.round()); |
+ check(ND10, () => ND10.round()); |
+ check(ND11, () => ND11.round()); |
+ |
+ check(X1, () => X1.round()); |
+ check(X2, () => X2.round()); |
+ check(X3, () => X3.round()); |
+ |
+ check(PQ1, () => PQ1.round()); |
+ check(PQ2, () => PQ2.round()); |
+ check(PQ3, () => PQ3.round()); |
+ check(PQ4, () => PQ4.round()); |
+ check(PQ5, () => PQ5.round()); |
+ check(PQ6, () => PQ6.round()); |
+ |
+ check(NQ1, () => NQ1.round()); |
+ check(NQ2, () => NQ2.round()); |
+ check(NQ3, () => NQ3.round()); |
+ check(NQ4, () => NQ4.round()); |
+ check(NQ5, () => NQ5.round()); |
+ check(NQ6, () => NQ6.round()); |
+ |
+ check(PI1, () => PI1.round()); |
+ check(PI2, () => PI2.round()); |
+ check(PI3, () => PI3.round()); |
+ check(PI4, () => PI4.round()); |
+ check(PI5, () => PI5.round()); |
+ check(PI6, () => PI6.round()); |
+ check(PI7, () => PI7.round()); |
+ |
+ check(NI1, () => NI1.round()); |
+ check(NI2, () => NI2.round()); |
+ check(NI3, () => NI3.round()); |
+ check(NI4, () => NI4.round()); |
+ check(NI5, () => NI5.round()); |
+ check(NI6, () => NI6.round()); |
+ check(NI7, () => NI7.round()); |
+ |
+ // Check that the operation is not removed if it can throw, even if the result |
+ // is unused. |
+ Expect.throws(() { X1.round(); }); |
+ Expect.throws(() { X2.round(); }); |
+ Expect.throws(() { X3.round(); }); |
+ unusedCall(0); |
+ Expect.throws(() { unusedCall(X1); }); |
+ Expect.throws(() { unusedCall(X2); }); |
+ Expect.throws(() { unusedCall(X3); }); |
+} |