super-with-spread.js 1.97 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Flags: --allow-natives-syntax

(function() {
  'use strict';

  class Point {
    constructor(x, y) {
      this.x = x;
      this.y = y;
    }
  }

  function testBaselineAndOpt(func) {
18
    %PrepareFunctionForOptimization(func);
19 20
    func(1, 2);
    func(1, 2);
21
    %OptimizeFunctionOnNextCall(func);
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 82 83 84 85 86 87 88 89
    return func(1, 2);
  }

  class RestPoint extends Point {
    constructor(...args) {
      super(...args);
    }
  }
  var r = testBaselineAndOpt(function(x, y) {
    return new RestPoint(x, y);
  });
  assertInstanceof(r, RestPoint);
  assertInstanceof(r, Point);
  assertEquals(r.x, 1);
  assertEquals(r.y, 2);

  class RestExtraPoint extends Point {
    constructor(...args) {
      super(-1, 0, ...args);
    }
  }
  r = testBaselineAndOpt(function(x, y) {
    return new RestExtraPoint(x, y);
  });
  assertInstanceof(r, RestExtraPoint);
  assertInstanceof(r, Point);
  assertEquals(r.x, -1);
  assertEquals(r.y, 0);

  class ArgumentsPoint extends Point {
    constructor() {
      super(...arguments);
    }
  }
  r = testBaselineAndOpt(function(x, y) {
    return new ArgumentsPoint(x, y);
  });
  assertInstanceof(r, ArgumentsPoint);
  assertInstanceof(r, Point);
  assertEquals(r.x, 1);
  assertEquals(r.y, 2);

  class ArgumentsExtraPoint extends Point {
    constructor() {
      super(1, 2, ...arguments);
    }
  }
  r = testBaselineAndOpt(function(x, y) {
    return new ArgumentsExtraPoint(x, y);
  });
  assertInstanceof(r, ArgumentsExtraPoint);
  assertInstanceof(r, Point);
  assertEquals(r.x, 1);
  assertEquals(r.y, 2);

  class LiteralPoint extends Point {
    constructor() {
      super(...[3, 4]);
    }
  }
  r = testBaselineAndOpt(function(x, y) {
    return new LiteralPoint(x, y);
  });
  assertInstanceof(r, LiteralPoint);
  assertInstanceof(r, Point);
  assertEquals(r.x, 3);
  assertEquals(r.y, 4);
})();