Chromium Code Reviews| Index: tests/html/js_array_test.dart |
| diff --git a/tests/html/js_array_test.dart b/tests/html/js_array_test.dart |
| index 4ede8ed70fb50a20e1b2c8adb3413eebb02b6151..fcc437d8731e6debeba880ae84a430873a7868b8 100644 |
| --- a/tests/html/js_array_test.dart |
| +++ b/tests/html/js_array_test.dart |
| @@ -2,165 +2,176 @@ |
| // 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. |
| -library jsArrayTest; |
| +@Js("ArrayTest.Util") |
| +library js_array_test; |
| import 'dart:html'; |
| import 'dart:js'; |
| +import 'package:js/js.dart'; |
| import 'package:unittest/unittest.dart'; |
| import 'package:unittest/html_config.dart'; |
| +import 'json_helper.dart' as json_helper; |
| _injectJs() { |
| document.body.append(new ScriptElement() |
| ..type = 'text/javascript' |
| ..innerHtml = r""" |
| -function callJsMethod(jsObj, jsMethodName, args) { |
| - return jsObj[jsMethodName].apply(jsObj, args); |
| -} |
| +ArrayTest = {}; |
| +ArrayTest.Util = { |
| + callJsMethod: function(jsObj, jsMethodName, args) { |
| + return jsObj[jsMethodName].apply(jsObj, args); |
| + }, |
| + |
| + jsEnumerateIndices: function(obj) { |
| + var ret = []; |
| + for(var i in obj) { |
| + ret.push(i); |
| + } |
| + return ret; |
| + }, |
| -function jsEnumerateIndices(obj) { |
| - var ret = []; |
| - for(var i in obj) { |
| - ret.push(i); |
| - } |
| - return ret; |
| -} |
| + checkIsArray: function(obj) { |
| + return Array.isArray(obj); |
| + }, |
| -function setValue(obj, index, value) { |
| - return obj[index] = value; |
| -} |
| + concatValues: function(obj) { |
| + return obj.concat("a", "b", ["c", "d"], 42, {foo: 10}); |
| + }, |
| -function getValue(obj, index) { |
| - return obj[index]; |
| -} |
| + concatOntoArray: function(obj) { |
| + return [1,2,3].concat(obj, "foo"); |
| + }, |
| -function checkIsArray(obj) { |
| - return Array.isArray(obj); |
| -} |
| + repeatedConcatOntoArray: function(obj) { |
| + return [1,2,3].concat(obj, obj); |
| + }, |
| -function concatValues(obj) { |
| - return obj.concat("a", "b", ["c", "d"], 42, {foo: 10}); |
| -} |
| + everyGreaterThanZero: function(obj) { |
| + return obj.every(function(currentValue, index, array) { |
| + return currentValue > 0; |
| + }); |
| + }, |
| -function concatOntoArray(obj) { |
| - return [1,2,3].concat(obj, "foo"); |
| -} |
| + everyGreaterThanZeroCheckThisArg: function(obj) { |
| + var j = 0; |
| + return obj.every(function(currentValue, index, array) { |
| + if (j != index) { |
| + throw "Unxpected index"; |
| + } |
| + j++; |
| + if (array !== obj) { |
| + throw "Array argument doesn't match obj"; |
| + } |
| + return currentValue > 0; |
| + }); |
| + }, |
| -function repeatedConcatOntoArray(obj) { |
| - return [1,2,3].concat(obj, obj); |
| -} |
| + filterGreater42: function(obj) { |
| + return obj.filter(function(currentValue, index, array) { |
| + return currentValue > 42; |
| + }); |
| + }, |
| -function everyGreaterThanZero(obj) { |
| - return obj.every(function(currentValue, index, array) { |
| - return currentValue > 0; |
| - }); |
| -} |
| + forEachCollectResult: function(array) { |
| + var result = []; |
| + array.forEach(function(currentValue) { |
| + result.push(currentValue * 2); |
| + }); |
| + return result; |
| + }, |
| -function everyGreaterThanZeroCheckThisArg(obj) { |
| - var j = 0; |
| - return obj.every(function(currentValue, index, array) { |
| - if (j != index) { |
| - throw "Unxpected index"; |
| - } |
| - j++; |
| - if (array !== obj) { |
| - throw "Array argument doesn't match obj"; |
| - } |
| - return currentValue > 0; |
| - }); |
| -} |
| + someEqual42: function(array) { |
| + return array.some(function(currentValue) { |
| + return currentValue == 42; |
| + }); |
| + }, |
| -function filterGreater42(obj) { |
| - return obj.filter(function(currentValue, index, array) { |
| - return currentValue > 42; |
| - }); |
| -} |
| + sortNumbersBackwards: function(array) { |
| + return array.sort(function(a, b) { |
| + return b - a; |
| + }); |
| + }, |
| -function forEachCollectResult(array, callback) { |
| - var result = []; |
| - array.forEach(function(currentValue) { |
| - result.push(currentValue * 2); |
| - }); |
| - return result; |
| -} |
| + spliceDummyItems: function(array) { |
| + return array.splice(1, 2, "quick" ,"brown", "fox"); |
| + }, |
| -function someEqual42(array, callback) { |
| - return array.some(function(currentValue) { |
| - return currentValue == 42; |
| - }); |
| -} |
| + spliceTestStringArgs: function(array) { |
| + return array.splice("1.2", "2.01", "quick" ,"brown", "fox"); |
| + }, |
| -function sortNumbersBackwards(array) { |
| - return array.sort(function(a, b) { |
| - return b - a; |
| - }); |
| -} |
| + splicePastEnd: function(array) { |
| + return array.splice(1, 5332, "quick" ,"brown", "fox"); |
| + }, |
| -function spliceDummyItems(array) { |
| - return array.splice(1, 2, "quick" ,"brown", "fox"); |
| -} |
| + callJsToString: function(array) { |
| + return array.toString(); |
| + }, |
| -function spliceTestStringArgs(array) { |
| - return array.splice("1.2", "2.01", "quick" ,"brown", "fox"); |
| -} |
| + mapAddIndexToEachElement: function(array) { |
| + return array.map(function(currentValue, index) { |
| + return currentValue + index; |
| + }); |
| + }, |
| -function splicePastEnd(array) { |
| - return array.splice(1, 5332, "quick" ,"brown", "fox"); |
| -} |
| + reduceSumDoubledElements: function(array) { |
| + return array.reduce(function(previousValue, currentValue) { |
| + return previousValue + currentValue*2; |
| + }, |
| + 0); |
| + }, |
| -function callJsToString(array) { |
| - return array.toString(); |
| -} |
| + // TODO(jacobr): add a test that distinguishes reduce from reduceRight. |
| + reduceRightSumDoubledElements: function(array) { |
| + return array.reduceRight(function(previousValue, currentValue) { |
| + return previousValue + currentValue*2; |
| + }, |
| + 0); |
| + }, |
| -function mapAddIndexToEachElement(array) { |
| - return array.map(function(currentValue, index) { |
| - return currentValue + index; |
| - }); |
| -} |
| + identical: function(o1, o2) { |
| + return o1 === o2; |
| + }, |
| -function reduceSumDoubledElements(array) { |
| - return array.reduce(function(previousValue, currentValue) { |
| - return previousValue + currentValue*2; |
| - }, |
| - 0); |
| -} |
| + getOwnPropertyDescriptorJson: function(array, property) { |
| + return JSON.stringify(Object.getOwnPropertyDescriptor(array, property)); |
| + }, |
| -// TODO(jacobr): add a test that distinguishes reduce from reduceRight. |
| -function reduceRightSumDoubledElements(array) { |
| - return array.reduceRight(function(previousValue, currentValue) { |
| - return previousValue + currentValue*2; |
| - }, |
| - 0); |
| -} |
| + setLength: function(array, len) { |
| + return array.length = len; |
| + }, |
| -function identical(o1, o2) { |
| - return o1 === o2; |
| -} |
| + getValue: function(obj, index) { |
| + return obj[index]; |
| + }, |
| -function getOwnPropertyDescriptorJson(array, property) { |
| - return JSON.stringify(Object.getOwnPropertyDescriptor(array, property)); |
| -} |
| + setValue: function(obj, index, value) { |
| + return obj[index] = value; |
| + }, |
| -function setLength(array, len) { |
| - return array.length = len; |
| -} |
| + // Calling a method from Dart List on an arbitrary target object. |
| + callListMethodOnTarget: function(dartArray, target, methodName, args) { |
| + return dartArray[methodName].apply(target, args); |
| + }, |
| -function jsonStringify(o) { |
| - return JSON.stringify(o); |
| -} |
| + newArray: function() { return []; }, |
| -// Calling a method from Dart List on an arbitrary target object. |
| -function callListMethodOnTarget(dartArray, target, methodName, args) { |
| - return dartArray[methodName].apply(target, args); |
| -} |
| + newLiteral: function() { return {}; }, |
| +}; |
| """); |
| } |
| +@Js() |
| +class SimpleJsLiteralClass extends JavaScriptObject { |
|
alexandre.ardhuin
2015/10/01 08:51:05
I can't find where this class is used.
Jacob
2015/10/02 20:08:16
There is a JS literal with a getter foo
see Line
alexandre.ardhuin
2015/10/02 20:29:56
I saw this JS line but on the dart side there's on
|
| + external get foo; |
| +} |
| + |
| class Foo {} |
| -callJsMethod(List array, String methodName, List args) => |
| - context.callMethod("callJsMethod", [array, methodName, args]); |
| +@Js() |
| +external callJsMethod(List array, String methodName, List args); |
| callIndexOf(List array, value) => callJsMethod(array, "indexOf", [value]); |
| callLastIndexOf(List array, value) => |
| @@ -170,13 +181,80 @@ callPop(List array) => callJsMethod(array, "pop", []); |
| callPush(List array, element) => callJsMethod(array, "push", [element]); |
| callShift(List array) => callJsMethod(array, "shift", []); |
| callReverse(List array) => callJsMethod(array, "reverse", []); |
| -callSetLength(List array, length) => |
| - context.callMethod("setLength", [array, length]); |
| -callListMethodOnObject(JsObject object, String methodName, List args) => context |
| - .callMethod("callListMethodOnTarget", [[], object, methodName, args]); |
| +callListMethodOnObject(object, String methodName, List args) => |
| + callListMethodOnTarget([], object, methodName, args); |
| + |
| +@Js() |
| +external jsEnumerateIndices(obj); |
| +@Js() |
| +external bool checkIsArray(obj); |
| +@Js() |
| +external concatValues(obj); |
| + |
| +@Js() |
| +external concatOntoArray(obj); |
| + |
| +@Js() |
| +external repeatedConcatOntoArray(obj); |
| +@Js() |
| +external bool everyGreaterThanZero(obj); |
| +@Js() |
| +external bool everyGreaterThanZeroCheckThisArg(obj); |
| + |
| +@Js() |
| +external filterGreater42(obj); |
| + |
| +@Js() |
| +external forEachCollectResult(List array); |
| +@Js() |
| +external someEqual42(List array); |
| +@Js() |
| +external sortNumbersBackwards(List array); |
| + |
| +@Js() |
| +external List spliceDummyItems(List array); |
| + |
| +@Js() |
| +external List spliceTestStringArgs(List array); |
| + |
| +@Js() |
| +external List splicePastEnd(List array); |
| + |
| +@Js() |
| +external String callJsToString(List array); |
| -jsonStringify(JsObject object) => context.callMethod("jsonStringify", [object]); |
| +@Js() |
| +external mapAddIndexToEachElement(List array); |
| +@Js() |
| +external reduceSumDoubledElements(List array); |
| + |
| +// TODO(jacobr): add a test that distinguishes reduce from reduceRight. |
| +@Js() |
| +external reduceRightSumDoubledElements(List array); |
| +@Js() |
| +external identical(o1, o2); |
| + |
| +@Js() |
| +external getOwnPropertyDescriptorJson(List array, property); |
| + |
| +@Js("setLength") |
| +external callSetLength(List array, length); |
| + |
| +@Js() |
| +external getValue(obj, index); |
| + |
| +@Js() |
| +external setValue(obj, index, value); |
| + |
| +@Js() |
| +external callListMethodOnTarget(List target, object, String methodName, List args); |
| + |
| +@Js() |
| +external newArray(); |
| + |
| +@Js() |
| +external newLiteral(); |
| main() { |
| _injectJs(); |
| @@ -238,7 +316,7 @@ main() { |
| test('default', () { |
| expect(callJsMethod(list, "join", []), equals("3,42,foo")); |
| expect(callJsMethod(listWithDartClasses, "join", []), |
| - equals("3,Instance of 'Foo',42,foo,Instance of 'Object'")); |
| + equals("3,${new Foo()},42,foo,${new Object()}")); |
| }); |
| test('custom separator', () { |
| @@ -375,7 +453,8 @@ main() { |
| group("js snippet tests", () { |
| test("enumerate indices", () { |
| var list = ["a", "b", "c", "d"]; |
| - var indices = context.callMethod('jsEnumerateIndices', [list]); |
| + var indices = |
| + jsEnumerateIndices(list); |
| expect(indices.length, equals(4)); |
| for (int i = 0; i < 4; i++) { |
| expect(indices[i], equals('$i')); |
| @@ -384,51 +463,56 @@ main() { |
| test("set element", () { |
| var list = ["a", "b", "c", "d"]; |
| - context.callMethod('setValue', [list, 0, 42]); |
| + setValue(list, 0, 42); |
| expect(list[0], equals(42)); |
| - context.callMethod('setValue', [list, 1, 84]); |
| + setValue(list, 1, 84); |
| expect(list[1], equals(84)); |
| - context.callMethod( |
| - 'setValue', [list, 6, 100]); // Off the end of the list. |
| + setValue(list, 6, 100); // Off the end of the list. |
| expect(list.length, equals(7)); |
| expect(list[4], equals(null)); |
| expect(list[6], equals(100)); |
| // These tests have to be commented out because we don't persist |
| // JS proxies for Dart objects like we could/should. |
| - // context.callMethod('setValue', [list, -1, "foo"]); // Not a valid array index |
| - // expect(context.callMethod('getValue', [list, -1]), equals("foo")); |
| - // expect(context.callMethod('getValue', [list, "-1"]), equals("foo")); |
| + // setValue(list, -1, "foo"); // Not a valid array index |
| + // expect(getValue(list, -1), equals("foo")); |
| + // expect(getValue(list, "-1"), equals("foo")); |
| }); |
| test("get element", () { |
| var list = ["a", "b", "c", "d"]; |
| - expect(context.callMethod('getValue', [list, 0]), equals("a")); |
| - expect(context.callMethod('getValue', [list, 1]), equals("b")); |
| - expect(context.callMethod('getValue', [list, 6]), equals(null)); |
| - expect(context.callMethod('getValue', [list, -1]), equals(null)); |
| + expect(getValue(list, 0), |
| + equals("a")); |
| + expect(getValue(list, 1), |
| + equals("b")); |
| + expect(getValue(list, 6), |
| + equals(null)); |
| + expect(getValue(list, -1), |
| + equals(null)); |
| - expect(context.callMethod('getValue', [list, "0"]), equals("a")); |
| - expect(context.callMethod('getValue', [list, "1"]), equals("b")); |
| + expect(getValue(list, "0"), |
| + equals("a")); |
| + expect(getValue(list, "1"), |
| + equals("b")); |
| }); |
| test("is array", () { |
| var list = ["a", "b"]; |
| - expect(context.callMethod("checkIsArray", [list]), isTrue); |
| + expect(checkIsArray(list), isTrue); |
| }); |
| test("property descriptors", () { |
| // This test matters to make behavior consistent with JS native arrays |
| // and to make devtools integration work well. |
| var list = ["a", "b"]; |
| - expect(context.callMethod("getOwnPropertyDescriptorJson", [list, 0]), |
| + expect(getOwnPropertyDescriptorJson(list, 0), |
| equals('{"value":"a",' |
| '"writable":true,' |
| '"enumerable":true,' |
| '"configurable":true}')); |
| expect( |
| - context.callMethod("getOwnPropertyDescriptorJson", [list, "length"]), |
| + getOwnPropertyDescriptorJson(list, "length"), |
| equals('{"value":2,' |
| '"writable":true,' |
| '"enumerable":false,' |
| @@ -440,21 +524,21 @@ main() { |
| // Tests that calling the concat method from JS will flatten out JS arrays |
| // We concat the array with "a", "b", ["c", "d"], 42, {foo: 10} |
| // which should generate ["1", "2", "a", "b", ["c", "d"], 42, {foo: 10}] |
| - var ret = context.callMethod("concatValues", [list]); |
| + var ret = concatValues(list); |
| expect(list.length, equals(2)); |
| expect(ret.length, equals(8)); |
| expect(ret[0], equals("1")); |
| expect(ret[3], equals("b")); |
| expect(ret[5], equals("d")); |
| expect(ret[6], equals(42)); |
| - expect(ret[7]['foo'], equals(10)); |
| + expect(ret[7].foo, equals(10)); |
| }); |
| test("concat onto arrays", () { |
| // This test only passes if we have monkey patched the core Array object |
| // prototype to handle Dart Lists. |
| var list = ["a", "b"]; |
| - var ret = context.callMethod("concatOntoArray", [list]); |
| + var ret = concatOntoArray(list); |
| expect(list.length, equals(2)); |
| expect(ret, equals([1, 2, 3, "a", "b", "foo"])); |
| }); |
| @@ -463,47 +547,62 @@ main() { |
| // This test only passes if we have monkey patched the core Array object |
| // prototype to handle Dart Lists. |
| var list = ["a", "b"]; |
| - var ret = callJsMethod(list, "concat", [["c", "d"], "e", ["f", "g"]]); |
| + var ret = callJsMethod(list, "concat", [ |
| + ["c", "d"], |
| + "e", |
| + ["f", "g"] |
| + ]); |
| expect(list.length, equals(2)); |
| expect(ret, equals(["a", "b", "c", "d", "e", "f", "g"])); |
| }); |
| test("every greater than zero", () { |
| - expect(context.callMethod("everyGreaterThanZero", [[1, 5]]), isTrue); |
| - expect(context.callMethod("everyGreaterThanZeroCheckThisArg", [[1, 5]]), |
| + expect( |
| + everyGreaterThanZero([1, 5]), |
| + isTrue); |
| + expect( |
| + everyGreaterThanZeroCheckThisArg([1, 5]), |
| + isTrue); |
| + expect( |
| + everyGreaterThanZero([1, 0]), |
| + isFalse); |
| + expect(everyGreaterThanZero([]), |
| isTrue); |
| - expect(context.callMethod("everyGreaterThanZero", [[1, 0]]), isFalse); |
| - expect(context.callMethod("everyGreaterThanZero", [[]]), isTrue); |
| }); |
| test("filter greater than 42", () { |
| - expect(context.callMethod("filterGreater42", [[1, 5]]), equals([])); |
| - expect(context.callMethod("filterGreater42", [[43, 5, 49]]), |
| + expect(filterGreater42([1, 5]), equals([])); |
| + expect( |
| + filterGreater42([43, 5, 49]), |
| equals([43, 49])); |
| - expect(context.callMethod("filterGreater42", [["43", "5", "49"]]), |
| + expect( |
| + filterGreater42(["43", "5", "49"]), |
| equals(["43", "49"])); |
| }); |
| test("for each collect result", () { |
| - expect(context.callMethod("forEachCollectResult", [[1, 5, 7]]), |
| + expect( |
| + forEachCollectResult([1, 5, 7]), |
| equals([2, 10, 14])); |
| }); |
| test("some", () { |
| - expect(context.callMethod("someEqual42", [[1, 5, 9]]), isFalse); |
| - expect(context.callMethod("someEqual42", [[1, 42, 9]]), isTrue); |
| + expect(someEqual42([1, 5, 9]), |
| + isFalse); |
| + expect(someEqual42([1, 42, 9]), |
| + isTrue); |
| }); |
| test("sort backwards", () { |
| var arr = [1, 5, 9]; |
| - var ret = context.callMethod("sortNumbersBackwards", [arr]); |
| + var ret = sortNumbersBackwards(arr); |
| expect(identical(arr, ret), isTrue); |
| expect(ret, equals([9, 5, 1])); |
| }); |
| test("splice dummy items", () { |
| var list = [1, 2, 3, 4]; |
| - var removed = context.callMethod("spliceDummyItems", [list]); |
| + var removed = spliceDummyItems(list); |
| expect(removed.length, equals(2)); |
| expect(removed[0], equals(2)); |
| expect(removed[1], equals(3)); |
| @@ -516,7 +615,7 @@ main() { |
| test("splice string args", () { |
| var list = [1, 2, 3, 4]; |
| - var removed = context.callMethod("spliceTestStringArgs", [list]); |
| + var removed = spliceTestStringArgs(list); |
| expect(removed.length, equals(2)); |
| expect(removed[0], equals(2)); |
| expect(removed[1], equals(3)); |
| @@ -529,7 +628,7 @@ main() { |
| test("splice pastEndOfArray", () { |
| var list = [1, 2, 3, 4]; |
| - var removed = context.callMethod("splicePastEnd", [list]); |
| + var removed = splicePastEnd(list); |
| expect(removed.length, equals(3)); |
| expect(list.first, equals(1)); |
| expect(list.length, equals(4)); |
| @@ -540,7 +639,7 @@ main() { |
| test("splice both bounds past end of array", () { |
| var list = [1]; |
| - var removed = context.callMethod("splicePastEnd", [list]); |
| + var removed = splicePastEnd(list); |
| expect(removed.length, equals(0)); |
| expect(list.first, equals(1)); |
| expect(list.length, equals(4)); |
| @@ -550,25 +649,25 @@ main() { |
| }); |
| test("call List method on JavaScript object", () { |
| - var jsObject = new JsObject.jsify({}); |
| + var jsObject = newLiteral(); |
| callListMethodOnObject(jsObject, 'push', ["a"]); |
| callListMethodOnObject(jsObject, 'push', ["b"]); |
| callListMethodOnObject(jsObject, 'push', ["c", "d"]); |
| callListMethodOnObject(jsObject, 'push', []); |
| - expect(jsonStringify(jsObject), |
| + expect(json_helper.stringify(jsObject), |
| equals('{"0":"a","1":"b","2":"c","3":"d","length":4}')); |
| expect(callListMethodOnObject(jsObject, 'pop', []), equals("d")); |
| expect(callListMethodOnObject(jsObject, 'join', ["#"]), equals("a#b#c")); |
| - var jsArray = new JsObject.jsify([]); |
| + var jsArray = newArray(); |
| callListMethodOnObject(jsArray, 'push', ["a"]); |
| callListMethodOnObject(jsArray, 'push', ["b"]); |
| callListMethodOnObject(jsArray, 'push', ["c", "d"]); |
| callListMethodOnObject(jsArray, 'push', []); |
| - expect(jsonStringify(jsArray), equals('["a","b","c","d"]')); |
| + expect(json_helper.stringify(jsArray), equals('["a","b","c","d"]')); |
| }); |
| }); |
| @@ -584,10 +683,10 @@ main() { |
| var listView = new UnmodifiableListView(list.getRange(1,3)); |
| expect(listView is List, isTrue); |
| expect(listView.length, equals(2)); |
| - expect(context.callMethod("checkIsArray", [listView]), isFalse); |
| - expect(context.callMethod("checkIsArray", [listView.toList()]), isTrue); |
| - expect(context.callMethod("getOwnPropertyDescriptorJson", |
| - [listView, "length"]), equals("null")); |
| + expect(checkIsArray(listView), isFalse); |
| + expect(checkIsArray(listView.toList()), isTrue); |
| + expect(getOwnPropertyDescriptorJson( |
| + listView, "length"), equals("null")); |
| }); |
| }); |
| */ |