Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(305)

Unified Diff: tests/language/src/BitOperationsTest.dart

Issue 9149005: split out vm-specific tests (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: keeping test closer to original Created 8 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/language/language.status ('k') | tests/language/src/BitOperationsVMTest.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/language/src/BitOperationsTest.dart
diff --git a/tests/language/src/BitOperationsTest.dart b/tests/language/src/BitOperationsTest.dart
index 2dd0a313fa7fc77d019ef4678b7bc296e176f449..173f80f960329b30cc4b554a2b133e80b446f4b5 100644
--- a/tests/language/src/BitOperationsTest.dart
+++ b/tests/language/src/BitOperationsTest.dart
@@ -1,7 +1,10 @@
// Copyright (c) 2011, 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.
-// Dart test for testing bitwise operations.
+// Dart test for testing bitwise operations. This test only includes small
+// enough numbers that even a dart implementation with the JS exemption is
+// expected to pass them. See BitOperationsVMTest for the tests that a
+// fully spec compliant implementation is expected to pass.
class BitOperationsTest {
static testMain() {
@@ -17,38 +20,29 @@ class BitOperationsTest {
Expect.equals(400, (100 << 2));
Expect.equals(-25, (-100 >> 2));
Expect.equals(-101, ~100);
- Expect.equals(0x10000000000000000, 1 << 64);
- Expect.equals(-0x10000000000000000, -1 << 64);
+ Expect.equals(0x10000000, 1 << 28);
Ivan Posva 2012/01/13 00:54:25 Isn't the range representable in bit operations in
+ Expect.equals(-0x10000000, -1 << 28);
Expect.equals(0x40000000, 0x04000000 << 4);
- Expect.equals(0x4000000000000000, 0x0400000000000000 << 4);
+ Expect.equals(0x4000000, 0x0400000 << 4);
Expect.equals(0, ~-1);
Expect.equals(-1, ~0);
- Expect.equals(0, 1 >> 160);
- Expect.equals(-1, -1 >> 160);
+ Expect.equals(0x10100F01, 0x10000001 | 0x10100F01);
+ Expect.equals(0x10100F11, 0x11 | 0x10100F01);
+ Expect.equals(0x10100F11, 0x10100F01 | 0x11);
- Expect.equals(0x100000000000000001,
- 0x100000000000000001 & 0x100000100F00000001);
- Expect.equals(0x1, 0x1 & 0x100000100F00000001);
- Expect.equals(0x1, 0x100000100F00000001 & 0x1);
+ Expect.equals(0x0F000F0,
+ 0x0F00F1 ^ 0xFF0001);
- Expect.equals(0x100000100F00000001,
- 0x100000000000000001 | 0x100000100F00000001);
- Expect.equals(0x100000100F00000011, 0x11 | 0x100000100F00000001);
- Expect.equals(0x100000100F00000011, 0x100000100F00000001 | 0x11);
+ Expect.equals(0x31, 0xF0F0001 ^ 0xF0F0030);
+ Expect.equals(0xF0F0031, 0xF0F0001 ^ 0x30);
+ Expect.equals(0xF0F0031, 0x30 ^ 0xF0F0001);
- Expect.equals(0x0F000F00000000000000,
- 0x0F00F00000000000001 ^ 0xFF00000000000000001);
- Expect.equals(0x31, 0xF00F00000000000001 ^ 0xF00F00000000000030);
- Expect.equals(0xF00F00000000000031, 0xF00F00000000000001 ^ 0x30);
- Expect.equals(0xF00F00000000000031, 0x30 ^ 0xF00F00000000000001);
+ Expect.equals(0xF0000F, 0xF0000F7 >> 4);
+ Expect.equals(15, 0xF000000 >> 24);
- Expect.equals(0xF0000000000000000F, 0xF0000000000000000F7 >> 4);
- Expect.equals(15, 0xF00000000 >> 32);
- Expect.equals(1030792151040, 16492674416655 >> 4);
-
- Expect.equals(0xF0000000000000000F0, 0xF0000000000000000F << 4);
- Expect.equals(0xF00000000, 15 << 32);
+ Expect.equals(0xF0000F0, 0xF0000F << 4);
+ Expect.equals(0xF000000, 15 << 24);
TestNegativeValueShifts();
TestPositiveValueShifts();
@@ -57,7 +51,7 @@ class BitOperationsTest {
static void TestNegativeValueShifts() {
for (int value = 0; value > -100; value--) {
- for (int i = 0; i < 300; i++) {
+ for (int i = 0; i < 24; i++) {
int b = (value << i) >> i;
Expect.equals(value, b);
}
@@ -66,7 +60,7 @@ class BitOperationsTest {
static void TestPositiveValueShifts() {
for (int value = 0; value < 100; value++) {
- for (int i = 0; i < 300; i++) {
+ for (int i = 0; i < 24; i++) {
int b = (value << i) >> i;
Expect.equals(value, b);
}
@@ -76,14 +70,14 @@ class BitOperationsTest {
static void TestNoMaskingOfShiftCount() {
// Shifts which would behave differently if shift count was masked into a
// range.
- Expect.equals(0, 0 >> 256);
- Expect.equals(0, 1 >> 256);
- Expect.equals(0, 2 >> 256);
- Expect.equals(0, ShiftRight(0, 256));
- Expect.equals(0, ShiftRight(1, 256));
- Expect.equals(0, ShiftRight(2, 256));
+ Expect.equals(0, 0 >> 30);
Ivan Posva 2012/01/13 00:54:25 Not sure about this. Does the JS exemption also re
kasperl 2012/01/16 08:37:32 This is an interesting question. We clearly need t
+ Expect.equals(0, 1 >> 30);
+ Expect.equals(0, 2 >> 30);
+ Expect.equals(0, ShiftRight(0, 30));
+ Expect.equals(0, ShiftRight(1, 30));
+ Expect.equals(0, ShiftRight(2, 30));
- for (int shift = 1; shift <= 256; shift++) {
+ for (int shift = 1; shift <= 30; shift++) {
Expect.equals(0, ShiftRight(1, shift));
Expect.equals(-1, ShiftRight(-1, shift));
Expect.equals(true, ShiftLeft(1, shift) > ShiftLeft(1, shift - 1));
« no previous file with comments | « tests/language/language.status ('k') | tests/language/src/BitOperationsVMTest.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698