I: pbuilder: network access will be disabled during build
I: Current time: Sun Jan  7 11:27:12 -12 2024
I: pbuilder-time-stamp: 1704670032
I: Building the build Environment
I: extracting base tarball [/var/cache/pbuilder/bullseye-reproducible-base.tgz]
I: copying local configuration
W: --override-config is not set; not updating apt.conf Read the manpage for details.
I: mounting /proc filesystem
I: mounting /sys filesystem
I: creating /{dev,run}/shm
I: mounting /dev/pts filesystem
I: redirecting /dev/ptmx to /dev/pts/ptmx
I: policy-rc.d already exists
I: Copying source file
I: copying [golang-github-dop251-goja_0.0~git20170430.0.d382686-2.dsc]
I: copying [./golang-github-dop251-goja_0.0~git20170430.0.d382686.orig.tar.xz]
I: copying [./golang-github-dop251-goja_0.0~git20170430.0.d382686-2.debian.tar.xz]
I: Extracting source
gpgv: unknown type of key resource 'trustedkeys.kbx'
gpgv: keyblock resource '/tmp/dpkg-verify-sig.eZPh73v3/trustedkeys.kbx': General error
gpgv: Signature made Sat Aug 26 10:54:15 2017 
gpgv:                using RSA key F34F09744E9F5DD9
gpgv: Can't check signature: No public key
dpkg-source: warning: failed to verify signature on ./golang-github-dop251-goja_0.0~git20170430.0.d382686-2.dsc
dpkg-source: info: extracting golang-github-dop251-goja in golang-github-dop251-goja-0.0~git20170430.0.d382686
dpkg-source: info: unpacking golang-github-dop251-goja_0.0~git20170430.0.d382686.orig.tar.xz
dpkg-source: info: unpacking golang-github-dop251-goja_0.0~git20170430.0.d382686-2.debian.tar.xz
I: using fakeroot in build.
I: Installing the build-deps
I: user script /srv/workspace/pbuilder/582/tmp/hooks/D02_print_environment starting
I: set
  BUILDDIR='/build/reproducible-path'
  BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other'
  BUILDUSERNAME='pbuilder1'
  BUILD_ARCH='armhf'
  DEBIAN_FRONTEND='noninteractive'
  DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all,-fixfilepath parallel=3 '
  DISTRIBUTION='bullseye'
  HOME='/root'
  HOST_ARCH='armhf'
  IFS=' 	
  '
  INVOCATION_ID='186109191c474c1b9f2936f4ca8a0a57'
  LANG='C'
  LANGUAGE='en_US:en'
  LC_ALL='C'
  MAIL='/var/mail/root'
  OPTIND='1'
  PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games'
  PBCURRENTCOMMANDLINEOPERATION='build'
  PBUILDER_OPERATION='build'
  PBUILDER_PKGDATADIR='/usr/share/pbuilder'
  PBUILDER_PKGLIBDIR='/usr/lib/pbuilder'
  PBUILDER_SYSCONFDIR='/etc'
  PPID='582'
  PS1='# '
  PS2='> '
  PS4='+ '
  PWD='/'
  SHELL='/bin/bash'
  SHLVL='2'
  SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.7fLwfTN8/pbuilderrc_JH8j --distribution bullseye --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bullseye-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.7fLwfTN8/b1 --logfile b1/build.log golang-github-dop251-goja_0.0~git20170430.0.d382686-2.dsc'
  SUDO_GID='113'
  SUDO_UID='107'
  SUDO_USER='jenkins'
  TERM='unknown'
  TZ='/usr/share/zoneinfo/Etc/GMT+12'
  USER='root'
  _='/usr/bin/systemd-run'
  http_proxy='http://10.0.0.15:3142/'
I: uname -a
  Linux virt64c 6.1.0-17-arm64 #1 SMP Debian 6.1.69-1 (2023-12-30) aarch64 GNU/Linux
I: ls -l /bin
  total 3580
  -rwxr-xr-x 1 root root 816764 Mar 27  2022 bash
  -rwxr-xr-x 3 root root  26052 Jul 20  2020 bunzip2
  -rwxr-xr-x 3 root root  26052 Jul 20  2020 bzcat
  lrwxrwxrwx 1 root root      6 Jul 20  2020 bzcmp -> bzdiff
  -rwxr-xr-x 1 root root   2225 Jul 20  2020 bzdiff
  lrwxrwxrwx 1 root root      6 Jul 20  2020 bzegrep -> bzgrep
  -rwxr-xr-x 1 root root   4877 Sep  4  2019 bzexe
  lrwxrwxrwx 1 root root      6 Jul 20  2020 bzfgrep -> bzgrep
  -rwxr-xr-x 1 root root   3775 Jul 20  2020 bzgrep
  -rwxr-xr-x 3 root root  26052 Jul 20  2020 bzip2
  -rwxr-xr-x 1 root root   9636 Jul 20  2020 bzip2recover
  lrwxrwxrwx 1 root root      6 Jul 20  2020 bzless -> bzmore
  -rwxr-xr-x 1 root root   1297 Jul 20  2020 bzmore
  -rwxr-xr-x 1 root root  26668 Sep 22  2020 cat
  -rwxr-xr-x 1 root root  43104 Sep 22  2020 chgrp
  -rwxr-xr-x 1 root root  38984 Sep 22  2020 chmod
  -rwxr-xr-x 1 root root  43112 Sep 22  2020 chown
  -rwxr-xr-x 1 root root  92616 Sep 22  2020 cp
  -rwxr-xr-x 1 root root  75524 Dec 10  2020 dash
  -rwxr-xr-x 1 root root  75880 Sep 22  2020 date
  -rwxr-xr-x 1 root root  55436 Sep 22  2020 dd
  -rwxr-xr-x 1 root root  59912 Sep 22  2020 df
  -rwxr-xr-x 1 root root  96764 Sep 22  2020 dir
  -rwxr-xr-x 1 root root  55012 Jan 20  2022 dmesg
  lrwxrwxrwx 1 root root      8 Nov  7  2019 dnsdomainname -> hostname
  lrwxrwxrwx 1 root root      8 Nov  7  2019 domainname -> hostname
  -rwxr-xr-x 1 root root  22508 Sep 22  2020 echo
  -rwxr-xr-x 1 root root     28 Jan 25  2023 egrep
  -rwxr-xr-x 1 root root  22496 Sep 22  2020 false
  -rwxr-xr-x 1 root root     28 Jan 25  2023 fgrep
  -rwxr-xr-x 1 root root  47492 Jan 20  2022 findmnt
  -rwsr-xr-x 1 root root  26076 Feb 26  2021 fusermount
  -rwxr-xr-x 1 root root 124508 Jan 25  2023 grep
  -rwxr-xr-x 2 root root   2346 Apr 10  2022 gunzip
  -rwxr-xr-x 1 root root   6447 Apr 10  2022 gzexe
  -rwxr-xr-x 1 root root  64212 Apr 10  2022 gzip
  -rwxr-xr-x 1 root root  13784 Nov  7  2019 hostname
  -rwxr-xr-x 1 root root  43180 Sep 22  2020 ln
  -rwxr-xr-x 1 root root  35068 Feb  7  2020 login
  -rwxr-xr-x 1 root root  96764 Sep 22  2020 ls
  -rwxr-xr-x 1 root root  99940 Jan 20  2022 lsblk
  -rwxr-xr-x 1 root root  51408 Sep 22  2020 mkdir
  -rwxr-xr-x 1 root root  43184 Sep 22  2020 mknod
  -rwxr-xr-x 1 root root  30780 Sep 22  2020 mktemp
  -rwxr-xr-x 1 root root  34408 Jan 20  2022 more
  -rwsr-xr-x 1 root root  34400 Jan 20  2022 mount
  -rwxr-xr-x 1 root root   9824 Jan 20  2022 mountpoint
  -rwxr-xr-x 1 root root  88524 Sep 22  2020 mv
  lrwxrwxrwx 1 root root      8 Nov  7  2019 nisdomainname -> hostname
  lrwxrwxrwx 1 root root     14 Dec 16  2021 pidof -> /sbin/killall5
  -rwxr-xr-x 1 root root  26652 Sep 22  2020 pwd
  lrwxrwxrwx 1 root root      4 Mar 27  2022 rbash -> bash
  -rwxr-xr-x 1 root root  30740 Sep 22  2020 readlink
  -rwxr-xr-x 1 root root  43104 Sep 22  2020 rm
  -rwxr-xr-x 1 root root  30732 Sep 22  2020 rmdir
  -rwxr-xr-x 1 root root  14144 Sep 27  2020 run-parts
  -rwxr-xr-x 1 root root  76012 Dec 22  2018 sed
  lrwxrwxrwx 1 root root      4 Jan  7 09:28 sh -> dash
  -rwxr-xr-x 1 root root  22532 Sep 22  2020 sleep
  -rwxr-xr-x 1 root root  55360 Sep 22  2020 stty
  -rwsr-xr-x 1 root root  46704 Jan 20  2022 su
  -rwxr-xr-x 1 root root  22532 Sep 22  2020 sync
  -rwxr-xr-x 1 root root 340872 Feb 17  2021 tar
  -rwxr-xr-x 1 root root   9808 Sep 27  2020 tempfile
  -rwxr-xr-x 1 root root  67696 Sep 22  2020 touch
  -rwxr-xr-x 1 root root  22496 Sep 22  2020 true
  -rwxr-xr-x 1 root root   9636 Feb 26  2021 ulockmgr_server
  -rwsr-xr-x 1 root root  22108 Jan 20  2022 umount
  -rwxr-xr-x 1 root root  22520 Sep 22  2020 uname
  -rwxr-xr-x 2 root root   2346 Apr 10  2022 uncompress
  -rwxr-xr-x 1 root root  96764 Sep 22  2020 vdir
  -rwxr-xr-x 1 root root  38512 Jan 20  2022 wdctl
  lrwxrwxrwx 1 root root      8 Nov  7  2019 ypdomainname -> hostname
  -rwxr-xr-x 1 root root   1984 Apr 10  2022 zcat
  -rwxr-xr-x 1 root root   1678 Apr 10  2022 zcmp
  -rwxr-xr-x 1 root root   5898 Apr 10  2022 zdiff
  -rwxr-xr-x 1 root root     29 Apr 10  2022 zegrep
  -rwxr-xr-x 1 root root     29 Apr 10  2022 zfgrep
  -rwxr-xr-x 1 root root   2081 Apr 10  2022 zforce
  -rwxr-xr-x 1 root root   8049 Apr 10  2022 zgrep
  -rwxr-xr-x 1 root root   2206 Apr 10  2022 zless
  -rwxr-xr-x 1 root root   1842 Apr 10  2022 zmore
  -rwxr-xr-x 1 root root   4577 Apr 10  2022 znew
I: user script /srv/workspace/pbuilder/582/tmp/hooks/D02_print_environment finished
 -> Attempting to satisfy build-dependencies
 -> Creating pbuilder-satisfydepends-dummy package
Package: pbuilder-satisfydepends-dummy
Version: 0.invalid.0
Architecture: armhf
Maintainer: Debian Pbuilder Team <pbuilder-maint@lists.alioth.debian.org>
Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder
 This package was created automatically by pbuilder to satisfy the
 build-dependencies of the package being currently built.
