I: pbuilder: network access will be disabled during build I: Current time: Tue Mar 26 09:50:20 +14 2024 I: pbuilder-time-stamp: 1711396220 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-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-tideland-golib_4.24.2-1.dsc] I: copying [./golang-github-tideland-golib_4.24.2.orig.tar.gz] I: copying [./golang-github-tideland-golib_4.24.2-1.debian.tar.xz] I: Extracting source gpgv: Signature made Sun Oct 8 14:12:20 2017 gpgv: using RSA key D1CB8F39BC5DED24C5D2C78C1302F1F036EBEB19 gpgv: Can't check signature: No public key dpkg-source: warning: cannot verify inline signature for ./golang-github-tideland-golib_4.24.2-1.dsc: no acceptable signature found dpkg-source: info: extracting golang-github-tideland-golib in golang-github-tideland-golib-4.24.2 dpkg-source: info: unpacking golang-github-tideland-golib_4.24.2.orig.tar.gz dpkg-source: info: unpacking golang-github-tideland-golib_4.24.2-1.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying skip_tests_short_mode.patch dpkg-source: info: applying fix-ftbfs.patch I: using fakeroot in build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/22285/tmp/hooks/D01_modify_environment starting debug: Running on virt64a. I: Changing host+domainname to test build reproducibility I: Adding a custom variable just for the fun of it... I: Changing /bin/sh to bash '/bin/sh' -> '/bin/bash' lrwxrwxrwx 1 root root 9 Mar 25 19:50 /bin/sh -> /bin/bash I: Setting pbuilder2's login shell to /bin/bash I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other I: user script /srv/workspace/pbuilder/22285/tmp/hooks/D01_modify_environment finished I: user script /srv/workspace/pbuilder/22285/tmp/hooks/D02_print_environment starting I: set BASH=/bin/sh BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath BASH_ALIASES=() BASH_ARGC=() BASH_ARGV=() BASH_CMDS=() BASH_LINENO=([0]="12" [1]="0") BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") BASH_VERSINFO=([0]="5" [1]="2" [2]="21" [3]="1" [4]="release" [5]="arm-unknown-linux-gnueabihf") BASH_VERSION='5.2.21(1)-release' BUILDDIR=/build/reproducible-path BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' BUILDUSERNAME=pbuilder2 BUILD_ARCH=armhf DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=4 ' DIRSTACK=() DISTRIBUTION=trixie EUID=0 FUNCNAME=([0]="Echo" [1]="main") GROUPS=() HOME=/root HOSTNAME=i-capture-the-hostname HOSTTYPE=arm HOST_ARCH=armhf IFS=' ' INVOCATION_ID=bc72c27dec8e4dd68d158f8eff5b419d LANG=C LANGUAGE=it_CH:it LC_ALL=C MACHTYPE=arm-unknown-linux-gnueabihf MAIL=/var/mail/root OPTERR=1 OPTIND=1 OSTYPE=linux-gnueabihf PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path PBCURRENTCOMMANDLINEOPERATION=build PBUILDER_OPERATION=build PBUILDER_PKGDATADIR=/usr/share/pbuilder PBUILDER_PKGLIBDIR=/usr/lib/pbuilder PBUILDER_SYSCONFDIR=/etc PIPESTATUS=([0]="0") POSIXLY_CORRECT=y PPID=22285 PS4='+ ' PWD=/ SHELL=/bin/bash SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix SHLVL=3 SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.8utpoSGS/pbuilderrc_0617 --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.8utpoSGS/b2 --logfile b2/build.log golang-github-tideland-golib_4.24.2-1.dsc' SUDO_GID=114 SUDO_UID=108 SUDO_USER=jenkins TERM=unknown TZ=/usr/share/zoneinfo/Etc/GMT-14 UID=0 USER=root _='I: set' http_proxy=http://10.0.0.15:3142/ I: uname -a Linux i-capture-the-hostname 6.1.0-18-arm64 #1 SMP Debian 6.1.76-1 (2024-02-01) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Mar 23 11:25 /bin -> usr/bin I: user script /srv/workspace/pbuilder/22285/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 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 dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19577 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. 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.22-go{a} golang-1.22-src{a} golang-any{a} golang-go{a} golang-src{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libdebhelper-perl{a} libelf1{a} libfile-stripnondeterminism-perl{a} libicu72{a} libmagic-mgc{a} libmagic1{a} libpipeline1{a} libsub-override-perl{a} libtool{a} libuchardet0{a} libxml2{a} m4{a} man-db{a} po-debconf{a} sensible-utils{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, 36 newly installed, 0 to remove and 0 not upgraded. Need to get 58.7 MB of archives. After unpacking 294 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian trixie/main armhf sensible-utils all 0.0.22 [22.4 kB] Get: 2 http://deb.debian.org/debian trixie/main armhf libmagic-mgc armhf 1:5.45-2+b1 [314 kB] Get: 3 http://deb.debian.org/debian trixie/main armhf libmagic1 armhf 1:5.45-2+b1 [97.9 kB] Get: 4 http://deb.debian.org/debian trixie/main armhf file armhf 1:5.45-2+b1 [42.2 kB] Get: 5 http://deb.debian.org/debian trixie/main armhf gettext-base armhf 0.21-14+b1 [157 kB] Get: 6 http://deb.debian.org/debian trixie/main armhf libuchardet0 armhf 0.0.8-1+b1 [65.7 kB] Get: 7 http://deb.debian.org/debian trixie/main armhf groff-base armhf 1.23.0-3 [1088 kB] Get: 8 http://deb.debian.org/debian trixie/main armhf bsdextrautils armhf 2.39.3-6 [81.2 kB] Get: 9 http://deb.debian.org/debian trixie/main armhf libpipeline1 armhf 1.5.7-1+b2 [33.4 kB] Get: 10 http://deb.debian.org/debian trixie/main armhf man-db armhf 2.12.0-3 [1367 kB] Get: 11 http://deb.debian.org/debian trixie/main armhf m4 armhf 1.4.19-4 [264 kB] Get: 12 http://deb.debian.org/debian trixie/main armhf autoconf all 2.71-3 [332 kB] Get: 13 http://deb.debian.org/debian trixie/main armhf autotools-dev all 20220109.1 [51.6 kB] Get: 14 http://deb.debian.org/debian trixie/main armhf automake all 1:1.16.5-1.3 [823 kB] Get: 15 http://deb.debian.org/debian trixie/main armhf autopoint all 0.21-14 [496 kB] Get: 16 http://deb.debian.org/debian trixie/main armhf libdebhelper-perl all 13.14.1 [85.6 kB] Get: 17 http://deb.debian.org/debian trixie/main armhf libtool all 2.4.7-7 [517 kB] Get: 18 http://deb.debian.org/debian trixie/main armhf dh-autoreconf all 20 [17.1 kB] Get: 19 http://deb.debian.org/debian trixie/main armhf libarchive-zip-perl all 1.68-1 [104 kB] Get: 20 http://deb.debian.org/debian trixie/main armhf libsub-override-perl all 0.10-1 [10.6 kB] Get: 21 http://deb.debian.org/debian trixie/main armhf libfile-stripnondeterminism-perl all 1.13.1-1 [19.4 kB] Get: 22 http://deb.debian.org/debian trixie/main armhf dh-strip-nondeterminism all 1.13.1-1 [8620 B] Get: 23 http://deb.debian.org/debian trixie/main armhf libelf1 armhf 0.190-1+b1 [171 kB] Get: 24 http://deb.debian.org/debian trixie/main armhf dwz armhf 0.15-1 [101 kB] Get: 25 http://deb.debian.org/debian trixie/main armhf libicu72 armhf 72.1-4+b1 [9070 kB] Get: 26 http://deb.debian.org/debian trixie/main armhf libxml2 armhf 2.9.14+dfsg-1.3+b2 [599 kB] Get: 27 http://deb.debian.org/debian trixie/main armhf gettext armhf 0.21-14+b1 [1230 kB] Get: 28 http://deb.debian.org/debian trixie/main armhf intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 29 http://deb.debian.org/debian trixie/main armhf po-debconf all 1.0.21+nmu1 [248 kB] Get: 30 http://deb.debian.org/debian trixie/main armhf debhelper all 13.14.1 [890 kB] Get: 31 http://deb.debian.org/debian trixie/main armhf dh-golang all 1.62 [24.7 kB] Get: 32 http://deb.debian.org/debian trixie/main armhf golang-1.22-src all 1.22.1-1 [18.8 MB] Get: 33 http://deb.debian.org/debian trixie/main armhf golang-1.22-go armhf 1.22.1-1 [21.5 MB] Get: 34 http://deb.debian.org/debian trixie/main armhf golang-src all 2:1.22~3 [5020 B] Get: 35 http://deb.debian.org/debian trixie/main armhf golang-go armhf 2:1.22~3 [44.2 kB] Get: 36 http://deb.debian.org/debian trixie/main armhf golang-any armhf 2:1.22~3 [5104 B] Fetched 58.7 MB in 8s (7467 kB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package sensible-utils. (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 ... 19577 files and directories currently installed.) Preparing to unpack .../00-sensible-utils_0.0.22_all.deb ... Unpacking sensible-utils (0.0.22) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../01-libmagic-mgc_1%3a5.45-2+b1_armhf.deb ... Unpacking libmagic-mgc (1:5.45-2+b1) ... Selecting previously unselected package libmagic1:armhf. Preparing to unpack .../02-libmagic1_1%3a5.45-2+b1_armhf.deb ... Unpacking libmagic1:armhf (1:5.45-2+b1) ... Selecting previously unselected package file. Preparing to unpack .../03-file_1%3a5.45-2+b1_armhf.deb ... Unpacking file (1:5.45-2+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../04-gettext-base_0.21-14+b1_armhf.deb ... Unpacking gettext-base (0.21-14+b1) ... Selecting previously unselected package libuchardet0:armhf. Preparing to unpack .../05-libuchardet0_0.0.8-1+b1_armhf.deb ... Unpacking libuchardet0:armhf (0.0.8-1+b1) ... Selecting previously unselected package groff-base. Preparing to unpack .../06-groff-base_1.23.0-3_armhf.deb ... Unpacking groff-base (1.23.0-3) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../07-bsdextrautils_2.39.3-6_armhf.deb ... Unpacking bsdextrautils (2.39.3-6) ... Selecting previously unselected package libpipeline1:armhf. Preparing to unpack .../08-libpipeline1_1.5.7-1+b2_armhf.deb ... Unpacking libpipeline1:armhf (1.5.7-1+b2) ... Selecting previously unselected package man-db. Preparing to unpack .../09-man-db_2.12.0-3_armhf.deb ... Unpacking man-db (2.12.0-3) ... Selecting previously unselected package m4. Preparing to unpack .../10-m4_1.4.19-4_armhf.deb ... Unpacking m4 (1.4.19-4) ... Selecting previously unselected package autoconf. Preparing to unpack .../11-autoconf_2.71-3_all.deb ... Unpacking autoconf (2.71-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../12-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../13-automake_1%3a1.16.5-1.3_all.deb ... Unpacking automake (1:1.16.5-1.3) ... Selecting previously unselected package autopoint. Preparing to unpack .../14-autopoint_0.21-14_all.deb ... Unpacking autopoint (0.21-14) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../15-libdebhelper-perl_13.14.1_all.deb ... Unpacking libdebhelper-perl (13.14.1) ... Selecting previously unselected package libtool. Preparing to unpack .../16-libtool_2.4.7-7_all.deb ... Unpacking libtool (2.4.7-7) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../17-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../18-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 .../19-libsub-override-perl_0.10-1_all.deb ... Unpacking libsub-override-perl (0.10-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../20-libfile-stripnondeterminism-perl_1.13.1-1_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.13.1-1) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../21-dh-strip-nondeterminism_1.13.1-1_all.deb ... Unpacking dh-strip-nondeterminism (1.13.1-1) ... Selecting previously unselected package libelf1:armhf. Preparing to unpack .../22-libelf1_0.190-1+b1_armhf.deb ... Unpacking libelf1:armhf (0.190-1+b1) ... Selecting previously unselected package dwz. Preparing to unpack .../23-dwz_0.15-1_armhf.deb ... Unpacking dwz (0.15-1) ... Selecting previously unselected package libicu72:armhf. Preparing to unpack .../24-libicu72_72.1-4+b1_armhf.deb ... Unpacking libicu72:armhf (72.1-4+b1) ... Selecting previously unselected package libxml2:armhf. Preparing to unpack .../25-libxml2_2.9.14+dfsg-1.3+b2_armhf.deb ... Unpacking libxml2:armhf (2.9.14+dfsg-1.3+b2) ... Selecting previously unselected package gettext. Preparing to unpack .../26-gettext_0.21-14+b1_armhf.deb ... Unpacking gettext (0.21-14+b1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../27-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../28-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../29-debhelper_13.14.1_all.deb ... Unpacking debhelper (13.14.1) ... Selecting previously unselected package dh-golang. Preparing to unpack .../30-dh-golang_1.62_all.deb ... Unpacking dh-golang (1.62) ... Selecting previously unselected package golang-1.22-src. Preparing to unpack .../31-golang-1.22-src_1.22.1-1_all.deb ... Unpacking golang-1.22-src (1.22.1-1) ... Selecting previously unselected package golang-1.22-go. Preparing to unpack .../32-golang-1.22-go_1.22.1-1_armhf.deb ... Unpacking golang-1.22-go (1.22.1-1) ... Selecting previously unselected package golang-src. Preparing to unpack .../33-golang-src_2%3a1.22~3_all.deb ... Unpacking golang-src (2:1.22~3) ... Selecting previously unselected package golang-go:armhf. Preparing to unpack .../34-golang-go_2%3a1.22~3_armhf.deb ... Unpacking golang-go:armhf (2:1.22~3) ... Selecting previously unselected package golang-any:armhf. Preparing to unpack .../35-golang-any_2%3a1.22~3_armhf.deb ... Unpacking golang-any:armhf (2:1.22~3) ... Setting up libpipeline1:armhf (1.5.7-1+b2) ... Setting up libicu72:armhf (72.1-4+b1) ... Setting up bsdextrautils (2.39.3-6) ... Setting up libmagic-mgc (1:5.45-2+b1) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libdebhelper-perl (13.14.1) ... Setting up libmagic1:armhf (1:5.45-2+b1) ... Setting up gettext-base (0.21-14+b1) ... Setting up m4 (1.4.19-4) ... Setting up file (1:5.45-2+b1) ... Setting up autotools-dev (20220109.1) ... Setting up golang-1.22-src (1.22.1-1) ... Setting up autopoint (0.21-14) ... Setting up autoconf (2.71-3) ... Setting up sensible-utils (0.0.22) ... Setting up libuchardet0:armhf (0.0.8-1+b1) ... Setting up libsub-override-perl (0.10-1) ... Setting up golang-src (2:1.22~3) ... Setting up libelf1:armhf (0.190-1+b1) ... Setting up libxml2:armhf (2.9.14+dfsg-1.3+b2) ... Setting up automake (1:1.16.5-1.3) ... update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.13.1-1) ... Setting up gettext (0.21-14+b1) ... Setting up libtool (2.4.7-7) ... Setting up golang-1.22-go (1.22.1-1) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up dh-strip-nondeterminism (1.13.1-1) ... Setting up dwz (0.15-1) ... Setting up groff-base (1.23.0-3) ... Setting up golang-go:armhf (2:1.22~3) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.12.0-3) ... Not building database; man-db/auto-update is not 'true'. Setting up golang-any:armhf (2:1.22~3) ... Setting up debhelper (13.14.1) ... Setting up dh-golang (1.62) ... Processing triggers for libc-bin (2.37-15) ... 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.33-1). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package I: user script /srv/workspace/pbuilder/22285/tmp/hooks/A99_set_merged_usr starting Not re-configuring usrmerge for trixie I: user script /srv/workspace/pbuilder/22285/tmp/hooks/A99_set_merged_usr finished hostname: Name or service not known I: Running cd /build/reproducible-path/golang-github-tideland-golib-4.24.2/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../golang-github-tideland-golib_4.24.2-1_source.changes dpkg-buildpackage: info: source package golang-github-tideland-golib dpkg-buildpackage: info: source version 4.24.2-1 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Dr. Tobias Quathamer 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 4 github.com/tideland/golib/audit github.com/tideland/golib/cache github.com/tideland/golib/collections github.com/tideland/golib/errors github.com/tideland/golib/etc github.com/tideland/golib/feed/atom github.com/tideland/golib/feed/rss github.com/tideland/golib/feed/utils github.com/tideland/golib/gjp github.com/tideland/golib/identifier github.com/tideland/golib/logger github.com/tideland/golib/loop github.com/tideland/golib/mapreduce github.com/tideland/golib/monitoring github.com/tideland/golib/numerics github.com/tideland/golib/redis github.com/tideland/golib/scene github.com/tideland/golib/scroller github.com/tideland/golib/sml github.com/tideland/golib/sort github.com/tideland/golib/stringex github.com/tideland/golib/timex github.com/tideland/golib/version internal/unsafeheader internal/coverage/rtcov internal/goarch internal/cpu internal/godebugs internal/abi internal/chacha8rand internal/goexperiment internal/goos internal/bytealg runtime/internal/atomic runtime/internal/math runtime/internal/sys runtime/internal/syscall internal/race sync/atomic unicode unicode/utf8 math/bits crypto/internal/alias internal/itoa crypto/internal/boring/sig math cmp slices internal/nettrace log/internal encoding container/list unicode/utf16 vendor/golang.org/x/crypto/cryptobyte/asn1 vendor/golang.org/x/crypto/internal/alias runtime sync crypto/subtle internal/reflectlite internal/testlog internal/bisect internal/singleflight runtime/cgo internal/godebug errors sort math/rand io strconv bytes hash crypto/internal/randutil internal/oserror syscall internal/safefilepath path strings crypto reflect regexp/syntax vendor/golang.org/x/net/dns/dnsmessage internal/syscall/unix time internal/syscall/execenv regexp internal/intern net/netip bufio html hash/crc32 crypto/internal/nistec/fiat crypto/rc4 internal/poll io/fs encoding/binary internal/fmtsort crypto/cipher crypto/md5 os context crypto/internal/boring crypto/sha1 crypto/aes crypto/des crypto/internal/edwards25519/field crypto/sha512 crypto/internal/edwards25519 crypto/hmac crypto/sha256 encoding/base64 encoding/pem vendor/golang.org/x/crypto/chacha20 fmt path/filepath net io/ioutil vendor/golang.org/x/crypto/internal/poly1305 vendor/golang.org/x/crypto/chacha20poly1305 vendor/golang.org/x/crypto/hkdf vendor/golang.org/x/text/transform github.com/tideland/golib/errors math/big encoding/hex log github.com/tideland/golib/collections encoding/xml compress/flate compress/gzip crypto/internal/nistec github.com/tideland/golib/sml github.com/tideland/golib/feed/utils net/url crypto/ecdh crypto/rand crypto/elliptic crypto/internal/bigmod github.com/tideland/golib/audit crypto/internal/boring/bbig encoding/asn1 crypto/ed25519 crypto/rsa crypto/dsa vendor/golang.org/x/text/unicode/bidi vendor/golang.org/x/text/unicode/norm vendor/golang.org/x/crypto/cryptobyte crypto/x509/pkix vendor/golang.org/x/text/secure/bidirule vendor/golang.org/x/net/http2/hpack crypto/ecdsa vendor/golang.org/x/net/idna mime mime/quotedprintable net/http/internal net/http/internal/ascii encoding/json hash/adler32 github.com/tideland/golib/mapreduce github.com/tideland/golib/numerics github.com/tideland/golib/sort github.com/tideland/golib/version github.com/tideland/golib/identifier net/textproto crypto/x509 log/syslog github.com/tideland/golib/logger vendor/golang.org/x/net/http/httpproxy vendor/golang.org/x/net/http/httpguts crypto/tls mime/multipart github.com/tideland/golib/loop github.com/tideland/golib/stringex github.com/tideland/golib/etc github.com/tideland/golib/cache github.com/tideland/golib/gjp github.com/tideland/golib/monitoring github.com/tideland/golib/scene github.com/tideland/golib/scroller github.com/tideland/golib/timex github.com/tideland/golib/redis net/http/httptrace net/http github.com/tideland/golib/feed/atom github.com/tideland/golib/feed/rss debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/golang-github-tideland-golib-4.24.2' dh_auto_test -- -short cd obj-arm-linux-gnueabihf && go test -vet=off -v -p 4 -short github.com/tideland/golib/audit github.com/tideland/golib/cache github.com/tideland/golib/collections github.com/tideland/golib/errors github.com/tideland/golib/etc github.com/tideland/golib/feed/atom github.com/tideland/golib/feed/rss github.com/tideland/golib/feed/utils github.com/tideland/golib/gjp github.com/tideland/golib/identifier github.com/tideland/golib/logger github.com/tideland/golib/loop github.com/tideland/golib/mapreduce github.com/tideland/golib/monitoring github.com/tideland/golib/numerics github.com/tideland/golib/redis github.com/tideland/golib/scene github.com/tideland/golib/scroller github.com/tideland/golib/sml github.com/tideland/golib/sort github.com/tideland/golib/stringex github.com/tideland/golib/timex github.com/tideland/golib/version === RUN TestAssertTrue asserts_test.go:485: testing assert "true" failed: 'false' (bool) <> 'true' (bool) [should fail and be logged] --- PASS: TestAssertTrue (0.00s) === RUN TestAssertFalse asserts_test.go:485: testing assert "false" failed: 'true' (bool) <> 'false' (bool) [should fail and be logged] --- PASS: TestAssertFalse (0.00s) === RUN TestAssertNil asserts_test.go:485: testing assert "nil" failed: 'not nil' (string) <> '' (invalid) [should fail and be logged] --- PASS: TestAssertNil (0.00s) === RUN TestAssertNotNil asserts_test.go:485: testing assert "not nil" failed: '' (invalid) <> '' (invalid) [should fail and be logged] --- PASS: TestAssertNotNil (0.00s) === RUN TestAssertEqual asserts_test.go:485: testing assert "equal" failed: 'one' (string) <> '1' (int) [should fail and be logged] asserts_test.go:485: testing assert "equal" failed: 'two' (string) <> '2' (string) [should fail and be logged] --- PASS: TestAssertEqual (0.00s) === RUN TestAssertDifferent asserts_test.go:485: testing assert "different" failed: 'one' (string) <> 'one' (string) [should fail and be logged] asserts_test.go:485: testing assert "different" failed: '2' (int) <> '2' (int) [should fail and be logged] --- PASS: TestAssertDifferent (0.00s) === RUN TestAssertAbout asserts_test.go:485: testing assert "about" failed: '0.8' (float64) <> '1' (float64) [different, out of bounds of extent] asserts_test.go:485: testing assert "about" failed: '1.2' (float64) <> '1' (float64) [different, out of bounds of extent] --- PASS: TestAssertAbout (0.00s) === RUN TestAssertRange asserts_test.go:485: testing assert "range" failed: '1' (uint8) <> '&{10 20}' (ptr to audit.lowHigh) [byte out of range] asserts_test.go:485: testing assert "range" failed: '1' (int) <> '&{10 20}' (ptr to audit.lowHigh) [int out of range] asserts_test.go:485: testing assert "range" failed: '1' (float64) <> '&{10 20}' (ptr to audit.lowHigh) [float64 out of range] asserts_test.go:485: testing assert "range" failed: '97' (int32) <> '&{120 122}' (ptr to audit.lowHigh) [rune out of range] asserts_test.go:485: testing assert "range" failed: 'aaa' (string) <> '&{uuuuu zzzzz}' (ptr to audit.lowHigh) [string out of range] asserts_test.go:485: testing assert "range" failed: '2024-03-25 19:55:42.992579612 +0000 UTC m=+0.002696690' (struct Time) <> '&{{13941054956479549468 60002696690 0x299df8} {13941058757525606428 3600002696690 0x299df8}}' (ptr to audit.lowHigh) [time out of range] asserts_test.go:485: testing assert "range" failed: '1s' (int64) <> '&{60000000000 3600000000000}' (ptr to audit.lowHigh) [duration in range] asserts_test.go:485: testing assert "range" failed: '[1 2 3]' (slice of int) <> '&{5 10}' (ptr to audit.lowHigh) [slice length out of range] asserts_test.go:485: testing assert "range" failed: '[1 2 3]' (array of int) <> '&{5 10}' (ptr to audit.lowHigh) [array length out of range] asserts_test.go:485: testing assert "range" failed: 'map[1:3 2:2 3:1]' (map of int) <> '&{5 10}' (ptr to audit.lowHigh) [map length out of range] --- PASS: TestAssertRange (0.00s) === RUN TestAssertContents asserts_test.go:485: testing assert "contents" failed: '4711' (int) <> 'foo' (string) asserts_test.go:485: testing assert "contents" failed: '4711' (int) <> '[1 2 3 4711 5 6 7 8 9]' (slice of interface {}) asserts_test.go:485: testing assert "contents" failed: 'foobar' (string) <> '[116 104 101 32 113 117 105 99 107 32 98 114 111 119 110 32 102 111 120 32 106 117 109 112 115 32 111 118 101 114 32 116 104 101 32 108 97 122 121 32 100 111 103]' (slice of uint8) --- PASS: TestAssertContents (0.00s) === RUN TestAssertContentsPrint asserts_test.go:161 TestAssertContentsPrint(): printing of failing content tests -------------------------------------------------------------------------------- asserts_test.go:162: Assert 'contents' failed! Function...: TestAssertContentsPrint() Part.......: foobar Full.......: the quick brown fox jumps over the lazy dog Description: test fails but passes, just visualization -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- asserts_test.go:163: Assert 'contents' failed! Function...: TestAssertContentsPrint() Part.......: [102 111 111 98 97 114] Full.......: [116 104 101 32 113 117 105 99 107 32 98 114 111 119 110 32 46 46 46] Description: test fails but passes, just visualization -------------------------------------------------------------------------------- --- PASS: TestAssertContentsPrint (0.00s) === RUN TestOffsetPrint -------------------------------------------------------------------------------- asserts_test.go:172: Assert failed! Function...: TestOffsetPrint() Description: should fail referencing line 172 -------------------------------------------------------------------------------- --- PASS: TestOffsetPrint (0.00s) === RUN TestAssertSubstring asserts_test.go:485: testing assert "substring" failed: 'foo' (string) <> 'this is assert test' (string) [should fail and be logged] asserts_test.go:485: testing assert "substring" failed: 'this is assert test' (string) <> 'this is assert test' (string) [should fail and be logged] --- PASS: TestAssertSubstring (0.00s) === RUN TestAssertCase asserts_test.go:485: testing assert "case" failed: 'Foo' (string) <> 'FOO' (string) [is mixed case] asserts_test.go:485: testing assert "case" failed: 'Foo' (string) <> 'foo' (string) [is mixed case] --- PASS: TestAssertCase (0.00s) === RUN TestAssertMatch asserts_test.go:485: testing assert "match" failed: 'this is assert test' (string) <> 'foo' (string) [should fail and be logged] asserts_test.go:485: testing assert "match" failed: 'this is assert test' (string) <> 'this*test' (string) [should fail and be logged] --- PASS: TestAssertMatch (0.00s) === RUN TestAssertErrorMatch asserts_test.go:485: testing assert "error match" failed: 'oops, an error' (ptr to errors.errorString) <> 'foo' (string) [should fail and be logged] --- PASS: TestAssertErrorMatch (0.00s) === RUN TestAssertImplementor asserts_test.go:485: testing assert "implementor" failed: 'string test' (string) <> '0x2100160' (ptr to error) [should fail and be logged] asserts_test.go:485: testing assert "implementor" failed: 'error test' (ptr to errors.errorString) <> '0x2100168' (ptr to io.Writer) [should fail and be logged] --- PASS: TestAssertImplementor (0.00s) === RUN TestAssertAssignable asserts_test.go:485: testing assert "assignable" failed: 'one' (string) <> '5' (int) [should fail and be logged] --- PASS: TestAssertAssignable (0.00s) === RUN TestAssertUnassignable asserts_test.go:485: testing assert "unassignable" failed: '1' (int) <> '5' (int) [should fail and be logged] --- PASS: TestAssertUnassignable (0.00s) === RUN TestAssertEmpty asserts_test.go:485: testing assert "empty" failed: '9' (int) <> '0' (int) [should fail and be logged] asserts_test.go:485: testing assert "empty" failed: '3' (int) <> '0' (int) [should also fail and be logged] asserts_test.go:485: testing assert "empty" failed: 'bool' (string) <> '0' (int) [obtained bool is no array, chan, map, slice, string or understands Len()] --- PASS: TestAssertEmpty (0.00s) === RUN TestAssertNotEmpty asserts_test.go:485: testing assert "not empty" failed: '0' (int) <> '0' (int) [should fail and be logged] asserts_test.go:485: testing assert "not empty" failed: '0' (int) <> '0' (int) [should also fail and be logged] asserts_test.go:485: testing assert "not empty" failed: 'bool' (string) <> '0' (int) [obtained bool is no array, chan, map, slice, string or understands Len()] --- PASS: TestAssertNotEmpty (0.00s) === RUN TestAssertLength asserts_test.go:485: testing assert "length" failed: '9' (int) <> '0' (int) [should fail and be logged] asserts_test.go:485: testing assert "length" failed: '3' (int) <> '10' (int) [should also fail and be logged] asserts_test.go:485: testing assert "length" failed: 'bool' (string) <> '1' (int) [obtained bool is no array, chan, map, slice, string or understands Len()] --- PASS: TestAssertLength (0.00s) === RUN TestAssertPanics asserts_test.go:485: testing assert "panics" failed: 'func ()' (string) <> '' (invalid) [should not panic] --- PASS: TestAssertPanics (0.00s) === RUN TestAssertPathExists asserts_test.go:485: testing assert "path exists" failed: '/this/path/will/hopefully/not/exist' (string) <> 'true' (bool) [illegal path] --- PASS: TestAssertPathExists (0.00s) === RUN TestAssertWait asserts_test.go:485: testing assert "wait" failed: 'false' (bool) <> 'true' (bool) [should be false] asserts_test.go:485: testing assert "wait" failed: 'timeout 100ms' (string) <> 'signal true' (string) [should timeout] --- PASS: TestAssertWait (0.21s) === RUN TestAssertWaitTested asserts_test.go:485: testing assert "nil" failed: 'illegal value' (ptr to errors.errorString) <> '' (invalid) [should be false] asserts_test.go:485: testing assert "wait" failed: 'timeout 100ms' (string) <> 'signal true' (string) [should timeout] --- PASS: TestAssertWaitTested (0.21s) === RUN TestAssertRetry asserts_test.go:485: testing assert "retry" failed: 'timeout after 119.980223ms and 10 retries' (string) <> 'successful call' (string) [should fail] --- PASS: TestAssertRetry (0.17s) === RUN TestAssertFail asserts_test.go:485: testing assert "fail" failed: '' (invalid) <> '' (invalid) [this should fail] --- PASS: TestAssertFail (0.00s) === RUN TestTestingAssertion -------------------------------------------------------------------------------- asserts_test.go:394: Assert 'assignable' failed! Function...: TestTestingAssertion() Obtained...: func () Expected...: int Description: should fail (but not the test) -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- asserts_test.go:395: Assert 'assignable' failed! Function...: TestTestingAssertion() Obtained...: func () Expected...: int -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- asserts_test.go:396: Assert 'assignable' failed! Function...: TestTestingAssertion() Obtained...: func () Expected...: int Description: this should fail too -------------------------------------------------------------------------------- --- PASS: TestTestingAssertion (0.00s) === RUN TestPanicAssert asserts_test.go:403: panic worked: 'assert 'assignable' failed: 'int' <> 'func ()' (should fail)' --- PASS: TestPanicAssert (0.00s) === RUN TestValidationAssertion asserts_test.go:430: [0] assert 'true' failed: 'false' (should fail) / [1] assert 'equal' failed: '1' <> '2' (should fail) --- PASS: TestValidationAssertion (0.00s) === RUN TestSetFailable === RUN TestSetFailable/success === RUN TestSetFailable/fail === NAME TestSetFailable asserts_test.go:485: testing assert "true" failed: 'false' (bool) <> 'true' (bool) --- PASS: TestSetFailable (0.00s) --- PASS: TestSetFailable/success (0.00s) --- PASS: TestSetFailable/fail (0.00s) === RUN TestTempDirCreate --- PASS: TestTempDirCreate (0.00s) === RUN TestTempDirRestore --- PASS: TestTempDirRestore (0.00s) === RUN TestEnvVarsSet --- PASS: TestEnvVarsSet (0.00s) === RUN TestEnvVarsRestore --- PASS: TestEnvVarsRestore (0.00s) === RUN TestBuildDate --- PASS: TestBuildDate (0.01s) === RUN TestInts --- PASS: TestInts (0.01s) === RUN TestOneOf --- PASS: TestOneOf (0.02s) === RUN TestWords --- PASS: TestWords (0.07s) === RUN TestPattern --- PASS: TestPattern (0.00s) === RUN TestText --- PASS: TestText (2.13s) === RUN TestName --- PASS: TestName (8.00s) === RUN TestDomain --- PASS: TestDomain (0.00s) === RUN TestURL --- PASS: TestURL (2.49s) === RUN TestEMail --- PASS: TestEMail (2.78s) === RUN TestTimes --- PASS: TestTimes (5.58s) PASS ok github.com/tideland/golib/audit 21.728s === RUN TestNoLoader --- PASS: TestNoLoader (0.00s) === RUN TestLoader 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::loader" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::loader" stopped --- PASS: TestLoader (0.00s) === RUN TestLoading 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::loading" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::loading" stopped --- PASS: TestLoading (0.06s) === RUN TestConcurrentLoading 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::concurrent-loading" starts cache_test.go:118 func1(): Goroutine 98 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 99 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 9 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 10 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 11 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 12 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 13 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 14 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 15 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 16 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 17 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 18 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 19 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 20 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 21 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 22 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 23 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 24 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 25 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 26 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 27 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 62 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 28 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 29 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 30 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 31 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 32 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 33 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 34 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 35 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 36 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 37 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 38 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 39 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 40 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 41 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 42 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 43 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 44 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 45 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 46 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 47 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 48 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 49 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 50 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 51 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 52 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 53 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 54 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 55 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 56 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 57 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 58 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 59 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 60 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 61 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 80 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 63 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 64 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 65 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 66 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 67 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 68 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 69 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 70 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 71 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 72 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 73 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 74 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 75 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 76 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 77 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 78 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 79 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 89 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 81 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 82 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 83 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 84 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 85 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 86 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 87 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 88 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 93 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 90 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 91 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 92 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 95 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 94 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 96 loaded "/concurrent" cache_test.go:118 func1(): Goroutine 97 loaded "/concurrent" 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::concurrent-loading" stopped --- PASS: TestConcurrentLoading (0.05s) === RUN TestOutdatingFail 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-fail" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-fail" stopped --- PASS: TestOutdatingFail (0.05s) === RUN TestOutdatingReload 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-reload" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-reload" stopped --- PASS: TestOutdatingReload (0.10s) === RUN TestOutdatingReloadError 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-reload-error" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::outdating-reload-error" stopped --- PASS: TestOutdatingReloadError (0.10s) === RUN TestDiscarding 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::discarding" starts 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::discarding" stopped --- PASS: TestDiscarding (0.21s) === RUN TestCleanup 2024-03-25 19:55:55 Z [INFO] [github.com/tideland/golib/loop] loop "cache::cleanup" starts cache_test.go:247 TestCleanup(): 1st: 7 > 2nd: 0 2024-03-25 19:55:58 Z [INFO] [github.com/tideland/golib/loop] loop "cache::cleanup" stopped --- PASS: TestCleanup (3.11s) === RUN TestClear 2024-03-25 19:55:58 Z [INFO] [github.com/tideland/golib/loop] loop "cache::clear" starts cache_test.go:271 TestClear(): 1st: 50 > 2nd: 0 2024-03-25 19:56:01 Z [INFO] [github.com/tideland/golib/loop] loop "cache::clear" stopped --- PASS: TestClear (2.61s) === RUN TestFileLoader loader_test.go:57 TestFileLoader(): test #0: fa with size 1 mb loader_test.go:57 TestFileLoader(): test #1: fb with size 2 mb loader_test.go:57 TestFileLoader(): test #2: fc with size 3 mb loader_test.go:57 TestFileLoader(): test #3: fd with size 4 mb loader_test.go:57 TestFileLoader(): test #4: fe with size 5 mb --- PASS: TestFileLoader (1.43s) PASS ok github.com/tideland/golib/cache 7.758s === RUN TestRingBufferPush --- PASS: TestRingBufferPush (0.00s) === RUN TestRingBufferPop --- PASS: TestRingBufferPop (0.00s) === RUN TestRingBufferGrow --- PASS: TestRingBufferGrow (0.00s) === RUN TestSetsAddRemove --- PASS: TestSetsAddRemove (0.00s) === RUN TestSetsFindAll --- PASS: TestSetsFindAll (0.00s) === RUN TestSetsDoAll --- PASS: TestSetsDoAll (0.00s) === RUN TestStringSetsAddRemove --- PASS: TestStringSetsAddRemove (0.00s) === RUN TestStringSetsFindAll --- PASS: TestStringSetsFindAll (0.00s) === RUN TestStringSetsDoAll --- PASS: TestStringSetsDoAll (0.00s) === RUN TestStackPushPop --- PASS: TestStackPushPop (0.00s) === RUN TestStackAll --- PASS: TestStackAll (0.00s) === RUN TestStringStackPushPop --- PASS: TestStringStackPushPop (0.00s) === RUN TestTreeCreate --- PASS: TestTreeCreate (0.00s) === RUN TestTreeRemove --- PASS: TestTreeRemove (0.00s) === RUN TestTreeSetValue --- PASS: TestTreeSetValue (0.00s) === RUN TestTreeFind --- PASS: TestTreeFind (0.01s) === RUN TestTreeDo --- PASS: TestTreeDo (0.00s) === RUN TestTreeCopy --- PASS: TestTreeCopy (0.00s) === RUN TestStringTreeCreate --- PASS: TestStringTreeCreate (0.00s) === RUN TestStringTreeRemove --- PASS: TestStringTreeRemove (0.00s) === RUN TestStringTreeSetValue --- PASS: TestStringTreeSetValue (0.00s) === RUN TestStringTreeFind --- PASS: TestStringTreeFind (0.00s) === RUN TestStringTreeDo --- PASS: TestStringTreeDo (0.00s) === RUN TestStringTreeCopy --- PASS: TestStringTreeCopy (0.00s) === RUN TestKeyValueTreeCreate --- PASS: TestKeyValueTreeCreate (0.00s) === RUN TestKeyValueTreeRemove --- PASS: TestKeyValueTreeRemove (0.00s) === RUN TestKeyValueTreeSetKey --- PASS: TestKeyValueTreeSetKey (0.00s) === RUN TestKeyValueTreeSetValue --- PASS: TestKeyValueTreeSetValue (0.00s) === RUN TestKeyValueTreeFind --- PASS: TestKeyValueTreeFind (0.00s) === RUN TestKeyValueTreeDo --- PASS: TestKeyValueTreeDo (0.00s) === RUN TestKeyValueTreeCopy --- PASS: TestKeyValueTreeCopy (0.00s) === RUN TestKeyStringValueTreeCreate --- PASS: TestKeyStringValueTreeCreate (0.00s) === RUN TestKeyStringValueTreeRemove --- PASS: TestKeyStringValueTreeRemove (0.00s) === RUN TestKeyStringValueTreeSetKey --- PASS: TestKeyStringValueTreeSetKey (0.00s) === RUN TestKeyStringValueTreeSetValue --- PASS: TestKeyStringValueTreeSetValue (0.00s) === RUN TestKeyStringValueTreeFind --- PASS: TestKeyStringValueTreeFind (0.00s) === RUN TestKeyStringValueTreeDo --- PASS: TestKeyStringValueTreeDo (0.00s) === RUN TestKeyStringValueTreeCopy --- PASS: TestKeyStringValueTreeCopy (0.00s) PASS ok github.com/tideland/golib/collections 0.060s === RUN TestIsError --- PASS: TestIsError (0.00s) === RUN TestValidation --- PASS: TestValidation (0.00s) === RUN TestAnnotation --- PASS: TestAnnotation (0.00s) === RUN TestCollection --- PASS: TestCollection (0.00s) === RUN TestDoAll --- PASS: TestDoAll (0.00s) PASS ok github.com/tideland/golib/errors 0.044s === RUN TestRead --- PASS: TestRead (0.00s) === RUN TestReadFile --- PASS: TestReadFile (0.01s) === RUN TestWrite --- PASS: TestWrite (0.00s) === RUN TestTemplates --- PASS: TestTemplates (0.01s) === RUN TestHasPath --- PASS: TestHasPath (0.00s) === RUN TestDo --- PASS: TestDo (0.00s) === RUN TestValueSuccess --- PASS: TestValueSuccess (0.00s) === RUN TestGetFail --- PASS: TestGetFail (0.00s) === RUN TestSplit --- PASS: TestSplit (0.00s) === RUN TestDump --- PASS: TestDump (0.00s) === RUN TestApply --- PASS: TestApply (0.01s) === RUN TestContext --- PASS: TestContext (0.00s) PASS ok github.com/tideland/golib/etc 0.074s === RUN TestParseComposeTime --- PASS: TestParseComposeTime (0.00s) === RUN TestEncodeDecode --- PASS: TestEncodeDecode (0.00s) === RUN TestGet atom_test.go:77: Network test skipped in short mode --- SKIP: TestGet (0.00s) PASS ok github.com/tideland/golib/feed/atom 0.049s === RUN TestParseComposeTime --- PASS: TestParseComposeTime (0.00s) === RUN TestEncodeDecode --- PASS: TestEncodeDecode (0.00s) === RUN TestValidate --- PASS: TestValidate (0.00s) === RUN TestGet rss_test.go:123: Network test skipped in short mode --- SKIP: TestGet (0.00s) PASS ok github.com/tideland/golib/feed/rss 0.031s === RUN TestStripTags --- PASS: TestStripTags (0.00s) PASS ok github.com/tideland/golib/feed/utils 0.024s === RUN TestParseError --- PASS: TestParseError (0.00s) === RUN TestClear --- PASS: TestClear (0.00s) === RUN TestLength --- PASS: TestLength (0.00s) === RUN TestProcessing gjp_test.go:82 func1(): path 01 => "/A" = "Level One" gjp_test.go:82 func1(): path 02 => "/B/0/D/A" = "Level Three - 0" gjp_test.go:82 func1(): path 03 => "/B/0/D/B" = "10.1" gjp_test.go:82 func1(): path 04 => "/B/0/S/0" = "red" gjp_test.go:82 func1(): path 05 => "/B/0/S/1" = "green" gjp_test.go:82 func1(): path 06 => "/B/0/S/2" = "1" gjp_test.go:82 func1(): path 07 => "/B/0/S/3" = "2.2" gjp_test.go:82 func1(): path 08 => "/B/0/S/4" = "true" gjp_test.go:82 func1(): path 09 => "/B/0/A" = "Level Two - 0" gjp_test.go:82 func1(): path 10 => "/B/0/B" = "100" gjp_test.go:82 func1(): path 11 => "/B/0/C" = "true" gjp_test.go:82 func1(): path 12 => "/B/1/A" = "Level Two - 1" gjp_test.go:82 func1(): path 13 => "/B/1/B" = "200" gjp_test.go:82 func1(): path 14 => "/B/1/C" = "false" gjp_test.go:82 func1(): path 15 => "/B/1/D/A" = "Level Three - 1" gjp_test.go:82 func1(): path 16 => "/B/1/D/B" = "20.2" gjp_test.go:82 func1(): path 17 => "/B/1/S/0" = "orange" gjp_test.go:82 func1(): path 18 => "/B/1/S/1" = "blue" gjp_test.go:82 func1(): path 19 => "/B/1/S/2" = "white" gjp_test.go:82 func1(): path 20 => "/B/2/C" = "true" gjp_test.go:82 func1(): path 21 => "/B/2/D/A" = "Level Three - 2" gjp_test.go:82 func1(): path 22 => "/B/2/D/B" = "30.3" gjp_test.go:82 func1(): path 23 => "/B/2/S" = "" gjp_test.go:82 func1(): path 24 => "/B/2/A" = "Level Two - 2" gjp_test.go:82 func1(): path 25 => "/B/2/B" = "300" gjp_test.go:82 func1(): path 26 => "/D" = "5000000000" gjp_test.go:82 func1(): path 27 => "/T" = "2017-04-29T20:30:00Z" --- PASS: TestProcessing (0.00s) === RUN TestSeparator --- PASS: TestSeparator (0.00s) === RUN TestCompare --- PASS: TestCompare (0.01s) === RUN TestString --- PASS: TestString (0.00s) === RUN TestInt --- PASS: TestInt (0.00s) === RUN TestFloat64 --- PASS: TestFloat64 (0.00s) === RUN TestBool --- PASS: TestBool (0.00s) === RUN TestQuery --- PASS: TestQuery (0.00s) === RUN TestBuilding --- PASS: TestBuilding (0.01s) === RUN TestMarshalJSON --- PASS: TestMarshalJSON (0.00s) PASS ok github.com/tideland/golib/gjp 0.064s === RUN TestTypeAsIdentifierPart --- PASS: TestTypeAsIdentifierPart (0.00s) === RUN TestIdentifier --- PASS: TestIdentifier (0.00s) === RUN TestSepIdentifier --- PASS: TestSepIdentifier (0.00s) === RUN TestStandardUUID --- PASS: TestStandardUUID (13.85s) === RUN TestUUIDVersions uuid_test.go:62 TestUUIDVersions(): UUID V1: 69a495d2-e1ea-1e01-8c17-95f92bededb9 uuid_test.go:67 TestUUIDVersions(): UUID V3: c4d91d8a-0d3e-3e3f-8dd6-924b8cc71909 uuid_test.go:72 TestUUIDVersions(): UUID V4: e8014a71-3152-48e3-87b8-08a995359ba8 uuid_test.go:77 TestUUIDVersions(): UUID V5: 479b560a-cc70-5da7-9009-dcda1e772b01 --- PASS: TestUUIDVersions (0.00s) === RUN TestUUIDByHex --- PASS: TestUUIDByHex (0.00s) PASS ok github.com/tideland/golib/identifier 14.136s === RUN TestGetSetLevel --- PASS: TestGetSetLevel (0.00s) === RUN TestGetSetLevelString --- PASS: TestGetSetLevelString (0.00s) === RUN TestFiltering --- PASS: TestFiltering (0.00s) === RUN TestGoLogger 2024/03/25 19:56:40 [DEBUG] [github.com/tideland/golib/logger_test] (logger_test.go:TestGoLogger:146) Debug. 2024/03/25 19:56:40 [INFO] [github.com/tideland/golib/logger_test] Info. 2024/03/25 19:56:40 [WARNING] [github.com/tideland/golib/logger_test] Warning. 2024/03/25 19:56:40 [ERROR] [github.com/tideland/golib/logger_test] Error. 2024/03/25 19:56:40 [CRITICAL] [github.com/tideland/golib/logger_test] (logger_test.go:TestGoLogger:150) Critical. --- PASS: TestGoLogger (0.00s) === RUN TestSysLogger logger_test.go:156: Network test skipped in short mode --- SKIP: TestSysLogger (0.00s) === RUN TestFatalExit --- PASS: TestFatalExit (0.00s) PASS ok github.com/tideland/golib/logger 0.040s === RUN TestSimpleStop 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-stop" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-stop" stopped --- PASS: TestSimpleStop (0.00s) === RUN TestLogging --- PASS: TestLogging (0.00s) === RUN TestSimpleRestart 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-restart" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-restart" stopped 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-restart" restarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-restart" stopped --- PASS: TestSimpleRestart (0.00s) === RUN TestSimpleKill 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-kill" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "simple-kill" stopped with error: ouch --- PASS: TestSimpleKill (0.00s) === RUN TestError 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "error" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "error" stopped with error: internal loop error --- PASS: TestError (0.00s) === RUN TestDeferredError 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "deferred-error" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "deferred-error" stopped with error: deferred error --- PASS: TestDeferredError (0.00s) === RUN TestStopRecoverings 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "stop-recoverings" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "stop-recoverings" tries to recover 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "stop-recoverings" recovered 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "stop-recoverings" stopped --- PASS: TestStopRecoverings (0.00s) === RUN TestEndRecoverings 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "end-recoverings" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "end-recoverings" stopped --- PASS: TestEndRecoverings (0.00s) === RUN TestRecoveringsPanic 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-panic" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" tries to recover 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-panic" recovered 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" tries to recover 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-panic" recovered 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" tries to recover 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-panic" recovered 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" tries to recover 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-panic" recovered 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" tries to recover 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-panic" stopped with error: too many panics --- PASS: TestRecoveringsPanic (0.00s) === RUN TestRecoveringsError 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "recoverings-error" starts 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-error" tries to recover 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "recoverings-error" stopped with error: error --- PASS: TestRecoveringsError (0.00s) === RUN TestDescription 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "one" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "two::three::four" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "two::three::four" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "one" stops observable "two::three::four" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "one" stops observable "" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "one" stopped --- PASS: TestDescription (0.00s) === RUN TestSimpleSentinel 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-sentinel" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "simple-sentinel" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "simple-sentinel" stops observable "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "simple-sentinel" stops observable "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "simple-sentinel" stopped --- PASS: TestSimpleSentinel (0.00s) === RUN TestSentinelStoppingLoop 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-stopping-loop" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] stopped observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" stopped 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-stopping-loop" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-stopping-loop" stops observable "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-stopping-loop" stopped --- PASS: TestSentinelStoppingLoop (0.01s) === RUN TestSentineForget 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-forget" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::d" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::d" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] stopped observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] stopped observing "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-forget" stops observable "loop::d" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-forget" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-forget" stopped --- PASS: TestSentineForget (0.00s) === RUN TestSentinelKillingLoopNoHandler 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-no-handler" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "loop::b" stopped with error: bang! 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] sentinel "sentinel-killing-loop-no-handler" kills all observables after error: bang! 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::a" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::b" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-no-handler" stopped with error: [LOOP:002] error handling for "loop::b" failed: bang! --- PASS: TestSentinelKillingLoopNoHandler (0.00s) === RUN TestSentinelKillingLoopHandlerRestarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-handler-restarts" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "loop::b" stopped with error: bang! 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" restarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-handler-restarts" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-handler-restarts" stops observable "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-handler-restarts" stops observable "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-handler-restarts" stopped --- PASS: TestSentinelKillingLoopHandlerRestarts (0.00s) === RUN TestSentinelKillingLoopHandlerStops 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-with-stops" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "loop::b" stopped with error: bang! 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] sentinel "sentinel-killing-loop-with-stops" kills all observables after error: oh no! 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::a" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::b" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop.(*sentinel).backendLoop] killing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-with-stops" stopped with error: [LOOP:002] error handling for "loop::b" failed: oh no! --- PASS: TestSentinelKillingLoopHandlerStops (0.01s) === RUN TestSentinelKillingLoopHandlerRestartAll 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-restarting-all" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::c" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::c" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "loop::b" stopped with error: bang! 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" restarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-restarting-all" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-restarting-all" stops observable "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-killing-loop-restarting-all" stops observable "loop::c" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-killing-loop-restarting-all" stopped --- PASS: TestSentinelKillingLoopHandlerRestartAll (0.00s) === RUN TestNestedSentinelKill 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "nested-sentinel-kill::top" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "nested-sentinel-kill::nested" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "nested-sentinel-kill::nested" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "nested-sentinel-kill::nested" stops observable "loop::b" 2024-03-25 19:56:42 Z [ERROR] [github.com/tideland/golib/loop] loop "nested-sentinel-kill::nested" stopped with error: bang! 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] sentinel "nested-sentinel-kill::nested" restarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "nested-sentinel-kill::nested" restarts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] stopped observing "loop::b" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::b" stopped 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "nested-sentinel-kill::top" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "nested-sentinel-kill::top" stops observable "nested-sentinel-kill::nested" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "nested-sentinel-kill::top" stopped --- PASS: TestNestedSentinelKill (0.00s) === RUN TestSentinelSwitch 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-switch::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-switch::b" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "loop::a" starts 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] stopped observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] started observing "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-switch::a" stopped 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop.(*sentinel).backendLoop] sentinel "sentinel-switch::b" stops observable "loop::a" 2024-03-25 19:56:42 Z [INFO] [github.com/tideland/golib/loop] loop "sentinel-switch::b" stopped --- PASS: TestSentinelSwitch (0.00s) PASS ok github.com/tideland/golib/loop 0.097s === RUN TestMapReduce --- PASS: TestMapReduce (14.21s) PASS ok github.com/tideland/golib/mapreduce 14.232s === RUN TestETMMonitor 2024-03-25 19:56:44 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts --- PASS: TestETMMonitor (0.60s) === RUN TestSSIMonitor 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" stopped --- PASS: TestSSIMonitor (0.01s) === RUN TestDSRMonitor 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" stopped 2024-03-25 19:56:45 Z [ERROR] [github.com/tideland/golib/loop] loop "monitoring-backend" tries to recover 2024-03-25 19:56:45 Z [WARNING] [github.com/tideland/golib/monitoring] standard monitor recovered: runtime error: integer divide by zero 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" recovered --- PASS: TestDSRMonitor (0.00s) === RUN TestInternalPanic 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" stopped 2024-03-25 19:56:45 Z [ERROR] [github.com/tideland/golib/loop] loop "monitoring-backend" tries to recover 2024-03-25 19:56:45 Z [WARNING] [github.com/tideland/golib/monitoring] standard monitor recovered: ouch 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" recovered --- PASS: TestInternalPanic (0.00s) === RUN TestBackendSwitch 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" stopped 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" stopped 2024-03-25 19:56:45 Z [INFO] [github.com/tideland/golib/loop] loop "monitoring-backend" starts --- PASS: TestBackendSwitch (0.06s) PASS ok github.com/tideland/golib/monitoring 0.717s === RUN TestSimplePoint --- PASS: TestSimplePoint (0.00s) === RUN TestSimplePointArray --- PASS: TestSimplePointArray (0.00s) === RUN TestSimplePolynomialFunction --- PASS: TestSimplePolynomialFunction (0.00s) === RUN TestPolynomialFunctionPrinting --- PASS: TestPolynomialFunctionPrinting (0.00s) === RUN TestQuadraticPolynomialFunction --- PASS: TestQuadraticPolynomialFunction (0.00s) === RUN TestPolynomialFunctionDifferentiation --- PASS: TestPolynomialFunctionDifferentiation (0.00s) === RUN TestInterpolation --- PASS: TestInterpolation (0.00s) === RUN TestPointsEvaluation --- PASS: TestPointsEvaluation (0.00s) === RUN TestLeastSquaresFunction --- PASS: TestLeastSquaresFunction (0.00s) PASS ok github.com/tideland/golib/numerics 0.028s === RUN TestSimpleKeyOperations commands_test.go:29: Redis test skipped in short mode --- SKIP: TestSimpleKeyOperations (0.00s) === RUN TestScan commands_test.go:90: Redis test skipped in short mode --- SKIP: TestScan (0.00s) === RUN TestHash commands_test.go:131: Redis test skipped in short mode --- SKIP: TestHash (0.00s) === RUN TestHScan commands_test.go:172: Redis test skipped in short mode --- SKIP: TestHScan (0.00s) === RUN TestList commands_test.go:215: Redis test skipped in short mode --- SKIP: TestList (0.00s) === RUN TestSet commands_test.go:233: Redis test skipped in short mode --- SKIP: TestSet (0.00s) === RUN TestSScan commands_test.go:258: Redis test skipped in short mode --- SKIP: TestSScan (0.00s) === RUN TestSortedSet commands_test.go:298: Redis test skipped in short mode --- SKIP: TestSortedSet (0.00s) === RUN TestZScan commands_test.go:324: Redis test skipped in short mode --- SKIP: TestZScan (0.00s) === RUN TestTransactionConnection commands_test.go:367: Redis test skipped in short mode --- SKIP: TestTransactionConnection (0.00s) === RUN TestTransactionPipeline commands_test.go:426: Redis test skipped in short mode --- SKIP: TestTransactionPipeline (0.00s) === RUN TestTransactionPipelineWatch commands_test.go:464: Redis test skipped in short mode --- SKIP: TestTransactionPipelineWatch (0.00s) === RUN TestScripting commands_test.go:499: Redis test skipped in short mode --- SKIP: TestScripting (0.00s) === RUN TestPubSub commands_test.go:540: Redis test skipped in short mode --- SKIP: TestPubSub (0.00s) === RUN TestUnixSocketConnection redis_test.go:29: Redis test skipped in short mode --- SKIP: TestUnixSocketConnection (0.00s) === RUN TestTcpConnection redis_test.go:58: Redis test skipped in short mode --- SKIP: TestTcpConnection (0.00s) === RUN TestPipelining redis_test.go:87: Redis test skipped in short mode --- SKIP: TestPipelining (0.00s) === RUN TestOptions 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "redis::tmp-redis-sock::0" starts --- PASS: TestOptions (0.01s) === RUN TestConcurrency redis_test.go:145: Redis test skipped in short mode --- SKIP: TestConcurrency (0.00s) PASS ok github.com/tideland/golib/redis 0.052s === RUN TestSimpleNoTimeout 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::56fcf243-289b-4d89-86fc-aeb93d6f87c7" starts 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::56fcf243-289b-4d89-86fc-aeb93d6f87c7" stopped --- PASS: TestSimpleNoTimeout (0.00s) === RUN TestAccessAfterStopping 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::6aff4c2f-f562-4f66-9d07-3b7f0393db23" starts 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::6aff4c2f-f562-4f66-9d07-3b7f0393db23" stopped --- PASS: TestAccessAfterStopping (0.00s) === RUN TestCleanupNoError 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::7c3a5bb2-5e00-444c-8154-04b523d2b85a" starts 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::7c3a5bb2-5e00-444c-8154-04b523d2b85a" stopped --- PASS: TestCleanupNoError (0.00s) === RUN TestCleanupWithErrors 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::64fbd9a1-21e6-46f3-881d-ba1a06b53b7f" starts 2024-03-25 19:56:55 Z [ERROR] [github.com/tideland/golib/loop] loop "scene::64fbd9a1-21e6-46f3-881d-ba1a06b53b7f" stopped with error: [SCENE:005] cleanup of property "bar" failed: ouch --- PASS: TestCleanupWithErrors (0.00s) === RUN TestSimpleInactivityTimeout 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::caca05a0-3626-454f-928b-3825de6d96b6" starts 2024-03-25 19:56:55 Z [ERROR] [github.com/tideland/golib/loop] loop "scene::caca05a0-3626-454f-928b-3825de6d96b6" stopped with error: [SCENE:002] scene inactivity timeout reached at 2024-03-25 19:56:55.130515032 +0000 UTC m=+0.107127224 --- PASS: TestSimpleInactivityTimeout (0.11s) === RUN TestSimpleAbsoluteTimeout 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::71cde9a0-225e-468a-9355-a875c83070a2" starts 2024-03-25 19:56:55 Z [ERROR] [github.com/tideland/golib/loop] loop "scene::71cde9a0-225e-468a-9355-a875c83070a2" stopped with error: [SCENE:002] scene absolute timeout reached at 2024-03-25 19:56:55.382491617 +0000 UTC m=+0.359103849 --- PASS: TestSimpleAbsoluteTimeout (0.27s) === RUN TestCleanupAfterTimeout 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::24701a89-8078-4f12-9e20-c027fa2c712e" starts 2024-03-25 19:56:55 Z [ERROR] [github.com/tideland/golib/loop] loop "scene::24701a89-8078-4f12-9e20-c027fa2c712e" stopped with error: [SCENE:002] scene absolute timeout reached at 2024-03-25 19:56:55.505028001 +0000 UTC m=+0.481640253 --- PASS: TestCleanupAfterTimeout (0.25s) === RUN TestAbort 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::ad1cd18d-0635-4698-908a-23de15bca784" starts 2024-03-25 19:56:55 Z [ERROR] [github.com/tideland/golib/loop] loop "scene::ad1cd18d-0635-4698-908a-23de15bca784" stopped with error: aborted --- PASS: TestAbort (0.00s) === RUN TestFlagNoTimeout 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scene::000c6382-58db-41de-904d-147a32d500db" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::000c6382-58db-41de-904d-147a32d500db" stopped --- PASS: TestFlagNoTimeout (0.36s) === RUN TestNoFlagDueToStop 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::4a84d18d-6a8c-401d-9a69-1a728f7089ab" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::4a84d18d-6a8c-401d-9a69-1a728f7089ab" stopped --- PASS: TestNoFlagDueToStop (0.10s) === RUN TestStoreAndFlag 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::b7493502-c225-4cad-9b94-fc9a6057b680" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::b7493502-c225-4cad-9b94-fc9a6057b680" stopped --- PASS: TestStoreAndFlag (0.10s) === RUN TestEarlyFlag 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::7b922252-eff3-46ed-95bc-1f3686e16cff" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::7b922252-eff3-46ed-95bc-1f3686e16cff" stopped --- PASS: TestEarlyFlag (0.10s) === RUN TestFlagTimeout 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::4662d175-c4cd-4337-9c21-ba4286e8c6c5" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::4662d175-c4cd-4337-9c21-ba4286e8c6c5" stopped --- PASS: TestFlagTimeout (0.10s) === RUN TestFlagUnflag 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::1b34454b-3944-43f9-81d1-c7634239ab40" starts 2024-03-25 19:56:56 Z [INFO] [github.com/tideland/golib/loop] loop "scene::1b34454b-3944-43f9-81d1-c7634239ab40" stopped --- PASS: TestFlagUnflag (0.05s) PASS ok github.com/tideland/golib/scene 1.476s === RUN TestScroller scroller_test.go:173 TestScroller(): test #1/10: no lines existing; initially no lines scrolled 2024-03-25 19:56:55 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:56:57 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #2/10: no lines existing; initially five lines scrolled 2024-03-25 19:56:57 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #3/10: ten lines existing; initially no lines scrolled 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:03 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #4/10: ten lines existing; initially five lines scrolled 2024-03-25 19:57:03 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:04 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #5/10: ten lines existing; initially twenty lines scrolled 2024-03-25 19:57:04 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:04 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #6/10: ten lines existing; initially twenty lines scrolled; buffer smaller than lines 2024-03-25 19:57:04 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:05 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #7/10: ten lines existing; initially three lines scrolled; filter lines with special prefix 2024-03-25 19:57:05 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #8/10: ten lines existing; initially five lines scrolled; error after further 25 lines 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:06 Z [ERROR] [github.com/tideland/golib/loop] loop "scroller" stopped with error: ouch scroller_test.go:173 TestScroller(): test #9/10: ten lines existing; initially five lines scrolled; simply stop after 25 lines 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped scroller_test.go:173 TestScroller(): test #10/10: unterminated last line is not scrolled 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" starts 2024-03-25 19:57:06 Z [INFO] [github.com/tideland/golib/loop] loop "scroller" stopped --- PASS: TestScroller (11.45s) PASS ok github.com/tideland/golib/scroller 11.481s === RUN TestTagValidation --- PASS: TestTagValidation (0.00s) === RUN TestCreating --- PASS: TestCreating (0.00s) === RUN TestWriterProcessing sml_test.go:86 TestWriterProcessing(): ===== WITH INDENT ===== sml_test.go:87 TestWriterProcessing(): {root Text A Text B {# A first comment. #} {sub-a:1st:important Text A.A {# A second comment. #} } {sub-b:2nd Text B.A {text Any text with the special characters ^{, ^}, and ^^. } } {sub-c Before raw. {! func Test(i int) { println(i) } !} After raw. } } sml_test.go:88 TestWriterProcessing(): ===== WITHOUT INDENT ===== sml_test.go:89 TestWriterProcessing(): {root Text A Text B {# A first comment. #} {sub-a:1st:important Text A.A {# A second comment. #}} {sub-b:2nd Text B.A {text Any text with the special characters ^{, ^}, and ^^.}} {sub-c Before raw. {! func Test(i int) { println(i) } !} After raw.}} sml_test.go:90 TestWriterProcessing(): ===== DONE ===== --- PASS: TestWriterProcessing (0.00s) === RUN TestPositiveNodeReading sml_test.go:112 TestPositiveNodeReading(): ===== PARSED SML ===== sml_test.go:113 TestPositiveNodeReading(): {foo:main {bar:1:first Yadda ^{Test^} 1 } {! Raw: }} { ! ^^^ !} {between } {bar:2:last Yadda {test ^^ } 2 } } sml_test.go:114 TestPositiveNodeReading(): ===== DONE ===== --- PASS: TestPositiveNodeReading (0.00s) === RUN TestNegativeNodeReading --- PASS: TestNegativeNodeReading (0.00s) === RUN TestPositiveTreeReading sml_test.go:135 TestPositiveTreeReading(): [config = '' [foo = '1'][bar = '2'][yadda = '' [up = 'down'][down = 'up']]] --- PASS: TestPositiveTreeReading (0.00s) === RUN TestNegativeTreeReading --- PASS: TestNegativeTreeReading (0.00s) === RUN TestSML2XML sml_test.go:178 TestSML2XML(): ===== XML ===== sml_test.go:179 TestSML2XML(): A test document

