Implemented Array.prototype.sort()
JerryScript-DCO-1.0-Signed-off-by: Dániel Bátyai dbatyai.u-szeged@partner.samsung.com JerryScript-DCO-1.0-Signed-off-by: Szilard Ledan szledan.u-szeged@partner.samsung.com
This commit is contained in:
committed by
Dániel Bátyai
parent
8b28cac99e
commit
6b8e34a9cd
@@ -0,0 +1,83 @@
|
||||
// Copyright 2015 Samsung Electronics Co., Ltd.
|
||||
// Copyright 2015 University of Szeged.
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
var array = ["Peach", "Apple", "Orange", "Grape", "Cherry", "Apricot", "Grapefruit"];
|
||||
var sorted = array.sort();
|
||||
|
||||
assert(sorted[0] === "Apple");
|
||||
assert(sorted[1] === "Apricot");
|
||||
assert(sorted[2] === "Cherry");
|
||||
assert(sorted[3] === "Grape");
|
||||
assert(sorted[4] === "Grapefruit");
|
||||
assert(sorted[5] === "Orange");
|
||||
assert(sorted[6] === "Peach");
|
||||
|
||||
var array = [6, 4, 5, 1, 2, 9, 7, 3, 0, 8];
|
||||
|
||||
// Default comparison
|
||||
var sorted = array.sort();
|
||||
for (i = 0; i < array.length; i++) {
|
||||
assert(sorted[i] === i);
|
||||
}
|
||||
|
||||
// Using custom comparison function
|
||||
function f(arg1, arg2) {
|
||||
if (arg1 < arg2) {
|
||||
return 1;
|
||||
} else if (arg1 > arg2) {
|
||||
return -1;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
var sorted = array.sort(f);
|
||||
for (i = 0; i < array.length; i++) {
|
||||
assert(sorted[sorted.length - i - 1] === i);
|
||||
}
|
||||
|
||||
// Checking behavior when provided comparefn is not callable
|
||||
var obj = {};
|
||||
var arr = [];
|
||||
try {
|
||||
arr.sort(obj);
|
||||
assert(false);
|
||||
} catch (e) {
|
||||
assert(e instanceof TypeError);
|
||||
}
|
||||
|
||||
// Checking behavior when unable to get length
|
||||
var obj = { sort : Array.prototype.sort}
|
||||
Object.defineProperty(obj, 'length', { 'get' : function () { throw new ReferenceError ("foo"); } });
|
||||
|
||||
try {
|
||||
obj.sort();
|
||||
assert(false);
|
||||
} catch (e) {
|
||||
assert(e.message === "foo");
|
||||
assert(e instanceof ReferenceError);
|
||||
}
|
||||
|
||||
// Checking behavior when unable to get element
|
||||
var obj = { sort : Array.prototype.sort, length : 1}
|
||||
Object.defineProperty(obj, '0', { 'get' : function () { throw new ReferenceError ("foo"); } });
|
||||
|
||||
try {
|
||||
obj.sort();
|
||||
assert(false);
|
||||
} catch (e) {
|
||||
assert(e.message === "foo");
|
||||
assert(e instanceof ReferenceError);
|
||||
}
|
||||
Reference in New Issue
Block a user