Depends: debhelper (>= 10), dh-golang, golang-any, golang-github-dlclark-regexp2-dev, golang-golang-x-text-dev, golang-gopkg-yaml.v2-dev, tzdata
dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'.
Selecting previously unselected package pbuilder-satisfydepends-dummy.
(Reading database ... 17486 files and directories currently installed.)
Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ...
Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ...
dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested:
 pbuilder-satisfydepends-dummy depends on debhelper (>= 10); however:
  Package debhelper is not installed.
 pbuilder-satisfydepends-dummy depends on dh-golang; however:
  Package dh-golang is not installed.
 pbuilder-satisfydepends-dummy depends on golang-any; however:
  Package golang-any is not installed.
 pbuilder-satisfydepends-dummy depends on golang-github-dlclark-regexp2-dev; however:
  Package golang-github-dlclark-regexp2-dev is not installed.
 pbuilder-satisfydepends-dummy depends on golang-golang-x-text-dev; however:
  Package golang-golang-x-text-dev is not installed.
 pbuilder-satisfydepends-dummy depends on golang-gopkg-yaml.v2-dev; however:
  Package golang-gopkg-yaml.v2-dev is not installed.
 pbuilder-satisfydepends-dummy depends on tzdata; however:
  Package tzdata is not installed.

Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ...
Reading package lists...
Building dependency tree...
Reading state information...
Initializing package states...
Writing extended state information...
Building tag database...
pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0)
pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0)
The following NEW packages will be installed:
  autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} debhelper{a} dh-autoreconf{a} dh-golang{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} golang-1.15-go{a} golang-1.15-src{a} golang-any{a} golang-github-dlclark-regexp2-dev{a} golang-go{a} golang-golang-x-text-dev{a} golang-gopkg-yaml.v2-dev{a} golang-src{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libdebhelper-perl{a} libelf1{a} libfile-stripnondeterminism-perl{a} libicu67{a} libmagic-mgc{a} libmagic1{a} libpipeline1{a} libsigsegv2{a} libsub-override-perl{a} libtool{a} libuchardet0{a} libxml2{a} m4{a} man-db{a} po-debconf{a} sensible-utils{a} tzdata{a} 
The following packages are RECOMMENDED but will NOT be installed:
  curl libarchive-cpio-perl libltdl-dev libmail-sendmail-perl lynx pkg-config pkgconf wget 
0 packages upgraded, 41 newly installed, 0 to remove and 0 not upgraded.
Need to get 79.1 MB of archives. After unpacking 437 MB will be used.
Writing extended state information...
Get: 1 http://deb.debian.org/debian bullseye/main armhf bsdextrautils armhf 2.36.1-8+deb11u1 [139 kB]
Get: 2 http://deb.debian.org/debian bullseye/main armhf libuchardet0 armhf 0.0.7-1 [65.0 kB]
Get: 3 http://deb.debian.org/debian bullseye/main armhf groff-base armhf 1.22.4-6 [847 kB]
Get: 4 http://deb.debian.org/debian bullseye/main armhf libpipeline1 armhf 1.5.3-1 [30.1 kB]
Get: 5 http://deb.debian.org/debian bullseye/main armhf man-db armhf 2.9.4-2 [1319 kB]
Get: 6 http://deb.debian.org/debian bullseye/main armhf tzdata all 2021a-1+deb11u10 [286 kB]
Get: 7 http://deb.debian.org/debian bullseye/main armhf sensible-utils all 0.0.14 [14.8 kB]
Get: 8 http://deb.debian.org/debian bullseye/main armhf libmagic-mgc armhf 1:5.39-3+deb11u1 [273 kB]
Get: 9 http://deb.debian.org/debian bullseye/main armhf libmagic1 armhf 1:5.39-3+deb11u1 [120 kB]
Get: 10 http://deb.debian.org/debian bullseye/main armhf file armhf 1:5.39-3+deb11u1 [68.2 kB]
Get: 11 http://deb.debian.org/debian bullseye/main armhf gettext-base armhf 0.21-4 [171 kB]
Get: 12 http://deb.debian.org/debian bullseye/main armhf libsigsegv2 armhf 2.13-1 [34.0 kB]
Get: 13 http://deb.debian.org/debian bullseye/main armhf m4 armhf 1.4.18-5 [192 kB]
Get: 14 http://deb.debian.org/debian bullseye/main armhf autoconf all 2.69-14 [313 kB]
Get: 15 http://deb.debian.org/debian bullseye/main armhf autotools-dev all 20180224.1+nmu1 [77.1 kB]
Get: 16 http://deb.debian.org/debian bullseye/main armhf automake all 1:1.16.3-2 [814 kB]
Get: 17 http://deb.debian.org/debian bullseye/main armhf autopoint all 0.21-4 [510 kB]
Get: 18 http://deb.debian.org/debian bullseye/main armhf libdebhelper-perl all 13.3.4 [189 kB]
Get: 19 http://deb.debian.org/debian bullseye/main armhf libtool all 2.4.6-15 [513 kB]
Get: 20 http://deb.debian.org/debian bullseye/main armhf dh-autoreconf all 20 [17.1 kB]
Get: 21 http://deb.debian.org/debian bullseye/main armhf libarchive-zip-perl all 1.68-1 [104 kB]
Get: 22 http://deb.debian.org/debian bullseye/main armhf libsub-override-perl all 0.09-2 [10.2 kB]
Get: 23 http://deb.debian.org/debian bullseye/main armhf libfile-stripnondeterminism-perl all 1.12.0-1 [26.3 kB]
Get: 24 http://deb.debian.org/debian bullseye/main armhf dh-strip-nondeterminism all 1.12.0-1 [15.4 kB]
Get: 25 http://deb.debian.org/debian bullseye/main armhf libelf1 armhf 0.183-1 [161 kB]
Get: 26 http://deb.debian.org/debian bullseye/main armhf dwz armhf 0.13+20210201-1 [179 kB]
Get: 27 http://deb.debian.org/debian bullseye/main armhf libicu67 armhf 67.1-7 [8319 kB]
Get: 28 http://deb.debian.org/debian bullseye/main armhf libxml2 armhf 2.9.10+dfsg-6.7+deb11u4 [602 kB]
Get: 29 http://deb.debian.org/debian bullseye/main armhf gettext armhf 0.21-4 [1243 kB]
Get: 30 http://deb.debian.org/debian bullseye/main armhf intltool-debian all 0.35.0+20060710.5 [26.8 kB]
Get: 31 http://deb.debian.org/debian bullseye/main armhf po-debconf all 1.0.21+nmu1 [248 kB]
Get: 32 http://deb.debian.org/debian bullseye/main armhf debhelper all 13.3.4 [1049 kB]
Get: 33 http://deb.debian.org/debian bullseye/main armhf dh-golang all 1.51 [24.6 kB]
Get: 34 http://deb.debian.org/debian bullseye/main armhf golang-1.15-src armhf 1.15.15-1~deb11u4 [13.9 MB]
Get: 35 http://deb.debian.org/debian bullseye/main armhf golang-1.15-go armhf 1.15.15-1~deb11u4 [43.2 MB]
Get: 36 http://deb.debian.org/debian bullseye/main armhf golang-src armhf 2:1.15~1 [4856 B]
Get: 37 http://deb.debian.org/debian bullseye/main armhf golang-go armhf 2:1.15~1 [23.9 kB]
Get: 38 http://deb.debian.org/debian bullseye/main armhf golang-any armhf 2:1.15~1 [4976 B]
Get: 39 http://deb.debian.org/debian bullseye/main armhf golang-github-dlclark-regexp2-dev all 1.2.0-1 [80.2 kB]
Get: 40 http://deb.debian.org/debian bullseye/main armhf golang-golang-x-text-dev all 0.3.6-1 [3857 kB]
Get: 41 http://deb.debian.org/debian bullseye/main armhf golang-gopkg-yaml.v2-dev all 2.4.0-1 [61.3 kB]
Fetched 79.1 MB in 5s (15.9 MB/s)
debconf: delaying package configuration, since apt-utils is not installed
Selecting previously unselected package bsdextrautils.
(Reading database ... 
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 17486 files and directories currently installed.)
Preparing to unpack .../00-bsdextrautils_2.36.1-8+deb11u1_armhf.deb ...
Unpacking bsdextrautils (2.36.1-8+deb11u1) ...
Selecting previously unselected package libuchardet0:armhf.
Preparing to unpack .../01-libuchardet0_0.0.7-1_armhf.deb ...
Unpacking libuchardet0:armhf (0.0.7-1) ...
Selecting previously unselected package groff-base.
Preparing to unpack .../02-groff-base_1.22.4-6_armhf.deb ...
Unpacking groff-base (1.22.4-6) ...
Selecting previously unselected package libpipeline1:armhf.
Preparing to unpack .../03-libpipeline1_1.5.3-1_armhf.deb ...
Unpacking libpipeline1:armhf (1.5.3-1) ...
Selecting previously unselected package man-db.
Preparing to unpack .../04-man-db_2.9.4-2_armhf.deb ...
Unpacking man-db (2.9.4-2) ...
Selecting previously unselected package tzdata.
Preparing to unpack .../05-tzdata_2021a-1+deb11u10_all.deb ...
Unpacking tzdata (2021a-1+deb11u10) ...
Selecting previously unselected package sensible-utils.
Preparing to unpack .../06-sensible-utils_0.0.14_all.deb ...
Unpacking sensible-utils (0.0.14) ...
Selecting previously unselected package libmagic-mgc.
Preparing to unpack .../07-libmagic-mgc_1%3a5.39-3+deb11u1_armhf.deb ...
Unpacking libmagic-mgc (1:5.39-3+deb11u1) ...
Selecting previously unselected package libmagic1:armhf.
Preparing to unpack .../08-libmagic1_1%3a5.39-3+deb11u1_armhf.deb ...
Unpacking libmagic1:armhf (1:5.39-3+deb11u1) ...
Selecting previously unselected package file.
Preparing to unpack .../09-file_1%3a5.39-3+deb11u1_armhf.deb ...
Unpacking file (1:5.39-3+deb11u1) ...
Selecting previously unselected package gettext-base.
Preparing to unpack .../10-gettext-base_0.21-4_armhf.deb ...
Unpacking gettext-base (0.21-4) ...
Selecting previously unselected package libsigsegv2:armhf.
Preparing to unpack .../11-libsigsegv2_2.13-1_armhf.deb ...
Unpacking libsigsegv2:armhf (2.13-1) ...
Selecting previously unselected package m4.
Preparing to unpack .../12-m4_1.4.18-5_armhf.deb ...
Unpacking m4 (1.4.18-5) ...
Selecting previously unselected package autoconf.
Preparing to unpack .../13-autoconf_2.69-14_all.deb ...
Unpacking autoconf (2.69-14) ...
Selecting previously unselected package autotools-dev.
Preparing to unpack .../14-autotools-dev_20180224.1+nmu1_all.deb ...
Unpacking autotools-dev (20180224.1+nmu1) ...
Selecting previously unselected package automake.
Preparing to unpack .../15-automake_1%3a1.16.3-2_all.deb ...
Unpacking automake (1:1.16.3-2) ...
Selecting previously unselected package autopoint.
Preparing to unpack .../16-autopoint_0.21-4_all.deb ...
Unpacking autopoint (0.21-4) ...
Selecting previously unselected package libdebhelper-perl.
Preparing to unpack .../17-libdebhelper-perl_13.3.4_all.deb ...
Unpacking libdebhelper-perl (13.3.4) ...
Selecting previously unselected package libtool.
Preparing to unpack .../18-libtool_2.4.6-15_all.deb ...
Unpacking libtool (2.4.6-15) ...
Selecting previously unselected package dh-autoreconf.
Preparing to unpack .../19-dh-autoreconf_20_all.deb ...
Unpacking dh-autoreconf (20) ...
Selecting previously unselected package libarchive-zip-perl.
Preparing to unpack .../20-libarchive-zip-perl_1.68-1_all.deb ...
Unpacking libarchive-zip-perl (1.68-1) ...
Selecting previously unselected package libsub-override-perl.
Preparing to unpack .../21-libsub-override-perl_0.09-2_all.deb ...
Unpacking libsub-override-perl (0.09-2) ...
Selecting previously unselected package libfile-stripnondeterminism-perl.
Preparing to unpack .../22-libfile-stripnondeterminism-perl_1.12.0-1_all.deb ...
Unpacking libfile-stripnondeterminism-perl (1.12.0-1) ...
Selecting previously unselected package dh-strip-nondeterminism.
Preparing to unpack .../23-dh-strip-nondeterminism_1.12.0-1_all.deb ...
Unpacking dh-strip-nondeterminism (1.12.0-1) ...
Selecting previously unselected package libelf1:armhf.
Preparing to unpack .../24-libelf1_0.183-1_armhf.deb ...
Unpacking libelf1:armhf (0.183-1) ...
Selecting previously unselected package dwz.
Preparing to unpack .../25-dwz_0.13+20210201-1_armhf.deb ...
Unpacking dwz (0.13+20210201-1) ...
Selecting previously unselected package libicu67:armhf.
Preparing to unpack .../26-libicu67_67.1-7_armhf.deb ...
Unpacking libicu67:armhf (67.1-7) ...
Selecting previously unselected package libxml2:armhf.
Preparing to unpack .../27-libxml2_2.9.10+dfsg-6.7+deb11u4_armhf.deb ...
Unpacking libxml2:armhf (2.9.10+dfsg-6.7+deb11u4) ...
Selecting previously unselected package gettext.
Preparing to unpack .../28-gettext_0.21-4_armhf.deb ...
Unpacking gettext (0.21-4) ...
Selecting previously unselected package intltool-debian.
Preparing to unpack .../29-intltool-debian_0.35.0+20060710.5_all.deb ...
Unpacking intltool-debian (0.35.0+20060710.5) ...
Selecting previously unselected package po-debconf.
Preparing to unpack .../30-po-debconf_1.0.21+nmu1_all.deb ...
Unpacking po-debconf (1.0.21+nmu1) ...
Selecting previously unselected package debhelper.
Preparing to unpack .../31-debhelper_13.3.4_all.deb ...
Unpacking debhelper (13.3.4) ...
Selecting previously unselected package dh-golang.
Preparing to unpack .../32-dh-golang_1.51_all.deb ...
Unpacking dh-golang (1.51) ...
Selecting previously unselected package golang-1.15-src.
Preparing to unpack .../33-golang-1.15-src_1.15.15-1~deb11u4_armhf.deb ...
Unpacking golang-1.15-src (1.15.15-1~deb11u4) ...
Selecting previously unselected package golang-1.15-go.
Preparing to unpack .../34-golang-1.15-go_1.15.15-1~deb11u4_armhf.deb ...
Unpacking golang-1.15-go (1.15.15-1~deb11u4) ...
Selecting previously unselected package golang-src:armhf.
Preparing to unpack .../35-golang-src_2%3a1.15~1_armhf.deb ...
Unpacking golang-src:armhf (2:1.15~1) ...
Selecting previously unselected package golang-go.
Preparing to unpack .../36-golang-go_2%3a1.15~1_armhf.deb ...
Unpacking golang-go (2:1.15~1) ...
Selecting previously unselected package golang-any:armhf.
Preparing to unpack .../37-golang-any_2%3a1.15~1_armhf.deb ...
Unpacking golang-any:armhf (2:1.15~1) ...
Selecting previously unselected package golang-github-dlclark-regexp2-dev.
Preparing to unpack .../38-golang-github-dlclark-regexp2-dev_1.2.0-1_all.deb ...
Unpacking golang-github-dlclark-regexp2-dev (1.2.0-1) ...
Selecting previously unselected package golang-golang-x-text-dev.
Preparing to unpack .../39-golang-golang-x-text-dev_0.3.6-1_all.deb ...
Unpacking golang-golang-x-text-dev (0.3.6-1) ...
Selecting previously unselected package golang-gopkg-yaml.v2-dev.
Preparing to unpack .../40-golang-gopkg-yaml.v2-dev_2.4.0-1_all.deb ...
Unpacking golang-gopkg-yaml.v2-dev (2.4.0-1) ...
Setting up libpipeline1:armhf (1.5.3-1) ...
Setting up golang-gopkg-yaml.v2-dev (2.4.0-1) ...
Setting up bsdextrautils (2.36.1-8+deb11u1) ...
update-alternatives: using /usr/bin/write.ul to provide /usr/bin/write (write) in auto mode
Setting up libicu67:armhf (67.1-7) ...
Setting up libmagic-mgc (1:5.39-3+deb11u1) ...
Setting up golang-1.15-src (1.15.15-1~deb11u4) ...
Setting up libarchive-zip-perl (1.68-1) ...
Setting up libdebhelper-perl (13.3.4) ...
Setting up libmagic1:armhf (1:5.39-3+deb11u1) ...
Setting up gettext-base (0.21-4) ...
Setting up golang-github-dlclark-regexp2-dev (1.2.0-1) ...
Setting up file (1:5.39-3+deb11u1) ...
Setting up tzdata (2021a-1+deb11u10) ...

Current default time zone: 'Etc/UTC'
Local time is now:      Sun Jan  7 23:29:08 UTC 2024.
Universal Time is now:  Sun Jan  7 23:29:08 UTC 2024.
Run 'dpkg-reconfigure tzdata' if you wish to change it.

Setting up autotools-dev (20180224.1+nmu1) ...
Setting up libsigsegv2:armhf (2.13-1) ...
Setting up autopoint (0.21-4) ...
Setting up sensible-utils (0.0.14) ...
Setting up golang-golang-x-text-dev (0.3.6-1) ...
Setting up libuchardet0:armhf (0.0.7-1) ...
Setting up libsub-override-perl (0.09-2) ...
Setting up golang-src:armhf (2:1.15~1) ...
Setting up golang-1.15-go (1.15.15-1~deb11u4) ...
Setting up libelf1:armhf (0.183-1) ...
Setting up libxml2:armhf (2.9.10+dfsg-6.7+deb11u4) ...
Setting up libfile-stripnondeterminism-perl (1.12.0-1) ...
Setting up gettext (0.21-4) ...
Setting up libtool (2.4.6-15) ...
Setting up golang-go (2:1.15~1) ...
Setting up m4 (1.4.18-5) ...
Setting up golang-any:armhf (2:1.15~1) ...
Setting up intltool-debian (0.35.0+20060710.5) ...
Setting up autoconf (2.69-14) ...
Setting up dh-strip-nondeterminism (1.12.0-1) ...
Setting up dwz (0.13+20210201-1) ...
Setting up groff-base (1.22.4-6) ...
Setting up automake (1:1.16.3-2) ...
update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode
Setting up po-debconf (1.0.21+nmu1) ...
Setting up man-db (2.9.4-2) ...
Not building database; man-db/auto-update is not 'true'.
Setting up dh-autoreconf (20) ...
Setting up debhelper (13.3.4) ...
Setting up dh-golang (1.51) ...
Processing triggers for libc-bin (2.31-13+deb11u6) ...
Reading package lists...
Building dependency tree...
Reading state information...
Reading extended state information...
Initializing package states...
Writing extended state information...
Building tag database...
 -> Finished parsing the build-deps
Reading package lists...
Building dependency tree...
Reading state information...
fakeroot is already the newest version (1.25.3-1.1).
0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
I: Building the package
I: Running cd /build/reproducible-path/golang-github-dop251-goja-0.0~git20170430.0.d382686/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S  > ../golang-github-dop251-goja_0.0~git20170430.0.d382686-2_source.changes
dpkg-buildpackage: info: source package golang-github-dop251-goja
dpkg-buildpackage: info: source version 0.0~git20170430.0.d382686-2
dpkg-buildpackage: info: source distribution unstable
dpkg-buildpackage: info: source changed by Diego M. Rodriguez <diego.plan9@gmail.com>
 dpkg-source --before-build .
dpkg-buildpackage: info: host architecture armhf
 fakeroot debian/rules clean
dh clean --buildsystem=golang --with=golang
   dh_auto_clean -O--buildsystem=golang
   dh_autoreconf_clean -O--buildsystem=golang
   dh_clean -O--buildsystem=golang
 debian/rules build
dh build --buildsystem=golang --with=golang
   dh_update_autotools_config -O--buildsystem=golang
   dh_autoreconf -O--buildsystem=golang
   dh_auto_configure -O--buildsystem=golang
   dh_auto_build -O--buildsystem=golang
	cd obj-arm-linux-gnueabihf && go install -trimpath -v -p 3 github.com/dop251/goja github.com/dop251/goja/ast github.com/dop251/goja/file github.com/dop251/goja/parser github.com/dop251/goja/token
internal/cpu
internal/unsafeheader
runtime/internal/sys
internal/race
runtime/internal/math
sync/atomic
unicode
internal/bytealg
runtime/internal/atomic
unicode/utf8
encoding
runtime
math/bits
math
internal/testlog
unicode/utf16
sync
internal/reflectlite
math/rand
errors
sort
io
strconv
internal/oserror
syscall
bytes
reflect
strings
github.com/dop251/goja/token
regexp/syntax
internal/syscall/unix
time
internal/syscall/execenv
regexp
internal/poll
encoding/binary
internal/fmtsort
os
encoding/base64
golang.org/x/text/internal/tag
golang.org/x/text/transform
fmt
path/filepath
io/ioutil
github.com/dop251/goja/file
github.com/dlclark/regexp2/syntax
encoding/json
github.com/dop251/goja/ast
github.com/dop251/goja/parser
go/token
golang.org/x/text/internal/language
go/scanner
github.com/dlclark/regexp2
go/ast
golang.org/x/text/internal/language/compact
golang.org/x/text/language
golang.org/x/text/unicode/norm
log
math/big
golang.org/x/text/internal
golang.org/x/text/internal/colltab
golang.org/x/text/cases
golang.org/x/text/collate
github.com/dop251/goja
   dh_auto_test -O--buildsystem=golang
	cd obj-arm-linux-gnueabihf && go test -vet=off -v -p 3 github.com/dop251/goja github.com/dop251/goja/ast github.com/dop251/goja/file github.com/dop251/goja/parser github.com/dop251/goja/token
=== RUN   TestSparseArraySetLengthWithPropItems
    compiler.go:151: values: [1 2 3 4 100000 5 false 2 42 length 0]
    compiler.go:153:  0: goja.bindName(a)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1(a)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja.loadVal(1)
    compiler.go:153:  5: goja.loadVal(2)
    compiler.go:153:  6: goja.loadVal(3)
    compiler.go:153:  7: goja.newArray(4)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(a)
    compiler.go:153:  11: goja.loadVal(4)
    compiler.go:153:  12: goja.loadVal(5)
    compiler.go:153:  13: goja._setElem({})
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja.resolveVar1(thrown)
    compiler.go:153:  16: goja.loadVal(6)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.getVar1(Object)
    compiler.go:153:  20: goja._dup({})
    compiler.go:153:  21: goja.getPropCallee(defineProperty)
    compiler.go:153:  22: goja.getVar1(a)
    compiler.go:153:  23: goja.loadVal(7)
    compiler.go:153:  24: goja._newObject({})
    compiler.go:153:  25: goja.loadVal(8)
    compiler.go:153:  26: goja.setProp1(value)
    compiler.go:153:  27: goja.loadVal(6)
    compiler.go:153:  28: goja.setProp1(configurable)
    compiler.go:153:  29: goja.loadVal(6)
    compiler.go:153:  30: goja.setProp1(writable)
    compiler.go:153:  31: goja.call(3)
    compiler.go:153:  32: goja._pop({})
    compiler.go:153:  33: goja.try({16 0 true})
    compiler.go:153:  34: goja.getVar1(Object)
    compiler.go:153:  35: goja._dup({})
    compiler.go:153:  36: goja.getPropCallee(defineProperty)
    compiler.go:153:  37: goja.getVar1(a)
    compiler.go:153:  38: goja.loadVal(9)
    compiler.go:153:  39: goja._newObject({})
    compiler.go:153:  40: goja.loadVal(10)
    compiler.go:153:  41: goja.setProp1(value)
    compiler.go:153:  42: goja.loadVal(6)
    compiler.go:153:  43: goja.setProp1(writable)
    compiler.go:153:  44: goja.call(3)
    compiler.go:153:  45: goja._pop({})
    compiler.go:153:  46: goja._halt({})
    compiler.go:153:  47: goja.jump(10)
    compiler.go:153:  48: <nil>(<nil>)
    compiler.go:153:  49: goja.enterCatch(e)
    compiler.go:153:  50: goja.resolveVar1(thrown)
    compiler.go:153:  51: goja.getLocal(0)
    compiler.go:153:  52: goja.getVar1(TypeError)
    compiler.go:153:  53: goja._op_instanceof({})
    compiler.go:153:  54: goja._putValue({})
    compiler.go:153:  55: goja._pop({})
    compiler.go:153:  56: goja._halt({})
    compiler.go:153:  57: goja.getVar1(thrown)
    compiler.go:153:  58: goja.jneq1(6)
    compiler.go:153:  59: goja._pop({})
    compiler.go:153:  60: goja.getVar1(a)
    compiler.go:153:  61: goja.getProp(length)
    compiler.go:153:  62: goja.loadVal(2)
    compiler.go:153:  63: goja._op_strict_eq({})
    compiler.go:153:  64: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestSparseArraySetLengthWithPropItems (0.00s)
=== RUN   TestSparseArraySwitch
    compiler.go:151: values: [20470 5 1 0 20471 Invalid length:  Invalid value at  : ]
    compiler.go:153:  0: goja.bindName(a)
    compiler.go:153:  1: goja.bindName(i)
    compiler.go:153:  2: goja.resolveVar1(a)
    compiler.go:153:  3: goja.newArray(0)
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.getVar1(a)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._setElem({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.resolveVar1(i)
    compiler.go:153:  12: goja.getVar1(a)
    compiler.go:153:  13: goja.getProp(length)
    compiler.go:153:  14: goja.loadVal(2)
    compiler.go:153:  15: goja._sub({})
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(i)
    compiler.go:153:  19: goja.loadVal(3)
    compiler.go:153:  20: goja._op_gte({})
    compiler.go:153:  21: goja.jne(12)
    compiler.go:153:  22: goja.getVar1(a)
    compiler.go:153:  23: goja.getVar1(i)
    compiler.go:153:  24: goja.getVar1(i)
    compiler.go:153:  25: goja._setElem({})
    compiler.go:153:  26: goja._pop({})
    compiler.go:153:  27: goja.resolveVar1(i)
    compiler.go:153:  28: goja._getValue({})
    compiler.go:153:  29: goja._dec({})
    compiler.go:153:  30: goja._putValue({})
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.jump(-14)
    compiler.go:153:  33: goja.getVar1(a)
    compiler.go:153:  34: goja.getProp(length)
    compiler.go:153:  35: goja.loadVal(4)
    compiler.go:153:  36: goja._op_neq({})
    compiler.go:153:  37: goja.jne(8)
    compiler.go:153:  38: goja.getVar1(Error)
    compiler.go:153:  39: goja.loadVal(5)
    compiler.go:153:  40: goja.getVar1(a)
    compiler.go:153:  41: goja.getProp(length)
    compiler.go:153:  42: goja._add({})
    compiler.go:153:  43: goja._new(1)
    compiler.go:153:  44: goja._throw({})
    compiler.go:153:  45: goja.resolveVar1(i)
    compiler.go:153:  46: goja.loadVal(3)
    compiler.go:153:  47: goja._putValue({})
    compiler.go:153:  48: goja._pop({})
    compiler.go:153:  49: goja._loadUndef({})
    compiler.go:153:  50: goja.getVar1(i)
    compiler.go:153:  51: goja.getVar1(a)
    compiler.go:153:  52: goja.getProp(length)
    compiler.go:153:  53: goja._op_lt({})
    compiler.go:153:  54: goja.jne(28)
    compiler.go:153:  55: goja.getVar1(a)
    compiler.go:153:  56: goja.getVar1(i)
    compiler.go:153:  57: goja._getElem({})
    compiler.go:153:  58: goja.getVar1(i)
    compiler.go:153:  59: goja._op_strict_neq({})
    compiler.go:153:  60: goja.jne(13)
    compiler.go:153:  61: goja.getVar1(Error)
    compiler.go:153:  62: goja.loadVal(6)
    compiler.go:153:  63: goja.getVar1(i)
    compiler.go:153:  64: goja._add({})
    compiler.go:153:  65: goja.loadVal(7)
    compiler.go:153:  66: goja._add({})
    compiler.go:153:  67: goja.getVar1(a)
    compiler.go:153:  68: goja.getVar1(i)
    compiler.go:153:  69: goja._getElem({})
    compiler.go:153:  70: goja._add({})
    compiler.go:153:  71: goja._new(1)
    compiler.go:153:  72: goja._throw({})
    compiler.go:153:  73: goja._loadUndef({})
    compiler.go:153:  74: goja.rdupN(1)
    compiler.go:153:  75: goja._pop({})
    compiler.go:153:  76: goja.resolveVar1(i)
    compiler.go:153:  77: goja._getValue({})
    compiler.go:153:  78: goja._inc({})
    compiler.go:153:  79: goja._putValue({})
    compiler.go:153:  80: goja._pop({})
    compiler.go:153:  81: goja.jump(-31)
    compiler.go:153:  82: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSparseArraySwitch (0.35s)
=== RUN   TestEncodeURI
    compiler.go:151: values: [тест]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja.getVar1Callee(encodeURI)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja.call(1)
    compiler.go:153:  4: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEncodeURI (0.00s)
=== RUN   TestDecodeURI
    compiler.go:151: values: [http://ru.wikipedia.org/wiki/%d0%ae%D0%bd%D0%B8%D0%BA%D0%BE%D0%B4]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja.getVar1Callee(decodeURI)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja.call(1)
    compiler.go:153:  4: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestDecodeURI (0.00s)
=== RUN   TestJSONMarshalObject
--- PASS: TestJSONMarshalObject (0.02s)
=== RUN   TestJSONMarshalObjectCircular
--- PASS: TestJSONMarshalObjectCircular (0.00s)
=== RUN   TestSubstr
    compiler.go:151: values: [abc 0 false  start: 0, length: false 1 start: 1, length: false 2 start: 2, length: false 3 start: 3, length: false start: 0, length: NaN start: 1, length: NaN start: 2, length: NaN start: 3, length: NaN start: 0, length: "" start: 1, length: "" start: 2, length: "" start: 3, length: "" null start: 0, length: null start: 1, length: null start: 2, length: null start: 3, length: null 0, -1 0, -2 0, -3 4 0, -4 1, -1 1, -2 1, -3 1, -4 2, -1 2, -2 2, -3 2, -4 3, -1 3, -2 3, -3 3, -4 a 0, 1 ab b 1, 1 bc c 2, 1 3, 1 start: 0, length: unspecified start: 1, length: unspecified start: 2, length: unspecified start: 3, length: unspecified start: 0, length: undefined start: 1, length: undefined start: 2, length: undefined start: 3, length: undefined]
    compiler.go:153:  0: goja.bindName($ERROR)
    compiler.go:153:  1: goja.bindName(assert)
    compiler.go:153:  2: goja.resolveVar1($ERROR)
    compiler.go:153:  3: *goja.newFunc(&{0x14aa750 $ERROR 1 false 1 56})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadStack(-1)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(assert)
    compiler.go:153:  7: *goja.newFunc(&{0x14aa780 assert 2 false 58 277})
    compiler.go:151: values: [true Expected true but got ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja.loadStack(-2)
    compiler.go:153: > 8: goja.getVar1(undefined)
    compiler.go:153: > 9: goja._op_strict_eq({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._loadUndef({})
    compiler.go:153: > 13: goja.getVar1Callee(String)
    compiler.go:153: > 14: goja.loadStack(-1)
    compiler.go:153: > 15: goja.call(1)
    compiler.go:153: > 16: goja._add({})
    compiler.go:153: > 17: goja.storeStack(-2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja.getVar1Callee($ERROR)
    compiler.go:153: > 21: goja.loadStack(-2)
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja._loadUndef({})
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(assert)
    compiler.go:153:  11: *goja.newFunc(&{0x14aa7b0  2 false 301 478})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadStack(-2)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(14)
    compiler.go:153: > 5: goja.loadStack(-1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_neq({})
    compiler.go:153: > 8: goja.jeq1(9)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadVal(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._div({})
    compiler.go:153: > 13: goja.loadVal(1)
    compiler.go:153: > 14: goja.loadStack(-2)
    compiler.go:153: > 15: goja._div({})
    compiler.go:153: > 16: goja._op_strict_eq({})
    compiler.go:153: > 17: goja._retStashless({})
    compiler.go:153: > 18: goja.loadStack(-1)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja._op_strict_neq({})
    compiler.go:153: > 21: goja.jneq1(5)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-2)
    compiler.go:153: > 24: goja.loadStack(-2)
    compiler.go:153: > 25: goja._op_strict_neq({})
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  12: goja.setProp(_isSameValue)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(assert)
    compiler.go:153:  15: *goja.newFunc(&{0x14aa7e0  3 false 500 839})
    compiler.go:151: values: [   Expected SameValue(« », « ») to be true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.getVar1(assert)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.getPropCallee(_isSameValue)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja.call(2)
    compiler.go:153: > 7: goja.jne(3)
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153: > 10: goja.loadStack(-3)
    compiler.go:153: > 11: goja.getVar1(undefined)
    compiler.go:153: > 12: goja._op_strict_eq({})
    compiler.go:153: > 13: goja.jne(5)
    compiler.go:153: > 14: goja.loadVal(0)
    compiler.go:153: > 15: goja.storeStack(-3)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.jump(6)
    compiler.go:153: > 18: goja.loadStack(-3)
    compiler.go:153: > 19: goja.loadVal(1)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja.storeStack(-3)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-3)
    compiler.go:153: > 24: goja.loadVal(2)
    compiler.go:153: > 25: goja._loadUndef({})
    compiler.go:153: > 26: goja.getVar1Callee(String)
    compiler.go:153: > 27: goja.loadStack(-1)
    compiler.go:153: > 28: goja.call(1)
    compiler.go:153: > 29: goja._add({})
    compiler.go:153: > 30: goja.loadVal(3)
    compiler.go:153: > 31: goja._add({})
    compiler.go:153: > 32: goja._loadUndef({})
    compiler.go:153: > 33: goja.getVar1Callee(String)
    compiler.go:153: > 34: goja.loadStack(-2)
    compiler.go:153: > 35: goja.call(1)
    compiler.go:153: > 36: goja._add({})
    compiler.go:153: > 37: goja.loadVal(4)
    compiler.go:153: > 38: goja._add({})
    compiler.go:153: > 39: goja._add({})
    compiler.go:153: > 40: goja.storeStack(-3)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja._loadUndef({})
    compiler.go:153: > 43: goja.getVar1Callee($ERROR)
    compiler.go:153: > 44: goja.loadStack(-3)
    compiler.go:153: > 45: goja.call(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja._loadUndef({})
    compiler.go:153: > 48: goja._retStashless({})
    compiler.go:153:  16: goja.setProp(sameValue)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(assert)
    compiler.go:153:  19: goja._dup({})
    compiler.go:153:  20: goja.getPropCallee(sameValue)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja._dup({})
    compiler.go:153:  23: goja.getPropCallee(substr)
    compiler.go:153:  24: goja.loadVal(1)
    compiler.go:153:  25: goja.loadVal(2)
    compiler.go:153:  26: goja.call(2)
    compiler.go:153:  27: goja.loadVal(3)
    compiler.go:153:  28: goja.loadVal(4)
    compiler.go:153:  29: goja.call(3)
    compiler.go:153:  30: goja._pop({})
    compiler.go:153:  31: goja.getVar1(assert)
    compiler.go:153:  32: goja._dup({})
    compiler.go:153:  33: goja.getPropCallee(sameValue)
    compiler.go:153:  34: goja.loadVal(0)
    compiler.go:153:  35: goja._dup({})
    compiler.go:153:  36: goja.getPropCallee(substr)
    compiler.go:153:  37: goja.loadVal(5)
    compiler.go:153:  38: goja.loadVal(2)
    compiler.go:153:  39: goja.call(2)
    compiler.go:153:  40: goja.loadVal(3)
    compiler.go:153:  41: goja.loadVal(6)
    compiler.go:153:  42: goja.call(3)
    compiler.go:153:  43: goja._pop({})
    compiler.go:153:  44: goja.getVar1(assert)
    compiler.go:153:  45: goja._dup({})
    compiler.go:153:  46: goja.getPropCallee(sameValue)
    compiler.go:153:  47: goja.loadVal(0)
    compiler.go:153:  48: goja._dup({})
    compiler.go:153:  49: goja.getPropCallee(substr)
    compiler.go:153:  50: goja.loadVal(7)
    compiler.go:153:  51: goja.loadVal(2)
    compiler.go:153:  52: goja.call(2)
    compiler.go:153:  53: goja.loadVal(3)
    compiler.go:153:  54: goja.loadVal(8)
    compiler.go:153:  55: goja.call(3)
    compiler.go:153:  56: goja._pop({})
    compiler.go:153:  57: goja.getVar1(assert)
    compiler.go:153:  58: goja._dup({})
    compiler.go:153:  59: goja.getPropCallee(sameValue)
    compiler.go:153:  60: goja.loadVal(0)
    compiler.go:153:  61: goja._dup({})
    compiler.go:153:  62: goja.getPropCallee(substr)
    compiler.go:153:  63: goja.loadVal(9)
    compiler.go:153:  64: goja.loadVal(2)
    compiler.go:153:  65: goja.call(2)
    compiler.go:153:  66: goja.loadVal(3)
    compiler.go:153:  67: goja.loadVal(10)
    compiler.go:153:  68: goja.call(3)
    compiler.go:153:  69: goja._pop({})
    compiler.go:153:  70: goja.getVar1(assert)
    compiler.go:153:  71: goja._dup({})
    compiler.go:153:  72: goja.getPropCallee(sameValue)
    compiler.go:153:  73: goja.loadVal(0)
    compiler.go:153:  74: goja._dup({})
    compiler.go:153:  75: goja.getPropCallee(substr)
    compiler.go:153:  76: goja.loadVal(1)
    compiler.go:153:  77: goja.getVar1(NaN)
    compiler.go:153:  78: goja.call(2)
    compiler.go:153:  79: goja.loadVal(3)
    compiler.go:153:  80: goja.loadVal(11)
    compiler.go:153:  81: goja.call(3)
    compiler.go:153:  82: goja._pop({})
    compiler.go:153:  83: goja.getVar1(assert)
    compiler.go:153:  84: goja._dup({})
    compiler.go:153:  85: goja.getPropCallee(sameValue)
    compiler.go:153:  86: goja.loadVal(0)
    compiler.go:153:  87: goja._dup({})
    compiler.go:153:  88: goja.getPropCallee(substr)
    compiler.go:153:  89: goja.loadVal(5)
    compiler.go:153:  90: goja.getVar1(NaN)
    compiler.go:153:  91: goja.call(2)
    compiler.go:153:  92: goja.loadVal(3)
    compiler.go:153:  93: goja.loadVal(12)
    compiler.go:153:  94: goja.call(3)
    compiler.go:153:  95: goja._pop({})
    compiler.go:153:  96: goja.getVar1(assert)
    compiler.go:153:  97: goja._dup({})
    compiler.go:153:  98: goja.getPropCallee(sameValue)
    compiler.go:153:  99: goja.loadVal(0)
    compiler.go:153:  100: goja._dup({})
    compiler.go:153:  101: goja.getPropCallee(substr)
    compiler.go:153:  102: goja.loadVal(7)
    compiler.go:153:  103: goja.getVar1(NaN)
    compiler.go:153:  104: goja.call(2)
    compiler.go:153:  105: goja.loadVal(3)
    compiler.go:153:  106: goja.loadVal(13)
    compiler.go:153:  107: goja.call(3)
    compiler.go:153:  108: goja._pop({})
    compiler.go:153:  109: goja.getVar1(assert)
    compiler.go:153:  110: goja._dup({})
    compiler.go:153:  111: goja.getPropCallee(sameValue)
    compiler.go:153:  112: goja.loadVal(0)
    compiler.go:153:  113: goja._dup({})
    compiler.go:153:  114: goja.getPropCallee(substr)
    compiler.go:153:  115: goja.loadVal(9)
    compiler.go:153:  116: goja.getVar1(NaN)
    compiler.go:153:  117: goja.call(2)
    compiler.go:153:  118: goja.loadVal(3)
    compiler.go:153:  119: goja.loadVal(14)
    compiler.go:153:  120: goja.call(3)
    compiler.go:153:  121: goja._pop({})
    compiler.go:153:  122: goja.getVar1(assert)
    compiler.go:153:  123: goja._dup({})
    compiler.go:153:  124: goja.getPropCallee(sameValue)
    compiler.go:153:  125: goja.loadVal(0)
    compiler.go:153:  126: goja._dup({})
    compiler.go:153:  127: goja.getPropCallee(substr)
    compiler.go:153:  128: goja.loadVal(1)
    compiler.go:153:  129: goja.loadVal(3)
    compiler.go:153:  130: goja.call(2)
    compiler.go:153:  131: goja.loadVal(3)
    compiler.go:153:  132: goja.loadVal(15)
    compiler.go:153:  133: goja.call(3)
    compiler.go:153:  134: goja._pop({})
    compiler.go:153:  135: goja.getVar1(assert)
    compiler.go:153:  136: goja._dup({})
    compiler.go:153:  137: goja.getPropCallee(sameValue)
    compiler.go:153:  138: goja.loadVal(0)
    compiler.go:153:  139: goja._dup({})
    compiler.go:153:  140: goja.getPropCallee(substr)
    compiler.go:153:  141: goja.loadVal(5)
    compiler.go:153:  142: goja.loadVal(3)
    compiler.go:153:  143: goja.call(2)
    compiler.go:153:  144: goja.loadVal(3)
    compiler.go:153:  145: goja.loadVal(16)
    compiler.go:153:  146: goja.call(3)
    compiler.go:153:  147: goja._pop({})
    compiler.go:153:  148: goja.getVar1(assert)
    compiler.go:153:  149: goja._dup({})
    compiler.go:153:  150: goja.getPropCallee(sameValue)
    compiler.go:153:  151: goja.loadVal(0)
    compiler.go:153:  152: goja._dup({})
    compiler.go:153:  153: goja.getPropCallee(substr)
    compiler.go:153:  154: goja.loadVal(7)
    compiler.go:153:  155: goja.loadVal(3)
    compiler.go:153:  156: goja.call(2)
    compiler.go:153:  157: goja.loadVal(3)
    compiler.go:153:  158: goja.loadVal(17)
    compiler.go:153:  159: goja.call(3)
    compiler.go:153:  160: goja._pop({})
    compiler.go:153:  161: goja.getVar1(assert)
    compiler.go:153:  162: goja._dup({})
    compiler.go:153:  163: goja.getPropCallee(sameValue)
    compiler.go:153:  164: goja.loadVal(0)
    compiler.go:153:  165: goja._dup({})
    compiler.go:153:  166: goja.getPropCallee(substr)
    compiler.go:153:  167: goja.loadVal(9)
    compiler.go:153:  168: goja.loadVal(3)
    compiler.go:153:  169: goja.call(2)
    compiler.go:153:  170: goja.loadVal(3)
    compiler.go:153:  171: goja.loadVal(18)
    compiler.go:153:  172: goja.call(3)
    compiler.go:153:  173: goja._pop({})
    compiler.go:153:  174: goja.getVar1(assert)
    compiler.go:153:  175: goja._dup({})
    compiler.go:153:  176: goja.getPropCallee(sameValue)
    compiler.go:153:  177: goja.loadVal(0)
    compiler.go:153:  178: goja._dup({})
    compiler.go:153:  179: goja.getPropCallee(substr)
    compiler.go:153:  180: goja.loadVal(1)
    compiler.go:153:  181: goja.loadVal(19)
    compiler.go:153:  182: goja.call(2)
    compiler.go:153:  183: goja.loadVal(3)
    compiler.go:153:  184: goja.loadVal(20)
    compiler.go:153:  185: goja.call(3)
    compiler.go:153:  186: goja._pop({})
    compiler.go:153:  187: goja.getVar1(assert)
    compiler.go:153:  188: goja._dup({})
    compiler.go:153:  189: goja.getPropCallee(sameValue)
    compiler.go:153:  190: goja.loadVal(0)
    compiler.go:153:  191: goja._dup({})
    compiler.go:153:  192: goja.getPropCallee(substr)
    compiler.go:153:  193: goja.loadVal(5)
    compiler.go:153:  194: goja.loadVal(19)
    compiler.go:153:  195: goja.call(2)
    compiler.go:153:  196: goja.loadVal(3)
    compiler.go:153:  197: goja.loadVal(21)
    compiler.go:153:  198: goja.call(3)
    compiler.go:153:  199: goja._pop({})
    compiler.go:153:  200: goja.getVar1(assert)
    compiler.go:153:  201: goja._dup({})
    compiler.go:153:  202: goja.getPropCallee(sameValue)
    compiler.go:153:  203: goja.loadVal(0)
    compiler.go:153:  204: goja._dup({})
    compiler.go:153:  205: goja.getPropCallee(substr)
    compiler.go:153:  206: goja.loadVal(7)
    compiler.go:153:  207: goja.loadVal(19)
    compiler.go:153:  208: goja.call(2)
    compiler.go:153:  209: goja.loadVal(3)
    compiler.go:153:  210: goja.loadVal(22)
    compiler.go:153:  211: goja.call(3)
    compiler.go:153:  212: goja._pop({})
    compiler.go:153:  213: goja.getVar1(assert)
    compiler.go:153:  214: goja._dup({})
    compiler.go:153:  215: goja.getPropCallee(sameValue)
    compiler.go:153:  216: goja.loadVal(0)
    compiler.go:153:  217: goja._dup({})
    compiler.go:153:  218: goja.getPropCallee(substr)
    compiler.go:153:  219: goja.loadVal(9)
    compiler.go:153:  220: goja.loadVal(19)
    compiler.go:153:  221: goja.call(2)
    compiler.go:153:  222: goja.loadVal(3)
    compiler.go:153:  223: goja.loadVal(23)
    compiler.go:153:  224: goja.call(3)
    compiler.go:153:  225: goja._pop({})
    compiler.go:153:  226: goja.getVar1(assert)
    compiler.go:153:  227: goja._dup({})
    compiler.go:153:  228: goja.getPropCallee(sameValue)
    compiler.go:153:  229: goja.loadVal(0)
    compiler.go:153:  230: goja._dup({})
    compiler.go:153:  231: goja.getPropCallee(substr)
    compiler.go:153:  232: goja.loadVal(1)
    compiler.go:153:  233: goja.loadVal(5)
    compiler.go:153:  234: goja._neg({})
    compiler.go:153:  235: goja.call(2)
    compiler.go:153:  236: goja.loadVal(3)
    compiler.go:153:  237: goja.loadVal(24)
    compiler.go:153:  238: goja.call(3)
    compiler.go:153:  239: goja._pop({})
    compiler.go:153:  240: goja.getVar1(assert)
    compiler.go:153:  241: goja._dup({})
    compiler.go:153:  242: goja.getPropCallee(sameValue)
    compiler.go:153:  243: goja.loadVal(0)
    compiler.go:153:  244: goja._dup({})
    compiler.go:153:  245: goja.getPropCallee(substr)
    compiler.go:153:  246: goja.loadVal(1)
    compiler.go:153:  247: goja.loadVal(7)
    compiler.go:153:  248: goja._neg({})
    compiler.go:153:  249: goja.call(2)
    compiler.go:153:  250: goja.loadVal(3)
    compiler.go:153:  251: goja.loadVal(25)
    compiler.go:153:  252: goja.call(3)
    compiler.go:153:  253: goja._pop({})
    compiler.go:153:  254: goja.getVar1(assert)
    compiler.go:153:  255: goja._dup({})
    compiler.go:153:  256: goja.getPropCallee(sameValue)
    compiler.go:153:  257: goja.loadVal(0)
    compiler.go:153:  258: goja._dup({})
    compiler.go:153:  259: goja.getPropCallee(substr)
    compiler.go:153:  260: goja.loadVal(1)
    compiler.go:153:  261: goja.loadVal(9)
    compiler.go:153:  262: goja._neg({})
    compiler.go:153:  263: goja.call(2)
    compiler.go:153:  264: goja.loadVal(3)
    compiler.go:153:  265: goja.loadVal(26)
    compiler.go:153:  266: goja.call(3)
    compiler.go:153:  267: goja._pop({})
    compiler.go:153:  268: goja.getVar1(assert)
    compiler.go:153:  269: goja._dup({})
    compiler.go:153:  270: goja.getPropCallee(sameValue)
    compiler.go:153:  271: goja.loadVal(0)
    compiler.go:153:  272: goja._dup({})
    compiler.go:153:  273: goja.getPropCallee(substr)
    compiler.go:153:  274: goja.loadVal(1)
    compiler.go:153:  275: goja.loadVal(27)
    compiler.go:153:  276: goja._neg({})
    compiler.go:153:  277: goja.call(2)
    compiler.go:153:  278: goja.loadVal(3)
    compiler.go:153:  279: goja.loadVal(28)
    compiler.go:153:  280: goja.call(3)
    compiler.go:153:  281: goja._pop({})
    compiler.go:153:  282: goja.getVar1(assert)
    compiler.go:153:  283: goja._dup({})
    compiler.go:153:  284: goja.getPropCallee(sameValue)
    compiler.go:153:  285: goja.loadVal(0)
    compiler.go:153:  286: goja._dup({})
    compiler.go:153:  287: goja.getPropCallee(substr)
    compiler.go:153:  288: goja.loadVal(5)
    compiler.go:153:  289: goja.loadVal(5)
    compiler.go:153:  290: goja._neg({})
    compiler.go:153:  291: goja.call(2)
    compiler.go:153:  292: goja.loadVal(3)
    compiler.go:153:  293: goja.loadVal(29)
    compiler.go:153:  294: goja.call(3)
    compiler.go:153:  295: goja._pop({})
    compiler.go:153:  296: goja.getVar1(assert)
    compiler.go:153:  297: goja._dup({})
    compiler.go:153:  298: goja.getPropCallee(sameValue)
    compiler.go:153:  299: goja.loadVal(0)
    compiler.go:153:  300: goja._dup({})
    compiler.go:153:  301: goja.getPropCallee(substr)
    compiler.go:153:  302: goja.loadVal(5)
    compiler.go:153:  303: goja.loadVal(7)
    compiler.go:153:  304: goja._neg({})
    compiler.go:153:  305: goja.call(2)
    compiler.go:153:  306: goja.loadVal(3)
    compiler.go:153:  307: goja.loadVal(30)
    compiler.go:153:  308: goja.call(3)
    compiler.go:153:  309: goja._pop({})
    compiler.go:153:  310: goja.getVar1(assert)
    compiler.go:153:  311: goja._dup({})
    compiler.go:153:  312: goja.getPropCallee(sameValue)
    compiler.go:153:  313: goja.loadVal(0)
    compiler.go:153:  314: goja._dup({})
    compiler.go:153:  315: goja.getPropCallee(substr)
    compiler.go:153:  316: goja.loadVal(5)
    compiler.go:153:  317: goja.loadVal(9)
    compiler.go:153:  318: goja._neg({})
    compiler.go:153:  319: goja.call(2)
    compiler.go:153:  320: goja.loadVal(3)
    compiler.go:153:  321: goja.loadVal(31)
    compiler.go:153:  322: goja.call(3)
    compiler.go:153:  323: goja._pop({})
    compiler.go:153:  324: goja.getVar1(assert)
    compiler.go:153:  325: goja._dup({})
    compiler.go:153:  326: goja.getPropCallee(sameValue)
    compiler.go:153:  327: goja.loadVal(0)
    compiler.go:153:  328: goja._dup({})
    compiler.go:153:  329: goja.getPropCallee(substr)
    compiler.go:153:  330: goja.loadVal(5)
    compiler.go:153:  331: goja.loadVal(27)
    compiler.go:153:  332: goja._neg({})
    compiler.go:153:  333: goja.call(2)
    compiler.go:153:  334: goja.loadVal(3)
    compiler.go:153:  335: goja.loadVal(32)
    compiler.go:153:  336: goja.call(3)
    compiler.go:153:  337: goja._pop({})
    compiler.go:153:  338: goja.getVar1(assert)
    compiler.go:153:  339: goja._dup({})
    compiler.go:153:  340: goja.getPropCallee(sameValue)
    compiler.go:153:  341: goja.loadVal(0)
    compiler.go:153:  342: goja._dup({})
    compiler.go:153:  343: goja.getPropCallee(substr)
    compiler.go:153:  344: goja.loadVal(7)
    compiler.go:153:  345: goja.loadVal(5)
    compiler.go:153:  346: goja._neg({})
    compiler.go:153:  347: goja.call(2)
    compiler.go:153:  348: goja.loadVal(3)
    compiler.go:153:  349: goja.loadVal(33)
    compiler.go:153:  350: goja.call(3)
    compiler.go:153:  351: goja._pop({})
    compiler.go:153:  352: goja.getVar1(assert)
    compiler.go:153:  353: goja._dup({})
    compiler.go:153:  354: goja.getPropCallee(sameValue)
    compiler.go:153:  355: goja.loadVal(0)
    compiler.go:153:  356: goja._dup({})
    compiler.go:153:  357: goja.getPropCallee(substr)
    compiler.go:153:  358: goja.loadVal(7)
    compiler.go:153:  359: goja.loadVal(7)
    compiler.go:153:  360: goja._neg({})
    compiler.go:153:  361: goja.call(2)
    compiler.go:153:  362: goja.loadVal(3)
    compiler.go:153:  363: goja.loadVal(34)
    compiler.go:153:  364: goja.call(3)
    compiler.go:153:  365: goja._pop({})
    compiler.go:153:  366: goja.getVar1(assert)
    compiler.go:153:  367: goja._dup({})
    compiler.go:153:  368: goja.getPropCallee(sameValue)
    compiler.go:153:  369: goja.loadVal(0)
    compiler.go:153:  370: goja._dup({})
    compiler.go:153:  371: goja.getPropCallee(substr)
    compiler.go:153:  372: goja.loadVal(7)
    compiler.go:153:  373: goja.loadVal(9)
    compiler.go:153:  374: goja._neg({})
    compiler.go:153:  375: goja.call(2)
    compiler.go:153:  376: goja.loadVal(3)
    compiler.go:153:  377: goja.loadVal(35)
    compiler.go:153:  378: goja.call(3)
    compiler.go:153:  379: goja._pop({})
    compiler.go:153:  380: goja.getVar1(assert)
    compiler.go:153:  381: goja._dup({})
    compiler.go:153:  382: goja.getPropCallee(sameValue)
    compiler.go:153:  383: goja.loadVal(0)
    compiler.go:153:  384: goja._dup({})
    compiler.go:153:  385: goja.getPropCallee(substr)
    compiler.go:153:  386: goja.loadVal(7)
    compiler.go:153:  387: goja.loadVal(27)
    compiler.go:153:  388: goja._neg({})
    compiler.go:153:  389: goja.call(2)
    compiler.go:153:  390: goja.loadVal(3)
    compiler.go:153:  391: goja.loadVal(36)
    compiler.go:153:  392: goja.call(3)
    compiler.go:153:  393: goja._pop({})
    compiler.go:153:  394: goja.getVar1(assert)
    compiler.go:153:  395: goja._dup({})
    compiler.go:153:  396: goja.getPropCallee(sameValue)
    compiler.go:153:  397: goja.loadVal(0)
    compiler.go:153:  398: goja._dup({})
    compiler.go:153:  399: goja.getPropCallee(substr)
    compiler.go:153:  400: goja.loadVal(9)
    compiler.go:153:  401: goja.loadVal(5)
    compiler.go:153:  402: goja._neg({})
    compiler.go:153:  403: goja.call(2)
    compiler.go:153:  404: goja.loadVal(3)
    compiler.go:153:  405: goja.loadVal(37)
    compiler.go:153:  406: goja.call(3)
    compiler.go:153:  407: goja._pop({})
    compiler.go:153:  408: goja.getVar1(assert)
    compiler.go:153:  409: goja._dup({})
    compiler.go:153:  410: goja.getPropCallee(sameValue)
    compiler.go:153:  411: goja.loadVal(0)
    compiler.go:153:  412: goja._dup({})
    compiler.go:153:  413: goja.getPropCallee(substr)
    compiler.go:153:  414: goja.loadVal(9)
    compiler.go:153:  415: goja.loadVal(7)
    compiler.go:153:  416: goja._neg({})
    compiler.go:153:  417: goja.call(2)
    compiler.go:153:  418: goja.loadVal(3)
    compiler.go:153:  419: goja.loadVal(38)
    compiler.go:153:  420: goja.call(3)
    compiler.go:153:  421: goja._pop({})
    compiler.go:153:  422: goja.getVar1(assert)
    compiler.go:153:  423: goja._dup({})
    compiler.go:153:  424: goja.getPropCallee(sameValue)
    compiler.go:153:  425: goja.loadVal(0)
    compiler.go:153:  426: goja._dup({})
    compiler.go:153:  427: goja.getPropCallee(substr)
    compiler.go:153:  428: goja.loadVal(9)
    compiler.go:153:  429: goja.loadVal(9)
    compiler.go:153:  430: goja._neg({})
    compiler.go:153:  431: goja.call(2)
    compiler.go:153:  432: goja.loadVal(3)
    compiler.go:153:  433: goja.loadVal(39)
    compiler.go:153:  434: goja.call(3)
    compiler.go:153:  435: goja._pop({})
    compiler.go:153:  436: goja.getVar1(assert)
    compiler.go:153:  437: goja._dup({})
    compiler.go:153:  438: goja.getPropCallee(sameValue)
    compiler.go:153:  439: goja.loadVal(0)
    compiler.go:153:  440: goja._dup({})
    compiler.go:153:  441: goja.getPropCallee(substr)
    compiler.go:153:  442: goja.loadVal(9)
    compiler.go:153:  443: goja.loadVal(27)
    compiler.go:153:  444: goja._neg({})
    compiler.go:153:  445: goja.call(2)
    compiler.go:153:  446: goja.loadVal(3)
    compiler.go:153:  447: goja.loadVal(40)
    compiler.go:153:  448: goja.call(3)
    compiler.go:153:  449: goja._pop({})
    compiler.go:153:  450: goja.getVar1(assert)
    compiler.go:153:  451: goja._dup({})
    compiler.go:153:  452: goja.getPropCallee(sameValue)
    compiler.go:153:  453: goja.loadVal(0)
    compiler.go:153:  454: goja._dup({})
    compiler.go:153:  455: goja.getPropCallee(substr)
    compiler.go:153:  456: goja.loadVal(1)
    compiler.go:153:  457: goja.loadVal(5)
    compiler.go:153:  458: goja.call(2)
    compiler.go:153:  459: goja.loadVal(41)
    compiler.go:153:  460: goja.loadVal(42)
    compiler.go:153:  461: goja.call(3)
    compiler.go:153:  462: goja._pop({})
    compiler.go:153:  463: goja.getVar1(assert)
    compiler.go:153:  464: goja._dup({})
    compiler.go:153:  465: goja.getPropCallee(sameValue)
    compiler.go:153:  466: goja.loadVal(0)
    compiler.go:153:  467: goja._dup({})
    compiler.go:153:  468: goja.getPropCallee(substr)
    compiler.go:153:  469: goja.loadVal(1)
    compiler.go:153:  470: goja.loadVal(7)
    compiler.go:153:  471: goja.call(2)
    compiler.go:153:  472: goja.loadVal(43)
    compiler.go:153:  473: goja.loadVal(42)
    compiler.go:153:  474: goja.call(3)
    compiler.go:153:  475: goja._pop({})
    compiler.go:153:  476: goja.getVar1(assert)
    compiler.go:153:  477: goja._dup({})
    compiler.go:153:  478: goja.getPropCallee(sameValue)
    compiler.go:153:  479: goja.loadVal(0)
    compiler.go:153:  480: goja._dup({})
    compiler.go:153:  481: goja.getPropCallee(substr)
    compiler.go:153:  482: goja.loadVal(1)
    compiler.go:153:  483: goja.loadVal(9)
    compiler.go:153:  484: goja.call(2)
    compiler.go:153:  485: goja.loadVal(0)
    compiler.go:153:  486: goja.loadVal(42)
    compiler.go:153:  487: goja.call(3)
    compiler.go:153:  488: goja._pop({})
    compiler.go:153:  489: goja.getVar1(assert)
    compiler.go:153:  490: goja._dup({})
    compiler.go:153:  491: goja.getPropCallee(sameValue)
    compiler.go:153:  492: goja.loadVal(0)
    compiler.go:153:  493: goja._dup({})
    compiler.go:153:  494: goja.getPropCallee(substr)
    compiler.go:153:  495: goja.loadVal(1)
    compiler.go:153:  496: goja.loadVal(27)
    compiler.go:153:  497: goja.call(2)
    compiler.go:153:  498: goja.loadVal(0)
    compiler.go:153:  499: goja.loadVal(42)
    compiler.go:153:  500: goja.call(3)
    compiler.go:153:  501: goja._pop({})
    compiler.go:153:  502: goja.getVar1(assert)
    compiler.go:153:  503: goja._dup({})
    compiler.go:153:  504: goja.getPropCallee(sameValue)
    compiler.go:153:  505: goja.loadVal(0)
    compiler.go:153:  506: goja._dup({})
    compiler.go:153:  507: goja.getPropCallee(substr)
    compiler.go:153:  508: goja.loadVal(5)
    compiler.go:153:  509: goja.loadVal(5)
    compiler.go:153:  510: goja.call(2)
    compiler.go:153:  511: goja.loadVal(44)
    compiler.go:153:  512: goja.loadVal(45)
    compiler.go:153:  513: goja.call(3)
    compiler.go:153:  514: goja._pop({})
    compiler.go:153:  515: goja.getVar1(assert)
    compiler.go:153:  516: goja._dup({})
    compiler.go:153:  517: goja.getPropCallee(sameValue)
    compiler.go:153:  518: goja.loadVal(0)
    compiler.go:153:  519: goja._dup({})
    compiler.go:153:  520: goja.getPropCallee(substr)
    compiler.go:153:  521: goja.loadVal(5)
    compiler.go:153:  522: goja.loadVal(7)
    compiler.go:153:  523: goja.call(2)
    compiler.go:153:  524: goja.loadVal(46)
    compiler.go:153:  525: goja.loadVal(45)
    compiler.go:153:  526: goja.call(3)
    compiler.go:153:  527: goja._pop({})
    compiler.go:153:  528: goja.getVar1(assert)
    compiler.go:153:  529: goja._dup({})
    compiler.go:153:  530: goja.getPropCallee(sameValue)
    compiler.go:153:  531: goja.loadVal(0)
    compiler.go:153:  532: goja._dup({})
    compiler.go:153:  533: goja.getPropCallee(substr)
    compiler.go:153:  534: goja.loadVal(5)
    compiler.go:153:  535: goja.loadVal(9)
    compiler.go:153:  536: goja.call(2)
    compiler.go:153:  537: goja.loadVal(46)
    compiler.go:153:  538: goja.loadVal(45)
    compiler.go:153:  539: goja.call(3)
    compiler.go:153:  540: goja._pop({})
    compiler.go:153:  541: goja.getVar1(assert)
    compiler.go:153:  542: goja._dup({})
    compiler.go:153:  543: goja.getPropCallee(sameValue)
    compiler.go:153:  544: goja.loadVal(0)
    compiler.go:153:  545: goja._dup({})
    compiler.go:153:  546: goja.getPropCallee(substr)
    compiler.go:153:  547: goja.loadVal(5)
    compiler.go:153:  548: goja.loadVal(27)
    compiler.go:153:  549: goja.call(2)
    compiler.go:153:  550: goja.loadVal(46)
    compiler.go:153:  551: goja.loadVal(45)
    compiler.go:153:  552: goja.call(3)
    compiler.go:153:  553: goja._pop({})
    compiler.go:153:  554: goja.getVar1(assert)
    compiler.go:153:  555: goja._dup({})
    compiler.go:153:  556: goja.getPropCallee(sameValue)
    compiler.go:153:  557: goja.loadVal(0)
    compiler.go:153:  558: goja._dup({})
    compiler.go:153:  559: goja.getPropCallee(substr)
    compiler.go:153:  560: goja.loadVal(7)
    compiler.go:153:  561: goja.loadVal(5)
    compiler.go:153:  562: goja.call(2)
    compiler.go:153:  563: goja.loadVal(47)
    compiler.go:153:  564: goja.loadVal(48)
    compiler.go:153:  565: goja.call(3)
    compiler.go:153:  566: goja._pop({})
    compiler.go:153:  567: goja.getVar1(assert)
    compiler.go:153:  568: goja._dup({})
    compiler.go:153:  569: goja.getPropCallee(sameValue)
    compiler.go:153:  570: goja.loadVal(0)
    compiler.go:153:  571: goja._dup({})
    compiler.go:153:  572: goja.getPropCallee(substr)
    compiler.go:153:  573: goja.loadVal(7)
    compiler.go:153:  574: goja.loadVal(7)
    compiler.go:153:  575: goja.call(2)
    compiler.go:153:  576: goja.loadVal(47)
    compiler.go:153:  577: goja.loadVal(48)
    compiler.go:153:  578: goja.call(3)
    compiler.go:153:  579: goja._pop({})
    compiler.go:153:  580: goja.getVar1(assert)
    compiler.go:153:  581: goja._dup({})
    compiler.go:153:  582: goja.getPropCallee(sameValue)
    compiler.go:153:  583: goja.loadVal(0)
    compiler.go:153:  584: goja._dup({})
    compiler.go:153:  585: goja.getPropCallee(substr)
    compiler.go:153:  586: goja.loadVal(7)
    compiler.go:153:  587: goja.loadVal(9)
    compiler.go:153:  588: goja.call(2)
    compiler.go:153:  589: goja.loadVal(47)
    compiler.go:153:  590: goja.loadVal(48)
    compiler.go:153:  591: goja.call(3)
    compiler.go:153:  592: goja._pop({})
    compiler.go:153:  593: goja.getVar1(assert)
    compiler.go:153:  594: goja._dup({})
    compiler.go:153:  595: goja.getPropCallee(sameValue)
    compiler.go:153:  596: goja.loadVal(0)
    compiler.go:153:  597: goja._dup({})
    compiler.go:153:  598: goja.getPropCallee(substr)
    compiler.go:153:  599: goja.loadVal(7)
    compiler.go:153:  600: goja.loadVal(27)
    compiler.go:153:  601: goja.call(2)
    compiler.go:153:  602: goja.loadVal(47)
    compiler.go:153:  603: goja.loadVal(48)
    compiler.go:153:  604: goja.call(3)
    compiler.go:153:  605: goja._pop({})
    compiler.go:153:  606: goja.getVar1(assert)
    compiler.go:153:  607: goja._dup({})
    compiler.go:153:  608: goja.getPropCallee(sameValue)
    compiler.go:153:  609: goja.loadVal(0)
    compiler.go:153:  610: goja._dup({})
    compiler.go:153:  611: goja.getPropCallee(substr)
    compiler.go:153:  612: goja.loadVal(9)
    compiler.go:153:  613: goja.loadVal(5)
    compiler.go:153:  614: goja.call(2)
    compiler.go:153:  615: goja.loadVal(3)
    compiler.go:153:  616: goja.loadVal(49)
    compiler.go:153:  617: goja.call(3)
    compiler.go:153:  618: goja._pop({})
    compiler.go:153:  619: goja.getVar1(assert)
    compiler.go:153:  620: goja._dup({})
    compiler.go:153:  621: goja.getPropCallee(sameValue)
    compiler.go:153:  622: goja.loadVal(0)
    compiler.go:153:  623: goja._dup({})
    compiler.go:153:  624: goja.getPropCallee(substr)
    compiler.go:153:  625: goja.loadVal(9)
    compiler.go:153:  626: goja.loadVal(7)
    compiler.go:153:  627: goja.call(2)
    compiler.go:153:  628: goja.loadVal(3)
    compiler.go:153:  629: goja.loadVal(49)
    compiler.go:153:  630: goja.call(3)
    compiler.go:153:  631: goja._pop({})
    compiler.go:153:  632: goja.getVar1(assert)
    compiler.go:153:  633: goja._dup({})
    compiler.go:153:  634: goja.getPropCallee(sameValue)
    compiler.go:153:  635: goja.loadVal(0)
    compiler.go:153:  636: goja._dup({})
    compiler.go:153:  637: goja.getPropCallee(substr)
    compiler.go:153:  638: goja.loadVal(9)
    compiler.go:153:  639: goja.loadVal(9)
    compiler.go:153:  640: goja.call(2)
    compiler.go:153:  641: goja.loadVal(3)
    compiler.go:153:  642: goja.loadVal(49)
    compiler.go:153:  643: goja.call(3)
    compiler.go:153:  644: goja._pop({})
    compiler.go:153:  645: goja.getVar1(assert)
    compiler.go:153:  646: goja._dup({})
    compiler.go:153:  647: goja.getPropCallee(sameValue)
    compiler.go:153:  648: goja.loadVal(0)
    compiler.go:153:  649: goja._dup({})
    compiler.go:153:  650: goja.getPropCallee(substr)
    compiler.go:153:  651: goja.loadVal(9)
    compiler.go:153:  652: goja.loadVal(27)
    compiler.go:153:  653: goja.call(2)
    compiler.go:153:  654: goja.loadVal(3)
    compiler.go:153:  655: goja.loadVal(49)
    compiler.go:153:  656: goja.call(3)
    compiler.go:153:  657: goja._pop({})
    compiler.go:153:  658: goja.getVar1(assert)
    compiler.go:153:  659: goja._dup({})
    compiler.go:153:  660: goja.getPropCallee(sameValue)
    compiler.go:153:  661: goja.loadVal(0)
    compiler.go:153:  662: goja._dup({})
    compiler.go:153:  663: goja.getPropCallee(substr)
    compiler.go:153:  664: goja.loadVal(1)
    compiler.go:153:  665: goja.call(1)
    compiler.go:153:  666: goja.loadVal(0)
    compiler.go:153:  667: goja.loadVal(50)
    compiler.go:153:  668: goja.call(3)
    compiler.go:153:  669: goja._pop({})
    compiler.go:153:  670: goja.getVar1(assert)
    compiler.go:153:  671: goja._dup({})
    compiler.go:153:  672: goja.getPropCallee(sameValue)
    compiler.go:153:  673: goja.loadVal(0)
    compiler.go:153:  674: goja._dup({})
    compiler.go:153:  675: goja.getPropCallee(substr)
    compiler.go:153:  676: goja.loadVal(5)
    compiler.go:153:  677: goja.call(1)
    compiler.go:153:  678: goja.loadVal(46)
    compiler.go:153:  679: goja.loadVal(51)
    compiler.go:153:  680: goja.call(3)
    compiler.go:153:  681: goja._pop({})
    compiler.go:153:  682: goja.getVar1(assert)
    compiler.go:153:  683: goja._dup({})
    compiler.go:153:  684: goja.getPropCallee(sameValue)
    compiler.go:153:  685: goja.loadVal(0)
    compiler.go:153:  686: goja._dup({})
    compiler.go:153:  687: goja.getPropCallee(substr)
    compiler.go:153:  688: goja.loadVal(7)
    compiler.go:153:  689: goja.call(1)
    compiler.go:153:  690: goja.loadVal(47)
    compiler.go:153:  691: goja.loadVal(52)
    compiler.go:153:  692: goja.call(3)
    compiler.go:153:  693: goja._pop({})
    compiler.go:153:  694: goja.getVar1(assert)
    compiler.go:153:  695: goja._dup({})
    compiler.go:153:  696: goja.getPropCallee(sameValue)
    compiler.go:153:  697: goja.loadVal(0)
    compiler.go:153:  698: goja._dup({})
    compiler.go:153:  699: goja.getPropCallee(substr)
    compiler.go:153:  700: goja.loadVal(9)
    compiler.go:153:  701: goja.call(1)
    compiler.go:153:  702: goja.loadVal(3)
    compiler.go:153:  703: goja.loadVal(53)
    compiler.go:153:  704: goja.call(3)
    compiler.go:153:  705: goja._pop({})
    compiler.go:153:  706: goja.getVar1(assert)
    compiler.go:153:  707: goja._dup({})
    compiler.go:153:  708: goja.getPropCallee(sameValue)
    compiler.go:153:  709: goja.loadVal(0)
    compiler.go:153:  710: goja._dup({})
    compiler.go:153:  711: goja.getPropCallee(substr)
    compiler.go:153:  712: goja.loadVal(1)
    compiler.go:153:  713: goja.getVar1(undefined)
    compiler.go:153:  714: goja.call(2)
    compiler.go:153:  715: goja.loadVal(0)
    compiler.go:153:  716: goja.loadVal(54)
    compiler.go:153:  717: goja.call(3)
    compiler.go:153:  718: goja._pop({})
    compiler.go:153:  719: goja.getVar1(assert)
    compiler.go:153:  720: goja._dup({})
    compiler.go:153:  721: goja.getPropCallee(sameValue)
    compiler.go:153:  722: goja.loadVal(0)
    compiler.go:153:  723: goja._dup({})
    compiler.go:153:  724: goja.getPropCallee(substr)
    compiler.go:153:  725: goja.loadVal(5)
    compiler.go:153:  726: goja.getVar1(undefined)
    compiler.go:153:  727: goja.call(2)
    compiler.go:153:  728: goja.loadVal(46)
    compiler.go:153:  729: goja.loadVal(55)
    compiler.go:153:  730: goja.call(3)
    compiler.go:153:  731: goja._pop({})
    compiler.go:153:  732: goja.getVar1(assert)
    compiler.go:153:  733: goja._dup({})
    compiler.go:153:  734: goja.getPropCallee(sameValue)
    compiler.go:153:  735: goja.loadVal(0)
    compiler.go:153:  736: goja._dup({})
    compiler.go:153:  737: goja.getPropCallee(substr)
    compiler.go:153:  738: goja.loadVal(7)
    compiler.go:153:  739: goja.getVar1(undefined)
    compiler.go:153:  740: goja.call(2)
    compiler.go:153:  741: goja.loadVal(47)
    compiler.go:153:  742: goja.loadVal(56)
    compiler.go:153:  743: goja.call(3)
    compiler.go:153:  744: goja._pop({})
    compiler.go:153:  745: goja.getVar1(assert)
    compiler.go:153:  746: goja._dup({})
    compiler.go:153:  747: goja.getPropCallee(sameValue)
    compiler.go:153:  748: goja.loadVal(0)
    compiler.go:153:  749: goja._dup({})
    compiler.go:153:  750: goja.getPropCallee(substr)
    compiler.go:153:  751: goja.loadVal(9)
    compiler.go:153:  752: goja.getVar1(undefined)
    compiler.go:153:  753: goja.call(2)
    compiler.go:153:  754: goja.loadVal(3)
    compiler.go:153:  755: goja.loadVal(57)
    compiler.go:153:  756: goja.call(3)
    compiler.go:153:  757: goja._halt({})
    compiler_test.go:60: stack size: 11
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSubstr (0.04s)
=== RUN   TestEmptyProgram
    compiler.go:151: values: []
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEmptyProgram (0.00s)
=== RUN   TestErrorProto
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(e)
    compiler.go:153:  1: goja.resolveVar1(e)
    compiler.go:153:  2: goja.getVar1(TypeError)
    compiler.go:153:  3: goja._new(0)
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.getVar1(e)
    compiler.go:153:  7: goja.getProp(name)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestErrorProto (0.00s)
=== RUN   TestThis1
    compiler.go:151: values: [42]
    compiler.go:153:  0: goja.bindName(independent)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.bindName(rv)
    compiler.go:153:  3: goja.resolveVar1(independent)
    compiler.go:153:  4: *goja.newFunc(&{0x10ec690 independent 0 false 2 49})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.getProp(prop)
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(o)
    compiler.go:153:  8: goja._newObject({})
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.getVar1(o)
    compiler.go:153:  12: goja._newObject({})
    compiler.go:153:  13: goja.getVar1(independent)
    compiler.go:153:  14: goja.setProp1(g)
    compiler.go:153:  15: goja.loadVal(0)
    compiler.go:153:  16: goja.setProp1(prop)
    compiler.go:153:  17: goja.setProp(b)
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(rv)
    compiler.go:153:  20: goja.getVar1(o)
    compiler.go:153:  21: goja.getProp(b)
    compiler.go:153:  22: goja._dup({})
    compiler.go:153:  23: goja.getPropCallee(g)
    compiler.go:153:  24: goja.call(0)
    compiler.go:153:  25: goja._putValue({})
    compiler.go:153:  26: goja._pop({})
    compiler.go:153:  27: goja._loadUndef({})
    compiler.go:153:  28: goja._halt({})
    compiler_test.go:27: stack size: 3
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestThis1 (0.00s)
=== RUN   TestThis2
    compiler.go:151: values: [37]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja.setProp1(prop)
    compiler.go:153:  6: *goja.newFunc(&{0x10ecae0  0 false 28 66})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.getProp(prop)
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  7: goja.setProp1(f)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.resolveVar1(rv)
    compiler.go:153:  11: goja.getVar1(o)
    compiler.go:153:  12: goja._dup({})
    compiler.go:153:  13: goja.getPropCallee(f)
    compiler.go:153:  14: goja.call(0)
    compiler.go:153:  15: goja._putValue({})
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja._loadUndef({})
    compiler.go:153:  18: goja._halt({})
    compiler_test.go:27: stack size: 3
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestThis2 (0.00s)
=== RUN   TestThisStrict
    compiler.go:151: values: [x 5]
    compiler.go:153:  0: goja.getVar1(Object)
    compiler.go:153:  1: goja._dup({})
    compiler.go:153:  2: goja.getPropCallee(defineProperty)
    compiler.go:153:  3: goja.getVar1(Object)
    compiler.go:153:  4: goja.getProp(prototype)
    compiler.go:153:  5: goja.loadVal(0)
    compiler.go:153:  6: goja._newObject({})
    compiler.go:153:  7: *goja.newFunc(&{0x10ece70  0 true 70 98})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.loadStack(0)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  8: goja.setProp1(get)
    compiler.go:153:  9: goja.call(3)
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja.getProp(x)
    compiler.go:153:  13: goja.loadVal(1)
    compiler.go:153:  14: goja._op_strict_eq({})
    compiler.go:153:  15: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestThisStrict (0.00s)
=== RUN   TestThisNoStrict
    compiler.go:151: values: [x 5]
    compiler.go:153:  0: goja.getVar1(Object)
    compiler.go:153:  1: goja._dup({})
    compiler.go:153:  2: goja.getPropCallee(defineProperty)
    compiler.go:153:  3: goja.getVar1(Object)
    compiler.go:153:  4: goja.getProp(prototype)
    compiler.go:153:  5: goja.loadVal(0)
    compiler.go:153:  6: goja._newObject({})
    compiler.go:153:  7: *goja.newFunc(&{0x10ed200  0 false 54 82})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja._retStashless({})
    compiler.go:153:  8: goja.setProp1(get)
    compiler.go:153:  9: goja.call(3)
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja.getProp(x)
    compiler.go:153:  13: goja.loadVal(1)
    compiler.go:153:  14: goja._op_eq({})
    compiler.go:153:  15: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestThisNoStrict (0.00s)
=== RUN   TestCallLessArgs
    compiler.go:151: values: [1 2]
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x10ed5c0 A 3 false 1 79})
    compiler.go:151: values: [ ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja._loadUndef({})
    compiler.go:153: > 2: goja.getVar1Callee(String)
    compiler.go:153: > 3: goja.loadStack(-1)
    compiler.go:153: > 4: goja.call(1)
    compiler.go:153: > 5: goja.loadVal(0)
    compiler.go:153: > 6: goja._add({})
    compiler.go:153: > 7: goja._loadUndef({})
    compiler.go:153: > 8: goja.getVar1Callee(String)
    compiler.go:153: > 9: goja.loadStack(-2)
    compiler.go:153: > 10: goja.call(1)
    compiler.go:153: > 11: goja._add({})
    compiler.go:153: > 12: goja.loadVal(0)
    compiler.go:153: > 13: goja._add({})
    compiler.go:153: > 14: goja._loadUndef({})
    compiler.go:153: > 15: goja.getVar1Callee(String)
    compiler.go:153: > 16: goja.loadStack(-3)
    compiler.go:153: > 17: goja.call(1)
    compiler.go:153: > 18: goja._add({})
    compiler.go:153: > 19: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.loadVal(0)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.call(2)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja._loadUndef({})
    compiler.go:153:  15: goja._halt({})
    compiler_test.go:27: stack size: 9
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestCallLessArgs (0.01s)
=== RUN   TestCallMoreArgs
    compiler.go:151: values: [1 2 3]
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x10ed920 A 2 false 1 52})
    compiler.go:151: values: [4]
    compiler.go:153: > 0: goja.enterFuncStashless({1 2})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja._sub({})
    compiler.go:153: > 7: goja.loadStack(1)
    compiler.go:153: > 8: goja._add({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.loadVal(0)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.loadVal(2)
    compiler.go:153:  12: goja.call(3)
    compiler.go:153:  13: goja._putValue({})
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja._loadUndef({})
    compiler.go:153:  16: goja._halt({})
    compiler_test.go:27: stack size: 8
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestCallMoreArgs (0.00s)
=== RUN   TestCallMoreArgsDynamic
    compiler.go:151: values: [1 2 3]
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x10edc80 A 2 false 1 81})
    compiler.go:151: values: [4]
    compiler.go:153: > 0: goja.enterFunc(2)
    compiler.go:153: > 1: goja.bindName(a)
    compiler.go:153: > 2: goja.bindName(b)
    compiler.go:153: > 3: goja.bindName(c)
    compiler.go:153: > 4: goja._boxThis({})
    compiler.go:153: > 5: goja.loadVal(0)
    compiler.go:153: > 6: goja.setLocal(2)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.getVar1(a)
    compiler.go:153: > 9: goja.getVar1(b)
    compiler.go:153: > 10: goja._sub({})
    compiler.go:153: > 11: goja.getVar1(c)
    compiler.go:153: > 12: goja._add({})
    compiler.go:153: > 13: goja._ret({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.loadVal(0)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.loadVal(2)
    compiler.go:153:  12: goja.call(3)
    compiler.go:153:  13: goja._putValue({})
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja._loadUndef({})
    compiler.go:153:  16: goja._halt({})
    compiler_test.go:27: stack size: 5
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestCallMoreArgsDynamic (0.00s)
=== RUN   TestCallLessArgsDynamic
    compiler.go:151: values: [1 2]
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x105c3c0 A 3 false 1 131})
    compiler.go:151: values: [ ]
    compiler.go:153: > 0: goja.enterFunc(3)
    compiler.go:153: > 1: goja.bindName(a)
    compiler.go:153: > 2: goja.bindName(b)
    compiler.go:153: > 3: goja.bindName(c)
    compiler.go:153: > 4: goja.bindName(B)
    compiler.go:153: > 5: *goja.newFunc(&{0x105c3f0 B 0 false 45 74})
    compiler.go:151: values: []
    compiler.go:153: >> 0: goja.enterFuncStashless({0 0})
    compiler.go:153: >> 1: goja.getLocal(0)
    compiler.go:153: >> 2: goja._retStashless({})
    compiler.go:153: > 6: goja.setLocal(3)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja.getVar1Callee(String)
    compiler.go:153: > 10: goja.getLocal(0)
    compiler.go:153: > 11: goja.call(1)
    compiler.go:153: > 12: goja.loadVal(0)
    compiler.go:153: > 13: goja._add({})
    compiler.go:153: > 14: goja._loadUndef({})
    compiler.go:153: > 15: goja.getVar1Callee(String)
    compiler.go:153: > 16: goja.getLocal(1)
    compiler.go:153: > 17: goja.call(1)
    compiler.go:153: > 18: goja._add({})
    compiler.go:153: > 19: goja.loadVal(0)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja._loadUndef({})
    compiler.go:153: > 22: goja.getVar1Callee(String)
    compiler.go:153: > 23: goja.getLocal(2)
    compiler.go:153: > 24: goja.call(1)
    compiler.go:153: > 25: goja._add({})
    compiler.go:153: > 26: goja._ret({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.loadVal(0)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.call(2)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja._loadUndef({})
    compiler.go:153:  15: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestCallLessArgsDynamic (0.01s)
=== RUN   TestCallLessArgsDynamicLocalVar
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x105c7b0 f 1 false 2 82})
    compiler.go:151: values: [42]
    compiler.go:153: > 0: goja.enterFunc(1)
    compiler.go:153: > 1: goja.bindName(param)
    compiler.go:153: > 2: goja.bindName(a)
    compiler.go:153: > 3: goja._boxThis({})
    compiler.go:153: > 4: goja.loadVal(0)
    compiler.go:153: > 5: goja.setLocal(1)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(a)
    compiler.go:153: > 8: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestCallLessArgsDynamicLocalVar (0.00s)
=== RUN   TestNativeCall
    compiler.go:151: values: [1 test 42]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(o)
    compiler.go:153:  3: goja._loadUndef({})
    compiler.go:153:  4: goja.getVar1Callee(Object)
    compiler.go:153:  5: goja.loadVal(0)
    compiler.go:153:  6: goja.call(1)
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.getVar1(Object)
    compiler.go:153:  10: goja._dup({})
    compiler.go:153:  11: goja.getPropCallee(defineProperty)
    compiler.go:153:  12: goja.getVar1(o)
    compiler.go:153:  13: goja.loadVal(1)
    compiler.go:153:  14: goja._newObject({})
    compiler.go:153:  15: goja.loadVal(2)
    compiler.go:153:  16: goja.setProp1(value)
    compiler.go:153:  17: goja.call(3)
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(rv)
    compiler.go:153:  20: goja.getVar1(o)
    compiler.go:153:  21: goja.getProp(test)
    compiler.go:153:  22: goja._putValue({})
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja._loadUndef({})
    compiler.go:153:  25: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestNativeCall (0.00s)
=== RUN   TestJSCall
    compiler.go:151: values: [1 42 test]
    compiler.go:153:  0: goja.bindName(getter)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.bindName(rv)
    compiler.go:153:  3: goja.resolveVar1(getter)
    compiler.go:153:  4: *goja.newFunc(&{0x105ced0 getter 0 false 2 41})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.getProp(x)
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(o)
    compiler.go:153:  8: goja._loadUndef({})
    compiler.go:153:  9: goja.getVar1Callee(Object)
    compiler.go:153:  10: goja.loadVal(0)
    compiler.go:153:  11: goja.call(1)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(o)
    compiler.go:153:  15: goja.loadVal(1)
    compiler.go:153:  16: goja.setProp(x)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(Object)
    compiler.go:153:  19: goja._dup({})
    compiler.go:153:  20: goja.getPropCallee(defineProperty)
    compiler.go:153:  21: goja.getVar1(o)
    compiler.go:153:  22: goja.loadVal(2)
    compiler.go:153:  23: goja._newObject({})
    compiler.go:153:  24: goja.getVar1(getter)
    compiler.go:153:  25: goja.setProp1(get)
    compiler.go:153:  26: goja.call(3)
    compiler.go:153:  27: goja._pop({})
    compiler.go:153:  28: goja.resolveVar1(rv)
    compiler.go:153:  29: goja.getVar1(o)
    compiler.go:153:  30: goja.getProp(test)
    compiler.go:153:  31: goja._putValue({})
    compiler.go:153:  32: goja._pop({})
    compiler.go:153:  33: goja._loadUndef({})
    compiler.go:153:  34: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestJSCall (0.01s)
=== RUN   TestLoop1
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x105d2c0 A 0 false 2 117})
    compiler.go:151: values: [1 0 2]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadVal(1)
    compiler.go:153: > 5: goja.storeStack(2)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadStack(2)
    compiler.go:153: > 8: goja.loadVal(0)
    compiler.go:153: > 9: goja._op_lt({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(2)
    compiler.go:153: > 12: goja.storeStack(1)
    compiler.go:153: > 13: goja._pop({})
    compiler.go:153: > 14: goja.loadStack(2)
    compiler.go:153: > 15: goja._inc({})
    compiler.go:153: > 16: goja.storeStack(2)
    compiler.go:153: > 17: goja._pop({})
    compiler.go:153: > 18: goja.jump(-11)
    compiler.go:153: > 19: goja.loadStack(1)
    compiler.go:153: > 20: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestLoop1 (0.00s)
=== RUN   TestLoopBreak
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x105d650 A 0 false 2 134})
    compiler.go:151: values: [1 0 2]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadVal(1)
    compiler.go:153: > 5: goja.storeStack(2)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadStack(2)
    compiler.go:153: > 8: goja.loadVal(0)
    compiler.go:153: > 9: goja._op_lt({})
    compiler.go:153: > 10: goja.jne(10)
    compiler.go:153: > 11: goja.jump(9)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja.storeStack(1)
    compiler.go:153: > 14: goja._pop({})
    compiler.go:153: > 15: goja.loadStack(2)
    compiler.go:153: > 16: goja._inc({})
    compiler.go:153: > 17: goja.storeStack(2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja.jump(-12)
    compiler.go:153: > 20: goja.loadStack(1)
    compiler.go:153: > 21: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestLoopBreak (0.01s)
=== RUN   TestForLoopOptionalExpr
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x105daa0 A 0 false 2 115})
    compiler.go:151: values: [1 2]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.jump(5)
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja.storeStack(1)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.jump(-4)
    compiler.go:153: > 9: goja.loadStack(1)
    compiler.go:153: > 10: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestForLoopOptionalExpr (0.00s)
=== RUN   TestBlockBreak
    compiler.go:151: values: [0 1 2 3]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.resolveVar1(rv)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.resolveVar1(rv)
    compiler.go:153:  6: goja.loadVal(1)
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.resolveVar1(rv)
    compiler.go:153:  10: goja.loadVal(2)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja.jump(5)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(rv)
    compiler.go:153:  15: goja.loadVal(3)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._halt({})
    compiler_test.go:27: stack size: 1
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestBlockBreak (0.00s)
=== RUN   TestTry
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x1330150 A 0 false 2 115})
    compiler.go:151: values: [1 2 3 4]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.try({8 13 false})
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja.storeStack(1)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja._halt({})
    compiler.go:153: > 9: goja.jump(13)
    compiler.go:153: > 10: <nil>(<nil>)
    compiler.go:153: > 11: <nil>(<nil>)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja.storeStack(1)
    compiler.go:153: > 14: goja._pop({})
    compiler.go:153: > 15: goja._halt({})
    compiler.go:153: > 16: goja.jump(6)
    compiler.go:153: > 17: goja.loadVal(3)
    compiler.go:153: > 18: goja.storeStack(1)
    compiler.go:153: > 19: goja._pop({})
    compiler.go:153: > 20: goja._halt({})
    compiler.go:153: > 21: goja._retFinally({})
    compiler.go:153: > 22: goja.loadStack(1)
    compiler.go:153: > 23: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestTry (0.01s)
=== RUN   TestTryCatch
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x13304b0 A 0 false 2 89})
    compiler.go:151: values: [4]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.try({5 0 false})
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._throw({})
    compiler.go:153: > 4: goja._halt({})
    compiler.go:153: > 5: goja.jump(7)
    compiler.go:153: > 6: goja.storeStack(2)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.loadStack(2)
    compiler.go:153: > 9: goja.storeStack(1)
    compiler.go:153: > 10: goja._pop({})
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja.loadStack(1)
    compiler.go:153: > 13: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(rv)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:27: stack size: 5
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestTryCatch (0.00s)
=== RUN   TestTryExceptionInCatch
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.bindName(rv)
    compiler.go:153:  2: goja.resolveVar1(A)
    compiler.go:153:  3: *goja.newFunc(&{0x1330810 A 0 false 2 91})
    compiler.go:151: values: [4 5]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.try({7 0 false})
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._throw({})
    compiler.go:153: > 4: goja._halt({})
    compiler.go:153: > 5: goja.jump(6)
    compiler.go:153: > 6: <nil>(<nil>)
    compiler.go:153: > 7: <nil>(<nil>)
    compiler.go:153: > 8: goja.loadVal(1)
    compiler.go:153: > 9: goja._throw({})
    compiler.go:153: > 10: goja._halt({})
    compiler.go:153: > 11: goja.loadStack(1)
    compiler.go:153: > 12: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.try({8 0 true})
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(A)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja._halt({})
    compiler.go:153:  12: goja.jump(8)
    compiler.go:153:  13: <nil>(<nil>)
    compiler.go:153:  14: goja.enterCatch(e)
    compiler.go:153:  15: goja.resolveVar1(rv)
    compiler.go:153:  16: goja.getLocal(0)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja._halt({})
    compiler.go:153:  20: goja._loadUndef({})
    compiler.go:153:  21: goja._halt({})
    compiler_test.go:27: stack size: 5
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestTryExceptionInCatch (0.00s)
=== RUN   TestTryContinueInFinally
    compiler.go:151: values: [0 2 ex1 1]
    compiler.go:153:  0: goja.bindName(c3)
    compiler.go:153:  1: goja.bindName(fin3)
    compiler.go:153:  2: goja.resolveVar1(c3)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(fin3)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(c3)
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja._op_lt({})
    compiler.go:153:  13: goja.jne(29)
    compiler.go:153:  14: goja.try({6 15 true})
    compiler.go:153:  15: goja.loadVal(2)
    compiler.go:153:  16: goja._throw({})
    compiler.go:153:  17: goja._halt({})
    compiler.go:153:  18: goja.jump(19)
    compiler.go:153:  19: <nil>(<nil>)
    compiler.go:153:  20: goja.enterCatch(er1)
    compiler.go:153:  21: goja.resolveVar1(c3)
    compiler.go:153:  22: goja._getValue({})
    compiler.go:153:  23: goja.loadVal(3)
    compiler.go:153:  24: goja._add({})
    compiler.go:153:  25: goja._putValue({})
    compiler.go:153:  26: goja._pop({})
    compiler.go:153:  27: goja._halt({})
    compiler.go:153:  28: goja.jump(9)
    compiler.go:153:  29: goja.resolveVar1(fin3)
    compiler.go:153:  30: goja.loadVal(3)
    compiler.go:153:  31: goja._putValue({})
    compiler.go:153:  32: goja._pop({})
    compiler.go:153:  33: goja._halt({})
    compiler.go:153:  34: goja.jump(-24)
    compiler.go:153:  35: goja._halt({})
    compiler.go:153:  36: goja._retFinally({})
    compiler.go:153:  37: goja.resolveVar1(fin3)
    compiler.go:153:  38: goja.loadVal(0)
    compiler.go:153:  39: goja._putValue({})
    compiler.go:153:  40: goja._pop({})
    compiler.go:153:  41: goja.jump(-31)
    compiler.go:153:  42: goja.getVar1(fin3)
    compiler.go:153:  43: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 2