A test document

The is a simple sentence with an emphasized and a strong text. We'll see how it renders.

  • It should be nice.
  • It should be error free.
  • It should be fast.
for foo := 0; foo < 42; foo++ {
	println(foo)
}
  
sml_test.go:180 TestSML2XML(): ===== DONE ===== --- PASS: TestSML2XML (0.00s) PASS ok github.com/tideland/golib/sml 0.033s === RUN TestPivot --- PASS: TestPivot (0.00s) PASS ok github.com/tideland/golib/sort 0.042s === RUN TestAsString defaulter_test.go:54 TestAsString(): test Defaulter{AsString} 0: value 'foo' without error and default bar defaulter_test.go:54 TestAsString(): test Defaulter{AsString} 1: value 'foo' with error and default bar 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsString) value returned with error: foo --- PASS: TestAsString (0.00s) === RUN TestAsStringSlice defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 0: value 'a/b/c' without error and default [a] defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 1: value 'a/b/c' with error and default [a] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringSlice) value returned with error: a/b/c defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 2: value 'a/b/c' without error and default [] defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 3: value 'a/b/c' with error and default [] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringSlice) value returned with error: a/b/c defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 4: value '' without error and default [] defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 5: value '' with error and default [foo] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringSlice) value returned with error: defaulter_test.go:80 TestAsStringSlice(): test Defaulter{AsStringSlice} 6: value 'a/b/c' without error and default [a] --- PASS: TestAsStringSlice (0.00s) === RUN TestAsStringMap defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 0: value 'a:1/b:2' without error and default map[a:1] defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 1: value 'a:1/b:2' with error and default map[a:1] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringMap) value returned with error: a:1/b:2 defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 2: value 'a:1/b:2' without error and default map[] defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 3: value 'a:1/b:2' with error and default map[] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringMap) value returned with error: a:1/b:2 defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 4: value '' without error and default map[] defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 5: value '' with error and default map[a:1] 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsStringMap) value returned with error: defaulter_test.go:107 TestAsStringMap(): test Defaulter{AsStringMap} 6: value 'a:1/b:2' without error and default map[] --- PASS: TestAsStringMap (0.00s) === RUN TestAsBool defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 0: value '1' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 1: value 't' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 2: value 'T' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 3: value 'TRUE' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 4: value 'true' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 5: value 'True' without error and default false defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 6: value 'wahr' without error and default true 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsBool) value has illegal format for "bool": strconv.ParseBool: parsing "wahr": invalid syntax defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 7: value '' with error and default true 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsBool) value returned with error: defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 8: value '0' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 9: value 'f' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 10: value 'F' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 11: value 'FALSE' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 12: value 'false' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 13: value 'False' without error and default true defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 14: value 'falsch' without error and default false 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsBool) value has illegal format for "bool": strconv.ParseBool: parsing "falsch": invalid syntax defaulter_test.go:141 TestAsBool(): test Defaulter{AsBool} 15: value '' with error and default false 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsBool) value returned with error: --- PASS: TestAsBool (0.00s) === RUN TestAsInt defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 0: value '0' without error and default 0 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 1: value '1' without error and default 0 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 2: value '-1' without error and default 0 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 3: value '2147483647' without error and default 0 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 4: value '-2147483648' without error and default 0 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 5: value '999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt) value has illegal format for "int": strconv.ParseInt: parsing "999999999999999999999": value out of range defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 6: value '-999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt) value has illegal format for "int": strconv.ParseInt: parsing "-999999999999999999999": value out of range defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 7: value 'one two three' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt) value has illegal format for "int": strconv.ParseInt: parsing "one two three": invalid syntax defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 8: value '1' with error and default 2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt) value returned with error: 1 defaulter_test.go:171 TestAsInt(): test Defaulter{AsInt} 9: value '-1' with error and default -2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt) value returned with error: -1 --- PASS: TestAsInt (0.00s) === RUN TestAsInt64 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 0: value '0' without error and default 0 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 1: value '1' without error and default 0 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 2: value '-1' without error and default 0 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 3: value '9223372036854775807' without error and default 0 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 4: value '-9223372036854775808' without error and default 0 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 5: value '999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt64) value has illegal format for "int64": strconv.ParseInt: parsing "999999999999999999999": value out of range defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 6: value '-999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt64) value has illegal format for "int64": strconv.ParseInt: parsing "-999999999999999999999": value out of range defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 7: value 'one two three' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt64) value has illegal format for "int64": strconv.ParseInt: parsing "one two three": invalid syntax defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 8: value '1' with error and default 2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt64) value returned with error: 1 defaulter_test.go:201 TestAsInt64(): test Defaulter{AsInt64} 9: value '-1' with error and default -2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsInt64) value returned with error: -1 --- PASS: TestAsInt64 (0.00s) === RUN TestAsUint defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 0: value '0' without error and default 0 defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 1: value '1' without error and default 0 defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 2: value '4294967295' without error and default 0 defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 3: value '999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUint) value has illegal format for "uint": strconv.ParseUint: parsing "999999999999999999999": value out of range defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 4: value 'one two three' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUint) value has illegal format for "uint": strconv.ParseUint: parsing "one two three": invalid syntax defaulter_test.go:226 TestAsUint(): test Defaulter{AsUint} 5: value '-1' with error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUint) value returned with error: -1 --- PASS: TestAsUint (0.00s) === RUN TestAsUInt64 defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 0: value '0' without error and default 0 defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 1: value '1' without error and default 0 defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 2: value '18446744073709551615' without error and default 0 defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 3: value '999999999999999999999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUInt64) value has illegal format for "uint64": strconv.ParseUint: parsing "999999999999999999999": value out of range defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 4: value 'one two three' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUInt64) value has illegal format for "uint64": strconv.ParseUint: parsing "one two three": invalid syntax defaulter_test.go:251 TestAsUInt64(): test Defaulter{AsUInt64} 5: value '-1' with error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsUInt64) value returned with error: -1 --- PASS: TestAsUInt64 (0.00s) === RUN TestAsFloat64 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 0: value '0.0' without error and default 0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 1: value '1.0' without error and default 0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 2: value '-1.0' without error and default 0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 3: value '1.7976931348623157e+308' without error and default 0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 4: value '-1.7976931348623157e+308' without error and default 0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 5: value '9e+999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsFloat4) value has illegal format for "float64": strconv.ParseFloat: parsing "9e+999": value out of range defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 6: value '-9e+999' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsFloat4) value has illegal format for "float64": strconv.ParseFloat: parsing "-9e+999": value out of range defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 7: value 'one.two' without error and default 1 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsFloat4) value has illegal format for "float64": strconv.ParseFloat: parsing "one.two": invalid syntax defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 8: value '1.0' with error and default 2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsFloat4) value returned with error: 1.0 defaulter_test.go:281 TestAsFloat64(): test Defaulter{AsFloat4} 9: value '-1.0' with error and default -2 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsFloat4) value returned with error: -1.0 --- PASS: TestAsFloat64 (0.00s) === RUN TestAsTime defaulter_test.go:307 TestAsTime(): test Defaulter{AsTime} 0: value '2024-03-25T19:56:59.421341375Z' without error and default 2000-01-01 00:00:00 +0000 UTC defaulter_test.go:307 TestAsTime(): test Defaulter{AsTime} 1: value '2024-03-25T19:56:59.421341375Z' with error and default 2000-01-01 00:00:00 +0000 UTC 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsTime) value returned with error: 2024-03-25T19:56:59.421341375Z defaulter_test.go:307 TestAsTime(): test Defaulter{AsTime} 2: value '2024-03-25T19:56:59.421341375Z' without error and default 2000-01-01 00:00:00 +0000 UTC 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsTime) value has illegal format for "time": parsing time "2024-03-25T19:56:59.421341375Z" as "any false layout": cannot parse "2024-03-25T19:56:59.421341375Z" as "any false layout" defaulter_test.go:307 TestAsTime(): test Defaulter{AsTime} 3: value '' without error and default 2000-01-01 00:00:00 +0000 UTC 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsTime) value has illegal format for "time": parsing time "" as "2006-01-02T15:04:05.999999999Z07:00": cannot parse "" as "2006" --- PASS: TestAsTime (0.00s) === RUN TestAsDuration defaulter_test.go:330 TestAsDuration(): test Defaulter{AsDuration} 0: value '1s' without error and default 1s defaulter_test.go:330 TestAsDuration(): test Defaulter{AsDuration} 1: value '1s' with error and default 1m0s 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsDuration) value returned with error: 1s defaulter_test.go:330 TestAsDuration(): test Defaulter{AsDuration} 2: value '2' without error and default 1m0s 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsDuration) value has illegal format for "duration": time: missing unit in duration "2" defaulter_test.go:330 TestAsDuration(): test Defaulter{AsDuration} 3: value '1 hour' without error and default 1m0s 2024-03-25 19:56:59 Z [ERROR] [github.com/tideland/golib/stringex] (AsDuration) value has illegal format for "duration": time: unknown unit " hour" in duration "1 hour" defaulter_test.go:330 TestAsDuration(): test Defaulter{AsDuration} 4: value '4711h' without error and default 1m0s --- PASS: TestAsDuration (0.00s) === RUN TestDefaulterString --- PASS: TestDefaulterString (0.00s) === RUN TestWrapping --- PASS: TestWrapping (0.00s) === RUN TestSplitMapProcessor --- PASS: TestSplitMapProcessor (0.00s) === RUN TestSubstringProcessor --- PASS: TestSubstringProcessor (0.00s) === RUN TestMatchProcessor --- PASS: TestMatchProcessor (0.00s) === RUN TestTrimmingProcessors --- PASS: TestTrimmingProcessors (0.00s) === RUN TestUpperLowerProcessor --- PASS: TestUpperLowerProcessor (0.00s) === RUN TestProcessorScenario --- PASS: TestProcessorScenario (0.00s) === RUN TestSplitFilter === RUN TestSplitFilter/all_fine === RUN TestSplitFilter/filter_empty_parts === RUN TestSplitFilter/filter_all_parts === RUN TestSplitFilter/filter_empty_input === RUN TestSplitFilter/filter_not_splitted --- PASS: TestSplitFilter (0.00s) --- PASS: TestSplitFilter/all_fine (0.00s) --- PASS: TestSplitFilter/filter_empty_parts (0.00s) --- PASS: TestSplitFilter/filter_all_parts (0.00s) --- PASS: TestSplitFilter/filter_empty_input (0.00s) --- PASS: TestSplitFilter/filter_not_splitted (0.00s) === RUN TestSplitMap === RUN TestSplitMap/uppercase_all === RUN TestSplitMap/filter_empty_parts,_uppercase_the_rest === RUN TestSplitMap/filter_all_parts === RUN TestSplitMap/encapsulate_even_empty_input === RUN TestSplitMap/uppercase_not_splitted --- PASS: TestSplitMap (0.00s) --- PASS: TestSplitMap/uppercase_all (0.00s) --- PASS: TestSplitMap/filter_empty_parts,_uppercase_the_rest (0.00s) --- PASS: TestSplitMap/filter_all_parts (0.00s) --- PASS: TestSplitMap/encapsulate_even_empty_input (0.00s) --- PASS: TestSplitMap/uppercase_not_splitted (0.00s) === RUN TestMatches === RUN TestMatches/equal_pattern_and_string_without_wildcards === RUN TestMatches/unequal_pattern_and_string_without_wildcards === RUN TestMatches/matching_pattern_with_one_question_mark === RUN TestMatches/matching_pattern_with_one_asterisk === RUN TestMatches/matching_pattern_with_char_group === RUN TestMatches/not-matching_pattern_with_char_group === RUN TestMatches/matching_pattern_with_char_range === RUN TestMatches/not-matching_pattern_with_char_range === RUN TestMatches/matching_pattern_with_char_group_not_ignoring_care === RUN TestMatches/not-matching_pattern_with_char_group_not_ignoring_care === RUN TestMatches/matching_pattern_with_escape === RUN TestMatches/not-matching_pattern_with_escape --- PASS: TestMatches (0.00s) --- PASS: TestMatches/equal_pattern_and_string_without_wildcards (0.00s) --- PASS: TestMatches/unequal_pattern_and_string_without_wildcards (0.00s) --- PASS: TestMatches/matching_pattern_with_one_question_mark (0.00s) --- PASS: TestMatches/matching_pattern_with_one_asterisk (0.00s) --- PASS: TestMatches/matching_pattern_with_char_group (0.00s) --- PASS: TestMatches/not-matching_pattern_with_char_group (0.00s) --- PASS: TestMatches/matching_pattern_with_char_range (0.00s) --- PASS: TestMatches/not-matching_pattern_with_char_range (0.00s) --- PASS: TestMatches/matching_pattern_with_char_group_not_ignoring_care (0.00s) --- PASS: TestMatches/not-matching_pattern_with_char_group_not_ignoring_care (0.00s) --- PASS: TestMatches/matching_pattern_with_escape (0.00s) --- PASS: TestMatches/not-matching_pattern_with_escape (0.00s) PASS ok github.com/tideland/golib/stringex 0.044s === RUN TestTimeContainments --- PASS: TestTimeContainments (0.00s) === RUN TestBeginOf --- PASS: TestBeginOf (0.00s) === RUN TestEndOf --- PASS: TestEndOf (0.00s) === RUN TestCrontabKeep 2024-03-25 19:56:59 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::50ms" starts 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::50ms" stopped --- PASS: TestCrontabKeep (1.00s) === RUN TestCrontabRemove 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::10ms" starts 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::10ms" stopped --- PASS: TestCrontabRemove (0.50s) === RUN TestCrontabError 2024-03-25 19:57:00 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::10ms" starts 2024-03-25 19:57:01 Z [ERROR] [github.com/tideland/golib/timex.(*Crontab).do] job "remove" removed after error: failed 2024-03-25 19:57:01 Z [INFO] [github.com/tideland/golib/loop] loop "crontab::10ms" stopped --- PASS: TestCrontabError (0.50s) === RUN TestRetrySuccess --- PASS: TestRetrySuccess (0.21s) === RUN TestRetryFuncError --- PASS: TestRetryFuncError (0.00s) === RUN TestRetryTooLong --- PASS: TestRetryTooLong (0.06s) === RUN TestRetryTooOften --- PASS: TestRetryTooOften (0.09s) PASS ok github.com/tideland/golib/timex 2.404s === RUN TestNew version_test.go:98 TestNew(): new test #0: "1.2.3" version_test.go:98 TestNew(): new test #1: "1.0.3" version_test.go:98 TestNew(): new test #2: "1.2.3-alpha.2014-08-03" version_test.go:98 TestNew(): new test #3: "1.2.3-alphabeta.7.11" version_test.go:98 TestNew(): new test #4: "1.2.3+007.a" version_test.go:98 TestNew(): new test #5: "1.2.3-alpha+007.a" version_test.go:98 TestNew(): new test #6: "1.2.3-ALPHA+007.a" --- PASS: TestNew (0.00s) === RUN TestParse version_test.go:212 TestParse(): parse test #0: "1" version_test.go:212 TestParse(): parse test #1: "1.1" version_test.go:212 TestParse(): parse test #2: "1.2.3" version_test.go:212 TestParse(): parse test #3: "1.0.3" version_test.go:212 TestParse(): parse test #4: "1.2.3-alpha.2016-11-14" version_test.go:212 TestParse(): parse test #5: "1.2.3-alphabeta.7.11" version_test.go:212 TestParse(): parse test #6: "1.2.3+007.a" version_test.go:212 TestParse(): parse test #7: "1.2.3-alpha+007.a" version_test.go:212 TestParse(): parse test #8: "1.2.3-ALPHA+007.a" version_test.go:212 TestParse(): parse test #9: "" version_test.go:212 TestParse(): parse test #10: "a" version_test.go:212 TestParse(): parse test #11: "1.a" version_test.go:212 TestParse(): parse test #12: "1,1" version_test.go:212 TestParse(): parse test #13: "-1" version_test.go:212 TestParse(): parse test #14: "1.-1" version_test.go:212 TestParse(): parse test #15: "+" --- PASS: TestParse (0.00s) === RUN TestCompare version_test.go:320 TestCompare(): compare test #0: "1.2.3" <> "1.2.3" -> 0 / all version_test.go:320 TestCompare(): compare test #1: "1.2.3" <> "1.2.4" -> -1 / patch version_test.go:320 TestCompare(): compare test #2: "1.2.3" <> "1.3.3" -> -1 / minor version_test.go:320 TestCompare(): compare test #3: "1.2.3" <> "2.2.3" -> -1 / major version_test.go:320 TestCompare(): compare test #4: "3.2.1" <> "1.2.3" -> 1 / major version_test.go:320 TestCompare(): compare test #5: "1.2.3-alpha" <> "1.2.3" -> -1 / pre-release version_test.go:320 TestCompare(): compare test #6: "1.2.3-alpha.1" <> "1.2.3-alpha" -> -1 / pre-release version_test.go:320 TestCompare(): compare test #7: "1.2.3-alpha.1" <> "1.2.3-alpha.2" -> -1 / pre-release version_test.go:320 TestCompare(): compare test #8: "1.2.3-alpha.4711" <> "1.2.3-alpha.471" -> 1 / pre-release version_test.go:320 TestCompare(): compare test #9: "1.2.3-alpha.48" <> "1.2.3-alpha.4711" -> -1 / pre-release version_test.go:320 TestCompare(): compare test #10: "1.2.3+alpha.1" <> "1.2.3+alpha.2" -> 0 / all version_test.go:320 TestCompare(): compare test #11: "1.2.3+alpha.2" <> "1.2.3+alpha.1" -> 0 / all version_test.go:320 TestCompare(): compare test #12: "1.2.3-alpha+alpha.2" <> "1.2.3-alpha+alpha.1" -> 0 / all version_test.go:320 TestCompare(): compare test #13: "1.2.3-alpha.48+alpha.2" <> "1.2.3-alpha.4711+alpha.1" -> -1 / pre-release version_test.go:320 TestCompare(): compare test #14: "1.2.3-alpha.2" <> "1.2.3-alpha.1b" -> 1 / pre-release --- PASS: TestCompare (0.00s) === RUN TestLess version_test.go:399 TestLess(): less test #0: "1.2.3" <> "1.2.3" -> false version_test.go:399 TestLess(): less test #1: "1.2.3" <> "1.2.4" -> true version_test.go:399 TestLess(): less test #2: "1.2.3" <> "1.3.3" -> true version_test.go:399 TestLess(): less test #3: "1.2.3" <> "2.2.3" -> true version_test.go:399 TestLess(): less test #4: "3.2.1" <> "1.2.3" -> false version_test.go:399 TestLess(): less test #5: "1.2.3-alpha" <> "1.2.3" -> true version_test.go:399 TestLess(): less test #6: "1.2.3-alpha.1" <> "1.2.3-alpha" -> true version_test.go:399 TestLess(): less test #7: "1.2.3-alpha.1" <> "1.2.3-alpha.2" -> true version_test.go:399 TestLess(): less test #8: "1.2.3-alpha.4711" <> "1.2.3-alpha.471" -> false version_test.go:399 TestLess(): less test #9: "1.2.3-alpha.48" <> "1.2.3-alpha.4711" -> true version_test.go:399 TestLess(): less test #10: "1.2.3+alpha.1" <> "1.2.3+alpha.2" -> false version_test.go:399 TestLess(): less test #11: "1.2.3+alpha.2" <> "1.2.3+alpha.1" -> false version_test.go:399 TestLess(): less test #12: "1.2.3-alpha+alpha.2" <> "1.2.3-alpha+alpha.1" -> false version_test.go:399 TestLess(): less test #13: "1.2.3-alpha.48+alpha.2" <> "1.2.3-alpha.4711+alpha.1" -> true version_test.go:399 TestLess(): less test #14: "1.2.3-alpha.2" <> "1.2.3-alpha.1b" -> false --- PASS: TestLess (0.00s) PASS ok github.com/tideland/golib/version 0.044s make[1]: Leaving directory '/build/reproducible-path/golang-github-tideland-golib-4.24.2' create-stamp debian/debhelper-build-stamp fakeroot debian/rules binary dh binary --buildsystem=golang --with=golang dh_testroot -O--buildsystem=golang dh_prep -O--buildsystem=golang dh_auto_install --destdir=debian/golang-github-tideland-golib-dev/ -O--buildsystem=golang dh_installdocs -O--buildsystem=golang dh_installchangelogs -O--buildsystem=golang dh_systemd_enable -O--buildsystem=golang dh_installinit -O--buildsystem=golang dh_systemd_start -O--buildsystem=golang dh_perl -O--buildsystem=golang dh_link -O--buildsystem=golang dh_strip_nondeterminism -O--buildsystem=golang dh_compress -O--buildsystem=golang dh_fixperms -O--buildsystem=golang dh_missing -O--buildsystem=golang dh_installdeb -O--buildsystem=golang dh_golang -O--buildsystem=golang dh_gencontrol -O--buildsystem=golang dpkg-gencontrol: warning: Depends field of package golang-github-tideland-golib-dev: substitution variable ${shlibs:Depends} used, but is not defined dh_md5sums -O--buildsystem=golang dh_builddeb -O--buildsystem=golang dpkg-deb: building package 'golang-github-tideland-golib-dev' in '../golang-github-tideland-golib-dev_4.24.2-1_all.deb'. dpkg-genbuildinfo --build=binary -O../golang-github-tideland-golib_4.24.2-1_armhf.buildinfo dpkg-genchanges --build=binary -O../golang-github-tideland-golib_4.24.2-1_armhf.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: including full source code in upload I: copying local configuration I: user script /srv/workspace/pbuilder/22285/tmp/hooks/B01_cleanup starting I: user script /srv/workspace/pbuilder/22285/tmp/hooks/B01_cleanup finished 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/22285 and its subdirectories I: Current time: Tue Mar 26 09:57:53 +14 2024 I: pbuilder-time-stamp: 1711396673