summaryrefslogtreecommitdiff
path: root/test/built-ins/Array/prototype/copyWithin/non-negative-target-start-and-end.js
blob: 4dbc5479cd511d9be4fb515366c840dbbc748933 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// Copyright (C) 2015 the V8 project authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-array.prototype.copywithin
es6id: 22.1.3.3
description: >
  Copy values with non-negative target, start and end positions.
info: |
  22.1.3.3 Array.prototype.copyWithin (target, start [ , end ] )

  ...
  7. If relativeTarget < 0, let to be max((len + relativeTarget),0); else let to
  be min(relativeTarget, len).
  ...
  10. If relativeStart < 0, let from be max((len + relativeStart),0); else let
  from be min(relativeStart, len).
  11. If end is undefined, let relativeEnd be len; else let relativeEnd be
  ToInteger(end).
  ...
  14. Let count be min(final-from, len-to).
  15. If from<to and to<from+count
    a. Let direction be -1.
    b. Let from be from + count -1.
    c. Let to be to + count -1.
  16. Else,
    a. Let direction = 1.
  17. Repeat, while count > 0
    ...
    a. If fromPresent is true, then
      i. Let fromVal be Get(O, fromKey).
      ...
      iii. Let setStatus be Set(O, toKey, fromVal, true).
  ...
includes: [compareArray.js]
---*/

assert(
  compareArray(
    [0, 1, 2, 3].copyWithin(0, 0, 0), [0, 1, 2, 3]
  ),
  '[0, 1, 2, 3].copyWithin(0, 0, 0) -> [0, 1, 2, 3]'
);

assert(
  compareArray(
    [0, 1, 2, 3].copyWithin(0, 0, 2), [0, 1, 2, 3]
  ),
  '[0, 1, 2, 3].copyWithin(0, 0, 2) -> [0, 1, 2, 3]'
);

assert(
  compareArray(
    [0, 1, 2, 3].copyWithin(0, 1, 2), [1, 1, 2, 3]
  ),
  '[0, 1, 2, 3].copyWithin(0, 1, 2) -> [1, 1, 2, 3]'
);

/*
 * 15. If from<to and to<from+count
 *   a. Let direction be -1.
 *   b. Let from be from + count -1.
 *   c. Let to be to + count -1.
 *
 *  0 < 1, 1 < 0 + 2
 *  direction = -1
 *  from = 0 + 2 - 1
 *  to = 1 + 2 - 1
 */
assert(
  compareArray(
    [0, 1, 2, 3].copyWithin(1, 0, 2), [0, 0, 1, 3]
  ),
  '[0, 1, 2, 3].copyWithin(1, 0, 2) -> [0, 0, 1, 3]'
);

assert(
  compareArray(
    [0, 1, 2, 3, 4, 5].copyWithin(1, 3, 5), [0, 3, 4, 3, 4, 5]
  ),
  '[0, 1, 2, 3, 4, 5].copyWithin(1, 3, 5) -> [0, 3, 4, 3, 4, 5]'
);