--- PASS: TestTryContinueInFinally (0.01s)
=== RUN   TestCatchLexicalEnv
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x1330f60 F 0 false 2 85})
    compiler.go:151: values: [1]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.try({5 0 false})
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._throw({})
    compiler.go:153: > 4: goja._halt({})
    compiler.go:153: > 5: goja.jump(7)
    compiler.go:153: > 6: goja.storeStack(2)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.loadStack(2)
    compiler.go:153: > 9: goja.storeStack(1)
    compiler.go:153: > 10: goja._pop({})
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja.loadStack(1)
    compiler.go:153: > 13: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestCatchLexicalEnv (0.00s)
=== RUN   TestThrowType
    compiler.go:151: values: [null object]
    compiler.go:153:  0: goja.bindName(Exception)
    compiler.go:153:  1: goja.bindName(A)
    compiler.go:153:  2: goja.bindName(thrown)
    compiler.go:153:  3: goja.bindName(rv)
    compiler.go:153:  4: goja.resolveVar1(Exception)
    compiler.go:153:  5: *goja.newFunc(&{0x13312f0 Exception 1 false 2 60})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.loadStack(-1)
    compiler.go:153: > 4: goja.setProp(message)
    compiler.go:153: > 5: goja._pop({})
    compiler.go:153: > 6: goja._loadUndef({})
    compiler.go:153: > 7: goja._retStashless({})
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(A)
    compiler.go:153:  9: *goja.newFunc(&{0x1331320 A 0 false 64 153})
    compiler.go:151: values: [boo!]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.try({7 0 false})
    compiler.go:153: > 2: goja.getVar1(Exception)
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._new(1)
    compiler.go:153: > 5: goja._throw({})
    compiler.go:153: > 6: goja._halt({})
    compiler.go:153: > 7: goja.jump(7)
    compiler.go:153: > 8: goja.storeStack(1)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadStack(1)
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja._retStashless({})
    compiler.go:153: > 13: goja._halt({})
    compiler.go:153: > 14: goja._loadUndef({})
    compiler.go:153: > 15: goja._retStashless({})
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(thrown)
    compiler.go:153:  13: goja._loadUndef({})
    compiler.go:153:  14: goja.getVar1Callee(A)
    compiler.go:153:  15: goja.call(0)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.resolveVar1(rv)
    compiler.go:153:  19: goja.getVar1(thrown)
    compiler.go:153:  20: goja.loadVal(0)
    compiler.go:153:  21: goja._op_strict_neq({})
    compiler.go:153:  22: goja.jneq1(6)
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.getVar1Callee(thrown)
    compiler.go:153:  25: goja._typeof({})
    compiler.go:153:  26: goja.loadVal(1)
    compiler.go:153:  27: goja._op_strict_eq({})
    compiler.go:153:  28: goja.jneq1(6)
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.getVar1(thrown)
    compiler.go:153:  31: goja.getProp(constructor)
    compiler.go:153:  32: goja.getVar1(Exception)
    compiler.go:153:  33: goja._op_strict_eq({})
    compiler.go:153:  34: goja._putValue({})
    compiler.go:153:  35: goja._pop({})
    compiler.go:153:  36: goja._loadUndef({})
    compiler.go:153:  37: goja._halt({})
    compiler_test.go:27: stack size: 9
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestThrowType (0.01s)
=== RUN   TestThrowConstructorName
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(Exception)
    compiler.go:153:  1: goja.bindName(A)
    compiler.go:153:  2: goja.resolveVar1(Exception)
    compiler.go:153:  3: *goja.newFunc(&{0x1331710 Exception 1 false 2 60})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.loadStack(-1)
    compiler.go:153: > 4: goja.setProp(message)
    compiler.go:153: > 5: goja._pop({})
    compiler.go:153: > 6: goja._loadUndef({})
    compiler.go:153: > 7: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(A)
    compiler.go:153:  7: *goja.newFunc(&{0x1331740 A 0 false 64 153})
    compiler.go:151: values: [boo!]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.try({7 0 false})
    compiler.go:153: > 2: goja.getVar1(Exception)
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._new(1)
    compiler.go:153: > 5: goja._throw({})
    compiler.go:153: > 6: goja._halt({})
    compiler.go:153: > 7: goja.jump(7)
    compiler.go:153: > 8: goja.storeStack(1)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadStack(1)
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja._retStashless({})
    compiler.go:153: > 13: goja._halt({})
    compiler.go:153: > 14: goja._loadUndef({})
    compiler.go:153: > 15: goja._retStashless({})
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja._loadUndef({})
    compiler.go:153:  11: goja.getVar1Callee(A)
    compiler.go:153:  12: goja.call(0)
    compiler.go:153:  13: goja.getProp(constructor)
    compiler.go:153:  14: goja.getProp(name)
    compiler.go:153:  15: goja._halt({})
    compiler_test.go:60: stack size: 9
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestThrowConstructorName (0.00s)
=== RUN   TestThrowNativeConstructorName
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.resolveVar1(A)
    compiler.go:153:  2: *goja.newFunc(&{0x1331b00 A 0 false 4 87})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.try({6 0 false})
    compiler.go:153: > 2: goja.getVar1(TypeError)
    compiler.go:153: > 3: goja._new(0)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._halt({})
    compiler.go:153: > 6: goja.jump(7)
    compiler.go:153: > 7: goja.storeStack(1)
    compiler.go:153: > 8: goja._pop({})
    compiler.go:153: > 9: goja.loadStack(1)
    compiler.go:153: > 10: goja._halt({})
    compiler.go:153: > 11: goja._retStashless({})
    compiler.go:153: > 12: goja._halt({})
    compiler.go:153: > 13: goja._loadUndef({})
    compiler.go:153: > 14: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(A)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja.getProp(constructor)
    compiler.go:153:  9: goja.getProp(name)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestThrowNativeConstructorName (0.00s)
=== RUN   TestEmptyTryNoCatch
    compiler.go:151: values: [false true]
    compiler.go:153:  0: goja.bindName(called)
    compiler.go:153:  1: goja.resolveVar1(called)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.try({0 4 true})
    compiler.go:153:  6: goja._halt({})
    compiler.go:153:  7: goja.jump(8)
    compiler.go:153:  8: goja.jump(7)
    compiler.go:153:  9: goja.resolveVar1(called)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja._halt({})
    compiler.go:153:  14: goja._retFinally({})
    compiler.go:153:  15: goja.getVar1(called)
    compiler.go:153:  16: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEmptyTryNoCatch (0.01s)
=== RUN   TestIfElse
    compiler.go:151: values: [passed failed]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.getVar1(rv)
    compiler.go:153:  2: goja.getVar1(undefined)
    compiler.go:153:  3: goja._op_strict_eq({})
    compiler.go:153:  4: goja.jne(5)
    compiler.go:153:  5: goja.resolveVar1(rv)
    compiler.go:153:  6: goja.loadVal(0)
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja.jump(4)
    compiler.go:153:  9: goja.resolveVar1(rv)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._halt({})
    compiler_test.go:27: stack size: 2
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestIfElse (0.00s)
=== RUN   TestIfElseRetVal
    compiler.go:151: values: [passed failed]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.getVar1(x)
    compiler.go:153:  2: goja.getVar1(undefined)
    compiler.go:153:  3: goja._op_strict_eq({})
    compiler.go:153:  4: goja.jne(3)
    compiler.go:153:  5: goja.loadVal(0)
    compiler.go:153:  6: goja.jump(2)
    compiler.go:153:  7: goja.loadVal(1)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestIfElseRetVal (0.00s)
=== RUN   TestBreakOutOfTry
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.resolveVar1(A)
    compiler.go:153:  2: *goja.newFunc(&{0x13d2750 A 0 false 2 146})
    compiler.go:151: values: [1 2 3 4]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.try({8 13 false})
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja.storeStack(1)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja._halt({})
    compiler.go:153: > 9: goja.jump(15)
    compiler.go:153: > 10: <nil>(<nil>)
    compiler.go:153: > 11: <nil>(<nil>)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja.storeStack(1)
    compiler.go:153: > 14: goja._pop({})
    compiler.go:153: > 15: goja._halt({})
    compiler.go:153: > 16: goja.jump(8)
    compiler.go:153: > 17: goja._halt({})
    compiler.go:153: > 18: goja.jump(6)
    compiler.go:153: > 19: goja.loadVal(3)
    compiler.go:153: > 20: goja.storeStack(1)
    compiler.go:153: > 21: goja._pop({})
    compiler.go:153: > 22: goja._halt({})
    compiler.go:153: > 23: goja._retFinally({})
    compiler.go:153: > 24: goja.loadStack(1)
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(A)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestBreakOutOfTry (0.00s)
=== RUN   TestReturnOutOfTryNested
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.resolveVar1(A)
    compiler.go:153:  2: *goja.newFunc(&{0x13d2b10 A 0 false 2 122})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: *goja.newFunc(&{0x13d2b40 nested 0 false 19 100})
    compiler.go:151: values: [1 2]
    compiler.go:153: >> 0: goja.enterFuncStashless({0 0})
    compiler.go:153: >> 1: goja.try({8 0 false})
    compiler.go:153: >> 2: goja.loadVal(0)
    compiler.go:153: >> 3: goja._halt({})
    compiler.go:153: >> 4: goja._retStashless({})
    compiler.go:153: >> 5: goja._halt({})
    compiler.go:153: >> 6: goja.jump(7)
    compiler.go:153: >> 7: <nil>(<nil>)
    compiler.go:153: >> 8: <nil>(<nil>)
    compiler.go:153: >> 9: goja.loadVal(1)
    compiler.go:153: >> 10: goja._halt({})
    compiler.go:153: >> 11: goja._retStashless({})
    compiler.go:153: >> 12: goja._halt({})
    compiler.go:153: >> 13: goja._loadUndef({})
    compiler.go:153: >> 14: goja._retStashless({})
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja._loadUndef({})
    compiler.go:153: > 5: goja.loadStack(1)
    compiler.go:153: > 6: goja.call(0)
    compiler.go:153: > 7: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(A)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestReturnOutOfTryNested (0.01s)
=== RUN   TestContinueLoop
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.resolveVar1(A)
    compiler.go:153:  2: *goja.newFunc(&{0x13d2ed0 A 0 false 2 123})
    compiler.go:151: values: [0 5 1]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadVal(0)
    compiler.go:153: > 5: goja.storeStack(2)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadStack(2)
    compiler.go:153: > 8: goja.loadVal(1)
    compiler.go:153: > 9: goja._op_lt({})
    compiler.go:153: > 10: goja.jne(15)
    compiler.go:153: > 11: goja.loadStack(2)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja._op_gt({})
    compiler.go:153: > 14: goja.jne(2)
    compiler.go:153: > 15: goja.jump(5)
    compiler.go:153: > 16: goja.loadStack(1)
    compiler.go:153: > 17: goja._inc({})
    compiler.go:153: > 18: goja.storeStack(1)
    compiler.go:153: > 19: goja._pop({})
    compiler.go:153: > 20: goja.loadStack(2)
    compiler.go:153: > 21: goja._inc({})
    compiler.go:153: > 22: goja.storeStack(2)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja.jump(-17)
    compiler.go:153: > 25: goja.loadStack(1)
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(A)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestContinueLoop (0.00s)
=== RUN   TestContinueOutOfTry
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(A)
    compiler.go:153:  1: goja.resolveVar1(A)
    compiler.go:153:  2: *goja.newFunc(&{0x13d3260 A 0 false 2 171})
    compiler.go:151: values: [0 5 1 99]
    compiler.go:153: > 0: goja.enterFuncStashless({2 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadVal(0)
    compiler.go:153: > 5: goja.storeStack(2)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadStack(2)
    compiler.go:153: > 8: goja.loadVal(1)
    compiler.go:153: > 9: goja._op_lt({})
    compiler.go:153: > 10: goja.jne(25)
    compiler.go:153: > 11: goja.try({11 0 false})
    compiler.go:153: > 12: goja.loadStack(2)
    compiler.go:153: > 13: goja.loadVal(2)
    compiler.go:153: > 14: goja._op_gt({})
    compiler.go:153: > 15: goja.jne(3)
    compiler.go:153: > 16: goja._halt({})
    compiler.go:153: > 17: goja.jump(13)
    compiler.go:153: > 18: goja._halt({})
    compiler.go:153: > 19: goja.jump(7)
    compiler.go:153: > 20: <nil>(<nil>)
    compiler.go:153: > 21: <nil>(<nil>)
    compiler.go:153: > 22: goja.loadVal(3)
    compiler.go:153: > 23: goja._halt({})
    compiler.go:153: > 24: goja._retStashless({})
    compiler.go:153: > 25: goja._halt({})
    compiler.go:153: > 26: goja.loadStack(1)
    compiler.go:153: > 27: goja._inc({})
    compiler.go:153: > 28: goja.storeStack(1)
    compiler.go:153: > 29: goja._pop({})
    compiler.go:153: > 30: goja.loadStack(2)
    compiler.go:153: > 31: goja._inc({})
    compiler.go:153: > 32: goja.storeStack(2)
    compiler.go:153: > 33: goja._pop({})
    compiler.go:153: > 34: goja.jump(-27)
    compiler.go:153: > 35: goja.loadStack(1)
    compiler.go:153: > 36: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(A)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestContinueOutOfTry (0.01s)
=== RUN   TestThisInCatch
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(O)
    compiler.go:153:  1: goja.bindName(f)
    compiler.go:153:  2: goja.bindName(o)
    compiler.go:153:  3: goja.resolveVar1(O)
    compiler.go:153:  4: *goja.newFunc(&{0x13d3620 O 0 false 2 85})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.try({7 0 false})
    compiler.go:153: > 3: goja._loadUndef({})
    compiler.go:153: > 4: goja.getVar1Callee(f)
    compiler.go:153: > 5: goja.call(0)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja._halt({})
    compiler.go:153: > 8: goja.jump(11)
    compiler.go:153: > 9: goja.storeStack(1)
    compiler.go:153: > 10: goja._pop({})
    compiler.go:153: > 11: goja.loadStack(0)
    compiler.go:153: > 12: goja.loadStack(1)
    compiler.go:153: > 13: goja._dup({})
    compiler.go:153: > 14: goja.getPropCallee(toString)
    compiler.go:153: > 15: goja.call(0)
    compiler.go:153: > 16: goja.setProp(value)
    compiler.go:153: > 17: goja._pop({})
    compiler.go:153: > 18: goja._halt({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(f)
    compiler.go:153:  8: *goja.newFunc(&{0x13d3680 f 0 false 88 119})
    compiler.go:151: values: [ex]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja._throw({})
    compiler.go:153: > 3: goja._loadUndef({})
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.resolveVar1(o)
    compiler.go:153:  12: goja.getVar1(O)
    compiler.go:153:  13: goja._new(0)
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.getVar1(o)
    compiler.go:153:  17: goja.getProp(value)
    compiler.go:153:  18: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestThisInCatch (0.00s)
=== RUN   TestNestedTry
    compiler.go:151: values: [ex1 ex2]
    compiler.go:153:  0: goja.bindName(ex)
    compiler.go:153:  1: goja.try({6 0 true})
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._throw({})
    compiler.go:153:  4: goja._halt({})
    compiler.go:153:  5: goja.jump(16)
    compiler.go:153:  6: <nil>(<nil>)
    compiler.go:153:  7: goja.enterCatch(er1)
    compiler.go:153:  8: goja.try({6 0 true})
    compiler.go:153:  9: goja.loadVal(1)
    compiler.go:153:  10: goja._throw({})
    compiler.go:153:  11: goja._halt({})
    compiler.go:153:  12: goja.jump(8)
    compiler.go:153:  13: <nil>(<nil>)
    compiler.go:153:  14: goja.enterCatch(er1)
    compiler.go:153:  15: goja.resolveVar1(ex)
    compiler.go:153:  16: goja.getLocal(0)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja._halt({})
    compiler.go:153:  20: goja._halt({})
    compiler.go:153:  21: goja.getVar1(ex)
    compiler.go:153:  22: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 2
--- PASS: TestNestedTry (0.00s)
=== RUN   TestNestedTryInStashlessFunc
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x13d3dd0 f 0 false 2 199})
    compiler.go:151: values: [ex1 ex2]
    compiler.go:153: > 0: goja.enterFuncStashless({4 0})
    compiler.go:153: > 1: goja.try({5 0 false})
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._throw({})
    compiler.go:153: > 4: goja._halt({})
    compiler.go:153: > 5: goja.jump(18)
    compiler.go:153: > 6: goja.storeStack(4)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.try({5 0 false})
    compiler.go:153: > 9: goja.loadVal(1)
    compiler.go:153: > 10: goja._throw({})
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja.jump(7)
    compiler.go:153: > 13: goja.storeStack(3)
    compiler.go:153: > 14: goja._pop({})
    compiler.go:153: > 15: goja.loadStack(3)
    compiler.go:153: > 16: goja.storeStack(2)
    compiler.go:153: > 17: goja._pop({})
    compiler.go:153: > 18: goja._halt({})
    compiler.go:153: > 19: goja.loadStack(4)
    compiler.go:153: > 20: goja.storeStack(1)
    compiler.go:153: > 21: goja._pop({})
    compiler.go:153: > 22: goja._halt({})
    compiler.go:153: > 23: goja.loadStack(1)
    compiler.go:153: > 24: goja.loadVal(0)
    compiler.go:153: > 25: goja._op_eq({})
    compiler.go:153: > 26: goja.jneq1(5)
    compiler.go:153: > 27: goja._pop({})
    compiler.go:153: > 28: goja.loadStack(2)
    compiler.go:153: > 29: goja.loadVal(1)
    compiler.go:153: > 30: goja._op_eq({})
    compiler.go:153: > 31: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 8
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestNestedTryInStashlessFunc (0.01s)
=== RUN   TestEvalInCatchInStashlessFunc
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x152e180 f 0 false 2 109})
    compiler.go:151: values: [ex1 ex = er1]
    compiler.go:153: > 0: goja.enterFunc(0)
    compiler.go:153: > 1: goja.bindName(ex)
    compiler.go:153: > 2: goja.try({6 0 true})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._halt({})
    compiler.go:153: > 6: goja.jump(9)
    compiler.go:153: > 7: <nil>(<nil>)
    compiler.go:153: > 8: goja.enterCatch(er1)
    compiler.go:153: > 9: goja._loadUndef({})
    compiler.go:153: > 10: goja.getVar1Callee(eval)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja.callEval(1)
    compiler.go:153: > 13: goja._pop({})
    compiler.go:153: > 14: goja._halt({})
    compiler.go:153: > 15: goja.getVar1(ex)
    compiler.go:153: > 16: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 2
--- PASS: TestEvalInCatchInStashlessFunc (0.00s)
=== RUN   TestCatchClosureInStashlessFunc
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x152e600 f 0 false 2 119})
    compiler.go:151: values: [ex1]
    compiler.go:153: > 0: goja.enterFunc(0)
    compiler.go:153: > 1: goja.bindName(ex)
    compiler.go:153: > 2: goja.try({6 0 true})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._halt({})
    compiler.go:153: > 6: goja.jump(7)
    compiler.go:153: > 7: <nil>(<nil>)
    compiler.go:153: > 8: goja.enterCatch(er1)
    compiler.go:153: > 9: *goja.newFunc(&{0x152e660  0 false 79 112})
    compiler.go:151: values: []
    compiler.go:153: >> 0: goja.enterFuncStashless({0 0})
    compiler.go:153: >> 1: goja.getLocal(0)
    compiler.go:153: >> 2: goja._retStashless({})
    compiler.go:153: > 10: goja._halt({})
    compiler.go:153: > 11: goja._ret({})
    compiler.go:153: > 12: goja._halt({})
    compiler.go:153: > 13: goja._loadUndef({})
    compiler.go:153: > 14: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja._loadUndef({})
    compiler.go:153:  7: goja.getVar1Callee(f)
    compiler.go:153:  8: goja.call(0)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 2
--- PASS: TestCatchClosureInStashlessFunc (0.01s)
=== RUN   TestCatchVarNotUsedInStashlessFunc
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x152ea20 f 0 false 2 102})
    compiler.go:151: values: [ex1 ok]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.try({7 0 false})
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._throw({})
    compiler.go:153: > 4: goja._halt({})
    compiler.go:153: > 5: goja.jump(7)
    compiler.go:153: > 6: <nil>(<nil>)
    compiler.go:153: > 7: <nil>(<nil>)
    compiler.go:153: > 8: goja.loadVal(1)
    compiler.go:153: > 9: goja.storeStack(1)
    compiler.go:153: > 10: goja._pop({})
    compiler.go:153: > 11: goja._halt({})
    compiler.go:153: > 12: goja.loadStack(1)
    compiler.go:153: > 13: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestCatchVarNotUsedInStashlessFunc (0.00s)
=== RUN   TestNew
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(O)
    compiler.go:153:  1: goja.resolveVar1(O)
    compiler.go:153:  2: *goja.newFunc(&{0x152ed80 O 0 false 2 34})
    compiler.go:151: values: [42]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.loadStack(0)
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja.setProp(x)
    compiler.go:153: > 5: goja._pop({})
    compiler.go:153: > 6: goja._loadUndef({})
    compiler.go:153: > 7: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.getVar1(O)
    compiler.go:153:  6: goja._new(0)
    compiler.go:153:  7: goja.getProp(x)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestNew (0.00s)
=== RUN   TestStringConstructor
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x152f140 F 0 false 2 63})
    compiler.go:151: values: [33   cows]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._loadUndef({})
    compiler.go:153: > 2: goja.getVar1Callee(String)
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja.call(1)
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja._add({})
    compiler.go:153: > 7: goja._loadUndef({})
    compiler.go:153: > 8: goja.getVar1Callee(String)
    compiler.go:153: > 9: goja.loadVal(2)
    compiler.go:153: > 10: goja.call(1)
    compiler.go:153: > 11: goja._add({})
    compiler.go:153: > 12: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestStringConstructor (0.00s)
=== RUN   TestError
    compiler.go:151: values: [test Error]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.bindName(e)
    compiler.go:153:  2: goja.bindName(rv)
    compiler.go:153:  3: goja.resolveVar1(F)
    compiler.go:153:  4: *goja.newFunc(&{0x152f4a0 F 0 false 2 47})
    compiler.go:151: values: [test]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(e)
    compiler.go:153:  8: goja._loadUndef({})
    compiler.go:153:  9: goja.getVar1Callee(F)
    compiler.go:153:  10: goja.call(0)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.resolveVar1(rv)
    compiler.go:153:  14: goja.getVar1(e)
    compiler.go:153:  15: goja.getProp(message)
    compiler.go:153:  16: goja.loadVal(0)
    compiler.go:153:  17: goja._op_eq({})
    compiler.go:153:  18: goja.jneq1(6)
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.getVar1(e)
    compiler.go:153:  21: goja.getProp(name)
    compiler.go:153:  22: goja.loadVal(1)
    compiler.go:153:  23: goja._op_eq({})
    compiler.go:153:  24: goja._putValue({})
    compiler.go:153:  25: goja._pop({})
    compiler.go:153:  26: goja._loadUndef({})
    compiler.go:153:  27: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestError (0.01s)
=== RUN   TestTypeError
    compiler.go:151: values: [test TypeError]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.bindName(e)
    compiler.go:153:  2: goja.resolveVar1(F)
    compiler.go:153:  3: *goja.newFunc(&{0x152f830 F 0 false 2 51})
    compiler.go:151: values: [test]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.getVar1(TypeError)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(e)
    compiler.go:153:  7: goja._loadUndef({})
    compiler.go:153:  8: goja.getVar1Callee(F)
    compiler.go:153:  9: goja.call(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.getVar1(e)
    compiler.go:153:  13: goja.getProp(message)
    compiler.go:153:  14: goja.loadVal(0)
    compiler.go:153:  15: goja._op_eq({})
    compiler.go:153:  16: goja.jneq1(6)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(e)
    compiler.go:153:  19: goja.getProp(name)
    compiler.go:153:  20: goja.loadVal(1)
    compiler.go:153:  21: goja._op_eq({})
    compiler.go:153:  22: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestTypeError (0.00s)
=== RUN   TestToString
    compiler.go:151: values: [42  ### ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(o1)
    compiler.go:153:  2: goja.resolveVar1(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja.setProp1(x)
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.getVar1(o)
    compiler.go:153:  9: *goja.newFunc(&{0x152fbc0  0 false 33 73})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja._loadUndef({})
    compiler.go:153: > 3: goja.getVar1Callee(String)
    compiler.go:153: > 4: goja.loadStack(0)
    compiler.go:153: > 5: goja.getProp(x)
    compiler.go:153: > 6: goja.call(1)
    compiler.go:153: > 7: goja._retStashless({})
    compiler.go:153:  10: goja.setProp(toString)
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(o1)
    compiler.go:153:  13: goja._newObject({})
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.getVar1(o)
    compiler.go:153:  17: goja._dup({})
    compiler.go:153:  18: goja.getPropCallee(toString)
    compiler.go:153:  19: goja.call(0)
    compiler.go:153:  20: goja.loadVal(1)
    compiler.go:153:  21: goja._add({})
    compiler.go:153:  22: goja.getVar1(o1)
    compiler.go:153:  23: goja._dup({})
    compiler.go:153:  24: goja.getPropCallee(toString)
    compiler.go:153:  25: goja.call(0)
    compiler.go:153:  26: goja._add({})
    compiler.go:153:  27: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestToString (0.01s)
=== RUN   TestEvalOrder
    compiler.go:151: values: [0 ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(trace)
    compiler.go:153:  2: goja.bindName(F1)
    compiler.go:153:  3: goja.bindName(F2)
    compiler.go:153:  4: goja.bindName(F3)
    compiler.go:153:  5: goja.bindName(rv)
    compiler.go:153:  6: goja.resolveVar1(F1)
    compiler.go:153:  7: *goja.newFunc(&{0x152e120 F1 0 false 64 121})
    compiler.go:151: values: [First!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(o)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.resolveVar1(F2)
    compiler.go:153:  11: *goja.newFunc(&{0x152e150 F2 0 false 124 184})
    compiler.go:151: values: [Second! f]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadVal(1)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(F3)
    compiler.go:153:  15: *goja.newFunc(&{0x152e180 F3 0 false 187 229})
    compiler.go:151: values: [Third!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja._loadUndef({})
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.resolveVar1(o)
    compiler.go:153:  19: goja._newObject({})
    compiler.go:153:  20: *goja.newFunc(&{0x152e1b0  0 false 14 36})
    compiler.go:151: values: [42]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  21: goja.setProp1(f)
    compiler.go:153:  22: goja.loadVal(0)
    compiler.go:153:  23: goja.setProp1(x)
    compiler.go:153:  24: goja._putValue({})
    compiler.go:153:  25: goja._pop({})
    compiler.go:153:  26: goja.resolveVar1(trace)
    compiler.go:153:  27: goja.loadVal(1)
    compiler.go:153:  28: goja._putValue({})
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.resolveVar1(rv)
    compiler.go:153:  31: goja._loadUndef({})
    compiler.go:153:  32: goja.getVar1Callee(F1)
    compiler.go:153:  33: goja.call(0)
    compiler.go:153:  34: goja._dup({})
    compiler.go:153:  35: goja._loadUndef({})
    compiler.go:153:  36: goja.getVar1Callee(F2)
    compiler.go:153:  37: goja.call(0)
    compiler.go:153:  38: goja._getElemCallee({})
    compiler.go:153:  39: goja._loadUndef({})
    compiler.go:153:  40: goja.getVar1Callee(F3)
    compiler.go:153:  41: goja.call(0)
    compiler.go:153:  42: goja.call(1)
    compiler.go:153:  43: goja._putValue({})
    compiler.go:153:  44: goja._pop({})
    compiler.go:153:  45: goja.resolveVar1(rv)
    compiler.go:153:  46: goja._loadUndef({})
    compiler.go:153:  47: goja._getValue({})
    compiler.go:153:  48: goja.getVar1(trace)
    compiler.go:153:  49: goja._add({})
    compiler.go:153:  50: goja.rdupN(1)
    compiler.go:153:  51: goja._putValue({})
    compiler.go:153:  52: goja._pop({})
    compiler.go:153:  53: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestEvalOrder (0.00s)
=== RUN   TestPostfixIncBracket
    compiler.go:151: values: [42 ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(trace)
    compiler.go:153:  2: goja.bindName(F1)
    compiler.go:153:  3: goja.bindName(F2)
    compiler.go:153:  4: goja.bindName(rv)
    compiler.go:153:  5: goja.resolveVar1(F1)
    compiler.go:153:  6: *goja.newFunc(&{0x152e570 F1 0 false 38 95})
    compiler.go:151: values: [First!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(o)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.resolveVar1(F2)
    compiler.go:153:  10: *goja.newFunc(&{0x152e5a0 F2 0 false 98 158})
    compiler.go:151: values: [Second! x]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadVal(1)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.resolveVar1(o)
    compiler.go:153:  14: goja._newObject({})
    compiler.go:153:  15: goja.loadVal(0)
    compiler.go:153:  16: goja.setProp1(x)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(trace)
    compiler.go:153:  20: goja.loadVal(1)
    compiler.go:153:  21: goja._putValue({})
    compiler.go:153:  22: goja._pop({})
    compiler.go:153:  23: goja.resolveVar1(rv)
    compiler.go:153:  24: goja._loadUndef({})
    compiler.go:153:  25: goja._loadUndef({})
    compiler.go:153:  26: goja.getVar1Callee(F1)
    compiler.go:153:  27: goja.call(0)
    compiler.go:153:  28: goja._loadUndef({})
    compiler.go:153:  29: goja.getVar1Callee(F2)
    compiler.go:153:  30: goja.call(0)
    compiler.go:153:  31: goja.dupN(1)
    compiler.go:153:  32: goja.dupN(1)
    compiler.go:153:  33: goja._getElem({})
    compiler.go:153:  34: goja._toNumber({})
    compiler.go:153:  35: goja.rdupN(3)
    compiler.go:153:  36: goja._inc({})
    compiler.go:153:  37: goja._setElem({})
    compiler.go:153:  38: goja._pop({})
    compiler.go:153:  39: goja._putValue({})
    compiler.go:153:  40: goja._pop({})
    compiler.go:153:  41: goja.resolveVar1(rv)
    compiler.go:153:  42: goja._loadUndef({})
    compiler.go:153:  43: goja._getValue({})
    compiler.go:153:  44: goja.getVar1(trace)
    compiler.go:153:  45: goja.getVar1(o)
    compiler.go:153:  46: goja.getProp(x)
    compiler.go:153:  47: goja._add({})
    compiler.go:153:  48: goja._add({})
    compiler.go:153:  49: goja.rdupN(1)
    compiler.go:153:  50: goja._putValue({})
    compiler.go:153:  51: goja._pop({})
    compiler.go:153:  52: goja._halt({})
    compiler_test.go:27: stack size: 6
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestPostfixIncBracket (0.00s)
=== RUN   TestPostfixIncDot
    compiler.go:151: values: [42 ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(trace)
    compiler.go:153:  2: goja.bindName(F1)
    compiler.go:153:  3: goja.bindName(rv)
    compiler.go:153:  4: goja.resolveVar1(F1)
    compiler.go:153:  5: *goja.newFunc(&{0x152e930 F1 0 false 38 95})
    compiler.go:151: values: [First!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(o)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(o)
    compiler.go:153:  9: goja._newObject({})
    compiler.go:153:  10: goja.loadVal(0)
    compiler.go:153:  11: goja.setProp1(x)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(trace)
    compiler.go:153:  15: goja.loadVal(1)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.resolveVar1(rv)
    compiler.go:153:  19: goja._loadUndef({})
    compiler.go:153:  20: goja._loadUndef({})
    compiler.go:153:  21: goja.getVar1Callee(F1)
    compiler.go:153:  22: goja.call(0)
    compiler.go:153:  23: goja._dup({})
    compiler.go:153:  24: goja.getProp(x)
    compiler.go:153:  25: goja._toNumber({})
    compiler.go:153:  26: goja.rdupN(2)
    compiler.go:153:  27: goja._inc({})
    compiler.go:153:  28: goja.setProp(x)
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja._putValue({})
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.resolveVar1(rv)
    compiler.go:153:  33: goja._loadUndef({})
    compiler.go:153:  34: goja._getValue({})
    compiler.go:153:  35: goja.getVar1(trace)
    compiler.go:153:  36: goja.getVar1(o)
    compiler.go:153:  37: goja.getProp(x)
    compiler.go:153:  38: goja._add({})
    compiler.go:153:  39: goja._add({})
    compiler.go:153:  40: goja.rdupN(1)
    compiler.go:153:  41: goja._putValue({})
    compiler.go:153:  42: goja._pop({})
    compiler.go:153:  43: goja._halt({})
    compiler_test.go:27: stack size: 5
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestPostfixIncDot (0.00s)
=== RUN   TestPrefixIncBracket
    compiler.go:151: values: [42 ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(trace)
    compiler.go:153:  2: goja.bindName(F1)
    compiler.go:153:  3: goja.bindName(F2)
    compiler.go:153:  4: goja.bindName(rv)
    compiler.go:153:  5: goja.resolveVar1(F1)
    compiler.go:153:  6: *goja.newFunc(&{0x152ecf0 F1 0 false 38 95})
    compiler.go:151: values: [First!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(o)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.resolveVar1(F2)
    compiler.go:153:  10: *goja.newFunc(&{0x152ed20 F2 0 false 98 158})
    compiler.go:151: values: [Second! x]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadVal(1)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.resolveVar1(o)
    compiler.go:153:  14: goja._newObject({})
    compiler.go:153:  15: goja.loadVal(0)
    compiler.go:153:  16: goja.setProp1(x)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(trace)
    compiler.go:153:  20: goja.loadVal(1)
    compiler.go:153:  21: goja._putValue({})
    compiler.go:153:  22: goja._pop({})
    compiler.go:153:  23: goja.resolveVar1(rv)
    compiler.go:153:  24: goja._loadUndef({})
    compiler.go:153:  25: goja.getVar1Callee(F1)
    compiler.go:153:  26: goja.call(0)
    compiler.go:153:  27: goja._loadUndef({})
    compiler.go:153:  28: goja.getVar1Callee(F2)
    compiler.go:153:  29: goja.call(0)
    compiler.go:153:  30: goja.dupN(1)
    compiler.go:153:  31: goja.dupN(1)
    compiler.go:153:  32: goja._getElem({})
    compiler.go:153:  33: goja._toNumber({})
    compiler.go:153:  34: goja._inc({})
    compiler.go:153:  35: goja._setElem({})
    compiler.go:153:  36: goja._putValue({})
    compiler.go:153:  37: goja._pop({})
    compiler.go:153:  38: goja.resolveVar1(rv)
    compiler.go:153:  39: goja._loadUndef({})
    compiler.go:153:  40: goja._getValue({})
    compiler.go:153:  41: goja.getVar1(trace)
    compiler.go:153:  42: goja.getVar1(o)
    compiler.go:153:  43: goja.getProp(x)
    compiler.go:153:  44: goja._add({})
    compiler.go:153:  45: goja._add({})
    compiler.go:153:  46: goja.rdupN(1)
    compiler.go:153:  47: goja._putValue({})
    compiler.go:153:  48: goja._pop({})
    compiler.go:153:  49: goja._halt({})
    compiler_test.go:27: stack size: 5
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestPrefixIncBracket (0.00s)
=== RUN   TestPrefixIncDot
    compiler.go:151: values: [42 ]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(trace)
    compiler.go:153:  2: goja.bindName(F1)
    compiler.go:153:  3: goja.bindName(rv)
    compiler.go:153:  4: goja.resolveVar1(F1)
    compiler.go:153:  5: *goja.newFunc(&{0x152f0b0 F1 0 false 38 95})
    compiler.go:151: values: [First!]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.getVar1(o)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(o)
    compiler.go:153:  9: goja._newObject({})
    compiler.go:153:  10: goja.loadVal(0)
    compiler.go:153:  11: goja.setProp1(x)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(trace)
    compiler.go:153:  15: goja.loadVal(1)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.resolveVar1(rv)
    compiler.go:153:  19: goja._loadUndef({})
    compiler.go:153:  20: goja.getVar1Callee(F1)
    compiler.go:153:  21: goja.call(0)
    compiler.go:153:  22: goja._dup({})
    compiler.go:153:  23: goja.getProp(x)
    compiler.go:153:  24: goja._toNumber({})
    compiler.go:153:  25: goja._inc({})
    compiler.go:153:  26: goja.setProp(x)
    compiler.go:153:  27: goja._putValue({})
    compiler.go:153:  28: goja._pop({})
    compiler.go:153:  29: goja.resolveVar1(rv)
    compiler.go:153:  30: goja._loadUndef({})
    compiler.go:153:  31: goja._getValue({})
    compiler.go:153:  32: goja.getVar1(trace)
    compiler.go:153:  33: goja.getVar1(o)
    compiler.go:153:  34: goja.getProp(x)
    compiler.go:153:  35: goja._add({})
    compiler.go:153:  36: goja._add({})
    compiler.go:153:  37: goja.rdupN(1)
    compiler.go:153:  38: goja._putValue({})
    compiler.go:153:  39: goja._pop({})
    compiler.go:153:  40: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 0
--- PASS: TestPrefixIncDot (0.01s)
=== RUN   TestPostDecObj
    compiler.go:151: values: [false 1 true]
    compiler.go:153:  0: goja.bindName(object)
    compiler.go:153:  1: goja.bindName(y)
    compiler.go:153:  2: goja.bindName(ok)
    compiler.go:153:  3: goja.resolveVar1(object)
    compiler.go:153:  4: goja._newObject({})
    compiler.go:153:  5: *goja.newFunc(&{0x152f440  0 false 25 46})
    compiler.go:151: values: [1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  6: goja.setProp1(valueOf)
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.resolveVar1(y)
    compiler.go:153:  10: goja.resolveVar1(object)
    compiler.go:153:  11: goja._loadUndef({})
    compiler.go:153:  12: goja._getValue({})
    compiler.go:153:  13: goja._toNumber({})
    compiler.go:153:  14: goja.rdupN(1)
    compiler.go:153:  15: goja._dec({})
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.resolveVar1(ok)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja._putValue({})
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.getVar1(y)
    compiler.go:153:  25: goja.loadVal(1)
    compiler.go:153:  26: goja._op_strict_eq({})
    compiler.go:153:  27: goja.jne(5)
    compiler.go:153:  28: goja.resolveVar1(ok)
    compiler.go:153:  29: goja.loadVal(2)
    compiler.go:153:  30: goja._putValue({})
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.getVar1(ok)
    compiler.go:153:  33: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestPostDecObj (0.00s)
=== RUN   TestPropAcc1
    compiler.go:151: values: [1 1]
    compiler.go:153:  0: goja.loadVal(0)
    compiler.go:153:  1: goja._dup({})
    compiler.go:153:  2: goja.getPropCallee(toString)
    compiler.go:153:  3: goja.call(0)
    compiler.go:153:  4: goja.loadVal(1)
    compiler.go:153:  5: goja._op_strict_eq({})
    compiler.go:153:  6: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestPropAcc1 (0.00s)
=== RUN   TestEvalDirect
    compiler.go:151: values: [false]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.bindName(foo)
    compiler.go:153:  2: goja.bindName(o)
    compiler.go:153:  3: goja.bindName(f)
    compiler.go:153:  4: goja.resolveVar1(foo)
    compiler.go:153:  5: *goja.newFunc(&{0x152faa0 foo 0 false 23 51})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(rv)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(f)
    compiler.go:153:  9: *goja.newFunc(&{0x152fad0 f 0 false 76 162})
    compiler.go:151: values: [o.bar( foo() );]
    compiler.go:153: > 0: goja.enterFunc(0)
    compiler.go:153: > 1: goja._boxThis({})
    compiler.go:153: > 2: goja.try({9 0 true})
    compiler.go:153: > 3: goja._loadUndef({})
    compiler.go:153: > 4: goja.getVar1Callee(eval)
    compiler.go:153: > 5: goja.loadVal(0)
    compiler.go:153: > 6: goja.callEval(1)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja._halt({})
    compiler.go:153: > 9: goja.jump(4)
    compiler.go:153: > 10: <nil>(<nil>)
    compiler.go:153: > 11: goja.enterCatch(e)
    compiler.go:153: > 12: goja._halt({})
    compiler.go:153: > 13: goja._loadUndef({})
    compiler.go:153: > 14: goja._ret({})
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(rv)
    compiler.go:153:  13: goja.loadVal(0)
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.resolveVar1(o)
    compiler.go:153:  17: goja._newObject({})
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja._loadUndef({})
    compiler.go:153:  21: goja.getVar1Callee(f)
    compiler.go:153:  22: goja.call(0)
    compiler.go:153:  23: goja._halt({})
    compiler_test.go:27: stack size: 11
    compiler_test.go:28: stashAllocs: 2
--- PASS: TestEvalDirect (0.00s)
=== RUN   TestEvalRet
    compiler.go:151: values: [for (var i = 0; i < 3; i++) {i}]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja.getVar1Callee(eval)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja.callEval(1)
    compiler.go:153:  4: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEvalRet (0.00s)
=== RUN   TestEvalFunctionDecl
    compiler.go:151: values: [function F() {}]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja.getVar1Callee(eval)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja.callEval(1)
    compiler.go:153:  4: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEvalFunctionDecl (0.00s)
=== RUN   TestEvalFunctionExpr
    compiler.go:151: values: [(function F() {return 42;})]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja._loadUndef({})
    compiler.go:153:  2: goja.getVar1Callee(eval)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja.callEval(1)
    compiler.go:153:  5: goja.call(0)
    compiler.go:153:  6: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestEvalFunctionExpr (0.01s)
=== RUN   TestLoopRet
    compiler.go:151: values: [0 20 1]
    compiler.go:153:  0: goja.bindName(i)
    compiler.go:153:  1: goja.resolveVar1(i)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1(i)
    compiler.go:153:  7: goja.loadVal(1)
    compiler.go:153:  8: goja._op_lt({})
    compiler.go:153:  9: goja.jne(18)
    compiler.go:153:  10: goja.getVar1(i)
    compiler.go:153:  11: goja.loadVal(2)
    compiler.go:153:  12: goja._op_gt({})
    compiler.go:153:  13: goja.jne(5)
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja._loadUndef({})
    compiler.go:153:  16: goja.jump(11)
    compiler.go:153:  17: goja.jump(2)
    compiler.go:153:  18: goja.getVar1(i)
    compiler.go:153:  19: goja.rdupN(1)
    compiler.go:153:  20: goja._pop({})
    compiler.go:153:  21: goja.resolveVar1(i)
    compiler.go:153:  22: goja._getValue({})
    compiler.go:153:  23: goja._inc({})
    compiler.go:153:  24: goja._putValue({})
    compiler.go:153:  25: goja._pop({})
    compiler.go:153:  26: goja.jump(-20)
    compiler.go:153:  27: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestLoopRet (0.00s)
=== RUN   TestLoopRet1
    compiler.go:151: values: [0 20]
    compiler.go:153:  0: goja.bindName(i)
    compiler.go:153:  1: goja.resolveVar1(i)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1(i)
    compiler.go:153:  7: goja.loadVal(1)
    compiler.go:153:  8: goja._op_lt({})
    compiler.go:153:  9: goja.jne(10)
    compiler.go:153:  10: goja._loadUndef({})
    compiler.go:153:  11: goja.rdupN(1)
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.resolveVar1(i)
    compiler.go:153:  14: goja._getValue({})
    compiler.go:153:  15: goja._inc({})
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.jump(-12)
    compiler.go:153:  19: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestLoopRet1 (0.00s)
=== RUN   TestInstanceof
    compiler.go:151: values: [true]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.try({8 0 true})
    compiler.go:153:  2: goja._loadUndef({})
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja.call(0)
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja._halt({})
    compiler.go:153:  7: goja.jump(10)
    compiler.go:153:  8: <nil>(<nil>)
    compiler.go:153:  9: goja.enterCatch(e)
    compiler.go:153:  10: goja.resolveVar1(rv)
    compiler.go:153:  11: goja.getLocal(0)
    compiler.go:153:  12: goja.getVar1(TypeError)
    compiler.go:153:  13: goja._op_instanceof({})
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja._halt({})
    compiler.go:153:  17: goja._loadUndef({})
    compiler.go:153:  18: goja._halt({})
    compiler_test.go:27: stack size: 2
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestInstanceof (0.00s)
=== RUN   TestStrictAssign
    compiler.go:151: values: [false  ]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.bindName(called)
    compiler.go:153:  2: goja.bindName(F)
    compiler.go:153:  3: goja.resolveVar1Strict(F)
    compiler.go:153:  4: *goja.newFunc(&{0x14ab860 F 0 true 47 93})
    compiler.go:151: values: [true 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1Strict(called)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1Strict(called)
    compiler.go:153:  8: goja.loadVal(0)
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.try({10 0 true})
    compiler.go:153:  12: goja.resolveVar1Strict(x)
    compiler.go:153:  13: goja._loadUndef({})
    compiler.go:153:  14: goja.getVar1Callee(F)
    compiler.go:153:  15: goja.call(0)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja._halt({})
    compiler.go:153:  19: goja.jump(10)
    compiler.go:153:  20: <nil>(<nil>)
    compiler.go:153:  21: goja.enterCatch(e)
    compiler.go:153:  22: goja.resolveVar1Strict(rv)
    compiler.go:153:  23: goja.getLocal(0)
    compiler.go:153:  24: goja.getVar1(ReferenceError)
    compiler.go:153:  25: goja._op_instanceof({})
    compiler.go:153:  26: goja._putValue({})
    compiler.go:153:  27: goja._pop({})
    compiler.go:153:  28: goja._halt({})
    compiler.go:153:  29: goja.resolveVar1Strict(rv)
    compiler.go:153:  30: goja._loadUndef({})
    compiler.go:153:  31: goja._getValue({})
    compiler.go:153:  32: goja.loadVal(1)
    compiler.go:153:  33: goja.getVar1(called)
    compiler.go:153:  34: goja._add({})
    compiler.go:153:  35: goja._add({})
    compiler.go:153:  36: goja.rdupN(1)
    compiler.go:153:  37: goja._putValue({})
    compiler.go:153:  38: goja._pop({})
    compiler.go:153:  39: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestStrictAssign (0.01s)
=== RUN   TestStrictScope
    compiler.go:151: values: [false 1  ]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.bindName(called)
    compiler.go:153:  2: goja.bindName(F)
    compiler.go:153:  3: goja.resolveVar1(F)
    compiler.go:153:  4: *goja.newFunc(&{0x14abc50 F 0 true 32 74})
    compiler.go:151: values: [1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1Strict(x)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(called)
    compiler.go:153:  8: goja.loadVal(0)
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.try({8 0 true})
    compiler.go:153:  12: goja._loadUndef({})
    compiler.go:153:  13: goja.getVar1Callee(F)
    compiler.go:153:  14: goja.call(0)
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja._halt({})
    compiler.go:153:  17: goja.jump(10)
    compiler.go:153:  18: <nil>(<nil>)
    compiler.go:153:  19: goja.enterCatch(e)
    compiler.go:153:  20: goja.resolveVar1(rv)
    compiler.go:153:  21: goja.getLocal(0)
    compiler.go:153:  22: goja.getVar1(ReferenceError)
    compiler.go:153:  23: goja._op_instanceof({})
    compiler.go:153:  24: goja._putValue({})
    compiler.go:153:  25: goja._pop({})
    compiler.go:153:  26: goja._halt({})
    compiler.go:153:  27: goja.resolveVar1(x)
    compiler.go:153:  28: goja.loadVal(1)
    compiler.go:153:  29: goja._putValue({})
    compiler.go:153:  30: goja._pop({})
    compiler.go:153:  31: goja.resolveVar1(rv)
    compiler.go:153:  32: goja._loadUndef({})
    compiler.go:153:  33: goja._getValue({})
    compiler.go:153:  34: goja.loadVal(2)
    compiler.go:153:  35: goja.getVar1(x)
    compiler.go:153:  36: goja._add({})
    compiler.go:153:  37: goja._add({})
    compiler.go:153:  38: goja.rdupN(1)
    compiler.go:153:  39: goja._putValue({})
    compiler.go:153:  40: goja._pop({})
    compiler.go:153:  41: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestStrictScope (0.00s)
=== RUN   TestStringObj
    compiler.go:151: values: [test 0 2 1]
    compiler.go:153:  0: goja.bindName(s)
    compiler.go:153:  1: goja.resolveVar1(s)
    compiler.go:153:  2: goja.getVar1(String)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._new(1)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.getVar1(s)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._getElem({})
    compiler.go:153:  10: goja.getVar1(s)
    compiler.go:153:  11: goja.loadVal(2)
    compiler.go:153:  12: goja._getElem({})
    compiler.go:153:  13: goja._add({})
    compiler.go:153:  14: goja.getVar1(s)
    compiler.go:153:  15: goja.loadVal(3)
    compiler.go:153:  16: goja._getElem({})
    compiler.go:153:  17: goja._add({})
    compiler.go:153:  18: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestStringObj (0.01s)
=== RUN   TestStringPrimitive
    compiler.go:151: values: [test 0 2 1]
    compiler.go:153:  0: goja.bindName(s)
    compiler.go:153:  1: goja.resolveVar1(s)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.getVar1(s)
    compiler.go:153:  6: goja.loadVal(1)
    compiler.go:153:  7: goja._getElem({})
    compiler.go:153:  8: goja.getVar1(s)
    compiler.go:153:  9: goja.loadVal(2)
    compiler.go:153:  10: goja._getElem({})
    compiler.go:153:  11: goja._add({})
    compiler.go:153:  12: goja.getVar1(s)
    compiler.go:153:  13: goja.loadVal(3)
    compiler.go:153:  14: goja._getElem({})
    compiler.go:153:  15: goja._add({})
    compiler.go:153:  16: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestStringPrimitive (0.00s)
=== RUN   TestCallGlobalObject
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.try({8 0 true})
    compiler.go:153:  2: goja._loadUndef({})
    compiler.go:153:  3: goja._loadGlobalObject({})
    compiler.go:153:  4: goja.call(0)
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja._halt({})
    compiler.go:153:  7: goja.jump(10)
    compiler.go:153:  8: <nil>(<nil>)
    compiler.go:153:  9: goja.enterCatch(e)
    compiler.go:153:  10: goja.resolveVar1(rv)
    compiler.go:153:  11: goja.getLocal(0)
    compiler.go:153:  12: goja.getVar1(TypeError)
    compiler.go:153:  13: goja._op_instanceof({})
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja._halt({})
    compiler.go:153:  17: goja._loadUndef({})
    compiler.go:153:  18: goja._halt({})
    compiler_test.go:27: stack size: 2
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestCallGlobalObject (0.00s)
=== RUN   TestFuncLength
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10ec9f0 F 2 false 2 24})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja._loadUndef({})
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.getVar1(F)
    compiler.go:153:  6: goja.getProp(length)
    compiler.go:153:  7: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestFuncLength (0.00s)
=== RUN   TestNativeFuncLength
    compiler.go:151: values: []
    compiler.go:153:  0: goja.getVar1(eval)
    compiler.go:153:  1: goja.getProp(length)
    compiler.go:153:  2: goja.getVar1(Object)
    compiler.go:153:  3: goja.getProp(defineProperty)
    compiler.go:153:  4: goja.getProp(length)
    compiler.go:153:  5: goja._add({})
    compiler.go:153:  6: goja.getVar1(String)
    compiler.go:153:  7: goja.getProp(length)
    compiler.go:153:  8: goja._add({})
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestNativeFuncLength (0.00s)
=== RUN   TestArguments
    compiler.go:151: values: [1 2 3]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10ecff0 F 0 false 2 67})
    compiler.go:151: values: [  1]
    compiler.go:153: > 0: goja.enterFunc(0)
    compiler.go:153: > 1: goja.bindName(arguments)
    compiler.go:153: > 2: goja.createArgs(0)
    compiler.go:153: > 3: goja.setLocalP(0)
    compiler.go:153: > 4: goja.getLocal(0)
    compiler.go:153: > 5: goja.getProp(length)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._add({})
    compiler.go:153: > 8: goja.getLocal(0)
    compiler.go:153: > 9: goja.loadVal(1)
    compiler.go:153: > 10: goja._getElem({})
    compiler.go:153: > 11: goja._add({})
    compiler.go:153: > 12: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.loadVal(2)
    compiler.go:153:  10: goja.call(3)
    compiler.go:153:  11: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArguments (0.01s)
=== RUN   TestArgumentsPut
    compiler.go:151: values: [5 2]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10ed3b0 F 2 false 2 67})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFunc(2)
    compiler.go:153: > 1: goja.bindName(x)
    compiler.go:153: > 2: goja.bindName(y)
    compiler.go:153: > 3: goja.bindName(arguments)
    compiler.go:153: > 4: goja.createArgs(2)
    compiler.go:153: > 5: goja.setLocalP(2)
    compiler.go:153: > 6: goja.getLocal(2)
    compiler.go:153: > 7: goja.loadVal(0)
    compiler.go:153: > 8: goja.dupN(1)
    compiler.go:153: > 9: goja.dupN(1)
    compiler.go:153: > 10: goja._getElem({})
    compiler.go:153: > 11: goja.getLocal(2)
    compiler.go:153: > 12: goja.loadVal(1)
    compiler.go:153: > 13: goja._getElem({})
    compiler.go:153: > 14: goja._sub({})
    compiler.go:153: > 15: goja._setElem({})
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.getLocal(0)
    compiler.go:153: > 18: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.call(2)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArgumentsPut (0.00s)
=== RUN   TestArgumentsPutStrict
    compiler.go:151: values: [5 2]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10ed770 F 2 true 2 83})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFunc(2)
    compiler.go:153: > 1: goja.bindName(x)
    compiler.go:153: > 2: goja.bindName(y)
    compiler.go:153: > 3: goja.bindName(arguments)
    compiler.go:153: > 4: goja.createArgsStrict(2)
    compiler.go:153: > 5: goja.setLocalP(2)
    compiler.go:153: > 6: goja.getLocal(2)
    compiler.go:153: > 7: goja.loadVal(0)
    compiler.go:153: > 8: goja.dupN(1)
    compiler.go:153: > 9: goja.dupN(1)
    compiler.go:153: > 10: goja._getElem({})
    compiler.go:153: > 11: goja.getLocal(2)
    compiler.go:153: > 12: goja.loadVal(1)
    compiler.go:153: > 13: goja._getElem({})
    compiler.go:153: > 14: goja._sub({})
    compiler.go:153: > 15: goja._setElemStrict({})
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.getLocal(0)
    compiler.go:153: > 18: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.call(2)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArgumentsPutStrict (0.01s)
=== RUN   TestArgumentsExtra
    compiler.go:151: values: [1 2 42]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10edb30 F 2 false 2 46})
    compiler.go:151: values: [2]
    compiler.go:153: > 0: goja.enterFunc(2)
    compiler.go:153: > 1: goja.bindName(x)
    compiler.go:153: > 2: goja.bindName(y)
    compiler.go:153: > 3: goja.bindName(arguments)
    compiler.go:153: > 4: goja.createArgs(2)
    compiler.go:153: > 5: goja.setLocalP(2)
    compiler.go:153: > 6: goja.getLocal(2)
    compiler.go:153: > 7: goja.loadVal(0)
    compiler.go:153: > 8: goja._getElem({})
    compiler.go:153: > 9: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.loadVal(2)
    compiler.go:153:  10: goja.call(3)
    compiler.go:153:  11: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArgumentsExtra (0.00s)
=== RUN   TestArgumentsExist
    compiler.go:151: values: [1 42]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x10edef0 F 2 false 2 51})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-2)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.call(2)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestArgumentsExist (0.00s)
=== RUN   TestArgumentsDelete
    compiler.go:151: values: [1]
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x105c5a0 f 1 false 2 76})
    compiler.go:151: values: [0 42]
    compiler.go:153: > 0: goja.enterFunc(1)
    compiler.go:153: > 1: goja.bindName(x)
    compiler.go:153: > 2: goja.bindName(arguments)
    compiler.go:153: > 3: goja.createArgs(1)
    compiler.go:153: > 4: goja.setLocalP(1)
    compiler.go:153: > 5: goja.getLocal(1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._deleteElem({})
    compiler.go:153: > 8: goja._pop({})
    compiler.go:153: > 9: goja.getLocal(1)
    compiler.go:153: > 10: goja.loadVal(0)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._setElem({})
    compiler.go:153: > 13: goja._pop({})
    compiler.go:153: > 14: goja.getLocal(0)
    compiler.go:153: > 15: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.call(1)
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArgumentsDelete (0.00s)
=== RUN   TestWith
    compiler.go:151: values: [1 41]
    compiler.go:153:  0: goja.bindName(b)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.resolveVar1(b)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(o)
    compiler.go:153:  7: goja._newObject({})
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.setProp1(a)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.getVar1(o)
    compiler.go:153:  13: goja._enterWith({})
    compiler.go:153:  14: goja.resolveVar1(a)
    compiler.go:153:  15: goja._getValue({})
    compiler.go:153:  16: goja.getVar1(b)
    compiler.go:153:  17: goja._add({})
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja._leaveWith({})
    compiler.go:153:  21: goja.getVar1(o)
    compiler.go:153:  22: goja.getProp(a)
    compiler.go:153:  23: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestWith (0.01s)
=== RUN   TestWithInFunc
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x105ccf0 F 0 false 2 115})
    compiler.go:151: values: [1 0 40]
    compiler.go:153: > 0: goja.enterFunc(0)
    compiler.go:153: > 1: goja.bindName(b)
    compiler.go:153: > 2: goja.bindName(c)
    compiler.go:153: > 3: goja.bindName(o)
    compiler.go:153: > 4: goja.loadVal(0)
    compiler.go:153: > 5: goja.setLocal(0)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.loadVal(1)
    compiler.go:153: > 8: goja.setLocal(1)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja._newObject({})
    compiler.go:153: > 11: goja.loadVal(2)
    compiler.go:153: > 12: goja.setProp1(a)
    compiler.go:153: > 13: goja.loadVal(0)
    compiler.go:153: > 14: goja.setProp1(c)
    compiler.go:153: > 15: goja.setLocal(2)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.getLocal(2)
    compiler.go:153: > 18: goja._enterWith({})
    compiler.go:153: > 19: goja.resolveVar1(a)
    compiler.go:153: > 20: goja._getValue({})
    compiler.go:153: > 21: goja.getVar({b 16777216 false})
    compiler.go:153: > 22: goja.getVar({c 16777217 false})
    compiler.go:153: > 23: goja._add({})
    compiler.go:153: > 24: goja._add({})
    compiler.go:153: > 25: goja._putValue({})
    compiler.go:153: > 26: goja._pop({})
    compiler.go:153: > 27: goja._leaveWith({})
    compiler.go:153: > 28: goja.getLocal(2)
    compiler.go:153: > 29: goja.getProp(a)
    compiler.go:153: > 30: goja._ret({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 2
--- PASS: TestWithInFunc (0.00s)
=== RUN   TestAssignNonExtendable
    compiler.go:151: values: [42]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.resolveVar1Strict(F)
    compiler.go:153:  3: *goja.newFunc(&{0x105d110 F 0 true 18 53})
    compiler.go:151: values: [1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.loadStack(0)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja.setPropStrict(x)
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1Strict(o)
    compiler.go:153:  7: goja.getVar1(F)
    compiler.go:153:  8: goja._new(0)
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.getVar1(Object)
    compiler.go:153:  12: goja._dup({})
    compiler.go:153:  13: goja.getPropCallee(preventExtensions)
    compiler.go:153:  14: goja.getVar1(o)
    compiler.go:153:  15: goja.call(1)
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja.getVar1(o)
    compiler.go:153:  18: goja.loadVal(0)
    compiler.go:153:  19: goja.setPropStrict(x)
    compiler.go:153:  20: goja._pop({})
    compiler.go:153:  21: goja.getVar1(o)
    compiler.go:153:  22: goja.getProp(x)
    compiler.go:153:  23: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestAssignNonExtendable (0.01s)
=== RUN   TestAssignNonExtendable1
    compiler.go:151: values: [42  ]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.bindName(rv)
    compiler.go:153:  3: goja.resolveVar1Strict(F)
    compiler.go:153:  4: *goja.newFunc(&{0x105d4d0 F 0 true 18 35})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._loadUndef({})
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1Strict(o)
    compiler.go:153:  8: goja.getVar1(F)
    compiler.go:153:  9: goja._new(0)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.getVar1(Object)
    compiler.go:153:  13: goja._dup({})
    compiler.go:153:  14: goja.getPropCallee(preventExtensions)
    compiler.go:153:  15: goja.getVar1(o)
    compiler.go:153:  16: goja.call(1)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.try({8 0 true})
    compiler.go:153:  19: goja.getVar1(o)
    compiler.go:153:  20: goja.loadVal(0)
    compiler.go:153:  21: goja.setPropStrict(x)
    compiler.go:153:  22: goja._pop({})
    compiler.go:153:  23: goja._halt({})
    compiler.go:153:  24: goja.jump(11)
    compiler.go:153:  25: <nil>(<nil>)
    compiler.go:153:  26: goja.enterCatch(e)
    compiler.go:153:  27: goja.resolveVar1Strict(rv)
    compiler.go:153:  28: goja.getLocal(0)
    compiler.go:153:  29: goja.getProp(constructor)
    compiler.go:153:  30: goja.getVar1(TypeError)
    compiler.go:153:  31: goja._op_strict_eq({})
    compiler.go:153:  32: goja._putValue({})
    compiler.go:153:  33: goja._pop({})
    compiler.go:153:  34: goja._halt({})
    compiler.go:153:  35: goja.resolveVar1Strict(rv)
    compiler.go:153:  36: goja._loadUndef({})
    compiler.go:153:  37: goja._getValue({})
    compiler.go:153:  38: goja.loadVal(1)
    compiler.go:153:  39: goja.getVar1(o)
    compiler.go:153:  40: goja.getProp(x)
    compiler.go:153:  41: goja._add({})
    compiler.go:153:  42: goja._add({})
    compiler.go:153:  43: goja.rdupN(1)
    compiler.go:153:  44: goja._putValue({})
    compiler.go:153:  45: goja._pop({})
    compiler.go:153:  46: goja._halt({})
    compiler_test.go:27: stack size: 4
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestAssignNonExtendable1 (0.00s)
=== RUN   TestAssignStrict
    compiler.go:151: values: [eval = 42]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.try({9 0 true})
    compiler.go:153:  2: goja._loadUndef({})
    compiler.go:153:  3: goja.getVar1Callee(eval)
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja.callEvalStrict(1)
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja._halt({})
    compiler.go:153:  8: goja.jump(10)
    compiler.go:153:  9: <nil>(<nil>)
    compiler.go:153:  10: goja.enterCatch(e)
    compiler.go:153:  11: goja.resolveVar1Strict(rv)
    compiler.go:153:  12: goja.getLocal(0)
    compiler.go:153:  13: goja.getVar1(SyntaxError)
    compiler.go:153:  14: goja._op_instanceof({})
    compiler.go:153:  15: goja._putValue({})
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja._halt({})
    compiler.go:153:  18: goja._loadUndef({})
    compiler.go:153:  19: goja._halt({})
    compiler_test.go:27: stack size: 3
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestAssignStrict (0.00s)
=== RUN   TestIllegalArgmentName
    compiler.go:151: values: [function F(eval) {}]
    compiler.go:153:  0: goja.bindName(rv)
    compiler.go:153:  1: goja.try({9 0 true})
    compiler.go:153:  2: goja._loadUndef({})
    compiler.go:153:  3: goja.getVar1Callee(eval)
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja.callEvalStrict(1)
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja._halt({})
    compiler.go:153:  8: goja.jump(10)
    compiler.go:153:  9: <nil>(<nil>)
    compiler.go:153:  10: goja.enterCatch(e)
    compiler.go:153:  11: goja.resolveVar1Strict(rv)
    compiler.go:153:  12: goja.getLocal(0)
    compiler.go:153:  13: goja.getVar1(SyntaxError)
    compiler.go:153:  14: goja._op_instanceof({})
    compiler.go:153:  15: goja._putValue({})
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja._halt({})
    compiler.go:153:  18: goja._loadUndef({})
    compiler.go:153:  19: goja._halt({})
    compiler_test.go:27: stack size: 3
    compiler_test.go:28: stashAllocs: 1
--- PASS: TestIllegalArgmentName (0.01s)
=== RUN   TestFunction
    compiler.go:151: values: [ return ' one' arg return ' ' + arg two]
    compiler.go:153:  0: goja.bindName(f0)
    compiler.go:153:  1: goja.bindName(f1)
    compiler.go:153:  2: goja.bindName(f2)
    compiler.go:153:  3: goja.resolveVar1(f0)
    compiler.go:153:  4: goja._loadUndef({})
    compiler.go:153:  5: goja.getVar1Callee(Function)
    compiler.go:153:  6: goja.loadVal(0)
    compiler.go:153:  7: goja.call(1)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.resolveVar1(f1)
    compiler.go:153:  11: goja._loadUndef({})
    compiler.go:153:  12: goja.getVar1Callee(Function)
    compiler.go:153:  13: goja.loadVal(1)
    compiler.go:153:  14: goja.call(1)
    compiler.go:153:  15: goja._putValue({})
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja.resolveVar1(f2)
    compiler.go:153:  18: goja._loadUndef({})
    compiler.go:153:  19: goja.getVar1Callee(Function)
    compiler.go:153:  20: goja.loadVal(2)
    compiler.go:153:  21: goja.loadVal(3)
    compiler.go:153:  22: goja.call(2)
    compiler.go:153:  23: goja._putValue({})
    compiler.go:153:  24: goja._pop({})
    compiler.go:153:  25: goja._loadUndef({})
    compiler.go:153:  26: goja.getVar1Callee(f0)
    compiler.go:153:  27: goja.call(0)
    compiler.go:153:  28: goja._loadUndef({})
    compiler.go:153:  29: goja.getVar1Callee(f1)
    compiler.go:153:  30: goja.call(0)
    compiler.go:153:  31: goja._add({})
    compiler.go:153:  32: goja._loadUndef({})
    compiler.go:153:  33: goja.getVar1Callee(f2)
    compiler.go:153:  34: goja.loadVal(4)
    compiler.go:153:  35: goja.call(1)
    compiler.go:153:  36: goja._add({})
    compiler.go:153:  37: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestFunction (0.00s)
=== RUN   TestFunction1
    compiler.go:151: values: [1]
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x132a690 f1 1 false 11 96})
    compiler.go:151: values: [0 true 1]
    compiler.go:153: > 0: goja.enterFuncStashless({1 1})
    compiler.go:153: > 1: goja._loadCallee({})
    compiler.go:153: > 2: goja.storeStackP(1)
    compiler.go:153: > 3: goja.loadStack(-1)
    compiler.go:153: > 4: goja.loadVal(0)
    compiler.go:153: > 5: goja._op_eq({})
    compiler.go:153: > 6: goja.jne(3)
    compiler.go:153: > 7: goja.loadVal(1)
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153: > 9: goja._loadUndef({})
    compiler.go:153: > 10: goja.loadStack(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja._sub({})
    compiler.go:153: > 14: goja.call(1)
    compiler.go:153: > 15: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.call(1)
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 10
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestFunction1 (0.01s)
=== RUN   TestFunction2
    compiler.go:151: values: [ 1]
    compiler.go:153:  0: goja.bindName(trace)
    compiler.go:153:  1: goja.bindName(f)
    compiler.go:153:  2: goja.bindName(f1)
    compiler.go:153:  3: goja.bindName(f2)
    compiler.go:153:  4: goja.resolveVar1(f)
    compiler.go:153:  5: *goja.newFunc(&{0x132aa20 f 1 false 19 147})
    compiler.go:151: values: [f( ) 0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja._add({})
    compiler.go:153: > 6: goja.loadVal(1)
    compiler.go:153: > 7: goja._add({})
    compiler.go:153: > 8: goja._add({})
    compiler.go:153: > 9: goja._putValue({})
    compiler.go:153: > 10: goja._pop({})
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja.loadVal(2)
    compiler.go:153: > 13: goja._op_eq({})
    compiler.go:153: > 14: goja.jne(3)
    compiler.go:153: > 15: goja._loadUndef({})
    compiler.go:153: > 16: goja._retStashless({})
    compiler.go:153: > 17: goja._loadUndef({})
    compiler.go:153: > 18: goja.getVar1Callee(f)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja.loadVal(3)
    compiler.go:153: > 21: goja._sub({})
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._retStashless({})
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(f1)
    compiler.go:153:  9: *goja.newFunc(&{0x132aa50 f1 0 false 150 189})
    compiler.go:151: values: [f1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(trace)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._add({})
    compiler.go:153: > 5: goja._putValue({})
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja._loadUndef({})
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(trace)
    compiler.go:153:  13: goja.loadVal(0)
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.resolveVar1(f2)
    compiler.go:153:  17: goja.getVar1(f)
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.resolveVar1(f)
    compiler.go:153:  21: goja.getVar1(f1)
    compiler.go:153:  22: goja._putValue({})
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja._loadUndef({})
    compiler.go:153:  25: goja.getVar1Callee(f2)
    compiler.go:153:  26: goja.loadVal(1)
    compiler.go:153:  27: goja.call(1)
    compiler.go:153:  28: goja._pop({})
    compiler.go:153:  29: goja.getVar1(trace)
    compiler.go:153:  30: goja._halt({})
    compiler_test.go:60: stack size: 8
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestFunction2 (0.00s)
=== RUN   TestFunctionToString
    compiler.go:151: values: [arg1 arg2 return 42]
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja.getVar1Callee(Function)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja.loadVal(1)
    compiler.go:153:  4: goja.loadVal(2)
    compiler.go:153:  5: goja.call(3)
    compiler.go:153:  6: goja._dup({})
    compiler.go:153:  7: goja.getPropCallee(toString)
    compiler.go:153:  8: goja.call(0)
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestFunctionToString (0.01s)
=== RUN   TestObjectLiteral
    compiler.go:151: values: [false 42]
    compiler.go:153:  0: goja.bindName(getterCalled)
    compiler.go:153:  1: goja.bindName(setterCalled)
    compiler.go:153:  2: goja.bindName(o)
    compiler.go:153:  3: goja.resolveVar1(getterCalled)
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(setterCalled)
    compiler.go:153:  8: goja.loadVal(0)
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.resolveVar1(o)
    compiler.go:153:  12: goja._newObject({})
    compiler.go:153:  13: *goja.newFunc(&{0x132b1a0  0 false 70 95})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(getterCalled)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  14: goja.setPropGetter(x)
    compiler.go:153:  15: *goja.newFunc(&{0x132b1d0  0 false 101 126})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(setterCalled)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  16: goja.setPropSetter(x)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.getVar1(o)
    compiler.go:153:  20: goja.getProp(x)
    compiler.go:153:  21: goja._pop({})
    compiler.go:153:  22: goja.getVar1(o)
    compiler.go:153:  23: goja.loadVal(1)
    compiler.go:153:  24: goja.setProp(x)
    compiler.go:153:  25: goja._pop({})
    compiler.go:153:  26: goja.getVar1(getterCalled)
    compiler.go:153:  27: goja.jneq1(3)
    compiler.go:153:  28: goja._pop({})
    compiler.go:153:  29: goja.getVar1(setterCalled)
    compiler.go:153:  30: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestObjectLiteral (0.00s)
=== RUN   TestConst
    compiler.go:151: values: [true -Infinity false]
    compiler.go:153:  0: goja.bindName(v1)
    compiler.go:153:  1: goja.bindName(v2)
    compiler.go:153:  2: goja.bindName(v3)
    compiler.go:153:  3: goja.bindName(v4)
    compiler.go:153:  4: goja.resolveVar1(v1)
    compiler.go:153:  5: goja.loadVal(0)
    compiler.go:153:  6: goja._putValue({})
    compiler.go:153:  7: goja._pop({})
    compiler.go:153:  8: goja.resolveVar1(v2)
    compiler.go:153:  9: goja.loadVal(1)
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(v3)
    compiler.go:153:  13: goja.getVar1(v1)
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.resolveVar1(v4)
    compiler.go:153:  17: goja.loadVal(2)
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.getVar1(v1)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja._op_strict_eq({})
    compiler.go:153:  23: goja.jneq1(6)
    compiler.go:153:  24: goja._pop({})
    compiler.go:153:  25: goja.getVar1(v2)
    compiler.go:153:  26: goja.getVar1(Infinity)
    compiler.go:153:  27: goja._neg({})
    compiler.go:153:  28: goja._op_strict_eq({})
    compiler.go:153:  29: goja.jneq1(5)
    compiler.go:153:  30: goja._pop({})
    compiler.go:153:  31: goja.getVar1(v3)
    compiler.go:153:  32: goja.getVar1(v1)
    compiler.go:153:  33: goja._op_strict_eq({})
    compiler.go:153:  34: goja.jneq1(5)
    compiler.go:153:  35: goja._pop({})
    compiler.go:153:  36: goja.getVar1(v4)
    compiler.go:153:  37: goja.loadVal(2)
    compiler.go:153:  38: goja._op_strict_eq({})
    compiler.go:153:  39: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestConst (0.00s)
=== RUN   TestConstWhile
    compiler.go:151: values: [0 9 10]
    compiler.go:153:  0: goja.bindName(c)
    compiler.go:153:  1: goja.resolveVar1(c)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.resolveVar1(c)
    compiler.go:153:  6: goja._loadUndef({})
    compiler.go:153:  7: goja._getValue({})
    compiler.go:153:  8: goja._toNumber({})
    compiler.go:153:  9: goja._inc({})
    compiler.go:153:  10: goja.rdupN(1)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.loadVal(1)
    compiler.go:153:  14: goja._op_gt({})
    compiler.go:153:  15: goja.jne(2)
    compiler.go:153:  16: goja.jump(2)
    compiler.go:153:  17: goja.jump(-12)
    compiler.go:153:  18: goja.getVar1(c)
    compiler.go:153:  19: goja.loadVal(2)
    compiler.go:153:  20: goja._op_strict_eq({})
    compiler.go:153:  21: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestConstWhile (0.01s)
=== RUN   TestConstWhileThrow
    compiler.go:151: values: [false Value is not an object: true]
    compiler.go:153:  0: goja.bindName(thrown)
    compiler.go:153:  1: goja.resolveVar1(thrown)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.try({8 0 true})
    compiler.go:153:  6: goja.getVar1(TypeError)
    compiler.go:153:  7: goja.loadVal(1)
    compiler.go:153:  8: goja._new(1)
    compiler.go:153:  9: goja._throw({})
    compiler.go:153:  10: goja._halt({})
    compiler.go:153:  11: goja.jump(10)
    compiler.go:153:  12: <nil>(<nil>)
    compiler.go:153:  13: goja.enterCatch(e)
    compiler.go:153:  14: goja.resolveVar1(thrown)
    compiler.go:153:  15: goja.getLocal(0)
    compiler.go:153:  16: goja.getVar1(TypeError)
    compiler.go:153:  17: goja._op_instanceof({})
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja._halt({})
    compiler.go:153:  21: goja.getVar1(thrown)
    compiler.go:153:  22: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestConstWhileThrow (0.00s)
=== RUN   TestDupParams
    compiler.go:151: values: [1 2]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x13c28a0 F 3 false 2 38})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.loadStack(-3)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja.call(2)
    compiler.go:153:  10: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestDupParams (0.01s)
=== RUN   TestUseUnsuppliedParam
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(getMessage)
    compiler.go:153:  1: goja.resolveVar1(getMessage)
    compiler.go:153:  2: *goja.newFunc(&{0x14ca090 getMessage 1 false 2 130})
    compiler.go:151: values: [  123 456]
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.getVar1(undefined)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(4)
    compiler.go:153: > 5: goja.loadVal(0)
    compiler.go:153: > 6: goja.storeStack(-1)
    compiler.go:153: > 7: goja._pop({})
    compiler.go:153: > 8: goja.loadStack(-1)
    compiler.go:153: > 9: goja.loadVal(1)
    compiler.go:153: > 10: goja._add({})
    compiler.go:153: > 11: goja.storeStack(-1)
    compiler.go:153: > 12: goja._pop({})
    compiler.go:153: > 13: goja.loadStack(-1)
    compiler.go:153: > 14: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(getMessage)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestUseUnsuppliedParam (0.00s)
=== RUN   TestForInLoop
    compiler.go:151: values: [42 44 45 false x y Already has X true Already has Y]
    compiler.go:153:  0: goja.bindName(Proto)
    compiler.go:153:  1: goja.bindName(o)
    compiler.go:153:  2: goja.bindName(hasX)
    compiler.go:153:  3: goja.bindName(hasY)
    compiler.go:153:  4: goja.bindName(i)
    compiler.go:153:  5: goja.resolveVar1(Proto)
    compiler.go:153:  6: *goja.newFunc(&{0x14ca3f0 Proto 0 false 2 21})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja._loadUndef({})
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.getVar1(Proto)
    compiler.go:153:  10: goja.getProp(prototype)
    compiler.go:153:  11: goja.loadVal(0)
    compiler.go:153:  12: goja.setProp(x)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(o)
    compiler.go:153:  15: goja.getVar1(Proto)
    compiler.go:153:  16: goja._new(0)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.getVar1(o)
    compiler.go:153:  20: goja.loadVal(1)
    compiler.go:153:  21: goja.setProp(y)
    compiler.go:153:  22: goja._pop({})
    compiler.go:153:  23: goja.getVar1(o)
    compiler.go:153:  24: goja.loadVal(2)
    compiler.go:153:  25: goja.setProp(x)
    compiler.go:153:  26: goja._pop({})
    compiler.go:153:  27: goja.resolveVar1(hasX)
    compiler.go:153:  28: goja.loadVal(3)
    compiler.go:153:  29: goja._putValue({})
    compiler.go:153:  30: goja._pop({})
    compiler.go:153:  31: goja.resolveVar1(hasY)
    compiler.go:153:  32: goja.loadVal(3)
    compiler.go:153:  33: goja._putValue({})
    compiler.go:153:  34: goja._pop({})
    compiler.go:153:  35: goja.getVar1(o)
    compiler.go:153:  36: goja._enumerate({})
    compiler.go:153:  37: goja.enumNext(43)
    compiler.go:153:  38: goja.resolveVar1(i)
    compiler.go:153:  39: goja._enumGet({})
    compiler.go:153:  40: goja._putValue({})
    compiler.go:153:  41: goja._pop({})
    compiler.go:153:  42: goja.getVar1(i)
    compiler.go:153:  43: goja._dup({})
    compiler.go:153:  44: goja.loadVal(4)
    compiler.go:153:  45: goja._op_strict_eq({})
    compiler.go:153:  46: goja.jne(3)
    compiler.go:153:  47: goja._pop({})
    compiler.go:153:  48: goja.jump(9)
    compiler.go:153:  49: goja._dup({})
    compiler.go:153:  50: goja.loadVal(5)
    compiler.go:153:  51: goja._op_strict_eq({})
    compiler.go:153:  52: goja.jne(3)
    compiler.go:153:  53: goja._pop({})
    compiler.go:153:  54: goja.jump(14)
    compiler.go:153:  55: goja._pop({})
    compiler.go:153:  56: goja.jump(23)
    compiler.go:153:  57: goja.getVar1(hasX)
    compiler.go:153:  58: goja.jne(5)
    compiler.go:153:  59: goja.getVar1(Error)
    compiler.go:153:  60: goja.loadVal(6)
    compiler.go:153:  61: goja._new(1)
    compiler.go:153:  62: goja._throw({})
    compiler.go:153:  63: goja.resolveVar1(hasX)
    compiler.go:153:  64: goja.loadVal(7)
    compiler.go:153:  65: goja._putValue({})
    compiler.go:153:  66: goja._pop({})
    compiler.go:153:  67: goja.jump(12)
    compiler.go:153:  68: goja.getVar1(hasY)
    compiler.go:153:  69: goja.jne(5)
    compiler.go:153:  70: goja.getVar1(Error)
    compiler.go:153:  71: goja.loadVal(8)
    compiler.go:153:  72: goja._new(1)
    compiler.go:153:  73: goja._throw({})
    compiler.go:153:  74: goja.resolveVar1(hasY)
    compiler.go:153:  75: goja.loadVal(7)
    compiler.go:153:  76: goja._putValue({})
    compiler.go:153:  77: goja._pop({})
    compiler.go:153:  78: goja.jump(1)
    compiler.go:153:  79: goja.jump(-42)
    compiler.go:153:  80: goja._enumPop({})
    compiler.go:153:  81: goja.getVar1(hasX)
    compiler.go:153:  82: goja.jneq1(3)
    compiler.go:153:  83: goja._pop({})
    compiler.go:153:  84: goja.getVar1(hasY)
    compiler.go:153:  85: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestForInLoop (0.00s)
=== RUN   TestForInLoopRet
    compiler.go:151: values: [1 2 true]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(i)
    compiler.go:153:  2: goja.resolveVar1(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.getVar1(o)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.setProp(x)
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(o)
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja.setProp(y)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(o)
    compiler.go:153:  15: goja._enumerate({})
    compiler.go:153:  16: goja._loadUndef({})
    compiler.go:153:  17: goja.enumNext(9)
    compiler.go:153:  18: goja.resolveVar1(i)
    compiler.go:153:  19: goja._enumGet({})
    compiler.go:153:  20: goja._putValue({})
    compiler.go:153:  21: goja._pop({})
    compiler.go:153:  22: goja.loadVal(2)
    compiler.go:153:  23: goja.rdupN(1)
    compiler.go:153:  24: goja._pop({})
    compiler.go:153:  25: goja.jump(-8)
    compiler.go:153:  26: goja._enumPop({})
    compiler.go:153:  27: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestForInLoopRet (0.00s)
=== RUN   TestWhileLoopResult
    compiler.go:151: values: []
    compiler.go:153:  0: goja._loadUndef({})
    compiler.go:153:  1: goja._halt({})
    compiler_test.go:60: stack size: 1
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestWhileLoopResult (0.00s)
=== RUN   TestSwitch
    compiler.go:151: values: [0 1 2 4]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x14cae70 F 1 false 2 165})
    compiler.go:151: values: [0 1 2 3]
    compiler.go:153: > 0: goja.enterFuncStashless({1 1})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja._dup({})
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_eq({})
    compiler.go:153: > 8: goja.jne(3)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.jump(21)
    compiler.go:153: > 11: goja._dup({})
    compiler.go:153: > 12: goja.loadVal(1)
    compiler.go:153: > 13: goja._op_strict_eq({})
    compiler.go:153: > 14: goja.jne(3)
    compiler.go:153: > 15: goja._pop({})
    compiler.go:153: > 16: goja.jump(19)
    compiler.go:153: > 17: goja._dup({})
    compiler.go:153: > 18: goja.loadVal(2)
    compiler.go:153: > 19: goja._op_strict_eq({})
    compiler.go:153: > 20: goja.jne(3)
    compiler.go:153: > 21: goja._pop({})
    compiler.go:153: > 22: goja.jump(21)
    compiler.go:153: > 23: goja._dup({})
    compiler.go:153: > 24: goja.loadVal(3)
    compiler.go:153: > 25: goja._op_strict_eq({})
    compiler.go:153: > 26: goja.jne(3)
    compiler.go:153: > 27: goja._pop({})
    compiler.go:153: > 28: goja.jump(20)
    compiler.go:153: > 29: goja._pop({})
    compiler.go:153: > 30: goja.jump(9)
    compiler.go:153: > 31: goja.loadStack(1)
    compiler.go:153: > 32: goja._inc({})
    compiler.go:153: > 33: goja.storeStack(1)
    compiler.go:153: > 34: goja._pop({})
    compiler.go:153: > 35: goja.loadStack(1)
    compiler.go:153: > 36: goja._inc({})
    compiler.go:153: > 37: goja.storeStack(1)
    compiler.go:153: > 38: goja._pop({})
    compiler.go:153: > 39: goja.loadStack(1)
    compiler.go:153: > 40: goja._inc({})
    compiler.go:153: > 41: goja.storeStack(1)
    compiler.go:153: > 42: goja._pop({})
    compiler.go:153: > 43: goja.loadStack(1)
    compiler.go:153: > 44: goja._inc({})
    compiler.go:153: > 45: goja.storeStack(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja.jump(5)
    compiler.go:153: > 48: goja.loadStack(1)
    compiler.go:153: > 49: goja._inc({})
    compiler.go:153: > 50: goja.storeStack(1)
    compiler.go:153: > 51: goja._pop({})
    compiler.go:153: > 52: goja.loadStack(1)
    compiler.go:153: > 53: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.call(1)
    compiler.go:153:  9: goja._loadUndef({})
    compiler.go:153:  10: goja.getVar1Callee(F)
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja.call(1)
    compiler.go:153:  13: goja._add({})
    compiler.go:153:  14: goja._loadUndef({})
    compiler.go:153:  15: goja.getVar1Callee(F)
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.call(1)
    compiler.go:153:  18: goja._add({})
    compiler.go:153:  19: goja._loadUndef({})
    compiler.go:153:  20: goja.getVar1Callee(F)
    compiler.go:153:  21: goja.loadVal(3)
    compiler.go:153:  22: goja.call(1)
    compiler.go:153:  23: goja._add({})
    compiler.go:153:  24: goja._halt({})
    compiler_test.go:60: stack size: 8
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSwitch (0.00s)
=== RUN   TestSwitchDefFirst
    compiler.go:151: values: [0 1 2 4]
    compiler.go:153:  0: goja.bindName(F)
    compiler.go:153:  1: goja.resolveVar1(F)
    compiler.go:153:  2: *goja.newFunc(&{0x14cb200 F 1 false 2 165})
    compiler.go:151: values: [0 1 2 3]
    compiler.go:153: > 0: goja.enterFuncStashless({1 1})
    compiler.go:153: > 1: goja.loadVal(0)
    compiler.go:153: > 2: goja.storeStack(1)
    compiler.go:153: > 3: goja._pop({})
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja._dup({})
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_eq({})
    compiler.go:153: > 8: goja.jne(3)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.jump(24)
    compiler.go:153: > 11: goja._dup({})
    compiler.go:153: > 12: goja.loadVal(1)
    compiler.go:153: > 13: goja._op_strict_eq({})
    compiler.go:153: > 14: goja.jne(3)
    compiler.go:153: > 15: goja._pop({})
    compiler.go:153: > 16: goja.jump(22)
    compiler.go:153: > 17: goja._dup({})
    compiler.go:153: > 18: goja.loadVal(2)
    compiler.go:153: > 19: goja._op_strict_eq({})
    compiler.go:153: > 20: goja.jne(3)
    compiler.go:153: > 21: goja._pop({})
    compiler.go:153: > 22: goja.jump(20)
    compiler.go:153: > 23: goja._dup({})
    compiler.go:153: > 24: goja.loadVal(3)
    compiler.go:153: > 25: goja._op_strict_eq({})
    compiler.go:153: > 26: goja.jne(3)
    compiler.go:153: > 27: goja._pop({})
    compiler.go:153: > 28: goja.jump(19)
    compiler.go:153: > 29: goja._pop({})
    compiler.go:153: > 30: goja.loadStack(1)
    compiler.go:153: > 31: goja._inc({})
    compiler.go:153: > 32: goja.storeStack(1)
    compiler.go:153: > 33: goja._pop({})
    compiler.go:153: > 34: goja.loadStack(1)
    compiler.go:153: > 35: goja._inc({})
    compiler.go:153: > 36: goja.storeStack(1)
    compiler.go:153: > 37: goja._pop({})
    compiler.go:153: > 38: goja.loadStack(1)
    compiler.go:153: > 39: goja._inc({})
    compiler.go:153: > 40: goja.storeStack(1)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja.loadStack(1)
    compiler.go:153: > 43: goja._inc({})
    compiler.go:153: > 44: goja.storeStack(1)
    compiler.go:153: > 45: goja._pop({})
    compiler.go:153: > 46: goja.jump(5)
    compiler.go:153: > 47: goja.loadStack(1)
    compiler.go:153: > 48: goja._inc({})
    compiler.go:153: > 49: goja.storeStack(1)
    compiler.go:153: > 50: goja._pop({})
    compiler.go:153: > 51: goja.loadStack(1)
    compiler.go:153: > 52: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(F)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.call(1)
    compiler.go:153:  9: goja._loadUndef({})
    compiler.go:153:  10: goja.getVar1Callee(F)
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja.call(1)
    compiler.go:153:  13: goja._add({})
    compiler.go:153:  14: goja._loadUndef({})
    compiler.go:153:  15: goja.getVar1Callee(F)
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.call(1)
    compiler.go:153:  18: goja._add({})
    compiler.go:153:  19: goja._loadUndef({})
    compiler.go:153:  20: goja.getVar1Callee(F)
    compiler.go:153:  21: goja.loadVal(3)
    compiler.go:153:  22: goja.call(1)
    compiler.go:153:  23: goja._add({})
    compiler.go:153:  24: goja._halt({})
    compiler_test.go:60: stack size: 8
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSwitchDefFirst (0.01s)
=== RUN   TestSwitchResult
    compiler.go:151: values: [2 0 1 3 zero one two three default]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.resolveVar1(x)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1(x)
    compiler.go:153:  7: goja._dup({})
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._op_strict_eq({})
    compiler.go:153:  10: goja.jne(3)
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.jump(21)
    compiler.go:153:  13: goja._dup({})
    compiler.go:153:  14: goja.loadVal(2)
    compiler.go:153:  15: goja._op_strict_eq({})
    compiler.go:153:  16: goja.jne(3)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.jump(17)
    compiler.go:153:  19: goja._dup({})
    compiler.go:153:  20: goja.loadVal(0)
    compiler.go:153:  21: goja._op_strict_eq({})
    compiler.go:153:  22: goja.jne(3)
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.jump(13)
    compiler.go:153:  25: goja._dup({})
    compiler.go:153:  26: goja.loadVal(3)
    compiler.go:153:  27: goja._op_strict_eq({})
    compiler.go:153:  28: goja.jne(3)
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.jump(10)
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.jump(10)
    compiler.go:153:  33: goja._pop({})
    compiler.go:153:  34: goja.loadVal(4)
    compiler.go:153:  35: goja._pop({})
    compiler.go:153:  36: goja.loadVal(5)
    compiler.go:153:  37: goja._pop({})
    compiler.go:153:  38: goja.loadVal(6)
    compiler.go:153:  39: goja.jump(5)
    compiler.go:153:  40: goja._pop({})
    compiler.go:153:  41: goja.loadVal(7)
    compiler.go:153:  42: goja._pop({})
    compiler.go:153:  43: goja.loadVal(8)
    compiler.go:153:  44: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSwitchResult (0.03s)
=== RUN   TestSwitchNoMatch
    compiler.go:151: values: [5 0 2]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.bindName(result)
    compiler.go:153:  2: goja.resolveVar1(x)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.getVar1(x)
    compiler.go:153:  7: goja._dup({})
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._op_strict_eq({})
    compiler.go:153:  10: goja.jne(3)
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.jump(3)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.jump(6)
    compiler.go:153:  15: goja.resolveVar1(result)
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.jump(1)
    compiler.go:153:  20: goja.getVar1(result)
    compiler.go:153:  21: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSwitchNoMatch (0.00s)
=== RUN   TestGetOwnPropertyNames
    compiler.go:151: values: [42 test false prop1 prop2 true]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(hasProp1)
    compiler.go:153:  2: goja.bindName(hasProp2)
    compiler.go:153:  3: goja.bindName(names)
    compiler.go:153:  4: goja.bindName(i)
    compiler.go:153:  5: goja.bindName(p)
    compiler.go:153:  6: goja.resolveVar1(o)
    compiler.go:153:  7: goja._newObject({})
    compiler.go:153:  8: goja.loadVal(0)
    compiler.go:153:  9: goja.setProp1(prop1)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.setProp1(prop2)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.resolveVar1(hasProp1)
    compiler.go:153:  15: goja.loadVal(2)
    compiler.go:153:  16: goja._putValue({})
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.resolveVar1(hasProp2)
    compiler.go:153:  19: goja.loadVal(2)
    compiler.go:153:  20: goja._putValue({})
    compiler.go:153:  21: goja._pop({})
    compiler.go:153:  22: goja.resolveVar1(names)
    compiler.go:153:  23: goja.getVar1(Object)
    compiler.go:153:  24: goja._dup({})
    compiler.go:153:  25: goja.getPropCallee(getOwnPropertyNames)
    compiler.go:153:  26: goja.getVar1(o)
    compiler.go:153:  27: goja.call(1)
    compiler.go:153:  28: goja._putValue({})
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.getVar1(names)
    compiler.go:153:  31: goja._enumerate({})
    compiler.go:153:  32: goja.enumNext(37)
    compiler.go:153:  33: goja.resolveVar1(i)
    compiler.go:153:  34: goja._enumGet({})
    compiler.go:153:  35: goja._putValue({})
    compiler.go:153:  36: goja._pop({})
    compiler.go:153:  37: goja.resolveVar1(p)
    compiler.go:153:  38: goja.getVar1(names)
    compiler.go:153:  39: goja.getVar1(i)
    compiler.go:153:  40: goja._getElem({})
    compiler.go:153:  41: goja._putValue({})
    compiler.go:153:  42: goja._pop({})
    compiler.go:153:  43: goja.getVar1(p)
    compiler.go:153:  44: goja._dup({})
    compiler.go:153:  45: goja.loadVal(3)
    compiler.go:153:  46: goja._op_strict_eq({})
    compiler.go:153:  47: goja.jne(3)
    compiler.go:153:  48: goja._pop({})
    compiler.go:153:  49: goja.jump(9)
    compiler.go:153:  50: goja._dup({})
    compiler.go:153:  51: goja.loadVal(4)
    compiler.go:153:  52: goja._op_strict_eq({})
    compiler.go:153:  53: goja.jne(3)
    compiler.go:153:  54: goja._pop({})
    compiler.go:153:  55: goja.jump(8)
    compiler.go:153:  56: goja._pop({})
    compiler.go:153:  57: goja.jump(11)
    compiler.go:153:  58: goja.resolveVar1(hasProp1)
    compiler.go:153:  59: goja.loadVal(5)
    compiler.go:153:  60: goja._putValue({})
    compiler.go:153:  61: goja._pop({})
    compiler.go:153:  62: goja.jump(6)
    compiler.go:153:  63: goja.resolveVar1(hasProp2)
    compiler.go:153:  64: goja.loadVal(5)
    compiler.go:153:  65: goja._putValue({})
    compiler.go:153:  66: goja._pop({})
    compiler.go:153:  67: goja.jump(1)
    compiler.go:153:  68: goja.jump(-36)
    compiler.go:153:  69: goja._enumPop({})
    compiler.go:153:  70: goja.getVar1(hasProp1)
    compiler.go:153:  71: goja.jneq1(3)
    compiler.go:153:  72: goja._pop({})
    compiler.go:153:  73: goja.getVar1(hasProp2)
    compiler.go:153:  74: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestGetOwnPropertyNames (0.00s)
=== RUN   TestArrayLiteral
    compiler.go:151: values: [false true]
    compiler.go:153:  0: goja.bindName(f1Called)
    compiler.go:153:  1: goja.bindName(f2Called)
    compiler.go:153:  2: goja.bindName(f3Called)
    compiler.go:153:  3: goja.bindName(errorThrown)
    compiler.go:153:  4: goja.bindName(F1)
    compiler.go:153:  5: goja.bindName(F2)
    compiler.go:153:  6: goja.bindName(F3)
    compiler.go:153:  7: goja.bindName(a)
    compiler.go:153:  8: goja.resolveVar1(F1)
    compiler.go:153:  9: *goja.newFunc(&{0x14ca810 F1 0 false 99 136})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(f1Called)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja.resolveVar1(F2)
    compiler.go:153:  13: *goja.newFunc(&{0x14ca840 F2 0 false 139 176})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(f2Called)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  14: goja._putValue({})
    compiler.go:153:  15: goja._pop({})
    compiler.go:153:  16: goja.resolveVar1(F3)
    compiler.go:153:  17: *goja.newFunc(&{0x14ca870 F3 0 false 179 216})
    compiler.go:151: values: [true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(f3Called)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._putValue({})
    compiler.go:153: > 4: goja._pop({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  18: goja._putValue({})
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.resolveVar1(f1Called)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja._putValue({})
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.resolveVar1(f2Called)
    compiler.go:153:  25: goja.loadVal(0)
    compiler.go:153:  26: goja._putValue({})
    compiler.go:153:  27: goja._pop({})
    compiler.go:153:  28: goja.resolveVar1(f3Called)
    compiler.go:153:  29: goja.loadVal(0)
    compiler.go:153:  30: goja._putValue({})
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.resolveVar1(errorThrown)
    compiler.go:153:  33: goja.loadVal(0)
    compiler.go:153:  34: goja._putValue({})
    compiler.go:153:  35: goja._pop({})
    compiler.go:153:  36: goja.try({20 0 true})
    compiler.go:153:  37: goja.resolveVar1(a)
    compiler.go:153:  38: goja._loadUndef({})
    compiler.go:153:  39: goja.getVar1Callee(F1)
    compiler.go:153:  40: goja.call(0)
    compiler.go:153:  41: goja._loadUndef({})
    compiler.go:153:  42: goja.getVar1Callee(x)
    compiler.go:153:  43: goja._loadUndef({})
    compiler.go:153:  44: goja.getVar1Callee(F3)
    compiler.go:153:  45: goja.call(0)
    compiler.go:153:  46: goja.call(1)
    compiler.go:153:  47: goja._loadUndef({})
    compiler.go:153:  48: goja.getVar1Callee(F2)
    compiler.go:153:  49: goja.call(0)
    compiler.go:153:  50: goja.newArray(3)
    compiler.go:153:  51: goja._putValue({})
    compiler.go:153:  52: goja._pop({})
    compiler.go:153:  53: goja._halt({})
    compiler.go:153:  54: goja.jump(15)
    compiler.go:153:  55: <nil>(<nil>)
    compiler.go:153:  56: goja.enterCatch(e)
    compiler.go:153:  57: goja.getLocal(0)
    compiler.go:153:  58: goja.getVar1(ReferenceError)
    compiler.go:153:  59: goja._op_instanceof({})
    compiler.go:153:  60: goja.jne(6)
    compiler.go:153:  61: goja.resolveVar1(errorThrown)
    compiler.go:153:  62: goja.loadVal(1)
    compiler.go:153:  63: goja._putValue({})
    compiler.go:153:  64: goja._pop({})
    compiler.go:153:  65: goja.jump(3)
    compiler.go:153:  66: goja.getLocal(0)
    compiler.go:153:  67: goja._throw({})
    compiler.go:153:  68: goja._halt({})
    compiler.go:153:  69: goja.getVar1(f1Called)
    compiler.go:153:  70: goja.jneq1(4)
    compiler.go:153:  71: goja._pop({})
    compiler.go:153:  72: goja.getVar1(f2Called)
    compiler.go:153:  73: goja._not({})
    compiler.go:153:  74: goja.jneq1(3)
    compiler.go:153:  75: goja._pop({})
    compiler.go:153:  76: goja.getVar1(f3Called)
    compiler.go:153:  77: goja.jneq1(3)
    compiler.go:153:  78: goja._pop({})
    compiler.go:153:  79: goja.getVar1(errorThrown)
    compiler.go:153:  80: goja.jneq1(5)
    compiler.go:153:  81: goja._pop({})
    compiler.go:153:  82: goja.getVar1(a)
    compiler.go:153:  83: goja.getVar1(undefined)
    compiler.go:153:  84: goja._op_strict_eq({})
    compiler.go:153:  85: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestArrayLiteral (0.00s)
=== RUN   TestJumpOutOfReturn
    compiler.go:151: values: []
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x14cac60 f 0 false 2 64})
    compiler.go:151: values: [0 true]
    compiler.go:153: > 0: goja.enterFuncStashless({1 0})
    compiler.go:153: > 1: goja.loadStack(1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja.loadVal(1)
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja._loadUndef({})
    compiler.go:153: > 8: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.call(0)
    compiler.go:153:  8: goja._halt({})
    compiler_test.go:60: stack size: 5
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestJumpOutOfReturn (0.01s)
=== RUN   TestSwitchJumpOutOfReturn
    compiler.go:151: values: [0]
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.resolveVar1(f)
    compiler.go:153:  2: *goja.newFunc(&{0x14caf90 f 1 false 2 82})
    compiler.go:151: values: [0]
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.loadVal(0)
    compiler.go:153: > 4: goja._op_strict_eq({})
    compiler.go:153: > 5: goja.jne(3)
    compiler.go:153: > 6: goja._pop({})
    compiler.go:153: > 7: goja.jump(3)
    compiler.go:153: > 8: goja._pop({})
    compiler.go:153: > 9: goja.jump(2)
    compiler.go:153: > 10: goja.jump(3)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._retStashless({})
    compiler.go:153: > 13: goja._loadUndef({})
    compiler.go:153: > 14: goja._retStashless({})
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja._loadUndef({})
    compiler.go:153:  6: goja.getVar1Callee(f)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja.call(1)
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSwitchJumpOutOfReturn (0.00s)
=== RUN   TestSetToReadOnlyPropertyStrictBracket
    compiler.go:151: values: [false test 42 true 43]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1Strict(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1Strict(thrown)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(Object)
    compiler.go:153:  11: goja._dup({})
    compiler.go:153:  12: goja.getPropCallee(defineProperty)
    compiler.go:153:  13: goja.getVar1(o)
    compiler.go:153:  14: goja.loadVal(1)
    compiler.go:153:  15: goja._newObject({})
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.setProp1(value)
    compiler.go:153:  18: goja.loadVal(3)
    compiler.go:153:  19: goja.setProp1(configurable)
    compiler.go:153:  20: goja.call(3)
    compiler.go:153:  21: goja._pop({})
    compiler.go:153:  22: goja.try({9 0 true})
    compiler.go:153:  23: goja.getVar1(o)
    compiler.go:153:  24: goja.loadVal(1)
    compiler.go:153:  25: goja.loadVal(4)
    compiler.go:153:  26: goja._setElemStrict({})
    compiler.go:153:  27: goja._pop({})
    compiler.go:153:  28: goja._halt({})
    compiler.go:153:  29: goja.jump(10)
    compiler.go:153:  30: <nil>(<nil>)
    compiler.go:153:  31: goja.enterCatch(e)
    compiler.go:153:  32: goja.resolveVar1Strict(thrown)
    compiler.go:153:  33: goja.getLocal(0)
    compiler.go:153:  34: goja.getVar1(TypeError)
    compiler.go:153:  35: goja._op_instanceof({})
    compiler.go:153:  36: goja._putValue({})
    compiler.go:153:  37: goja._pop({})
    compiler.go:153:  38: goja._halt({})
    compiler.go:153:  39: goja.getVar1(thrown)
    compiler.go:153:  40: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestSetToReadOnlyPropertyStrictBracket (0.00s)
=== RUN   TestSetToReadOnlyPropertyStrictDot
    compiler.go:151: values: [false test 42 true 43]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1Strict(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1Strict(thrown)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(Object)
    compiler.go:153:  11: goja._dup({})
    compiler.go:153:  12: goja.getPropCallee(defineProperty)
    compiler.go:153:  13: goja.getVar1(o)
    compiler.go:153:  14: goja.loadVal(1)
    compiler.go:153:  15: goja._newObject({})
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.setProp1(value)
    compiler.go:153:  18: goja.loadVal(3)
    compiler.go:153:  19: goja.setProp1(configurable)
    compiler.go:153:  20: goja.call(3)
    compiler.go:153:  21: goja._pop({})
    compiler.go:153:  22: goja.try({8 0 true})
    compiler.go:153:  23: goja.getVar1(o)
    compiler.go:153:  24: goja.loadVal(4)
    compiler.go:153:  25: goja.setPropStrict(test)
    compiler.go:153:  26: goja._pop({})
    compiler.go:153:  27: goja._halt({})
    compiler.go:153:  28: goja.jump(10)
    compiler.go:153:  29: <nil>(<nil>)
    compiler.go:153:  30: goja.enterCatch(e)
    compiler.go:153:  31: goja.resolveVar1Strict(thrown)
    compiler.go:153:  32: goja.getLocal(0)
    compiler.go:153:  33: goja.getVar1(TypeError)
    compiler.go:153:  34: goja._op_instanceof({})
    compiler.go:153:  35: goja._putValue({})
    compiler.go:153:  36: goja._pop({})
    compiler.go:153:  37: goja._halt({})
    compiler.go:153:  38: goja.getVar1(thrown)
    compiler.go:153:  39: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestSetToReadOnlyPropertyStrictDot (0.01s)
=== RUN   TestDeleteNonConfigurablePropertyStrictBracket
    compiler.go:151: values: [false test 42]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1Strict(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1Strict(thrown)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(Object)
    compiler.go:153:  11: goja._dup({})
    compiler.go:153:  12: goja.getPropCallee(defineProperty)
    compiler.go:153:  13: goja.getVar1(o)
    compiler.go:153:  14: goja.loadVal(1)
    compiler.go:153:  15: goja._newObject({})
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.setProp1(value)
    compiler.go:153:  18: goja.call(3)
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.try({8 0 true})
    compiler.go:153:  21: goja.getVar1(o)
    compiler.go:153:  22: goja.loadVal(1)
    compiler.go:153:  23: goja._deleteElemStrict({})
    compiler.go:153:  24: goja._pop({})
    compiler.go:153:  25: goja._halt({})
    compiler.go:153:  26: goja.jump(10)
    compiler.go:153:  27: <nil>(<nil>)
    compiler.go:153:  28: goja.enterCatch(e)
    compiler.go:153:  29: goja.resolveVar1Strict(thrown)
    compiler.go:153:  30: goja.getLocal(0)
    compiler.go:153:  31: goja.getVar1(TypeError)
    compiler.go:153:  32: goja._op_instanceof({})
    compiler.go:153:  33: goja._putValue({})
    compiler.go:153:  34: goja._pop({})
    compiler.go:153:  35: goja._halt({})
    compiler.go:153:  36: goja.getVar1(thrown)
    compiler.go:153:  37: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestDeleteNonConfigurablePropertyStrictBracket (0.00s)
=== RUN   TestDeleteNonConfigurablePropertyStrictDot
    compiler.go:151: values: [false test 42]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1Strict(o)
    compiler.go:153:  3: goja._newObject({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1Strict(thrown)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(Object)
    compiler.go:153:  11: goja._dup({})
    compiler.go:153:  12: goja.getPropCallee(defineProperty)
    compiler.go:153:  13: goja.getVar1(o)
    compiler.go:153:  14: goja.loadVal(1)
    compiler.go:153:  15: goja._newObject({})
    compiler.go:153:  16: goja.loadVal(2)
    compiler.go:153:  17: goja.setProp1(value)
    compiler.go:153:  18: goja.call(3)
    compiler.go:153:  19: goja._pop({})
    compiler.go:153:  20: goja.try({7 0 true})
    compiler.go:153:  21: goja.getVar1(o)
    compiler.go:153:  22: goja.deletePropStrict(test)
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja._halt({})
    compiler.go:153:  25: goja.jump(10)
    compiler.go:153:  26: <nil>(<nil>)
    compiler.go:153:  27: goja.enterCatch(e)
    compiler.go:153:  28: goja.resolveVar1Strict(thrown)
    compiler.go:153:  29: goja.getLocal(0)
    compiler.go:153:  30: goja.getVar1(TypeError)
    compiler.go:153:  31: goja._op_instanceof({})
    compiler.go:153:  32: goja._putValue({})
    compiler.go:153:  33: goja._pop({})
    compiler.go:153:  34: goja._halt({})
    compiler.go:153:  35: goja.getVar1(thrown)
    compiler.go:153:  36: goja._halt({})
    compiler_test.go:60: stack size: 6
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestDeleteNonConfigurablePropertyStrictDot (0.01s)
=== RUN   TestCompound1
    compiler.go:151: values: [0 1 2]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.bindName(scope)
    compiler.go:153:  2: goja.bindName(f)
    compiler.go:153:  3: goja.resolveVar1(x)
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(scope)
    compiler.go:153:  8: goja._newObject({})
    compiler.go:153:  9: goja.loadVal(1)
    compiler.go:153:  10: goja.setProp1(x)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.getVar1(scope)
    compiler.go:153:  14: goja._enterWith({})
    compiler.go:153:  15: goja.resolveVar1(f)
    compiler.go:153:  16: *goja.newFunc(&{0x14aa9f0  0 false 76 132})
    compiler.go:151: values: [2]
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.resolveVar1(x)
    compiler.go:153: > 2: goja._getValue({})
    compiler.go:153: > 3: goja.getVar1(scope)
    compiler.go:153: > 4: goja.deleteProp(x)
    compiler.go:153: > 5: goja._pop({})
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._mul({})
    compiler.go:153: > 8: goja._putValue({})
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja._loadUndef({})
    compiler.go:153: > 11: goja._retStashless({})
    compiler.go:153:  17: goja._putValue({})
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja._leaveWith({})
    compiler.go:153:  20: goja._loadUndef({})
    compiler.go:153:  21: goja.getVar1Callee(f)
    compiler.go:153:  22: goja.call(0)
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.getVar1(scope)
    compiler.go:153:  25: goja.getProp(x)
    compiler.go:153:  26: goja.loadVal(2)
    compiler.go:153:  27: goja._op_strict_eq({})
    compiler.go:153:  28: goja.jneq1(5)
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.getVar1(x)
    compiler.go:153:  31: goja.loadVal(0)
    compiler.go:153:  32: goja._op_strict_eq({})
    compiler.go:153:  33: goja._halt({})
    compiler_test.go:60: stack size: 4
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestCompound1 (0.00s)
=== RUN   TestCompound2
    compiler.go:151: values: [x 1]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.resolveVar1(x)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.resolveVar1(x)
    compiler.go:153:  6: goja._loadUndef({})
    compiler.go:153:  7: goja._getValue({})
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._xor({})
    compiler.go:153:  10: goja.rdupN(1)
    compiler.go:153:  11: goja._putValue({})
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestCompound2 (0.00s)
=== RUN   TestDeleteArguments
--- PASS: TestDeleteArguments (0.00s)
=== RUN   TestReturnUndefined
    compiler.go:151: values: [false]
    compiler.go:153:  0: goja.bindName(f)
    compiler.go:153:  1: goja.bindName(thrown)
    compiler.go:153:  2: goja.resolveVar1(f)
    compiler.go:153:  3: *goja.newFunc(&{0x14ab1a0 f 0 false 2 35})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 0})
    compiler.go:153: > 1: goja.getVar1(x)
    compiler.go:153: > 2: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(thrown)
    compiler.go:153:  7: goja.loadVal(0)
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.try({8 0 true})
    compiler.go:153:  11: goja._loadUndef({})
    compiler.go:153:  12: goja.getVar1Callee(f)
    compiler.go:153:  13: goja.call(0)
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja._halt({})
    compiler.go:153:  16: goja.jump(10)
    compiler.go:153:  17: <nil>(<nil>)
    compiler.go:153:  18: goja.enterCatch(e)
    compiler.go:153:  19: goja.resolveVar1(thrown)
    compiler.go:153:  20: goja.getLocal(0)
    compiler.go:153:  21: goja.getVar1(ReferenceError)
    compiler.go:153:  22: goja._op_instanceof({})
    compiler.go:153:  23: goja._putValue({})
    compiler.go:153:  24: goja._pop({})
    compiler.go:153:  25: goja._halt({})
    compiler.go:153:  26: goja.getVar1(thrown)
    compiler.go:153:  27: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestReturnUndefined (0.01s)
=== RUN   TestForBreak
    compiler.go:151: values: [5 for(count=0;;) {if (count===supreme)break;else count++; } undefined #1: __evaluated === 4. Actual:  __evaluated ===]
    compiler.go:153:  0: goja.bindName(supreme)
    compiler.go:153:  1: goja.bindName(count)
    compiler.go:153:  2: goja.bindName(__evaluated)
    compiler.go:153:  3: goja.resolveVar1(supreme)
    compiler.go:153:  4: goja.loadVal(0)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(__evaluated)
    compiler.go:153:  8: goja._loadUndef({})
    compiler.go:153:  9: goja.getVar1Callee(eval)
    compiler.go:153:  10: goja.loadVal(1)
    compiler.go:153:  11: goja.callEval(1)
    compiler.go:153:  12: goja._putValue({})
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(__evaluated)
    compiler.go:153:  15: goja.loadVal(2)
    compiler.go:153:  16: goja._op_strict_neq({})
    compiler.go:153:  17: goja.jne(7)
    compiler.go:153:  18: goja.getVar1(Error)
    compiler.go:153:  19: goja.loadVal(3)
    compiler.go:153:  20: goja.getVar1(__evaluated)
    compiler.go:153:  21: goja._add({})
    compiler.go:153:  22: goja._new(1)
    compiler.go:153:  23: goja._throw({})
    compiler.go:153:  24: goja._loadUndef({})
    compiler.go:153:  25: goja._halt({})
    compiler_test.go:60: stack size: 7
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestForBreak (0.00s)
=== RUN   TestLargeNumberLiteral
    compiler.go:151: values: [9.671406556917033e+24]
    compiler.go:153:  0: goja.bindName(x)
    compiler.go:153:  1: goja.resolveVar1(x)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.getVar1(x)
    compiler.go:153:  6: goja._dup({})
    compiler.go:153:  7: goja.getPropCallee(toString)
    compiler.go:153:  8: goja.call(0)
    compiler.go:153:  9: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestLargeNumberLiteral (0.00s)
=== RUN   TestIncDelete
    compiler.go:151: values: [1]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.resolveVar1(o)
    compiler.go:153:  2: goja._newObject({})
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja.setProp1(x)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.getVar1(o)
    compiler.go:153:  8: goja._dup({})
    compiler.go:153:  9: goja.getProp(x)
    compiler.go:153:  10: goja.getVar1(o)
    compiler.go:153:  11: goja.deleteProp(x)
    compiler.go:153:  12: goja._pop({})
    compiler.go:153:  13: goja.loadVal(0)
    compiler.go:153:  14: goja._add({})
    compiler.go:153:  15: goja.setProp(x)
    compiler.go:153:  16: goja._pop({})
    compiler.go:153:  17: goja.getVar1(o)
    compiler.go:153:  18: goja.getProp(x)
    compiler.go:153:  19: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestIncDelete (0.01s)
=== RUN   TestCompoundAssignRefError
    compiler.go:151: values: [false 1 true]
    compiler.go:153:  0: goja.bindName(thrown)
    compiler.go:153:  1: goja.resolveVar1(thrown)
    compiler.go:153:  2: goja.loadVal(0)
    compiler.go:153:  3: goja._putValue({})
    compiler.go:153:  4: goja._pop({})
    compiler.go:153:  5: goja.try({10 0 true})
    compiler.go:153:  6: goja.resolveVar1(a)
    compiler.go:153:  7: goja._getValue({})
    compiler.go:153:  8: goja.loadVal(1)
    compiler.go:153:  9: goja._mul({})
    compiler.go:153:  10: goja._putValue({})
    compiler.go:153:  11: goja._pop({})
    compiler.go:153:  12: goja._halt({})
    compiler.go:153:  13: goja.jump(15)
    compiler.go:153:  14: <nil>(<nil>)
    compiler.go:153:  15: goja.enterCatch(e)
    compiler.go:153:  16: goja.getLocal(0)
    compiler.go:153:  17: goja.getVar1(ReferenceError)
    compiler.go:153:  18: goja._op_instanceof({})
    compiler.go:153:  19: goja.jne(6)
    compiler.go:153:  20: goja.resolveVar1(thrown)
    compiler.go:153:  21: goja.loadVal(2)
    compiler.go:153:  22: goja._putValue({})
    compiler.go:153:  23: goja._pop({})
    compiler.go:153:  24: goja.jump(3)
    compiler.go:153:  25: goja.getLocal(0)
    compiler.go:153:  26: goja._throw({})
    compiler.go:153:  27: goja._halt({})
    compiler.go:153:  28: goja.getVar1(thrown)
    compiler.go:153:  29: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 1
--- PASS: TestCompoundAssignRefError (0.00s)
=== RUN   TestObjectLiteral__Proto__
    compiler.go:151: values: [null 42]
    compiler.go:153:  0: goja.bindName(o)
    compiler.go:153:  1: goja.resolveVar1(o)
    compiler.go:153:  2: goja._newObject({})
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._setProto({})
    compiler.go:153:  5: goja.loadVal(1)
    compiler.go:153:  6: goja.setProp1(test)
    compiler.go:153:  7: goja._putValue({})
    compiler.go:153:  8: goja._pop({})
    compiler.go:153:  9: goja.getVar1(Object)
    compiler.go:153:  10: goja._dup({})
    compiler.go:153:  11: goja.getPropCallee(getPrototypeOf)
    compiler.go:153:  12: goja.getVar1(o)
    compiler.go:153:  13: goja.call(1)
    compiler.go:153:  14: goja._halt({})
    compiler_test.go:60: stack size: 3
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestObjectLiteral__Proto__ (0.00s)
=== RUN   TestDateUTC
    compiler.go:151: values: [1970 0 1970, 0 2016 1451606400000 2016, 0 6 1467331200000 2016, 6 1 2016, 6, 1 5 1467676800000 2016, 6, 5 2016, 6, 5, 0 15 1467730800000 2016, 6, 5, 15 2016, 6, 5, 15, 0 34 1467732840000 2016, 6, 5, 15, 34 2016, 6, 5, 15, 34, 0 45 1467732885000 2016, 6, 5, 15, 34, 45]
    compiler.go:153:  0: goja.bindName($ERROR)
    compiler.go:153:  1: goja.bindName(assert)
    compiler.go:153:  2: goja.resolveVar1($ERROR)
    compiler.go:153:  3: *goja.newFunc(&{0x105cc60 $ERROR 1 false 1 56})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadStack(-1)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(assert)
    compiler.go:153:  7: *goja.newFunc(&{0x105cc90 assert 2 false 58 277})
    compiler.go:151: values: [true Expected true but got ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja.loadStack(-2)
    compiler.go:153: > 8: goja.getVar1(undefined)
    compiler.go:153: > 9: goja._op_strict_eq({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._loadUndef({})
    compiler.go:153: > 13: goja.getVar1Callee(String)
    compiler.go:153: > 14: goja.loadStack(-1)
    compiler.go:153: > 15: goja.call(1)
    compiler.go:153: > 16: goja._add({})
    compiler.go:153: > 17: goja.storeStack(-2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja.getVar1Callee($ERROR)
    compiler.go:153: > 21: goja.loadStack(-2)
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja._loadUndef({})
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(assert)
    compiler.go:153:  11: *goja.newFunc(&{0x105ccc0  2 false 301 478})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadStack(-2)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(14)
    compiler.go:153: > 5: goja.loadStack(-1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_neq({})
    compiler.go:153: > 8: goja.jeq1(9)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadVal(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._div({})
    compiler.go:153: > 13: goja.loadVal(1)
    compiler.go:153: > 14: goja.loadStack(-2)
    compiler.go:153: > 15: goja._div({})
    compiler.go:153: > 16: goja._op_strict_eq({})
    compiler.go:153: > 17: goja._retStashless({})
    compiler.go:153: > 18: goja.loadStack(-1)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja._op_strict_neq({})
    compiler.go:153: > 21: goja.jneq1(5)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-2)
    compiler.go:153: > 24: goja.loadStack(-2)
    compiler.go:153: > 25: goja._op_strict_neq({})
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  12: goja.setProp(_isSameValue)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(assert)
    compiler.go:153:  15: *goja.newFunc(&{0x105ccf0  3 false 500 839})
    compiler.go:151: values: [   Expected SameValue(« », « ») to be true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.getVar1(assert)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.getPropCallee(_isSameValue)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja.call(2)
    compiler.go:153: > 7: goja.jne(3)
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153: > 10: goja.loadStack(-3)
    compiler.go:153: > 11: goja.getVar1(undefined)
    compiler.go:153: > 12: goja._op_strict_eq({})
    compiler.go:153: > 13: goja.jne(5)
    compiler.go:153: > 14: goja.loadVal(0)
    compiler.go:153: > 15: goja.storeStack(-3)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.jump(6)
    compiler.go:153: > 18: goja.loadStack(-3)
    compiler.go:153: > 19: goja.loadVal(1)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja.storeStack(-3)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-3)
    compiler.go:153: > 24: goja.loadVal(2)
    compiler.go:153: > 25: goja._loadUndef({})
    compiler.go:153: > 26: goja.getVar1Callee(String)
    compiler.go:153: > 27: goja.loadStack(-1)
    compiler.go:153: > 28: goja.call(1)
    compiler.go:153: > 29: goja._add({})
    compiler.go:153: > 30: goja.loadVal(3)
    compiler.go:153: > 31: goja._add({})
    compiler.go:153: > 32: goja._loadUndef({})
    compiler.go:153: > 33: goja.getVar1Callee(String)
    compiler.go:153: > 34: goja.loadStack(-2)
    compiler.go:153: > 35: goja.call(1)
    compiler.go:153: > 36: goja._add({})
    compiler.go:153: > 37: goja.loadVal(4)
    compiler.go:153: > 38: goja._add({})
    compiler.go:153: > 39: goja._add({})
    compiler.go:153: > 40: goja.storeStack(-3)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja._loadUndef({})
    compiler.go:153: > 43: goja.getVar1Callee($ERROR)
    compiler.go:153: > 44: goja.loadStack(-3)
    compiler.go:153: > 45: goja.call(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja._loadUndef({})
    compiler.go:153: > 48: goja._retStashless({})
    compiler.go:153:  16: goja.setProp(sameValue)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(assert)
    compiler.go:153:  19: goja._dup({})
    compiler.go:153:  20: goja.getPropCallee(sameValue)
    compiler.go:153:  21: goja.getVar1(Date)
    compiler.go:153:  22: goja._dup({})
    compiler.go:153:  23: goja.getPropCallee(UTC)
    compiler.go:153:  24: goja.loadVal(0)
    compiler.go:153:  25: goja.loadVal(1)
    compiler.go:153:  26: goja.call(2)
    compiler.go:153:  27: goja.loadVal(1)
    compiler.go:153:  28: goja.loadVal(2)
    compiler.go:153:  29: goja.call(3)
    compiler.go:153:  30: goja._pop({})
    compiler.go:153:  31: goja.getVar1(assert)
    compiler.go:153:  32: goja._dup({})
    compiler.go:153:  33: goja.getPropCallee(sameValue)
    compiler.go:153:  34: goja.getVar1(Date)
    compiler.go:153:  35: goja._dup({})
    compiler.go:153:  36: goja.getPropCallee(UTC)
    compiler.go:153:  37: goja.loadVal(3)
    compiler.go:153:  38: goja.loadVal(1)
    compiler.go:153:  39: goja.call(2)
    compiler.go:153:  40: goja.loadVal(4)
    compiler.go:153:  41: goja.loadVal(5)
    compiler.go:153:  42: goja.call(3)
    compiler.go:153:  43: goja._pop({})
    compiler.go:153:  44: goja.getVar1(assert)
    compiler.go:153:  45: goja._dup({})
    compiler.go:153:  46: goja.getPropCallee(sameValue)
    compiler.go:153:  47: goja.getVar1(Date)
    compiler.go:153:  48: goja._dup({})
    compiler.go:153:  49: goja.getPropCallee(UTC)
    compiler.go:153:  50: goja.loadVal(3)
    compiler.go:153:  51: goja.loadVal(6)
    compiler.go:153:  52: goja.call(2)
    compiler.go:153:  53: goja.loadVal(7)
    compiler.go:153:  54: goja.loadVal(8)
    compiler.go:153:  55: goja.call(3)
    compiler.go:153:  56: goja._pop({})
    compiler.go:153:  57: goja.getVar1(assert)
    compiler.go:153:  58: goja._dup({})
    compiler.go:153:  59: goja.getPropCallee(sameValue)
    compiler.go:153:  60: goja.getVar1(Date)
    compiler.go:153:  61: goja._dup({})
    compiler.go:153:  62: goja.getPropCallee(UTC)
    compiler.go:153:  63: goja.loadVal(3)
    compiler.go:153:  64: goja.loadVal(6)
    compiler.go:153:  65: goja.loadVal(9)
    compiler.go:153:  66: goja.call(3)
    compiler.go:153:  67: goja.loadVal(7)
    compiler.go:153:  68: goja.loadVal(10)
    compiler.go:153:  69: goja.call(3)
    compiler.go:153:  70: goja._pop({})
    compiler.go:153:  71: goja.getVar1(assert)
    compiler.go:153:  72: goja._dup({})
    compiler.go:153:  73: goja.getPropCallee(sameValue)
    compiler.go:153:  74: goja.getVar1(Date)
    compiler.go:153:  75: goja._dup({})
    compiler.go:153:  76: goja.getPropCallee(UTC)
    compiler.go:153:  77: goja.loadVal(3)
    compiler.go:153:  78: goja.loadVal(6)
    compiler.go:153:  79: goja.loadVal(11)
    compiler.go:153:  80: goja.call(3)
    compiler.go:153:  81: goja.loadVal(12)
    compiler.go:153:  82: goja.loadVal(13)
    compiler.go:153:  83: goja.call(3)
    compiler.go:153:  84: goja._pop({})
    compiler.go:153:  85: goja.getVar1(assert)
    compiler.go:153:  86: goja._dup({})
    compiler.go:153:  87: goja.getPropCallee(sameValue)
    compiler.go:153:  88: goja.getVar1(Date)
    compiler.go:153:  89: goja._dup({})
    compiler.go:153:  90: goja.getPropCallee(UTC)
    compiler.go:153:  91: goja.loadVal(3)
    compiler.go:153:  92: goja.loadVal(6)
    compiler.go:153:  93: goja.loadVal(11)
    compiler.go:153:  94: goja.loadVal(1)
    compiler.go:153:  95: goja.call(4)
    compiler.go:153:  96: goja.loadVal(12)
    compiler.go:153:  97: goja.loadVal(14)
    compiler.go:153:  98: goja.call(3)
    compiler.go:153:  99: goja._pop({})
    compiler.go:153:  100: goja.getVar1(assert)
    compiler.go:153:  101: goja._dup({})
    compiler.go:153:  102: goja.getPropCallee(sameValue)
    compiler.go:153:  103: goja.getVar1(Date)
    compiler.go:153:  104: goja._dup({})
    compiler.go:153:  105: goja.getPropCallee(UTC)
    compiler.go:153:  106: goja.loadVal(3)
    compiler.go:153:  107: goja.loadVal(6)
    compiler.go:153:  108: goja.loadVal(11)
    compiler.go:153:  109: goja.loadVal(15)
    compiler.go:153:  110: goja.call(4)
    compiler.go:153:  111: goja.loadVal(16)
    compiler.go:153:  112: goja.loadVal(17)
    compiler.go:153:  113: goja.call(3)
    compiler.go:153:  114: goja._pop({})
    compiler.go:153:  115: goja.getVar1(assert)
    compiler.go:153:  116: goja._dup({})
    compiler.go:153:  117: goja.getPropCallee(sameValue)
    compiler.go:153:  118: goja.getVar1(Date)
    compiler.go:153:  119: goja._dup({})
    compiler.go:153:  120: goja.getPropCallee(UTC)
    compiler.go:153:  121: goja.loadVal(3)
    compiler.go:153:  122: goja.loadVal(6)
    compiler.go:153:  123: goja.loadVal(11)
    compiler.go:153:  124: goja.loadVal(15)
    compiler.go:153:  125: goja.loadVal(1)
    compiler.go:153:  126: goja.call(5)
    compiler.go:153:  127: goja.loadVal(16)
    compiler.go:153:  128: goja.loadVal(18)
    compiler.go:153:  129: goja.call(3)
    compiler.go:153:  130: goja._pop({})
    compiler.go:153:  131: goja.getVar1(assert)
    compiler.go:153:  132: goja._dup({})
    compiler.go:153:  133: goja.getPropCallee(sameValue)
    compiler.go:153:  134: goja.getVar1(Date)
    compiler.go:153:  135: goja._dup({})
    compiler.go:153:  136: goja.getPropCallee(UTC)
    compiler.go:153:  137: goja.loadVal(3)
    compiler.go:153:  138: goja.loadVal(6)
    compiler.go:153:  139: goja.loadVal(11)
    compiler.go:153:  140: goja.loadVal(15)
    compiler.go:153:  141: goja.loadVal(19)
    compiler.go:153:  142: goja.call(5)
    compiler.go:153:  143: goja.loadVal(20)
    compiler.go:153:  144: goja.loadVal(21)
    compiler.go:153:  145: goja.call(3)
    compiler.go:153:  146: goja._pop({})
    compiler.go:153:  147: goja.getVar1(assert)
    compiler.go:153:  148: goja._dup({})
    compiler.go:153:  149: goja.getPropCallee(sameValue)
    compiler.go:153:  150: goja.getVar1(Date)
    compiler.go:153:  151: goja._dup({})
    compiler.go:153:  152: goja.getPropCallee(UTC)
    compiler.go:153:  153: goja.loadVal(3)
    compiler.go:153:  154: goja.loadVal(6)
    compiler.go:153:  155: goja.loadVal(11)
    compiler.go:153:  156: goja.loadVal(15)
    compiler.go:153:  157: goja.loadVal(19)
    compiler.go:153:  158: goja.loadVal(1)
    compiler.go:153:  159: goja.call(6)
    compiler.go:153:  160: goja.loadVal(20)
    compiler.go:153:  161: goja.loadVal(22)
    compiler.go:153:  162: goja.call(3)
    compiler.go:153:  163: goja._pop({})
    compiler.go:153:  164: goja.getVar1(assert)
    compiler.go:153:  165: goja._dup({})
    compiler.go:153:  166: goja.getPropCallee(sameValue)
    compiler.go:153:  167: goja.getVar1(Date)
    compiler.go:153:  168: goja._dup({})
    compiler.go:153:  169: goja.getPropCallee(UTC)
    compiler.go:153:  170: goja.loadVal(3)
    compiler.go:153:  171: goja.loadVal(6)
    compiler.go:153:  172: goja.loadVal(11)
    compiler.go:153:  173: goja.loadVal(15)
    compiler.go:153:  174: goja.loadVal(19)
    compiler.go:153:  175: goja.loadVal(23)
    compiler.go:153:  176: goja.call(6)
    compiler.go:153:  177: goja.loadVal(24)
    compiler.go:153:  178: goja.loadVal(25)
    compiler.go:153:  179: goja.call(3)
    compiler.go:153:  180: goja._halt({})
    compiler_test.go:60: stack size: 12
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestDateUTC (0.02s)
=== RUN   TestNewDate
    compiler.go:151: values: [2016-09-01T12:34:56Z 12]
    compiler.go:153:  0: goja.bindName(d1)
    compiler.go:153:  1: goja.resolveVar1(d1)
    compiler.go:153:  2: goja.getVar1(Date)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._new(1)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.getVar1(d1)
    compiler.go:153:  8: goja._dup({})
    compiler.go:153:  9: goja.getPropCallee(getUTCHours)
    compiler.go:153:  10: goja.call(0)
    compiler.go:153:  11: goja.loadVal(1)
    compiler.go:153:  12: goja._op_strict_eq({})
    compiler.go:153:  13: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestNewDate (0.01s)
=== RUN   TestNewDate0
    compiler.go:151: values: [0]
    compiler.go:153:  0: goja.getVar1(Date)
    compiler.go:153:  1: goja.loadVal(0)
    compiler.go:153:  2: goja._new(1)
    compiler.go:153:  3: goja._dup({})
    compiler.go:153:  4: goja.getPropCallee(toUTCString)
    compiler.go:153:  5: goja.call(0)
    compiler.go:153:  6: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestNewDate0 (0.00s)
=== RUN   TestSetHour
    compiler.go:151: values: [2016 8 1 12 23 45 16 13 9]
    compiler.go:153:  0: goja.bindName($ERROR)
    compiler.go:153:  1: goja.bindName(assert)
    compiler.go:153:  2: goja.bindName(d)
    compiler.go:153:  3: goja.resolveVar1($ERROR)
    compiler.go:153:  4: *goja.newFunc(&{0x13fa450 $ERROR 1 false 1 56})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadStack(-1)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(assert)
    compiler.go:153:  8: *goja.newFunc(&{0x13fa480 assert 2 false 58 277})
    compiler.go:151: values: [true Expected true but got ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja.loadStack(-2)
    compiler.go:153: > 8: goja.getVar1(undefined)
    compiler.go:153: > 9: goja._op_strict_eq({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._loadUndef({})
    compiler.go:153: > 13: goja.getVar1Callee(String)
    compiler.go:153: > 14: goja.loadStack(-1)
    compiler.go:153: > 15: goja.call(1)
    compiler.go:153: > 16: goja._add({})
    compiler.go:153: > 17: goja.storeStack(-2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja.getVar1Callee($ERROR)
    compiler.go:153: > 21: goja.loadStack(-2)
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja._loadUndef({})
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.getVar1(assert)
    compiler.go:153:  12: *goja.newFunc(&{0x13fa4b0  2 false 301 478})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadStack(-2)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(14)
    compiler.go:153: > 5: goja.loadStack(-1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_neq({})
    compiler.go:153: > 8: goja.jeq1(9)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadVal(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._div({})
    compiler.go:153: > 13: goja.loadVal(1)
    compiler.go:153: > 14: goja.loadStack(-2)
    compiler.go:153: > 15: goja._div({})
    compiler.go:153: > 16: goja._op_strict_eq({})
    compiler.go:153: > 17: goja._retStashless({})
    compiler.go:153: > 18: goja.loadStack(-1)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja._op_strict_neq({})
    compiler.go:153: > 21: goja.jneq1(5)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-2)
    compiler.go:153: > 24: goja.loadStack(-2)
    compiler.go:153: > 25: goja._op_strict_neq({})
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  13: goja.setProp(_isSameValue)
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja.getVar1(assert)
    compiler.go:153:  16: *goja.newFunc(&{0x13fa4e0  3 false 500 839})
    compiler.go:151: values: [   Expected SameValue(« », « ») to be true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.getVar1(assert)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.getPropCallee(_isSameValue)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja.call(2)
    compiler.go:153: > 7: goja.jne(3)
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153: > 10: goja.loadStack(-3)
    compiler.go:153: > 11: goja.getVar1(undefined)
    compiler.go:153: > 12: goja._op_strict_eq({})
    compiler.go:153: > 13: goja.jne(5)
    compiler.go:153: > 14: goja.loadVal(0)
    compiler.go:153: > 15: goja.storeStack(-3)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.jump(6)
    compiler.go:153: > 18: goja.loadStack(-3)
    compiler.go:153: > 19: goja.loadVal(1)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja.storeStack(-3)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-3)
    compiler.go:153: > 24: goja.loadVal(2)
    compiler.go:153: > 25: goja._loadUndef({})
    compiler.go:153: > 26: goja.getVar1Callee(String)
    compiler.go:153: > 27: goja.loadStack(-1)
    compiler.go:153: > 28: goja.call(1)
    compiler.go:153: > 29: goja._add({})
    compiler.go:153: > 30: goja.loadVal(3)
    compiler.go:153: > 31: goja._add({})
    compiler.go:153: > 32: goja._loadUndef({})
    compiler.go:153: > 33: goja.getVar1Callee(String)
    compiler.go:153: > 34: goja.loadStack(-2)
    compiler.go:153: > 35: goja.call(1)
    compiler.go:153: > 36: goja._add({})
    compiler.go:153: > 37: goja.loadVal(4)
    compiler.go:153: > 38: goja._add({})
    compiler.go:153: > 39: goja._add({})
    compiler.go:153: > 40: goja.storeStack(-3)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja._loadUndef({})
    compiler.go:153: > 43: goja.getVar1Callee($ERROR)
    compiler.go:153: > 44: goja.loadStack(-3)
    compiler.go:153: > 45: goja.call(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja._loadUndef({})
    compiler.go:153: > 48: goja._retStashless({})
    compiler.go:153:  17: goja.setProp(sameValue)
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(d)
    compiler.go:153:  20: goja.getVar1(Date)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja.loadVal(1)
    compiler.go:153:  23: goja.loadVal(2)
    compiler.go:153:  24: goja.loadVal(3)
    compiler.go:153:  25: goja.loadVal(4)
    compiler.go:153:  26: goja.loadVal(5)
    compiler.go:153:  27: goja._new(6)
    compiler.go:153:  28: goja._putValue({})
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.getVar1(assert)
    compiler.go:153:  31: goja._dup({})
    compiler.go:153:  32: goja.getPropCallee(sameValue)
    compiler.go:153:  33: goja.getVar1(d)
    compiler.go:153:  34: goja._dup({})
    compiler.go:153:  35: goja.getPropCallee(getHours)
    compiler.go:153:  36: goja.call(0)
    compiler.go:153:  37: goja.loadVal(3)
    compiler.go:153:  38: goja.call(2)
    compiler.go:153:  39: goja._pop({})
    compiler.go:153:  40: goja.getVar1(assert)
    compiler.go:153:  41: goja._dup({})
    compiler.go:153:  42: goja.getPropCallee(sameValue)
    compiler.go:153:  43: goja.getVar1(d)
    compiler.go:153:  44: goja._dup({})
    compiler.go:153:  45: goja.getPropCallee(getUTCHours)
    compiler.go:153:  46: goja.call(0)
    compiler.go:153:  47: goja.loadVal(6)
    compiler.go:153:  48: goja.call(2)
    compiler.go:153:  49: goja._pop({})
    compiler.go:153:  50: goja.getVar1(d)
    compiler.go:153:  51: goja._dup({})
    compiler.go:153:  52: goja.getPropCallee(setHours)
    compiler.go:153:  53: goja.loadVal(7)
    compiler.go:153:  54: goja.call(1)
    compiler.go:153:  55: goja._pop({})
    compiler.go:153:  56: goja.getVar1(assert)
    compiler.go:153:  57: goja._dup({})
    compiler.go:153:  58: goja.getPropCallee(sameValue)
    compiler.go:153:  59: goja.getVar1(d)
    compiler.go:153:  60: goja._dup({})
    compiler.go:153:  61: goja.getPropCallee(getHours)
    compiler.go:153:  62: goja.call(0)
    compiler.go:153:  63: goja.loadVal(7)
    compiler.go:153:  64: goja.call(2)
    compiler.go:153:  65: goja._pop({})
    compiler.go:153:  66: goja.getVar1(assert)
    compiler.go:153:  67: goja._dup({})
    compiler.go:153:  68: goja.getPropCallee(sameValue)
    compiler.go:153:  69: goja.getVar1(d)
    compiler.go:153:  70: goja._dup({})
    compiler.go:153:  71: goja.getPropCallee(getMinutes)
    compiler.go:153:  72: goja.call(0)
    compiler.go:153:  73: goja.loadVal(4)
    compiler.go:153:  74: goja.call(2)
    compiler.go:153:  75: goja._pop({})
    compiler.go:153:  76: goja.getVar1(assert)
    compiler.go:153:  77: goja._dup({})
    compiler.go:153:  78: goja.getPropCallee(sameValue)
    compiler.go:153:  79: goja.getVar1(d)
    compiler.go:153:  80: goja._dup({})
    compiler.go:153:  81: goja.getPropCallee(getSeconds)
    compiler.go:153:  82: goja.call(0)
    compiler.go:153:  83: goja.loadVal(5)
    compiler.go:153:  84: goja.call(2)
    compiler.go:153:  85: goja._pop({})
    compiler.go:153:  86: goja.getVar1(d)
    compiler.go:153:  87: goja._dup({})
    compiler.go:153:  88: goja.getPropCallee(setUTCHours)
    compiler.go:153:  89: goja.loadVal(7)
    compiler.go:153:  90: goja.call(1)
    compiler.go:153:  91: goja._pop({})
    compiler.go:153:  92: goja.getVar1(assert)
    compiler.go:153:  93: goja._dup({})
    compiler.go:153:  94: goja.getPropCallee(sameValue)
    compiler.go:153:  95: goja.getVar1(d)
    compiler.go:153:  96: goja._dup({})
    compiler.go:153:  97: goja.getPropCallee(getHours)
    compiler.go:153:  98: goja.call(0)
    compiler.go:153:  99: goja.loadVal(8)
    compiler.go:153:  100: goja.call(2)
    compiler.go:153:  101: goja._pop({})
    compiler.go:153:  102: goja.getVar1(assert)
    compiler.go:153:  103: goja._dup({})
    compiler.go:153:  104: goja.getPropCallee(sameValue)
    compiler.go:153:  105: goja.getVar1(d)
    compiler.go:153:  106: goja._dup({})
    compiler.go:153:  107: goja.getPropCallee(getMinutes)
    compiler.go:153:  108: goja.call(0)
    compiler.go:153:  109: goja.loadVal(4)
    compiler.go:153:  110: goja.call(2)
    compiler.go:153:  111: goja._pop({})
    compiler.go:153:  112: goja.getVar1(assert)
    compiler.go:153:  113: goja._dup({})
    compiler.go:153:  114: goja.getPropCallee(sameValue)
    compiler.go:153:  115: goja.getVar1(d)
    compiler.go:153:  116: goja._dup({})
    compiler.go:153:  117: goja.getPropCallee(getSeconds)
    compiler.go:153:  118: goja.call(0)
    compiler.go:153:  119: goja.loadVal(5)
    compiler.go:153:  120: goja.call(2)
    compiler.go:153:  121: goja._halt({})
    compiler_test.go:60: stack size: 11
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSetHour (0.01s)
=== RUN   TestSetMinute
    compiler.go:151: values: [2016 8 1 12 23 45 6 53 55 52 22 13]
    compiler.go:153:  0: goja.bindName($ERROR)
    compiler.go:153:  1: goja.bindName(assert)
    compiler.go:153:  2: goja.bindName(d)
    compiler.go:153:  3: goja.resolveVar1($ERROR)
    compiler.go:153:  4: *goja.newFunc(&{0x13fa960 $ERROR 1 false 1 56})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadStack(-1)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.resolveVar1(assert)
    compiler.go:153:  8: *goja.newFunc(&{0x13fa990 assert 2 false 58 277})
    compiler.go:151: values: [true Expected true but got ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja.loadStack(-2)
    compiler.go:153: > 8: goja.getVar1(undefined)
    compiler.go:153: > 9: goja._op_strict_eq({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._loadUndef({})
    compiler.go:153: > 13: goja.getVar1Callee(String)
    compiler.go:153: > 14: goja.loadStack(-1)
    compiler.go:153: > 15: goja.call(1)
    compiler.go:153: > 16: goja._add({})
    compiler.go:153: > 17: goja.storeStack(-2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja.getVar1Callee($ERROR)
    compiler.go:153: > 21: goja.loadStack(-2)
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja._loadUndef({})
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  9: goja._putValue({})
    compiler.go:153:  10: goja._pop({})
    compiler.go:153:  11: goja.getVar1(assert)
    compiler.go:153:  12: *goja.newFunc(&{0x13fa9c0  2 false 301 478})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadStack(-2)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(14)
    compiler.go:153: > 5: goja.loadStack(-1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_neq({})
    compiler.go:153: > 8: goja.jeq1(9)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadVal(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._div({})
    compiler.go:153: > 13: goja.loadVal(1)
    compiler.go:153: > 14: goja.loadStack(-2)
    compiler.go:153: > 15: goja._div({})
    compiler.go:153: > 16: goja._op_strict_eq({})
    compiler.go:153: > 17: goja._retStashless({})
    compiler.go:153: > 18: goja.loadStack(-1)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja._op_strict_neq({})
    compiler.go:153: > 21: goja.jneq1(5)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-2)
    compiler.go:153: > 24: goja.loadStack(-2)
    compiler.go:153: > 25: goja._op_strict_neq({})
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  13: goja.setProp(_isSameValue)
    compiler.go:153:  14: goja._pop({})
    compiler.go:153:  15: goja.getVar1(assert)
    compiler.go:153:  16: *goja.newFunc(&{0x13fa9f0  3 false 500 839})
    compiler.go:151: values: [   Expected SameValue(« », « ») to be true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.getVar1(assert)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.getPropCallee(_isSameValue)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja.call(2)
    compiler.go:153: > 7: goja.jne(3)
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153: > 10: goja.loadStack(-3)
    compiler.go:153: > 11: goja.getVar1(undefined)
    compiler.go:153: > 12: goja._op_strict_eq({})
    compiler.go:153: > 13: goja.jne(5)
    compiler.go:153: > 14: goja.loadVal(0)
    compiler.go:153: > 15: goja.storeStack(-3)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.jump(6)
    compiler.go:153: > 18: goja.loadStack(-3)
    compiler.go:153: > 19: goja.loadVal(1)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja.storeStack(-3)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-3)
    compiler.go:153: > 24: goja.loadVal(2)
    compiler.go:153: > 25: goja._loadUndef({})
    compiler.go:153: > 26: goja.getVar1Callee(String)
    compiler.go:153: > 27: goja.loadStack(-1)
    compiler.go:153: > 28: goja.call(1)
    compiler.go:153: > 29: goja._add({})
    compiler.go:153: > 30: goja.loadVal(3)
    compiler.go:153: > 31: goja._add({})
    compiler.go:153: > 32: goja._loadUndef({})
    compiler.go:153: > 33: goja.getVar1Callee(String)
    compiler.go:153: > 34: goja.loadStack(-2)
    compiler.go:153: > 35: goja.call(1)
    compiler.go:153: > 36: goja._add({})
    compiler.go:153: > 37: goja.loadVal(4)
    compiler.go:153: > 38: goja._add({})
    compiler.go:153: > 39: goja._add({})
    compiler.go:153: > 40: goja.storeStack(-3)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja._loadUndef({})
    compiler.go:153: > 43: goja.getVar1Callee($ERROR)
    compiler.go:153: > 44: goja.loadStack(-3)
    compiler.go:153: > 45: goja.call(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja._loadUndef({})
    compiler.go:153: > 48: goja._retStashless({})
    compiler.go:153:  17: goja.setProp(sameValue)
    compiler.go:153:  18: goja._pop({})
    compiler.go:153:  19: goja.resolveVar1(d)
    compiler.go:153:  20: goja.getVar1(Date)
    compiler.go:153:  21: goja.loadVal(0)
    compiler.go:153:  22: goja.loadVal(1)
    compiler.go:153:  23: goja.loadVal(2)
    compiler.go:153:  24: goja.loadVal(3)
    compiler.go:153:  25: goja.loadVal(4)
    compiler.go:153:  26: goja.loadVal(5)
    compiler.go:153:  27: goja._new(6)
    compiler.go:153:  28: goja._putValue({})
    compiler.go:153:  29: goja._pop({})
    compiler.go:153:  30: goja.getVar1(assert)
    compiler.go:153:  31: goja._dup({})
    compiler.go:153:  32: goja.getPropCallee(sameValue)
    compiler.go:153:  33: goja.getVar1(d)
    compiler.go:153:  34: goja._dup({})
    compiler.go:153:  35: goja.getPropCallee(getHours)
    compiler.go:153:  36: goja.call(0)
    compiler.go:153:  37: goja.loadVal(3)
    compiler.go:153:  38: goja.call(2)
    compiler.go:153:  39: goja._pop({})
    compiler.go:153:  40: goja.getVar1(assert)
    compiler.go:153:  41: goja._dup({})
    compiler.go:153:  42: goja.getPropCallee(sameValue)
    compiler.go:153:  43: goja.getVar1(d)
    compiler.go:153:  44: goja._dup({})
    compiler.go:153:  45: goja.getPropCallee(getUTCHours)
    compiler.go:153:  46: goja.call(0)
    compiler.go:153:  47: goja.loadVal(6)
    compiler.go:153:  48: goja.call(2)
    compiler.go:153:  49: goja._pop({})
    compiler.go:153:  50: goja.getVar1(assert)
    compiler.go:153:  51: goja._dup({})
    compiler.go:153:  52: goja.getPropCallee(sameValue)
    compiler.go:153:  53: goja.getVar1(d)
    compiler.go:153:  54: goja._dup({})
    compiler.go:153:  55: goja.getPropCallee(getMinutes)
    compiler.go:153:  56: goja.call(0)
    compiler.go:153:  57: goja.loadVal(4)
    compiler.go:153:  58: goja.call(2)
    compiler.go:153:  59: goja._pop({})
    compiler.go:153:  60: goja.getVar1(assert)
    compiler.go:153:  61: goja._dup({})
    compiler.go:153:  62: goja.getPropCallee(sameValue)
    compiler.go:153:  63: goja.getVar1(d)
    compiler.go:153:  64: goja._dup({})
    compiler.go:153:  65: goja.getPropCallee(getUTCMinutes)
    compiler.go:153:  66: goja.call(0)
    compiler.go:153:  67: goja.loadVal(7)
    compiler.go:153:  68: goja.call(2)
    compiler.go:153:  69: goja._pop({})
    compiler.go:153:  70: goja.getVar1(d)
    compiler.go:153:  71: goja._dup({})
    compiler.go:153:  72: goja.getPropCallee(setMinutes)
    compiler.go:153:  73: goja.loadVal(8)
    compiler.go:153:  74: goja.call(1)
    compiler.go:153:  75: goja._pop({})
    compiler.go:153:  76: goja.getVar1(assert)
    compiler.go:153:  77: goja._dup({})
    compiler.go:153:  78: goja.getPropCallee(sameValue)
    compiler.go:153:  79: goja.getVar1(d)
    compiler.go:153:  80: goja._dup({})
    compiler.go:153:  81: goja.getPropCallee(getMinutes)
    compiler.go:153:  82: goja.call(0)
    compiler.go:153:  83: goja.loadVal(8)
    compiler.go:153:  84: goja.call(2)
    compiler.go:153:  85: goja._pop({})
    compiler.go:153:  86: goja.getVar1(assert)
    compiler.go:153:  87: goja._dup({})
    compiler.go:153:  88: goja.getPropCallee(sameValue)
    compiler.go:153:  89: goja.getVar1(d)
    compiler.go:153:  90: goja._dup({})
    compiler.go:153:  91: goja.getPropCallee(getSeconds)
    compiler.go:153:  92: goja.call(0)
    compiler.go:153:  93: goja.loadVal(5)
    compiler.go:153:  94: goja.call(2)
    compiler.go:153:  95: goja._pop({})
    compiler.go:153:  96: goja.getVar1(d)
    compiler.go:153:  97: goja._dup({})
    compiler.go:153:  98: goja.getPropCallee(setUTCMinutes)
    compiler.go:153:  99: goja.loadVal(9)
    compiler.go:153:  100: goja.call(1)
    compiler.go:153:  101: goja._pop({})
    compiler.go:153:  102: goja.getVar1(assert)
    compiler.go:153:  103: goja._dup({})
    compiler.go:153:  104: goja.getPropCallee(sameValue)
    compiler.go:153:  105: goja.getVar1(d)
    compiler.go:153:  106: goja._dup({})
    compiler.go:153:  107: goja.getPropCallee(getMinutes)
    compiler.go:153:  108: goja.call(0)
    compiler.go:153:  109: goja.loadVal(10)
    compiler.go:153:  110: goja.call(2)
    compiler.go:153:  111: goja._pop({})
    compiler.go:153:  112: goja.getVar1(assert)
    compiler.go:153:  113: goja._dup({})
    compiler.go:153:  114: goja.getPropCallee(sameValue)
    compiler.go:153:  115: goja.getVar1(d)
    compiler.go:153:  116: goja._dup({})
    compiler.go:153:  117: goja.getPropCallee(getHours)
    compiler.go:153:  118: goja.call(0)
    compiler.go:153:  119: goja.loadVal(11)
    compiler.go:153:  120: goja.call(2)
    compiler.go:153:  121: goja._halt({})
    compiler_test.go:60: stack size: 11
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestSetMinute (0.01s)
=== RUN   TestTimezoneOffset
    compiler.go:151: values: [0]
    compiler.go:153:  0: goja.bindName(d)
    compiler.go:153:  1: goja.resolveVar1(d)
    compiler.go:153:  2: goja.getVar1(Date)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._new(1)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.getVar1(d)
    compiler.go:153:  8: goja._dup({})
    compiler.go:153:  9: goja.getPropCallee(getTimezoneOffset)
    compiler.go:153:  10: goja.call(0)
    compiler.go:153:  11: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestTimezoneOffset (0.00s)
=== RUN   TestDateValueOf
    compiler.go:151: values: [1230000000000000]
    compiler.go:153:  0: goja.bindName(d9)
    compiler.go:153:  1: goja.resolveVar1(d9)
    compiler.go:153:  2: goja.getVar1(Date)
    compiler.go:153:  3: goja.loadVal(0)
    compiler.go:153:  4: goja._new(1)
    compiler.go:153:  5: goja._putValue({})
    compiler.go:153:  6: goja._pop({})
    compiler.go:153:  7: goja.getVar1(d9)
    compiler.go:153:  8: goja._dup({})
    compiler.go:153:  9: goja.getPropCallee(valueOf)
    compiler.go:153:  10: goja.call(0)
    compiler.go:153:  11: goja._halt({})
    compiler_test.go:60: stack size: 2
    compiler_test.go:61: stashAllocs: 0
--- PASS: TestDateValueOf (0.00s)
=== RUN   TestDateSetters
    compiler.go:151: values: [0 2345 setMilliseconds() setUTCMilliseconds() 12 12000 setSeconds() setUTCSeconds() 720 1000 setMinutes() setUTCMinutes() 2016-06-01 1 1464739200000 setHours() 1464742800000 setUTCHours() 2 86400000 setDate() setUTCDate() 5097600000 setMonth() setUTCMonth() 1971 31536000000 setFullYear() 3 36806400000 setFullYear(Y,M,D) setUTCFullYear() setUTCFullYear(Y,M,D)]
    compiler.go:153:  0: goja.bindName($ERROR)
    compiler.go:153:  1: goja.bindName(assert)
    compiler.go:153:  2: goja.resolveVar1($ERROR)
    compiler.go:153:  3: *goja.newFunc(&{0x13fb470 $ERROR 1 false 1 56})
    compiler.go:151: values: []
    compiler.go:153: > 0: goja.enterFuncStashless({0 1})
    compiler.go:153: > 1: goja.getVar1(Error)
    compiler.go:153: > 2: goja.loadStack(-1)
    compiler.go:153: > 3: goja._new(1)
    compiler.go:153: > 4: goja._throw({})
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153:  4: goja._putValue({})
    compiler.go:153:  5: goja._pop({})
    compiler.go:153:  6: goja.resolveVar1(assert)
    compiler.go:153:  7: *goja.newFunc(&{0x13fb4a0 assert 2 false 58 277})
    compiler.go:151: values: [true Expected true but got ]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadVal(0)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(3)
    compiler.go:153: > 5: goja._loadUndef({})
    compiler.go:153: > 6: goja._retStashless({})
    compiler.go:153: > 7: goja.loadStack(-2)
    compiler.go:153: > 8: goja.getVar1(undefined)
    compiler.go:153: > 9: goja._op_strict_eq({})
    compiler.go:153: > 10: goja.jne(9)
    compiler.go:153: > 11: goja.loadVal(1)
    compiler.go:153: > 12: goja._loadUndef({})
    compiler.go:153: > 13: goja.getVar1Callee(String)
    compiler.go:153: > 14: goja.loadStack(-1)
    compiler.go:153: > 15: goja.call(1)
    compiler.go:153: > 16: goja._add({})
    compiler.go:153: > 17: goja.storeStack(-2)
    compiler.go:153: > 18: goja._pop({})
    compiler.go:153: > 19: goja._loadUndef({})
    compiler.go:153: > 20: goja.getVar1Callee($ERROR)
    compiler.go:153: > 21: goja.loadStack(-2)
    compiler.go:153: > 22: goja.call(1)
    compiler.go:153: > 23: goja._pop({})
    compiler.go:153: > 24: goja._loadUndef({})
    compiler.go:153: > 25: goja._retStashless({})
    compiler.go:153:  8: goja._putValue({})
    compiler.go:153:  9: goja._pop({})
    compiler.go:153:  10: goja.getVar1(assert)
    compiler.go:153:  11: *goja.newFunc(&{0x13fb4d0  2 false 301 478})
    compiler.go:151: values: [0 1]
    compiler.go:153: > 0: goja.enterFuncStashless({0 2})
    compiler.go:153: > 1: goja.loadStack(-1)
    compiler.go:153: > 2: goja.loadStack(-2)
    compiler.go:153: > 3: goja._op_strict_eq({})
    compiler.go:153: > 4: goja.jne(14)
    compiler.go:153: > 5: goja.loadStack(-1)
    compiler.go:153: > 6: goja.loadVal(0)
    compiler.go:153: > 7: goja._op_strict_neq({})
    compiler.go:153: > 8: goja.jeq1(9)
    compiler.go:153: > 9: goja._pop({})
    compiler.go:153: > 10: goja.loadVal(1)
    compiler.go:153: > 11: goja.loadStack(-1)
    compiler.go:153: > 12: goja._div({})
    compiler.go:153: > 13: goja.loadVal(1)
    compiler.go:153: > 14: goja.loadStack(-2)
    compiler.go:153: > 15: goja._div({})
    compiler.go:153: > 16: goja._op_strict_eq({})
    compiler.go:153: > 17: goja._retStashless({})
    compiler.go:153: > 18: goja.loadStack(-1)
    compiler.go:153: > 19: goja.loadStack(-1)
    compiler.go:153: > 20: goja._op_strict_neq({})
    compiler.go:153: > 21: goja.jneq1(5)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-2)
    compiler.go:153: > 24: goja.loadStack(-2)
    compiler.go:153: > 25: goja._op_strict_neq({})
    compiler.go:153: > 26: goja._retStashless({})
    compiler.go:153:  12: goja.setProp(_isSameValue)
    compiler.go:153:  13: goja._pop({})
    compiler.go:153:  14: goja.getVar1(assert)
    compiler.go:153:  15: *goja.newFunc(&{0x13fb500  3 false 500 839})
    compiler.go:151: values: [   Expected SameValue(« », « ») to be true]
    compiler.go:153: > 0: goja.enterFuncStashless({0 3})
    compiler.go:153: > 1: goja.getVar1(assert)
    compiler.go:153: > 2: goja._dup({})
    compiler.go:153: > 3: goja.getPropCallee(_isSameValue)
    compiler.go:153: > 4: goja.loadStack(-1)
    compiler.go:153: > 5: goja.loadStack(-2)
    compiler.go:153: > 6: goja.call(2)
    compiler.go:153: > 7: goja.jne(3)
    compiler.go:153: > 8: goja._loadUndef({})
    compiler.go:153: > 9: goja._retStashless({})
    compiler.go:153: > 10: goja.loadStack(-3)
    compiler.go:153: > 11: goja.getVar1(undefined)
    compiler.go:153: > 12: goja._op_strict_eq({})
    compiler.go:153: > 13: goja.jne(5)
    compiler.go:153: > 14: goja.loadVal(0)
    compiler.go:153: > 15: goja.storeStack(-3)
    compiler.go:153: > 16: goja._pop({})
    compiler.go:153: > 17: goja.jump(6)
    compiler.go:153: > 18: goja.loadStack(-3)
    compiler.go:153: > 19: goja.loadVal(1)
    compiler.go:153: > 20: goja._add({})
    compiler.go:153: > 21: goja.storeStack(-3)
    compiler.go:153: > 22: goja._pop({})
    compiler.go:153: > 23: goja.loadStack(-3)
    compiler.go:153: > 24: goja.loadVal(2)
    compiler.go:153: > 25: goja._loadUndef({})
    compiler.go:153: > 26: goja.getVar1Callee(String)
    compiler.go:153: > 27: goja.loadStack(-1)
    compiler.go:153: > 28: goja.call(1)
    compiler.go:153: > 29: goja._add({})
    compiler.go:153: > 30: goja.loadVal(3)
    compiler.go:153: > 31: goja._add({})
    compiler.go:153: > 32: goja._loadUndef({})
    compiler.go:153: > 33: goja.getVar1Callee(String)
    compiler.go:153: > 34: goja.loadStack(-2)
    compiler.go:153: > 35: goja.call(1)
    compiler.go:153: > 36: goja._add({})
    compiler.go:153: > 37: goja.loadVal(4)
    compiler.go:153: > 38: goja._add({})
    compiler.go:153: > 39: goja._add({})
    compiler.go:153: > 40: goja.storeStack(-3)
    compiler.go:153: > 41: goja._pop({})
    compiler.go:153: > 42: goja._loadUndef({})
    compiler.go:153: > 43: goja.getVar1Callee($ERROR)
    compiler.go:153: > 44: goja.loadStack(-3)
    compiler.go:153: > 45: goja.call(1)
    compiler.go:153: > 46: goja._pop({})
    compiler.go:153: > 47: goja._loadUndef({})
    compiler.go:153: > 48: goja._retStashless({})
    compiler.go:153:  16: goja.setProp(sameValue)
    compiler.go:153:  17: goja._pop({})
    compiler.go:153:  18: goja.getVar1(assert)
    compiler.go:153:  19: goja._dup({})
    compiler.go:153:  20: goja.getPropCallee(sameValue)
    compiler.go:153:  21: goja.getVar1(Date)
    compiler.go:153:  22: goja.loadVal(0)
    compiler.go:153:  23: goja._new(1)
    compiler.go:153:  24: goja._dup({})
    compiler.go:153:  25: goja.getPropCallee(setMilliseconds)
    compiler.go:153:  26: goja.loadVal(1)
    compiler.go:153:  27: goja.call(1)
    compiler.go:153:  28: goja.loadVal(1)
    compiler.go:153:  29: goja.loadVal(2)
    compiler.go:153:  30: goja.call(3)
    compiler.go:153:  31: goja._pop({})
    compiler.go:153:  32: goja.getVar1(assert)
    compiler.go:153:  33: goja._dup({})
    compiler.go:153:  34: goja.getPropCallee(sameValue)
    compiler.go:153:  35: goja.getVar1(Date)
    compiler.go:153:  36: goja.loadVal(0)
    compiler.go:153:  37: goja._new(1)
    compiler.go:153:  38: goja._dup({})
    compiler.go:153:  39: goja.getPropCallee(setUTCMilliseconds)
    compiler.go:153:  40: goja.loadVal(1)
    compiler.go:153:  41: goja.call(1)
    compiler.go:153:  42: goja.loadVal(1)
    compiler.go:153:  43: goja.loadVal(3)
    compiler.go:153:  44: goja.call(3)
    compiler.go:153:  45: goja._pop({})
    compiler.go:153:  46: goja.getVar1(assert)
    compiler.go:153:  47: goja._dup({})
    compiler.go:153:  48: goja.getPropCallee(sameValue)
    compiler.go:153:  49: goja.getVar1(Date)
    compiler.go:153:  50: goja.loadVal(0)
    compiler.go:153:  51: goja._new(1)
    compiler.go:153:  52: goja._dup({})
    compiler.go:153:  53: goja.getPropCallee(setSeconds)
    compiler.go:153:  54: goja.loadVal(4)
    compiler.go:153:  55: goja.call(1)
    compiler.go:153:  56: goja.loadVal(5)
    compiler.go:153:  57: goja.loadVal(6)
    compiler.go:153:  58: goja.call(3)
    compiler.go:153:  59: goja._pop({})
    compiler.go:153:  60: goja.getVar1(assert)
    compiler.go:153:  61: goja._dup({})
    compiler.go:153:  62: goja.getPropCallee(sameValue)
    compiler.go:153:  63: goja.getVar1(Date)
    compiler.go:153:  64: goja.loadVal(0)
    compiler.go:153:  65: goja._new(1)
    compiler.go:153:  66: goja._dup({})
    compiler.go:153:  67: goja.getPropCallee(setUTCSeconds)
    compiler.go:153:  68: goja.loadVal(4)
    compiler.go:153:  69: goja.call(1)
    compiler.go:153:  70: goja.loadVal(5)
    compiler.go:153:  71: goja.loadVal(7)
    compiler.go:153:  72: goja.call(3)
    compiler.go:153:  73: goja._pop({})
    compiler.go:153:  74: goja.getVar1(assert)
    compiler.go:153:  75: goja._dup({})
    compiler.go:153:  76: goja.getPropCallee(sameValue)
    compiler.go:153:  77: goja.getVar1(Date)
    compiler.go:153:  78: goja.loadVal(0)
    compiler.go:153:  79: goja._new(1)
    compiler.go:153:  80: goja._dup({})
    compiler.go:153:  81: goja.getPropCallee(setMinutes)
    compiler.go:153:  82: goja.loadVal(4)
    compiler.go:153:  83: goja.call(1)
    compiler.go:153:  84: goja.loadVal(8)
    compiler.go:153:  85: goja.loadVal(9)
    compiler.go:153:  86: goja._mul({})
    compiler.go:153:  87: goja.loadVal(10)
    compiler.go:153:  88: goja.call(3)
    compiler.go:153:  89: goja._pop({})
    compiler.go:153:  90: goja.getVar1(assert)
    compiler.go:153:  91: goja._dup({})
    compiler.go:153:  92: goja.getPropCallee(sameValue)
    compiler.go:153:  93: goja.getVar1(Date)
    compiler.go:153:  94: goja.loadVal(0)
    compiler.go:153:  95: goja._new(1)
    compiler.go:153:  96: goja._dup({})
    compiler.go:153:  97: goja.getPropCallee(setUTCMinutes)
    compiler.go:153:  98: goja.loadVal(4)
    compiler.go:153:  99: goja.call(1)
    compiler.go:153:  100: goja.loadVal(8)
    compiler.go:153:  101: goja.loadVal(9)
    compiler.go:153:  102: goja._mul({})
    compiler.go:153:  103: goja.loadVal(11)
    compiler.go:153:  104: goja.call(3)
    compiler.go:153:  105: goja._pop({})
    compiler.go:153:  106: goja.getVar1(assert)
    compiler.go:153:  107: goja._dup({})
    compiler.go:153:  108: goja.getPropCallee(sameValue)
    compiler.go:153:  109: goja.getVar1(Date)
    compiler.go:153:  110: goja.loadVal(12)
    compiler.go:153:  111: goja._new(1)
    compiler.go:153:  112: goja._dup({})
    compiler.go:153:  113: goja.getPropCallee(setHours)
    compiler.go:153:  114: goja.loadVal(13)
    compiler.go:153:  115: goja.call(1)
    compiler.go:153:  116: goja.loadVal(14)
    compiler.go:153:  117: goja.loadVal(15)
    compiler.go:153:  118: goja.call(3)
    compiler.go:153:  119: goja._pop({})
    compiler.go:153:  120: goja.getVar1(assert)
    compiler.go:153:  121: goja._dup({})
    compiler.go:153:  122: goja.getPropCallee(sameValue)
    compiler.go:153:  123: goja.getVar1(Date)
    compiler.go:153:  124: goja.loadVal(12)
    compiler.go:153:  125: goja._new(1)
    compiler.go:153:  126: goja._dup({})
    compiler.go:153:  127: goja.getPropCallee(setUTCHours)
    compiler.go:153:  128: goja.loadVal(13)
    compiler.go:153:  129: goja.call(1)
    compiler.go:153:  130: goja.loadVal(16)
    compiler.go:153:  131: goja.loadVal(17)
    compiler.go:153:  132: goja.call(3)
    compiler.go:153:  133: goja._pop({})
    compiler.go:153:  134: goja.getVar1(assert)
    compiler.go:153:  135: goja._dup({})
    compiler.go:153:  136: goja.getPropCallee(sameValue)
    compiler.go:153:  137: goja.getVar1(Date)
    compiler.go:153:  138: goja.loadVal(0)
    compiler.go:153:  139: goja._new(1)
    compiler.go:153:  140: goja._dup({})
    compiler.go:153:  141: goja.getPropCallee(setDate)
    compiler.go:153:  142: goja.loadVal(18)
    compiler.go:153:  143: goja.call(1)
    compiler.go:153:  144: goja.loadVal(19)
    compiler.go:153:  145: goja.loadVal(20)
    compiler.go:153:  146: goja.call(3)
    compiler.go:153:  147: goja._pop({})
    compiler.go:153:  148: goja.getVar1(assert)
    compiler.go:153:  149: goja._dup({})
    compiler.go:153:  150: goja.getPropCallee(sameValue)
    compiler.go:153:  151: goja.getVar1(Date)
    compiler.go:153:  152: goja.loadVal(0)
    compiler.go:153:  153: goja._new(1)
    compiler.go:153:  154: goja._dup({})
    compiler.go:153:  155: goja.getPropCallee(setUTCDate)
    compiler.go:153:  156: goja.loadVal(18)
    compiler.go:153:  157: goja.call(1)
    compiler.go:153:  158: goja.loadVal(19)
    compiler.go:153:  159: goja.loadVal(21)
    compiler.go:153:  160: goja.call(3)
    compiler.go:153:  161: goja._pop({})
    compiler.go:153:  162: goja.getVar1(assert)
    compiler.go:153:  163: goja._dup({})
    compiler.go:153:  164: goja.getPropCallee(sameValue)
    compiler.go:153:  165: goja.getVar1(Date)
    compiler.go:153:  166: goja.loadVal(0)
    compiler.go:153:  167: goja._new(1)
    compiler.go:153:  168: goja._dup({})
    compiler.go:153:  169: goja.getPropCallee(setMonth)
    compiler.go:153:  170: goja.loadVal(18)
    compiler.go:153:  171: goja.call(1)
    compiler.go:153:  172: goja.loadVal(22)
    compiler.go:153:  173: goja.loadVal(23)
    compiler.go:153:  174: goja.call(3)
    compiler.go:153:  175: goja._pop({})
    compiler.go:153:  176: goja.getVar1(assert)
    compiler.go:153:  177: goja._dup({})
    compiler.go:153:  178: goja.getPropCallee(sameValue)
    compiler.go:153:  179: goja.getVar1(Date)
    compiler.go:153:  180: goja.loadVal(0)
    compiler.go:153:  181: goja._new(1)
    compiler.go:153:  182: goja._dup({})
    compiler.go:153:  183: goja.getPropCallee(setUTCMonth)
    compiler.go:153:  184: goja.loadVal(18)
    compiler.go:153:  185: goja.call(1)
    compiler.go:153:  186: goja.loadVal(22)
    compiler.go:153:  187: goja.loadVal(24)
    compiler.go:153:  188: goja.call(3)
    compiler.go:153:  189: goja._pop({})
    compiler.go:153:  190: goja.getVar1(assert)
    compiler.go:153:  191: goja._dup({})
    compiler.go:153:  192: goja.getPropCallee(sameValue)
    compiler.go:153:  193: goja.getVar1(Date)
    compiler.go:153:  194: goja.loadVal(0)
    compiler.go:153:  195: goja._new(1)
    compiler.go:153:  196: goja._dup({})
    compiler.go:153:  197: goja.getPropCallee(setFullYear)
    compiler.go:153:  198: goja.loadVal(25)
    compiler.go:153:  199: goja.call(1)
    compiler.go:153:  200: goja.loadVal(26)
    compiler.go:153:  201: goja.loadVal(27)
    compiler.go:153:  202: goja.call(3)
    compiler.go:153:  203: goja._pop({})
    compiler.go:153:  204: goja.getVar1(assert)
    compiler.go:153:  205: goja._dup({})
    compiler.go:153:  206: goja.getPropCallee(sameValue)
    compiler.go:153:  207: goja.getVar1(Date)
    compiler.go:153:  208: goja.loadVal(0)
    compiler.go:153:  209: goja._new(1)
    compiler.go:153:  210: goja._dup({})
    compiler.go:153:  211: goja.getPropCallee(setFullYear)
    compiler.go:153:  212: goja.loadVal(25)
    compiler.go:153:  213: goja.loadVal(18)
    compiler.go:153:  214: goja.loadVal(28)
    compiler.go:153:  215: goja.call(3)
    compiler.go:153:  216: goja.loadVal(29)
    compiler.go:153:  217: goja.loadVal(30)
    compiler.go:153:  218: goja.call(3)
    compiler.go:153:  219: goja._pop({})
    compiler.go:153:  220: goja.getVar1(assert)
    compiler.go:153:  221: goja._dup({})
    compiler.go:153:  222: goja.getPropCallee(sameValue)
    compiler.go:153:  223: goja.getVar1(Date)
    compiler.go:153:  224: goja.loadVal(0)
    compiler.go:153:  225: goja._new(1)
    compiler.go:153:  226: goja._dup({})
    compiler.go:153:  227: goja.getPropCallee(setUTCFullYear)
    compiler.go:153:  228: goja.loadVal(25)
    compiler.go:153:  229: goja.call(1)
    compiler.go:153:  230: goja.loadVal(26)
    compiler.go:153:  231: goja.loadVal(31)
    compiler.go:153:  232: goja.call(3)
    compiler.go:153:  233: goja._pop({})
    compiler.go:153:  234: goja.getVar1(assert)
    compiler.go:153:  235: goja._dup({})
    compiler.go:153:  236: goja.getPropCallee(sameValue)
    compiler.go:153:  237: goja.getVar1(Date)
    compiler.go:153:  238: goja.loadVal(0)
    compiler.go:153:  239: goja._new(1)
    compiler.go:153:  240: goja._dup({})
    compiler.go:153:  241: goja.getPropCallee(setUTCFullYear)
    compiler.go:153:  242: goja.loadVal(25)
    compiler.go:153:  243: goja.loadVal(18)
    compiler.go:153:  244: goja.loadVal(28)
    compiler.go:153:  245: goja.call(3)
    compiler.go:153:  246: goja.loadVal(29)
    compiler.go:153:  247: goja.loadVal(32)
    compiler.go:153:  248: goja.call(3)
    compiler.go:153:  249: goja._halt({})
--- FAIL: TestDateSetters (0.02s)
panic: Error: setMilliseconds() Expected SameValue(«-1949», «2345») to be true [recovered]
	panic: Error: setMilliseconds() Expected SameValue(«-1949», «2345») to be true

goroutine 125 [running]:
testing.tRunner.func1.1(0x3030a0, 0x141f4b0)
	/usr/lib/go-1.15/src/testing/testing.go:1072 +0x264
testing.tRunner.func1(0x1320460)
	/usr/lib/go-1.15/src/testing/testing.go:1075 +0x364
panic(0x3030a0, 0x141f4b0)
	/usr/lib/go-1.15/src/runtime/panic.go:969 +0x158
github.com/dop251/goja._throw.exec(...)
	/build/reproducible-path/golang-github-dop251-goja-0.0~git20170430.0.d382686/obj-arm-linux-gnueabihf/src/github.com/dop251/goja/vm.go:2294
github.com/dop251/goja.(*vm).run(0x13c1180)
	/build/reproducible-path/golang-github-dop251-goja-0.0~git20170430.0.d382686/obj-arm-linux-gnueabihf/src/github.com/dop251/goja/vm.go:288 +0x40
github.com/dop251/goja.testScript1(0x32b47f, 0x878, 0x37d7a8, 0x661cb8, 0x1320460)
	/build/reproducible-path/golang-github-dop251-goja-0.0~git20170430.0.d382686/obj-arm-linux-gnueabihf/src/github.com/dop251/goja/compiler_test.go:58 +0x24c
github.com/dop251/goja.TestDateSetters(0x1320460)
	/build/reproducible-path/golang-github-dop251-goja-0.0~git20170430.0.d382686/obj-arm-linux-gnueabihf/src/github.com/dop251/goja/date_test.go:218 +0xf8
testing.tRunner(0x1320460, 0x330b90)
	/usr/lib/go-1.15/src/testing/testing.go:1123 +0xc8
created by testing.(*T).Run
	/usr/lib/go-1.15/src/testing/testing.go:1168 +0x220
FAIL	github.com/dop251/goja	0.900s
?   	github.com/dop251/goja/ast	[no test files]
?   	github.com/dop251/goja/file	[no test files]
=== RUN   TestLexer
--- PASS: TestLexer (0.00s)
=== RUN   TestParserAST
--- PASS: TestParserAST (0.01s)
=== RUN   TestParseFile
--- PASS: TestParseFile (0.00s)
=== RUN   TestParseFunction
--- PASS: TestParseFunction (0.00s)
=== RUN   TestParserErr
--- PASS: TestParserErr (0.01s)
=== RUN   TestParser
--- PASS: TestParser (0.00s)
=== RUN   Test_parseStringLiteral
--- PASS: Test_parseStringLiteral (0.00s)
=== RUN   Test_parseNumberLiteral
--- PASS: Test_parseNumberLiteral (0.00s)
=== RUN   TestPosition
--- PASS: TestPosition (0.00s)
=== RUN   TestRegExp
--- PASS: TestRegExp (0.00s)
=== RUN   TestTransformRegExp
--- PASS: TestTransformRegExp (0.00s)
PASS
ok  	github.com/dop251/goja/parser	0.068s
?   	github.com/dop251/goja/token	[no test files]
FAIL
dh_auto_test: error: cd obj-arm-linux-gnueabihf && go test -vet=off -v -p 3 github.com/dop251/goja github.com/dop251/goja/ast github.com/dop251/goja/file github.com/dop251/goja/parser github.com/dop251/goja/token returned exit code 1
make: *** [debian/rules:10: build] Error 25
dpkg-buildpackage: error: debian/rules build subprocess returned exit status 2
I: copying local configuration
E: Failed autobuilding of package
I: unmounting dev/ptmx filesystem
I: unmounting dev/pts filesystem
I: unmounting dev/shm filesystem
I: unmounting proc filesystem
I: unmounting sys filesystem
I: cleaning the build env 
I: removing directory /srv/workspace/pbuilder/582 and its subdirectories