0s autopkgtest [18:23:02]: starting date and time: 2024-11-01 18:23:02+0000 0s autopkgtest [18:23:02]: git checkout: 6f3be7a8 Fix armhf LXD image generation for plucky 0s autopkgtest [18:23:02]: host juju-7f2275-prod-proposed-migration-environment-2; command line: /home/ubuntu/autopkgtest/runner/autopkgtest --output-dir /tmp/autopkgtest-work.rnz__54b/out --timeout-copy=6000 --setup-commands /home/ubuntu/autopkgtest-cloud/worker-config-production/setup-canonical.sh --apt-pocket=proposed=src:libdbd-sqlite3-perl --apt-upgrade sqitch --timeout-short=300 --timeout-copy=20000 --timeout-build=20000 --env=ADT_TEST_TRIGGERS=libdbd-sqlite3-perl/1.76-1 -- ssh -s /home/ubuntu/autopkgtest/ssh-setup/nova -- --flavor autopkgtest --security-groups autopkgtest-juju-7f2275-prod-proposed-migration-environment-2@bos03-arm64-25.secgroup --name adt-plucky-arm64-sqitch-20241101-182301-juju-7f2275-prod-proposed-migration-environment-2-27160b3b-f700-41f0-a1a3-782a721947a1 --image adt/ubuntu-plucky-arm64-server --keyname testbed-juju-7f2275-prod-proposed-migration-environment-2 --net-id=net_prod-proposed-migration -e TERM=linux -e ''"'"'http_proxy=http://squid.internal:3128'"'"'' -e ''"'"'https_proxy=http://squid.internal:3128'"'"'' -e ''"'"'no_proxy=127.0.0.1,127.0.1.1,login.ubuntu.com,localhost,localdomain,novalocal,internal,archive.ubuntu.com,ports.ubuntu.com,security.ubuntu.com,ddebs.ubuntu.com,changelogs.ubuntu.com,keyserver.ubuntu.com,launchpadlibrarian.net,launchpadcontent.net,launchpad.net,10.24.0.0/24,keystone.ps5.canonical.com,objectstorage.prodstack5.canonical.com'"'"'' --mirror=http://ftpmaster.internal/ubuntu/ 91s autopkgtest [18:24:33]: testbed dpkg architecture: arm64 91s autopkgtest [18:24:33]: testbed apt version: 2.9.8 91s autopkgtest [18:24:33]: @@@@@@@@@@@@@@@@@@@@ test bed setup 92s Get:1 http://ftpmaster.internal/ubuntu plucky-proposed InRelease [73.9 kB] 93s Get:2 http://ftpmaster.internal/ubuntu plucky-proposed/main Sources [183 kB] 93s Get:3 http://ftpmaster.internal/ubuntu plucky-proposed/multiverse Sources [44.0 kB] 93s Get:4 http://ftpmaster.internal/ubuntu plucky-proposed/universe Sources [2775 kB] 93s Get:5 http://ftpmaster.internal/ubuntu plucky-proposed/restricted Sources [7016 B] 93s Get:6 http://ftpmaster.internal/ubuntu plucky-proposed/main arm64 Packages [241 kB] 93s Get:7 http://ftpmaster.internal/ubuntu plucky-proposed/restricted arm64 Packages [50.3 kB] 93s Get:8 http://ftpmaster.internal/ubuntu plucky-proposed/universe arm64 Packages [2023 kB] 93s Get:9 http://ftpmaster.internal/ubuntu plucky-proposed/multiverse arm64 Packages [36.5 kB] 94s Fetched 5433 kB in 1s (4062 kB/s) 94s Reading package lists... 97s Reading package lists... 98s Building dependency tree... 98s Reading state information... 99s Calculating upgrade... 100s The following packages will be upgraded: 100s libevdev2 libftdi1-2 libinih1 nano python3-lazr.uri 100s 5 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 100s Need to get 374 kB of archives. 100s After this operation, 17.4 kB of additional disk space will be used. 100s Get:1 http://ftpmaster.internal/ubuntu plucky/main arm64 libevdev2 arm64 1.13.3+dfsg-1 [36.0 kB] 101s Get:2 http://ftpmaster.internal/ubuntu plucky/main arm64 nano arm64 8.2-1 [289 kB] 101s Get:3 http://ftpmaster.internal/ubuntu plucky/main arm64 libftdi1-2 arm64 1.5-7 [28.4 kB] 101s Get:4 http://ftpmaster.internal/ubuntu plucky/main arm64 libinih1 arm64 58-1ubuntu1 [7412 B] 101s Get:5 http://ftpmaster.internal/ubuntu plucky/main arm64 python3-lazr.uri all 1.0.6-4 [13.6 kB] 101s Fetched 374 kB in 0s (815 kB/s) 102s (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 ... 79705 files and directories currently installed.) 102s Preparing to unpack .../libevdev2_1.13.3+dfsg-1_arm64.deb ... 102s Unpacking libevdev2:arm64 (1.13.3+dfsg-1) over (1.13.2+dfsg-1) ... 102s Preparing to unpack .../archives/nano_8.2-1_arm64.deb ... 102s Unpacking nano (8.2-1) over (8.1-1) ... 102s Preparing to unpack .../libftdi1-2_1.5-7_arm64.deb ... 102s Unpacking libftdi1-2:arm64 (1.5-7) over (1.5-6build5) ... 102s Preparing to unpack .../libinih1_58-1ubuntu1_arm64.deb ... 102s Unpacking libinih1:arm64 (58-1ubuntu1) over (55-1ubuntu2) ... 102s Preparing to unpack .../python3-lazr.uri_1.0.6-4_all.deb ... 102s Unpacking python3-lazr.uri (1.0.6-4) over (1.0.6-3) ... 102s Setting up libinih1:arm64 (58-1ubuntu1) ... 102s Setting up python3-lazr.uri (1.0.6-4) ... 102s Setting up libftdi1-2:arm64 (1.5-7) ... 102s Setting up nano (8.2-1) ... 102s Setting up libevdev2:arm64 (1.13.3+dfsg-1) ... 102s Processing triggers for man-db (2.12.1-3) ... 104s Processing triggers for install-info (7.1.1-1) ... 104s Processing triggers for libc-bin (2.40-1ubuntu3) ... 104s Reading package lists... 104s Building dependency tree... 104s Reading state information... 105s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 106s Hit:1 http://ftpmaster.internal/ubuntu plucky-proposed InRelease 106s Hit:2 http://ftpmaster.internal/ubuntu plucky InRelease 106s Hit:3 http://ftpmaster.internal/ubuntu plucky-updates InRelease 106s Hit:4 http://ftpmaster.internal/ubuntu plucky-security InRelease 108s Reading package lists... 108s Reading package lists... 108s Building dependency tree... 108s Reading state information... 109s Calculating upgrade... 109s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 109s Reading package lists... 110s Building dependency tree... 110s Reading state information... 111s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 114s autopkgtest [18:24:56]: testbed running kernel: Linux 6.11.0-8-generic #8-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 16 14:19:41 UTC 2024 115s autopkgtest [18:24:57]: @@@@@@@@@@@@@@@@@@@@ apt-source sqitch 117s Get:1 http://ftpmaster.internal/ubuntu plucky/universe sqitch 1.4.1-1 (dsc) [3728 B] 117s Get:2 http://ftpmaster.internal/ubuntu plucky/universe sqitch 1.4.1-1 (tar) [641 kB] 117s Get:3 http://ftpmaster.internal/ubuntu plucky/universe sqitch 1.4.1-1 (diff) [6120 B] 117s gpgv: Signature made Thu Feb 8 23:51:53 2024 UTC 117s gpgv: using RSA key D1E1316E93A760A8104D85FABB3A68018649AA06 117s gpgv: Can't check signature: No public key 117s dpkg-source: warning: cannot verify inline signature for ./sqitch_1.4.1-1.dsc: no acceptable signature found 117s autopkgtest [18:24:59]: testing package sqitch version 1.4.1-1 118s autopkgtest [18:25:00]: build not needed 119s autopkgtest [18:25:01]: test autodep8-perl-build-deps: preparing testbed 121s Reading package lists... 121s Building dependency tree... 121s Reading state information... 122s Starting pkgProblemResolver with broken count: 0 122s Starting 2 pkgProblemResolver with broken count: 0 122s Done 123s The following additional packages will be installed: 123s autoconf autodep8 automake autopoint autotools-dev build-essential cpp 123s cpp-14 cpp-14-aarch64-linux-gnu cpp-aarch64-linux-gnu dctrl-tools debhelper 123s debugedit dh-autoreconf dh-strip-nondeterminism dwz g++ g++-14 123s g++-14-aarch64-linux-gnu g++-aarch64-linux-gnu gcc gcc-14 123s gcc-14-aarch64-linux-gnu gcc-aarch64-linux-gnu gettext intltool-debian 123s libalgorithm-backoff-perl libalgorithm-c3-perl libalgorithm-diff-perl 123s libappconfig-perl libarchive-zip-perl libasan8 libb-hooks-endofscope-perl 123s libb-hooks-op-check-perl libcapture-tiny-perl libcc1-0 libclass-c3-perl 123s libclass-data-inheritable-perl libclass-inspector-perl 123s libclass-method-modifiers-perl libclass-singleton-perl 123s libclass-xsaccessor-perl libclone-choose-perl libclone-perl 123s libconfig-gitlike-perl libdata-optlist-perl libdatetime-locale-perl 123s libdatetime-perl libdatetime-timezone-perl libdbd-pg-perl 123s libdbd-sqlite3-perl libdbi-perl libdebhelper-perl libdevel-callchecker-perl 123s libdevel-stacktrace-perl libdynaloader-functions-perl libencode-locale-perl 123s libeval-closure-perl libexception-class-perl libexporter-tiny-perl 123s libfile-sharedir-perl libfile-stripnondeterminism-perl libfile-which-perl 123s libgcc-14-dev libgomp1 libhash-merge-perl libhwasan0 libimport-into-perl 123s libintl-perl libio-pager-perl libipc-run3-perl libipc-system-simple-perl 123s libisl23 libitm1 liblist-moreutils-perl liblist-moreutils-xs-perl liblsan0 123s libmodule-build-perl libmodule-implementation-perl libmodule-runtime-perl 123s libmoo-perl libmoox-types-mooselike-perl libmpc3 libmro-compat-perl 123s libnamespace-autoclean-perl libnamespace-clean-perl libpackage-stash-perl 123s libparams-classify-perl libparams-util-perl 123s libparams-validationcompiler-perl libpath-class-perl 123s libperlio-utf8-strict-perl libpod-parser-perl libpq5 123s libreturn-multilevel-perl librole-tiny-perl libspecio-perl libstdc++-14-dev 123s libstring-formatter-perl libstring-shellquote-perl libsub-exporter-perl 123s libsub-exporter-progressive-perl libsub-identify-perl libsub-install-perl 123s libsub-name-perl libsub-quote-perl libsub-uplevel-perl libsuper-perl 123s libtemplate-perl libtemplate-tiny-perl libterm-readkey-perl 123s libtest-deep-perl libtest-dir-perl libtest-exception-perl libtest-exit-perl 123s libtest-file-contents-perl libtest-file-perl libtest-mockmodule-perl 123s libtest-mockobject-perl libtest-nowarnings-perl libtest-warn-perl 123s libtext-diff-perl libthrowable-perl libtool libtry-tiny-perl libtsan2 123s libtype-tiny-perl libtype-tiny-xs-perl libubsan1 libuniversal-can-perl 123s libuniversal-isa-perl liburi-db-perl liburi-nested-perl liburi-perl 123s libvariable-magic-perl libxstring-perl m4 pkg-perl-autopkgtest po-debconf 123s postgresql-client postgresql-client-16 postgresql-client-common sqitch 123s sqlite3 123s Suggested packages: 123s autoconf-archive gnu-standards autoconf-doc cpp-doc gcc-14-locales 123s cpp-14-doc debtags dh-make gcc-14-doc gcc-multilib manpages-dev flex bison 123s gdb gcc-doc gdb-aarch64-linux-gnu gettext-doc libasprintf-dev 123s libgettextpo-dev libmldbm-perl libnet-daemon-perl libsql-statement-perl 123s libmoox-types-mooselike-numeric-perl libmoox-types-setobject-perl 123s libscalar-number-perl libtest-fatal-perl libstdc++-14-doc 123s libtemplate-plugin-gd-perl libtemplate-plugin-xml-perl libtool-doc gfortran 123s | fortran95-compiler gcj-jdk libdevel-lexalias-perl libbusiness-isbn-perl 123s libregexp-ipv6-perl libwww-perl m4-doc libmail-box-perl postgresql-16 123s postgresql-doc-16 sqlite3-doc 123s Recommended packages: 123s libalgorithm-diff-xs-perl libclass-c3-xs-perl libdevel-lexalias-perl 123s libarchive-cpio-perl libintl-xs-perl libmodule-signature-perl 123s libpod-readme-perl libsoftware-license-perl libpackage-stash-xs-perl 123s libscope-upper-perl libref-util-perl libltdl-dev libmail-sendmail-perl 123s The following NEW packages will be installed: 123s autoconf autodep8 automake autopkgtest-satdep autopoint autotools-dev 123s build-essential cpp cpp-14 cpp-14-aarch64-linux-gnu cpp-aarch64-linux-gnu 123s dctrl-tools debhelper debugedit dh-autoreconf dh-strip-nondeterminism dwz 123s g++ g++-14 g++-14-aarch64-linux-gnu g++-aarch64-linux-gnu gcc gcc-14 123s gcc-14-aarch64-linux-gnu gcc-aarch64-linux-gnu gettext intltool-debian 123s libalgorithm-backoff-perl libalgorithm-c3-perl libalgorithm-diff-perl 123s libappconfig-perl libarchive-zip-perl libasan8 libb-hooks-endofscope-perl 123s libb-hooks-op-check-perl libcapture-tiny-perl libcc1-0 libclass-c3-perl 123s libclass-data-inheritable-perl libclass-inspector-perl 123s libclass-method-modifiers-perl libclass-singleton-perl 123s libclass-xsaccessor-perl libclone-choose-perl libclone-perl 123s libconfig-gitlike-perl libdata-optlist-perl libdatetime-locale-perl 123s libdatetime-perl libdatetime-timezone-perl libdbd-pg-perl 123s libdbd-sqlite3-perl libdbi-perl libdebhelper-perl libdevel-callchecker-perl 123s libdevel-stacktrace-perl libdynaloader-functions-perl libencode-locale-perl 123s libeval-closure-perl libexception-class-perl libexporter-tiny-perl 123s libfile-sharedir-perl libfile-stripnondeterminism-perl libfile-which-perl 123s libgcc-14-dev libgomp1 libhash-merge-perl libhwasan0 libimport-into-perl 123s libintl-perl libio-pager-perl libipc-run3-perl libipc-system-simple-perl 123s libisl23 libitm1 liblist-moreutils-perl liblist-moreutils-xs-perl liblsan0 123s libmodule-build-perl libmodule-implementation-perl libmodule-runtime-perl 123s libmoo-perl libmoox-types-mooselike-perl libmpc3 libmro-compat-perl 123s libnamespace-autoclean-perl libnamespace-clean-perl libpackage-stash-perl 123s libparams-classify-perl libparams-util-perl 123s libparams-validationcompiler-perl libpath-class-perl 123s libperlio-utf8-strict-perl libpod-parser-perl libpq5 123s libreturn-multilevel-perl librole-tiny-perl libspecio-perl libstdc++-14-dev 123s libstring-formatter-perl libstring-shellquote-perl libsub-exporter-perl 123s libsub-exporter-progressive-perl libsub-identify-perl libsub-install-perl 123s libsub-name-perl libsub-quote-perl libsub-uplevel-perl libsuper-perl 123s libtemplate-perl libtemplate-tiny-perl libterm-readkey-perl 123s libtest-deep-perl libtest-dir-perl libtest-exception-perl libtest-exit-perl 123s libtest-file-contents-perl libtest-file-perl libtest-mockmodule-perl 123s libtest-mockobject-perl libtest-nowarnings-perl libtest-warn-perl 123s libtext-diff-perl libthrowable-perl libtool libtry-tiny-perl libtsan2 123s libtype-tiny-perl libtype-tiny-xs-perl libubsan1 libuniversal-can-perl 123s libuniversal-isa-perl liburi-db-perl liburi-nested-perl liburi-perl 123s libvariable-magic-perl libxstring-perl m4 pkg-perl-autopkgtest po-debconf 123s postgresql-client postgresql-client-16 postgresql-client-common sqitch 123s sqlite3 123s 0 upgraded, 145 newly installed, 0 to remove and 0 not upgraded. 123s Need to get 75.1 MB/75.1 MB of archives. 123s After this operation, 278 MB of additional disk space will be used. 123s Get:1 /tmp/autopkgtest.NaAPUz/1-autopkgtest-satdep.deb autopkgtest-satdep arm64 0 [1120 B] 124s Get:2 http://ftpmaster.internal/ubuntu plucky/main arm64 m4 arm64 1.4.19-4build1 [240 kB] 124s Get:3 http://ftpmaster.internal/ubuntu plucky/main arm64 autoconf all 2.72-3 [382 kB] 124s Get:4 http://ftpmaster.internal/ubuntu plucky/main arm64 dctrl-tools arm64 2.24-3build3 [103 kB] 124s Get:5 http://ftpmaster.internal/ubuntu plucky/main arm64 autodep8 all 0.28+nmu1ubuntu1 [13.7 kB] 124s Get:6 http://ftpmaster.internal/ubuntu plucky/main arm64 autotools-dev all 20220109.1 [44.9 kB] 124s Get:7 http://ftpmaster.internal/ubuntu plucky/main arm64 automake all 1:1.16.5-1.3ubuntu1 [558 kB] 124s Get:8 http://ftpmaster.internal/ubuntu plucky/main arm64 autopoint all 0.22.5-2 [616 kB] 124s Get:9 http://ftpmaster.internal/ubuntu plucky/main arm64 libisl23 arm64 0.27-1 [676 kB] 124s Get:10 http://ftpmaster.internal/ubuntu plucky/main arm64 libmpc3 arm64 1.3.1-1build2 [56.8 kB] 124s Get:11 http://ftpmaster.internal/ubuntu plucky/main arm64 cpp-14-aarch64-linux-gnu arm64 14.2.0-7ubuntu1 [10.6 MB] 125s Get:12 http://ftpmaster.internal/ubuntu plucky/main arm64 cpp-14 arm64 14.2.0-7ubuntu1 [1030 B] 125s Get:13 http://ftpmaster.internal/ubuntu plucky/main arm64 cpp-aarch64-linux-gnu arm64 4:14.1.0-2ubuntu1 [5452 B] 125s Get:14 http://ftpmaster.internal/ubuntu plucky/main arm64 cpp arm64 4:14.1.0-2ubuntu1 [22.5 kB] 125s Get:15 http://ftpmaster.internal/ubuntu plucky/main arm64 libcc1-0 arm64 14.2.0-7ubuntu1 [49.7 kB] 125s Get:16 http://ftpmaster.internal/ubuntu plucky/main arm64 libgomp1 arm64 14.2.0-7ubuntu1 [145 kB] 125s Get:17 http://ftpmaster.internal/ubuntu plucky/main arm64 libitm1 arm64 14.2.0-7ubuntu1 [27.8 kB] 125s Get:18 http://ftpmaster.internal/ubuntu plucky/main arm64 libasan8 arm64 14.2.0-7ubuntu1 [2893 kB] 125s Get:19 http://ftpmaster.internal/ubuntu plucky/main arm64 liblsan0 arm64 14.2.0-7ubuntu1 [1283 kB] 125s Get:20 http://ftpmaster.internal/ubuntu plucky/main arm64 libtsan2 arm64 14.2.0-7ubuntu1 [2691 kB] 125s Get:21 http://ftpmaster.internal/ubuntu plucky/main arm64 libubsan1 arm64 14.2.0-7ubuntu1 [1151 kB] 125s Get:22 http://ftpmaster.internal/ubuntu plucky/main arm64 libhwasan0 arm64 14.2.0-7ubuntu1 [1599 kB] 125s Get:23 http://ftpmaster.internal/ubuntu plucky/main arm64 libgcc-14-dev arm64 14.2.0-7ubuntu1 [2594 kB] 125s Get:24 http://ftpmaster.internal/ubuntu plucky/main arm64 gcc-14-aarch64-linux-gnu arm64 14.2.0-7ubuntu1 [20.9 MB] 125s Get:25 http://ftpmaster.internal/ubuntu plucky/main arm64 gcc-14 arm64 14.2.0-7ubuntu1 [515 kB] 125s Get:26 http://ftpmaster.internal/ubuntu plucky/main arm64 gcc-aarch64-linux-gnu arm64 4:14.1.0-2ubuntu1 [1200 B] 125s Get:27 http://ftpmaster.internal/ubuntu plucky/main arm64 gcc arm64 4:14.1.0-2ubuntu1 [4994 B] 125s Get:28 http://ftpmaster.internal/ubuntu plucky/main arm64 libstdc++-14-dev arm64 14.2.0-7ubuntu1 [2474 kB] 126s Get:29 http://ftpmaster.internal/ubuntu plucky/main arm64 g++-14-aarch64-linux-gnu arm64 14.2.0-7ubuntu1 [12.1 MB] 126s Get:30 http://ftpmaster.internal/ubuntu plucky/main arm64 g++-14 arm64 14.2.0-7ubuntu1 [19.8 kB] 126s Get:31 http://ftpmaster.internal/ubuntu plucky/main arm64 g++-aarch64-linux-gnu arm64 4:14.1.0-2ubuntu1 [958 B] 126s Get:32 http://ftpmaster.internal/ubuntu plucky/main arm64 g++ arm64 4:14.1.0-2ubuntu1 [1080 B] 126s Get:33 http://ftpmaster.internal/ubuntu plucky/main arm64 build-essential arm64 12.10ubuntu1 [4932 B] 126s Get:34 http://ftpmaster.internal/ubuntu plucky/main arm64 libdebhelper-perl all 13.20ubuntu1 [94.2 kB] 126s Get:35 http://ftpmaster.internal/ubuntu plucky/main arm64 libtool all 2.4.7-7build1 [166 kB] 126s Get:36 http://ftpmaster.internal/ubuntu plucky/main arm64 dh-autoreconf all 20 [16.1 kB] 126s Get:37 http://ftpmaster.internal/ubuntu plucky/main arm64 libarchive-zip-perl all 1.68-1 [90.2 kB] 126s Get:38 http://ftpmaster.internal/ubuntu plucky/main arm64 libfile-stripnondeterminism-perl all 1.14.0-1 [20.1 kB] 126s Get:39 http://ftpmaster.internal/ubuntu plucky/main arm64 dh-strip-nondeterminism all 1.14.0-1 [5058 B] 126s Get:40 http://ftpmaster.internal/ubuntu plucky/main arm64 debugedit arm64 1:5.1-1 [45.9 kB] 126s Get:41 http://ftpmaster.internal/ubuntu plucky/main arm64 dwz arm64 0.15-1build6 [113 kB] 126s Get:42 http://ftpmaster.internal/ubuntu plucky/main arm64 gettext arm64 0.22.5-2 [930 kB] 126s Get:43 http://ftpmaster.internal/ubuntu plucky/main arm64 intltool-debian all 0.35.0+20060710.6 [23.2 kB] 126s Get:44 http://ftpmaster.internal/ubuntu plucky/main arm64 po-debconf all 1.0.21+nmu1 [233 kB] 126s Get:45 http://ftpmaster.internal/ubuntu plucky/main arm64 debhelper all 13.20ubuntu1 [893 kB] 126s Get:46 http://ftpmaster.internal/ubuntu plucky/universe arm64 libalgorithm-backoff-perl all 0.010-1 [37.3 kB] 126s Get:47 http://ftpmaster.internal/ubuntu plucky/universe arm64 libalgorithm-c3-perl all 0.11-2 [10.2 kB] 126s Get:48 http://ftpmaster.internal/ubuntu plucky/main arm64 libalgorithm-diff-perl all 1.201-1 [41.8 kB] 126s Get:49 http://ftpmaster.internal/ubuntu plucky/main arm64 libappconfig-perl all 1.71-2.3 [64.8 kB] 126s Get:50 http://ftpmaster.internal/ubuntu plucky/main arm64 libb-hooks-op-check-perl arm64 0.22-3build2 [9348 B] 126s Get:51 http://ftpmaster.internal/ubuntu plucky/main arm64 libdynaloader-functions-perl all 0.004-1 [11.4 kB] 126s Get:52 http://ftpmaster.internal/ubuntu plucky/main arm64 libdevel-callchecker-perl arm64 0.009-1build1 [14.0 kB] 126s Get:53 http://ftpmaster.internal/ubuntu plucky/main arm64 libparams-classify-perl arm64 0.015-2build6 [19.8 kB] 126s Get:54 http://ftpmaster.internal/ubuntu plucky/main arm64 libmodule-runtime-perl all 0.016-2 [16.4 kB] 126s Get:55 http://ftpmaster.internal/ubuntu plucky/main arm64 libtry-tiny-perl all 0.31-2 [20.8 kB] 126s Get:56 http://ftpmaster.internal/ubuntu plucky/main arm64 libmodule-implementation-perl all 0.09-2 [12.0 kB] 126s Get:57 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-exporter-progressive-perl all 0.001013-3 [6718 B] 126s Get:58 http://ftpmaster.internal/ubuntu plucky/main arm64 libvariable-magic-perl arm64 0.64-1build1 [35.3 kB] 126s Get:59 http://ftpmaster.internal/ubuntu plucky/main arm64 libb-hooks-endofscope-perl all 0.28-1 [15.8 kB] 126s Get:60 http://ftpmaster.internal/ubuntu plucky/main arm64 libcapture-tiny-perl all 0.48-2 [20.2 kB] 126s Get:61 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclass-c3-perl all 0.35-2 [18.4 kB] 126s Get:62 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-data-inheritable-perl all 0.08-3 [8084 B] 126s Get:63 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-inspector-perl all 1.36-3 [15.4 kB] 126s Get:64 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-method-modifiers-perl all 2.15-1 [16.1 kB] 126s Get:65 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclass-singleton-perl all 1.6-2 [11.5 kB] 126s Get:66 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-xsaccessor-perl arm64 1.19-4build5 [32.7 kB] 126s Get:67 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclone-choose-perl all 0.010-2 [7738 B] 126s Get:68 http://ftpmaster.internal/ubuntu plucky/main arm64 libclone-perl arm64 0.47-1 [10.4 kB] 126s Get:69 http://ftpmaster.internal/ubuntu plucky/main arm64 libimport-into-perl all 1.002005-2 [10.7 kB] 126s Get:70 http://ftpmaster.internal/ubuntu plucky/main arm64 librole-tiny-perl all 2.002004-1 [16.3 kB] 126s Get:71 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-quote-perl all 2.006008-1ubuntu1 [20.7 kB] 126s Get:72 http://ftpmaster.internal/ubuntu plucky/main arm64 libmoo-perl all 2.005005-1 [47.4 kB] 126s Get:73 http://ftpmaster.internal/ubuntu plucky/universe arm64 libmoox-types-mooselike-perl all 0.29-2 [16.7 kB] 126s Get:74 http://ftpmaster.internal/ubuntu plucky/universe arm64 libconfig-gitlike-perl all 1.18-2 [33.8 kB] 126s Get:75 http://ftpmaster.internal/ubuntu plucky/main arm64 libparams-util-perl arm64 1.102-3build1 [20.6 kB] 126s Get:76 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-install-perl all 0.929-1 [9764 B] 126s Get:77 http://ftpmaster.internal/ubuntu plucky/main arm64 libdata-optlist-perl all 0.114-1 [9708 B] 126s Get:78 http://ftpmaster.internal/ubuntu plucky/main arm64 libdbi-perl arm64 1.645-1 [826 kB] 126s Get:79 http://ftpmaster.internal/ubuntu plucky/main arm64 libpq5 arm64 17.0-1 [248 kB] 126s Get:80 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdbd-pg-perl arm64 3.18.0-1build4 [190 kB] 126s Get:81 http://ftpmaster.internal/ubuntu plucky-proposed/universe arm64 libdbd-sqlite3-perl arm64 1.76-1 [160 kB] 126s Get:82 http://ftpmaster.internal/ubuntu plucky/main arm64 libdevel-stacktrace-perl all 2.0500-1 [22.1 kB] 126s Get:83 http://ftpmaster.internal/ubuntu plucky/main arm64 libencode-locale-perl all 1.05-3 [11.6 kB] 126s Get:84 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-exporter-perl all 0.990-1 [49.0 kB] 126s Get:85 http://ftpmaster.internal/ubuntu plucky/universe arm64 libeval-closure-perl all 0.14-3 [10.1 kB] 126s Get:86 http://ftpmaster.internal/ubuntu plucky/main arm64 libexception-class-perl all 1.45-1 [28.6 kB] 126s Get:87 http://ftpmaster.internal/ubuntu plucky/main arm64 libexporter-tiny-perl all 1.006002-1 [36.8 kB] 126s Get:88 http://ftpmaster.internal/ubuntu plucky/main arm64 libfile-sharedir-perl all 1.118-3 [14.0 kB] 126s Get:89 http://ftpmaster.internal/ubuntu plucky/main arm64 libfile-which-perl all 1.27-2 [12.5 kB] 126s Get:90 http://ftpmaster.internal/ubuntu plucky/universe arm64 libhash-merge-perl all 0.302-1 [13.0 kB] 126s Get:91 http://ftpmaster.internal/ubuntu plucky/main arm64 libintl-perl all 1.33-1build4 [703 kB] 126s Get:92 http://ftpmaster.internal/ubuntu plucky/main arm64 libterm-readkey-perl arm64 2.38-2build5 [23.2 kB] 126s Get:93 http://ftpmaster.internal/ubuntu plucky/universe arm64 libio-pager-perl all 2.10-1 [50.5 kB] 126s Get:94 http://ftpmaster.internal/ubuntu plucky/main arm64 libipc-system-simple-perl all 1.30-2 [22.3 kB] 127s Get:95 http://ftpmaster.internal/ubuntu plucky/universe arm64 liblist-moreutils-xs-perl arm64 0.430-4build1 [39.9 kB] 127s Get:96 http://ftpmaster.internal/ubuntu plucky/universe arm64 liblist-moreutils-perl all 0.430-2 [38.2 kB] 127s Get:97 http://ftpmaster.internal/ubuntu plucky/universe arm64 libmodule-build-perl all 0.423400-2 [200 kB] 127s Get:98 http://ftpmaster.internal/ubuntu plucky/universe arm64 libmro-compat-perl all 0.15-2 [10.1 kB] 127s Get:99 http://ftpmaster.internal/ubuntu plucky/main arm64 libpackage-stash-perl all 0.40-1 [19.5 kB] 127s Get:100 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-identify-perl arm64 0.14-3build4 [9762 B] 127s Get:101 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-name-perl arm64 0.27-1build4 [10.6 kB] 127s Get:102 http://ftpmaster.internal/ubuntu plucky/main arm64 libnamespace-clean-perl all 0.27-2 [14.0 kB] 127s Get:103 http://ftpmaster.internal/ubuntu plucky/universe arm64 libnamespace-autoclean-perl all 0.29-2 [11.7 kB] 127s Get:104 http://ftpmaster.internal/ubuntu plucky/universe arm64 libparams-validationcompiler-perl all 0.31-1 [28.3 kB] 127s Get:105 http://ftpmaster.internal/ubuntu plucky/universe arm64 libpath-class-perl all 0.37-4 [36.8 kB] 127s Get:106 http://ftpmaster.internal/ubuntu plucky/main arm64 libperlio-utf8-strict-perl arm64 0.010-1build4 [11.1 kB] 127s Get:107 http://ftpmaster.internal/ubuntu plucky/main arm64 libpod-parser-perl all 1.67-1 [80.6 kB] 127s Get:108 http://ftpmaster.internal/ubuntu plucky/universe arm64 libreturn-multilevel-perl all 0.08-1 [7784 B] 127s Get:109 http://ftpmaster.internal/ubuntu plucky/universe arm64 libxstring-perl arm64 0.005-2build4 [7866 B] 127s Get:110 http://ftpmaster.internal/ubuntu plucky/universe arm64 libspecio-perl all 0.48-1 [137 kB] 127s Get:111 http://ftpmaster.internal/ubuntu plucky/universe arm64 libstring-formatter-perl all 1.235-1 [21.3 kB] 127s Get:112 http://ftpmaster.internal/ubuntu plucky/main arm64 libstring-shellquote-perl all 1.04-3 [11.3 kB] 127s Get:113 http://ftpmaster.internal/ubuntu plucky/universe arm64 libsub-uplevel-perl all 0.2800-3 [11.6 kB] 127s Get:114 http://ftpmaster.internal/ubuntu plucky/universe arm64 libsuper-perl all 1.20190531-1 [10.4 kB] 127s Get:115 http://ftpmaster.internal/ubuntu plucky/main arm64 libtemplate-perl arm64 2.27-1build11 [497 kB] 127s Get:116 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtemplate-tiny-perl all 1.14-2 [11.0 kB] 127s Get:117 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-deep-perl all 1.204-1 [47.1 kB] 127s Get:118 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-dir-perl all 1.16-3 [10.4 kB] 127s Get:119 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-exception-perl all 0.43-3 [13.4 kB] 127s Get:120 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-exit-perl all 0.11-2 [6444 B] 127s Get:121 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtext-diff-perl all 1.45-2 [25.6 kB] 127s Get:122 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-file-contents-perl all 0.242-1 [9360 B] 127s Get:123 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-file-perl all 1.993-1 [20.7 kB] 127s Get:124 http://ftpmaster.internal/ubuntu plucky/universe arm64 libuniversal-can-perl all 1.20140328-3 [10.7 kB] 127s Get:125 http://ftpmaster.internal/ubuntu plucky/universe arm64 libuniversal-isa-perl all 1.20171012-3 [7866 B] 127s Get:126 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-mockobject-perl all 1.20200122-4 [23.4 kB] 127s Get:127 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-nowarnings-perl all 1.06-2 [10.1 kB] 127s Get:128 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-warn-perl all 0.37-2 [12.6 kB] 127s Get:129 http://ftpmaster.internal/ubuntu plucky/universe arm64 libthrowable-perl all 1.001-2 [14.2 kB] 127s Get:130 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtype-tiny-perl all 2.004000-1 [354 kB] 127s Get:131 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtype-tiny-xs-perl arm64 0.025-2build1 [25.2 kB] 127s Get:132 http://ftpmaster.internal/ubuntu plucky/main arm64 liburi-perl all 5.28-1 [88.1 kB] 127s Get:133 http://ftpmaster.internal/ubuntu plucky/universe arm64 liburi-nested-perl all 0.10-4 [7926 B] 127s Get:134 http://ftpmaster.internal/ubuntu plucky/universe arm64 liburi-db-perl all 0.22-1 [20.2 kB] 127s Get:135 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client-common all 262 [36.7 kB] 127s Get:136 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client-16 arm64 16.4-3 [1269 kB] 127s Get:137 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client all 16+262 [11.8 kB] 127s Get:138 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-locale-perl all 1:1.41-1 [3193 kB] 127s Get:139 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-timezone-perl all 1:2.62-1+2024a [262 kB] 127s Get:140 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-perl arm64 2:1.65-1build3 [95.9 kB] 127s Get:141 http://ftpmaster.internal/ubuntu plucky/main arm64 libipc-run3-perl all 0.049-1 [28.8 kB] 127s Get:142 http://ftpmaster.internal/ubuntu plucky/main arm64 sqlite3 arm64 3.46.1-1 [147 kB] 127s Get:143 http://ftpmaster.internal/ubuntu plucky/universe arm64 sqitch all 1.4.1-1 [609 kB] 127s Get:144 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtest-mockmodule-perl all 0.178.0-1 [12.9 kB] 127s Get:145 http://ftpmaster.internal/ubuntu plucky/universe arm64 pkg-perl-autopkgtest all 0.79 [18.5 kB] 128s Fetched 75.1 MB in 4s (18.5 MB/s) 128s Selecting previously unselected package m4. 128s (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 ... 79705 files and directories currently installed.) 128s Preparing to unpack .../000-m4_1.4.19-4build1_arm64.deb ... 128s Unpacking m4 (1.4.19-4build1) ... 128s Selecting previously unselected package autoconf. 128s Preparing to unpack .../001-autoconf_2.72-3_all.deb ... 128s Unpacking autoconf (2.72-3) ... 128s Selecting previously unselected package dctrl-tools. 128s Preparing to unpack .../002-dctrl-tools_2.24-3build3_arm64.deb ... 129s Unpacking dctrl-tools (2.24-3build3) ... 129s Selecting previously unselected package autodep8. 129s Preparing to unpack .../003-autodep8_0.28+nmu1ubuntu1_all.deb ... 129s Unpacking autodep8 (0.28+nmu1ubuntu1) ... 129s Selecting previously unselected package autotools-dev. 129s Preparing to unpack .../004-autotools-dev_20220109.1_all.deb ... 129s Unpacking autotools-dev (20220109.1) ... 129s Selecting previously unselected package automake. 129s Preparing to unpack .../005-automake_1%3a1.16.5-1.3ubuntu1_all.deb ... 129s Unpacking automake (1:1.16.5-1.3ubuntu1) ... 129s Selecting previously unselected package autopoint. 129s Preparing to unpack .../006-autopoint_0.22.5-2_all.deb ... 129s Unpacking autopoint (0.22.5-2) ... 129s Selecting previously unselected package libisl23:arm64. 129s Preparing to unpack .../007-libisl23_0.27-1_arm64.deb ... 129s Unpacking libisl23:arm64 (0.27-1) ... 129s Selecting previously unselected package libmpc3:arm64. 129s Preparing to unpack .../008-libmpc3_1.3.1-1build2_arm64.deb ... 129s Unpacking libmpc3:arm64 (1.3.1-1build2) ... 129s Selecting previously unselected package cpp-14-aarch64-linux-gnu. 129s Preparing to unpack .../009-cpp-14-aarch64-linux-gnu_14.2.0-7ubuntu1_arm64.deb ... 129s Unpacking cpp-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 129s Selecting previously unselected package cpp-14. 129s Preparing to unpack .../010-cpp-14_14.2.0-7ubuntu1_arm64.deb ... 129s Unpacking cpp-14 (14.2.0-7ubuntu1) ... 129s Selecting previously unselected package cpp-aarch64-linux-gnu. 129s Preparing to unpack .../011-cpp-aarch64-linux-gnu_4%3a14.1.0-2ubuntu1_arm64.deb ... 129s Unpacking cpp-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 129s Selecting previously unselected package cpp. 129s Preparing to unpack .../012-cpp_4%3a14.1.0-2ubuntu1_arm64.deb ... 129s Unpacking cpp (4:14.1.0-2ubuntu1) ... 129s Selecting previously unselected package libcc1-0:arm64. 129s Preparing to unpack .../013-libcc1-0_14.2.0-7ubuntu1_arm64.deb ... 129s Unpacking libcc1-0:arm64 (14.2.0-7ubuntu1) ... 129s Selecting previously unselected package libgomp1:arm64. 130s Preparing to unpack .../014-libgomp1_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libgomp1:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libitm1:arm64. 130s Preparing to unpack .../015-libitm1_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libitm1:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libasan8:arm64. 130s Preparing to unpack .../016-libasan8_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libasan8:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package liblsan0:arm64. 130s Preparing to unpack .../017-liblsan0_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking liblsan0:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libtsan2:arm64. 130s Preparing to unpack .../018-libtsan2_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libtsan2:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libubsan1:arm64. 130s Preparing to unpack .../019-libubsan1_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libubsan1:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libhwasan0:arm64. 130s Preparing to unpack .../020-libhwasan0_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libhwasan0:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package libgcc-14-dev:arm64. 130s Preparing to unpack .../021-libgcc-14-dev_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking libgcc-14-dev:arm64 (14.2.0-7ubuntu1) ... 130s Selecting previously unselected package gcc-14-aarch64-linux-gnu. 130s Preparing to unpack .../022-gcc-14-aarch64-linux-gnu_14.2.0-7ubuntu1_arm64.deb ... 130s Unpacking gcc-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 131s Selecting previously unselected package gcc-14. 131s Preparing to unpack .../023-gcc-14_14.2.0-7ubuntu1_arm64.deb ... 131s Unpacking gcc-14 (14.2.0-7ubuntu1) ... 131s Selecting previously unselected package gcc-aarch64-linux-gnu. 131s Preparing to unpack .../024-gcc-aarch64-linux-gnu_4%3a14.1.0-2ubuntu1_arm64.deb ... 131s Unpacking gcc-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 131s Selecting previously unselected package gcc. 131s Preparing to unpack .../025-gcc_4%3a14.1.0-2ubuntu1_arm64.deb ... 131s Unpacking gcc (4:14.1.0-2ubuntu1) ... 131s Selecting previously unselected package libstdc++-14-dev:arm64. 131s Preparing to unpack .../026-libstdc++-14-dev_14.2.0-7ubuntu1_arm64.deb ... 131s Unpacking libstdc++-14-dev:arm64 (14.2.0-7ubuntu1) ... 131s Selecting previously unselected package g++-14-aarch64-linux-gnu. 131s Preparing to unpack .../027-g++-14-aarch64-linux-gnu_14.2.0-7ubuntu1_arm64.deb ... 131s Unpacking g++-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 131s Selecting previously unselected package g++-14. 132s Preparing to unpack .../028-g++-14_14.2.0-7ubuntu1_arm64.deb ... 132s Unpacking g++-14 (14.2.0-7ubuntu1) ... 132s Selecting previously unselected package g++-aarch64-linux-gnu. 132s Preparing to unpack .../029-g++-aarch64-linux-gnu_4%3a14.1.0-2ubuntu1_arm64.deb ... 132s Unpacking g++-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 132s Selecting previously unselected package g++. 132s Preparing to unpack .../030-g++_4%3a14.1.0-2ubuntu1_arm64.deb ... 132s Unpacking g++ (4:14.1.0-2ubuntu1) ... 132s Selecting previously unselected package build-essential. 132s Preparing to unpack .../031-build-essential_12.10ubuntu1_arm64.deb ... 132s Unpacking build-essential (12.10ubuntu1) ... 132s Selecting previously unselected package libdebhelper-perl. 132s Preparing to unpack .../032-libdebhelper-perl_13.20ubuntu1_all.deb ... 132s Unpacking libdebhelper-perl (13.20ubuntu1) ... 132s Selecting previously unselected package libtool. 132s Preparing to unpack .../033-libtool_2.4.7-7build1_all.deb ... 132s Unpacking libtool (2.4.7-7build1) ... 132s Selecting previously unselected package dh-autoreconf. 132s Preparing to unpack .../034-dh-autoreconf_20_all.deb ... 132s Unpacking dh-autoreconf (20) ... 132s Selecting previously unselected package libarchive-zip-perl. 132s Preparing to unpack .../035-libarchive-zip-perl_1.68-1_all.deb ... 132s Unpacking libarchive-zip-perl (1.68-1) ... 132s Selecting previously unselected package libfile-stripnondeterminism-perl. 132s Preparing to unpack .../036-libfile-stripnondeterminism-perl_1.14.0-1_all.deb ... 132s Unpacking libfile-stripnondeterminism-perl (1.14.0-1) ... 132s Selecting previously unselected package dh-strip-nondeterminism. 132s Preparing to unpack .../037-dh-strip-nondeterminism_1.14.0-1_all.deb ... 132s Unpacking dh-strip-nondeterminism (1.14.0-1) ... 132s Selecting previously unselected package debugedit. 132s Preparing to unpack .../038-debugedit_1%3a5.1-1_arm64.deb ... 132s Unpacking debugedit (1:5.1-1) ... 132s Selecting previously unselected package dwz. 132s Preparing to unpack .../039-dwz_0.15-1build6_arm64.deb ... 132s Unpacking dwz (0.15-1build6) ... 132s Selecting previously unselected package gettext. 132s Preparing to unpack .../040-gettext_0.22.5-2_arm64.deb ... 132s Unpacking gettext (0.22.5-2) ... 132s Selecting previously unselected package intltool-debian. 132s Preparing to unpack .../041-intltool-debian_0.35.0+20060710.6_all.deb ... 132s Unpacking intltool-debian (0.35.0+20060710.6) ... 132s Selecting previously unselected package po-debconf. 132s Preparing to unpack .../042-po-debconf_1.0.21+nmu1_all.deb ... 132s Unpacking po-debconf (1.0.21+nmu1) ... 133s Selecting previously unselected package debhelper. 133s Preparing to unpack .../043-debhelper_13.20ubuntu1_all.deb ... 133s Unpacking debhelper (13.20ubuntu1) ... 133s Selecting previously unselected package libalgorithm-backoff-perl. 133s Preparing to unpack .../044-libalgorithm-backoff-perl_0.010-1_all.deb ... 133s Unpacking libalgorithm-backoff-perl (0.010-1) ... 133s Selecting previously unselected package libalgorithm-c3-perl. 133s Preparing to unpack .../045-libalgorithm-c3-perl_0.11-2_all.deb ... 133s Unpacking libalgorithm-c3-perl (0.11-2) ... 133s Selecting previously unselected package libalgorithm-diff-perl. 133s Preparing to unpack .../046-libalgorithm-diff-perl_1.201-1_all.deb ... 133s Unpacking libalgorithm-diff-perl (1.201-1) ... 133s Selecting previously unselected package libappconfig-perl. 133s Preparing to unpack .../047-libappconfig-perl_1.71-2.3_all.deb ... 133s Unpacking libappconfig-perl (1.71-2.3) ... 133s Selecting previously unselected package libb-hooks-op-check-perl:arm64. 133s Preparing to unpack .../048-libb-hooks-op-check-perl_0.22-3build2_arm64.deb ... 133s Unpacking libb-hooks-op-check-perl:arm64 (0.22-3build2) ... 133s Selecting previously unselected package libdynaloader-functions-perl. 133s Preparing to unpack .../049-libdynaloader-functions-perl_0.004-1_all.deb ... 133s Unpacking libdynaloader-functions-perl (0.004-1) ... 133s Selecting previously unselected package libdevel-callchecker-perl:arm64. 133s Preparing to unpack .../050-libdevel-callchecker-perl_0.009-1build1_arm64.deb ... 133s Unpacking libdevel-callchecker-perl:arm64 (0.009-1build1) ... 133s Selecting previously unselected package libparams-classify-perl:arm64. 133s Preparing to unpack .../051-libparams-classify-perl_0.015-2build6_arm64.deb ... 133s Unpacking libparams-classify-perl:arm64 (0.015-2build6) ... 133s Selecting previously unselected package libmodule-runtime-perl. 133s Preparing to unpack .../052-libmodule-runtime-perl_0.016-2_all.deb ... 133s Unpacking libmodule-runtime-perl (0.016-2) ... 133s Selecting previously unselected package libtry-tiny-perl. 133s Preparing to unpack .../053-libtry-tiny-perl_0.31-2_all.deb ... 133s Unpacking libtry-tiny-perl (0.31-2) ... 133s Selecting previously unselected package libmodule-implementation-perl. 133s Preparing to unpack .../054-libmodule-implementation-perl_0.09-2_all.deb ... 133s Unpacking libmodule-implementation-perl (0.09-2) ... 133s Selecting previously unselected package libsub-exporter-progressive-perl. 133s Preparing to unpack .../055-libsub-exporter-progressive-perl_0.001013-3_all.deb ... 133s Unpacking libsub-exporter-progressive-perl (0.001013-3) ... 133s Selecting previously unselected package libvariable-magic-perl. 133s Preparing to unpack .../056-libvariable-magic-perl_0.64-1build1_arm64.deb ... 133s Unpacking libvariable-magic-perl (0.64-1build1) ... 133s Selecting previously unselected package libb-hooks-endofscope-perl. 133s Preparing to unpack .../057-libb-hooks-endofscope-perl_0.28-1_all.deb ... 133s Unpacking libb-hooks-endofscope-perl (0.28-1) ... 133s Selecting previously unselected package libcapture-tiny-perl. 134s Preparing to unpack .../058-libcapture-tiny-perl_0.48-2_all.deb ... 134s Unpacking libcapture-tiny-perl (0.48-2) ... 134s Selecting previously unselected package libclass-c3-perl. 134s Preparing to unpack .../059-libclass-c3-perl_0.35-2_all.deb ... 134s Unpacking libclass-c3-perl (0.35-2) ... 134s Selecting previously unselected package libclass-data-inheritable-perl. 134s Preparing to unpack .../060-libclass-data-inheritable-perl_0.08-3_all.deb ... 134s Unpacking libclass-data-inheritable-perl (0.08-3) ... 134s Selecting previously unselected package libclass-inspector-perl. 134s Preparing to unpack .../061-libclass-inspector-perl_1.36-3_all.deb ... 134s Unpacking libclass-inspector-perl (1.36-3) ... 134s Selecting previously unselected package libclass-method-modifiers-perl. 134s Preparing to unpack .../062-libclass-method-modifiers-perl_2.15-1_all.deb ... 134s Unpacking libclass-method-modifiers-perl (2.15-1) ... 134s Selecting previously unselected package libclass-singleton-perl. 134s Preparing to unpack .../063-libclass-singleton-perl_1.6-2_all.deb ... 134s Unpacking libclass-singleton-perl (1.6-2) ... 134s Selecting previously unselected package libclass-xsaccessor-perl. 134s Preparing to unpack .../064-libclass-xsaccessor-perl_1.19-4build5_arm64.deb ... 134s Unpacking libclass-xsaccessor-perl (1.19-4build5) ... 134s Selecting previously unselected package libclone-choose-perl. 134s Preparing to unpack .../065-libclone-choose-perl_0.010-2_all.deb ... 134s Unpacking libclone-choose-perl (0.010-2) ... 134s Selecting previously unselected package libclone-perl:arm64. 134s Preparing to unpack .../066-libclone-perl_0.47-1_arm64.deb ... 134s Unpacking libclone-perl:arm64 (0.47-1) ... 134s Selecting previously unselected package libimport-into-perl. 134s Preparing to unpack .../067-libimport-into-perl_1.002005-2_all.deb ... 134s Unpacking libimport-into-perl (1.002005-2) ... 134s Selecting previously unselected package librole-tiny-perl. 134s Preparing to unpack .../068-librole-tiny-perl_2.002004-1_all.deb ... 134s Unpacking librole-tiny-perl (2.002004-1) ... 134s Selecting previously unselected package libsub-quote-perl. 134s Preparing to unpack .../069-libsub-quote-perl_2.006008-1ubuntu1_all.deb ... 134s Unpacking libsub-quote-perl (2.006008-1ubuntu1) ... 134s Selecting previously unselected package libmoo-perl. 134s Preparing to unpack .../070-libmoo-perl_2.005005-1_all.deb ... 134s Unpacking libmoo-perl (2.005005-1) ... 134s Selecting previously unselected package libmoox-types-mooselike-perl. 134s Preparing to unpack .../071-libmoox-types-mooselike-perl_0.29-2_all.deb ... 134s Unpacking libmoox-types-mooselike-perl (0.29-2) ... 135s Selecting previously unselected package libconfig-gitlike-perl. 135s Preparing to unpack .../072-libconfig-gitlike-perl_1.18-2_all.deb ... 135s Unpacking libconfig-gitlike-perl (1.18-2) ... 135s Selecting previously unselected package libparams-util-perl. 135s Preparing to unpack .../073-libparams-util-perl_1.102-3build1_arm64.deb ... 135s Unpacking libparams-util-perl (1.102-3build1) ... 135s Selecting previously unselected package libsub-install-perl. 135s Preparing to unpack .../074-libsub-install-perl_0.929-1_all.deb ... 135s Unpacking libsub-install-perl (0.929-1) ... 135s Selecting previously unselected package libdata-optlist-perl. 135s Preparing to unpack .../075-libdata-optlist-perl_0.114-1_all.deb ... 135s Unpacking libdata-optlist-perl (0.114-1) ... 135s Selecting previously unselected package libdbi-perl:arm64. 135s Preparing to unpack .../076-libdbi-perl_1.645-1_arm64.deb ... 135s Unpacking libdbi-perl:arm64 (1.645-1) ... 135s Selecting previously unselected package libpq5:arm64. 135s Preparing to unpack .../077-libpq5_17.0-1_arm64.deb ... 135s Unpacking libpq5:arm64 (17.0-1) ... 135s Selecting previously unselected package libdbd-pg-perl. 135s Preparing to unpack .../078-libdbd-pg-perl_3.18.0-1build4_arm64.deb ... 135s Unpacking libdbd-pg-perl (3.18.0-1build4) ... 135s Selecting previously unselected package libdbd-sqlite3-perl:arm64. 135s Preparing to unpack .../079-libdbd-sqlite3-perl_1.76-1_arm64.deb ... 135s Unpacking libdbd-sqlite3-perl:arm64 (1.76-1) ... 135s Selecting previously unselected package libdevel-stacktrace-perl. 135s Preparing to unpack .../080-libdevel-stacktrace-perl_2.0500-1_all.deb ... 135s Unpacking libdevel-stacktrace-perl (2.0500-1) ... 135s Selecting previously unselected package libencode-locale-perl. 135s Preparing to unpack .../081-libencode-locale-perl_1.05-3_all.deb ... 135s Unpacking libencode-locale-perl (1.05-3) ... 135s Selecting previously unselected package libsub-exporter-perl. 135s Preparing to unpack .../082-libsub-exporter-perl_0.990-1_all.deb ... 135s Unpacking libsub-exporter-perl (0.990-1) ... 135s Selecting previously unselected package libeval-closure-perl. 135s Preparing to unpack .../083-libeval-closure-perl_0.14-3_all.deb ... 135s Unpacking libeval-closure-perl (0.14-3) ... 135s Selecting previously unselected package libexception-class-perl. 135s Preparing to unpack .../084-libexception-class-perl_1.45-1_all.deb ... 135s Unpacking libexception-class-perl (1.45-1) ... 135s Selecting previously unselected package libexporter-tiny-perl. 135s Preparing to unpack .../085-libexporter-tiny-perl_1.006002-1_all.deb ... 135s Unpacking libexporter-tiny-perl (1.006002-1) ... 135s Selecting previously unselected package libfile-sharedir-perl. 136s Preparing to unpack .../086-libfile-sharedir-perl_1.118-3_all.deb ... 136s Unpacking libfile-sharedir-perl (1.118-3) ... 136s Selecting previously unselected package libfile-which-perl. 136s Preparing to unpack .../087-libfile-which-perl_1.27-2_all.deb ... 136s Unpacking libfile-which-perl (1.27-2) ... 136s Selecting previously unselected package libhash-merge-perl. 136s Preparing to unpack .../088-libhash-merge-perl_0.302-1_all.deb ... 136s Unpacking libhash-merge-perl (0.302-1) ... 136s Selecting previously unselected package libintl-perl. 136s Preparing to unpack .../089-libintl-perl_1.33-1build4_all.deb ... 136s Unpacking libintl-perl (1.33-1build4) ... 136s Selecting previously unselected package libterm-readkey-perl. 136s Preparing to unpack .../090-libterm-readkey-perl_2.38-2build5_arm64.deb ... 136s Unpacking libterm-readkey-perl (2.38-2build5) ... 136s Selecting previously unselected package libio-pager-perl. 136s Preparing to unpack .../091-libio-pager-perl_2.10-1_all.deb ... 136s Unpacking libio-pager-perl (2.10-1) ... 136s Selecting previously unselected package libipc-system-simple-perl. 136s Preparing to unpack .../092-libipc-system-simple-perl_1.30-2_all.deb ... 136s Unpacking libipc-system-simple-perl (1.30-2) ... 136s Selecting previously unselected package liblist-moreutils-xs-perl. 136s Preparing to unpack .../093-liblist-moreutils-xs-perl_0.430-4build1_arm64.deb ... 136s Unpacking liblist-moreutils-xs-perl (0.430-4build1) ... 136s Selecting previously unselected package liblist-moreutils-perl. 136s Preparing to unpack .../094-liblist-moreutils-perl_0.430-2_all.deb ... 136s Unpacking liblist-moreutils-perl (0.430-2) ... 136s Selecting previously unselected package libmodule-build-perl. 136s Preparing to unpack .../095-libmodule-build-perl_0.423400-2_all.deb ... 136s Adding 'diversion of /usr/bin/config_data to /usr/bin/config_data.diverted by libmodule-build-perl' 136s Adding 'diversion of /usr/share/man/man1/config_data.1.gz to /usr/share/man/man1/config_data.diverted.1.gz by libmodule-build-perl' 136s Unpacking libmodule-build-perl (0.423400-2) ... 136s Selecting previously unselected package libmro-compat-perl. 136s Preparing to unpack .../096-libmro-compat-perl_0.15-2_all.deb ... 136s Unpacking libmro-compat-perl (0.15-2) ... 136s Selecting previously unselected package libpackage-stash-perl. 136s Preparing to unpack .../097-libpackage-stash-perl_0.40-1_all.deb ... 136s Unpacking libpackage-stash-perl (0.40-1) ... 136s Selecting previously unselected package libsub-identify-perl. 136s Preparing to unpack .../098-libsub-identify-perl_0.14-3build4_arm64.deb ... 136s Unpacking libsub-identify-perl (0.14-3build4) ... 136s Selecting previously unselected package libsub-name-perl:arm64. 136s Preparing to unpack .../099-libsub-name-perl_0.27-1build4_arm64.deb ... 136s Unpacking libsub-name-perl:arm64 (0.27-1build4) ... 137s Selecting previously unselected package libnamespace-clean-perl. 137s Preparing to unpack .../100-libnamespace-clean-perl_0.27-2_all.deb ... 137s Unpacking libnamespace-clean-perl (0.27-2) ... 137s Selecting previously unselected package libnamespace-autoclean-perl. 137s Preparing to unpack .../101-libnamespace-autoclean-perl_0.29-2_all.deb ... 137s Unpacking libnamespace-autoclean-perl (0.29-2) ... 137s Selecting previously unselected package libparams-validationcompiler-perl. 137s Preparing to unpack .../102-libparams-validationcompiler-perl_0.31-1_all.deb ... 137s Unpacking libparams-validationcompiler-perl (0.31-1) ... 137s Selecting previously unselected package libpath-class-perl. 137s Preparing to unpack .../103-libpath-class-perl_0.37-4_all.deb ... 137s Unpacking libpath-class-perl (0.37-4) ... 137s Selecting previously unselected package libperlio-utf8-strict-perl. 137s Preparing to unpack .../104-libperlio-utf8-strict-perl_0.010-1build4_arm64.deb ... 137s Unpacking libperlio-utf8-strict-perl (0.010-1build4) ... 137s Selecting previously unselected package libpod-parser-perl. 137s Preparing to unpack .../105-libpod-parser-perl_1.67-1_all.deb ... 137s Adding 'diversion of /usr/bin/podselect to /usr/bin/podselect.bundled by libpod-parser-perl' 137s Adding 'diversion of /usr/share/man/man1/podselect.1.gz to /usr/share/man/man1/podselect.bundled.1.gz by libpod-parser-perl' 137s Unpacking libpod-parser-perl (1.67-1) ... 137s Selecting previously unselected package libreturn-multilevel-perl. 137s Preparing to unpack .../106-libreturn-multilevel-perl_0.08-1_all.deb ... 137s Unpacking libreturn-multilevel-perl (0.08-1) ... 137s Selecting previously unselected package libxstring-perl:arm64. 137s Preparing to unpack .../107-libxstring-perl_0.005-2build4_arm64.deb ... 137s Unpacking libxstring-perl:arm64 (0.005-2build4) ... 137s Selecting previously unselected package libspecio-perl. 137s Preparing to unpack .../108-libspecio-perl_0.48-1_all.deb ... 137s Unpacking libspecio-perl (0.48-1) ... 137s Selecting previously unselected package libstring-formatter-perl. 137s Preparing to unpack .../109-libstring-formatter-perl_1.235-1_all.deb ... 137s Unpacking libstring-formatter-perl (1.235-1) ... 137s Selecting previously unselected package libstring-shellquote-perl. 137s Preparing to unpack .../110-libstring-shellquote-perl_1.04-3_all.deb ... 137s Unpacking libstring-shellquote-perl (1.04-3) ... 137s Selecting previously unselected package libsub-uplevel-perl. 137s Preparing to unpack .../111-libsub-uplevel-perl_0.2800-3_all.deb ... 137s Unpacking libsub-uplevel-perl (0.2800-3) ... 138s Selecting previously unselected package libsuper-perl. 138s Preparing to unpack .../112-libsuper-perl_1.20190531-1_all.deb ... 138s Unpacking libsuper-perl (1.20190531-1) ... 138s Selecting previously unselected package libtemplate-perl. 138s Preparing to unpack .../113-libtemplate-perl_2.27-1build11_arm64.deb ... 138s Unpacking libtemplate-perl (2.27-1build11) ... 138s Selecting previously unselected package libtemplate-tiny-perl. 138s Preparing to unpack .../114-libtemplate-tiny-perl_1.14-2_all.deb ... 138s Unpacking libtemplate-tiny-perl (1.14-2) ... 138s Selecting previously unselected package libtest-deep-perl. 138s Preparing to unpack .../115-libtest-deep-perl_1.204-1_all.deb ... 138s Unpacking libtest-deep-perl (1.204-1) ... 138s Selecting previously unselected package libtest-dir-perl. 138s Preparing to unpack .../116-libtest-dir-perl_1.16-3_all.deb ... 138s Unpacking libtest-dir-perl (1.16-3) ... 138s Selecting previously unselected package libtest-exception-perl. 138s Preparing to unpack .../117-libtest-exception-perl_0.43-3_all.deb ... 138s Unpacking libtest-exception-perl (0.43-3) ... 138s Selecting previously unselected package libtest-exit-perl. 138s Preparing to unpack .../118-libtest-exit-perl_0.11-2_all.deb ... 138s Unpacking libtest-exit-perl (0.11-2) ... 138s Selecting previously unselected package libtext-diff-perl. 138s Preparing to unpack .../119-libtext-diff-perl_1.45-2_all.deb ... 138s Unpacking libtext-diff-perl (1.45-2) ... 138s Selecting previously unselected package libtest-file-contents-perl. 138s Preparing to unpack .../120-libtest-file-contents-perl_0.242-1_all.deb ... 138s Unpacking libtest-file-contents-perl (0.242-1) ... 138s Selecting previously unselected package libtest-file-perl. 138s Preparing to unpack .../121-libtest-file-perl_1.993-1_all.deb ... 138s Unpacking libtest-file-perl (1.993-1) ... 138s Selecting previously unselected package libuniversal-can-perl. 138s Preparing to unpack .../122-libuniversal-can-perl_1.20140328-3_all.deb ... 138s Unpacking libuniversal-can-perl (1.20140328-3) ... 138s Selecting previously unselected package libuniversal-isa-perl. 138s Preparing to unpack .../123-libuniversal-isa-perl_1.20171012-3_all.deb ... 138s Unpacking libuniversal-isa-perl (1.20171012-3) ... 138s Selecting previously unselected package libtest-mockobject-perl. 138s Preparing to unpack .../124-libtest-mockobject-perl_1.20200122-4_all.deb ... 138s Unpacking libtest-mockobject-perl (1.20200122-4) ... 139s Selecting previously unselected package libtest-nowarnings-perl. 139s Preparing to unpack .../125-libtest-nowarnings-perl_1.06-2_all.deb ... 139s Unpacking libtest-nowarnings-perl (1.06-2) ... 139s Selecting previously unselected package libtest-warn-perl. 139s Preparing to unpack .../126-libtest-warn-perl_0.37-2_all.deb ... 139s Unpacking libtest-warn-perl (0.37-2) ... 139s Selecting previously unselected package libthrowable-perl. 139s Preparing to unpack .../127-libthrowable-perl_1.001-2_all.deb ... 139s Unpacking libthrowable-perl (1.001-2) ... 139s Selecting previously unselected package libtype-tiny-perl. 139s Preparing to unpack .../128-libtype-tiny-perl_2.004000-1_all.deb ... 139s Unpacking libtype-tiny-perl (2.004000-1) ... 139s Selecting previously unselected package libtype-tiny-xs-perl:arm64. 139s Preparing to unpack .../129-libtype-tiny-xs-perl_0.025-2build1_arm64.deb ... 139s Unpacking libtype-tiny-xs-perl:arm64 (0.025-2build1) ... 139s Selecting previously unselected package liburi-perl. 139s Preparing to unpack .../130-liburi-perl_5.28-1_all.deb ... 139s Unpacking liburi-perl (5.28-1) ... 139s Selecting previously unselected package liburi-nested-perl. 139s Preparing to unpack .../131-liburi-nested-perl_0.10-4_all.deb ... 139s Unpacking liburi-nested-perl (0.10-4) ... 139s Selecting previously unselected package liburi-db-perl. 139s Preparing to unpack .../132-liburi-db-perl_0.22-1_all.deb ... 139s Unpacking liburi-db-perl (0.22-1) ... 139s Selecting previously unselected package postgresql-client-common. 139s Preparing to unpack .../133-postgresql-client-common_262_all.deb ... 139s Unpacking postgresql-client-common (262) ... 139s Selecting previously unselected package postgresql-client-16. 139s Preparing to unpack .../134-postgresql-client-16_16.4-3_arm64.deb ... 139s Unpacking postgresql-client-16 (16.4-3) ... 139s Selecting previously unselected package postgresql-client. 139s Preparing to unpack .../135-postgresql-client_16+262_all.deb ... 139s Unpacking postgresql-client (16+262) ... 139s Selecting previously unselected package libdatetime-locale-perl. 139s Preparing to unpack .../136-libdatetime-locale-perl_1%3a1.41-1_all.deb ... 139s Unpacking libdatetime-locale-perl (1:1.41-1) ... 140s Selecting previously unselected package libdatetime-timezone-perl. 140s Preparing to unpack .../137-libdatetime-timezone-perl_1%3a2.62-1+2024a_all.deb ... 140s Unpacking libdatetime-timezone-perl (1:2.62-1+2024a) ... 140s Selecting previously unselected package libdatetime-perl. 140s Preparing to unpack .../138-libdatetime-perl_2%3a1.65-1build3_arm64.deb ... 140s Unpacking libdatetime-perl (2:1.65-1build3) ... 140s Selecting previously unselected package libipc-run3-perl. 140s Preparing to unpack .../139-libipc-run3-perl_0.049-1_all.deb ... 140s Unpacking libipc-run3-perl (0.049-1) ... 140s Selecting previously unselected package sqlite3. 140s Preparing to unpack .../140-sqlite3_3.46.1-1_arm64.deb ... 140s Unpacking sqlite3 (3.46.1-1) ... 140s Selecting previously unselected package sqitch. 140s Preparing to unpack .../141-sqitch_1.4.1-1_all.deb ... 140s Unpacking sqitch (1.4.1-1) ... 140s Selecting previously unselected package libtest-mockmodule-perl. 140s Preparing to unpack .../142-libtest-mockmodule-perl_0.178.0-1_all.deb ... 140s Unpacking libtest-mockmodule-perl (0.178.0-1) ... 140s Selecting previously unselected package pkg-perl-autopkgtest. 140s Preparing to unpack .../143-pkg-perl-autopkgtest_0.79_all.deb ... 140s Unpacking pkg-perl-autopkgtest (0.79) ... 140s Selecting previously unselected package autopkgtest-satdep. 140s Preparing to unpack .../144-1-autopkgtest-satdep.deb ... 140s Unpacking autopkgtest-satdep (0) ... 141s Setting up postgresql-client-common (262) ... 141s Setting up libfile-which-perl (1.27-2) ... 141s Setting up libclass-inspector-perl (1.36-3) ... 141s Setting up libdynaloader-functions-perl (0.004-1) ... 141s Setting up libtest-deep-perl (1.204-1) ... 141s Setting up libclass-method-modifiers-perl (2.15-1) ... 141s Setting up libpath-class-perl (0.37-4) ... 141s Setting up libclone-perl:arm64 (0.47-1) ... 141s Setting up libalgorithm-diff-perl (1.201-1) ... 141s Setting up libarchive-zip-perl (1.68-1) ... 141s Setting up libsub-identify-perl (0.14-3build4) ... 141s Setting up libtest-file-perl (1.993-1) ... 141s Setting up libdebhelper-perl (13.20ubuntu1) ... 141s Setting up libalgorithm-backoff-perl (0.010-1) ... 141s Setting up libtry-tiny-perl (0.31-2) ... 141s Setting up libpq5:arm64 (17.0-1) ... 141s Setting up m4 (1.4.19-4build1) ... 141s Setting up libclone-choose-perl (0.010-2) ... 141s Setting up libclass-singleton-perl (1.6-2) ... 141s Setting up libencode-locale-perl (1.05-3) ... 141s Setting up libxstring-perl:arm64 (0.005-2build4) ... 141s Setting up libgomp1:arm64 (14.2.0-7ubuntu1) ... 141s Setting up libtest-nowarnings-perl (1.06-2) ... 141s Setting up libstring-shellquote-perl (1.04-3) ... 141s Setting up libsub-install-perl (0.929-1) ... 141s Setting up libmodule-build-perl (0.423400-2) ... 141s Setting up libuniversal-isa-perl (1.20171012-3) ... 141s Setting up autotools-dev (20220109.1) ... 141s Setting up libclass-data-inheritable-perl (0.08-3) ... 141s Setting up libalgorithm-c3-perl (0.11-2) ... 141s Setting up libtext-diff-perl (1.45-2) ... 141s Setting up libipc-system-simple-perl (1.30-2) ... 141s Setting up libperlio-utf8-strict-perl (0.010-1build4) ... 141s Setting up libmpc3:arm64 (1.3.1-1build2) ... 141s Setting up libvariable-magic-perl (0.64-1build1) ... 141s Setting up libpod-parser-perl (1.67-1) ... 141s Setting up autopoint (0.22.5-2) ... 141s Setting up libb-hooks-op-check-perl:arm64 (0.22-3build2) ... 141s Setting up liblist-moreutils-xs-perl (0.430-4build1) ... 141s Setting up libparams-util-perl (1.102-3build1) ... 141s Setting up autoconf (2.72-3) ... 141s Setting up libsub-exporter-progressive-perl (0.001013-3) ... 141s Setting up libcapture-tiny-perl (0.48-2) ... 141s Setting up libreturn-multilevel-perl (0.08-1) ... 141s Setting up libubsan1:arm64 (14.2.0-7ubuntu1) ... 141s Setting up libsub-name-perl:arm64 (0.27-1build4) ... 141s Setting up libtype-tiny-xs-perl:arm64 (0.025-2build1) ... 141s Setting up dwz (0.15-1build6) ... 141s Setting up libhwasan0:arm64 (14.2.0-7ubuntu1) ... 141s Setting up libasan8:arm64 (14.2.0-7ubuntu1) ... 141s Setting up librole-tiny-perl (2.002004-1) ... 141s Setting up libintl-perl (1.33-1build4) ... 141s Setting up debugedit (1:5.1-1) ... 141s Setting up libipc-run3-perl (0.049-1) ... 141s Setting up libfile-sharedir-perl (1.118-3) ... 141s Setting up libsub-uplevel-perl (0.2800-3) ... 141s Setting up libsub-quote-perl (2.006008-1ubuntu1) ... 141s Setting up libdevel-stacktrace-perl (2.0500-1) ... 141s Setting up libclass-xsaccessor-perl (1.19-4build5) ... 141s Setting up libtemplate-tiny-perl (1.14-2) ... 141s Setting up libtsan2:arm64 (14.2.0-7ubuntu1) ... 141s Setting up libexporter-tiny-perl (1.006002-1) ... 141s Setting up libuniversal-can-perl (1.20140328-3) ... 141s Setting up libterm-readkey-perl (2.38-2build5) ... 141s Setting up libisl23:arm64 (0.27-1) ... 141s Setting up libtest-dir-perl (1.16-3) ... 141s Setting up libcc1-0:arm64 (14.2.0-7ubuntu1) ... 141s Setting up liburi-perl (5.28-1) ... 141s Setting up sqlite3 (3.46.1-1) ... 141s Setting up libappconfig-perl (1.71-2.3) ... 141s Setting up libdbi-perl:arm64 (1.645-1) ... 141s Setting up liblsan0:arm64 (14.2.0-7ubuntu1) ... 141s Setting up dctrl-tools (2.24-3build3) ... 141s Setting up libitm1:arm64 (14.2.0-7ubuntu1) ... 141s Setting up autodep8 (0.28+nmu1ubuntu1) ... 141s Setting up automake (1:1.16.5-1.3ubuntu1) ... 141s update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode 141s Setting up libfile-stripnondeterminism-perl (1.14.0-1) ... 141s Setting up libtest-mockobject-perl (1.20200122-4) ... 141s Setting up libio-pager-perl (2.10-1) ... 141s Setting up libsuper-perl (1.20190531-1) ... 141s Setting up gettext (0.22.5-2) ... 141s Setting up libtest-mockmodule-perl (0.178.0-1) ... 141s Setting up libtest-exit-perl (0.11-2) ... 141s Setting up liblist-moreutils-perl (0.430-2) ... 141s Setting up libtest-warn-perl (0.37-2) ... 141s Setting up postgresql-client-16 (16.4-3) ... 142s update-alternatives: using /usr/share/postgresql/16/man/man1/psql.1.gz to provide /usr/share/man/man1/psql.1.gz (psql.1.gz) in auto mode 142s Setting up libhash-merge-perl (0.302-1) ... 142s Setting up libtype-tiny-perl (2.004000-1) ... 142s Setting up libtest-file-contents-perl (0.242-1) ... 142s Setting up liburi-nested-perl (0.10-4) ... 142s Setting up libdbd-pg-perl (3.18.0-1build4) ... 142s Setting up libexception-class-perl (1.45-1) ... 142s Setting up libclass-c3-perl (0.35-2) ... 142s Setting up libdevel-callchecker-perl:arm64 (0.009-1build1) ... 142s Setting up intltool-debian (0.35.0+20060710.6) ... 142s Setting up libtest-exception-perl (0.43-3) ... 142s Setting up liburi-db-perl (0.22-1) ... 142s Setting up libdata-optlist-perl (0.114-1) ... 142s Setting up pkg-perl-autopkgtest (0.79) ... 142s Setting up libtemplate-perl (2.27-1build11) ... 142s Setting up dh-strip-nondeterminism (1.14.0-1) ... 142s Setting up cpp-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 142s Setting up libdbd-sqlite3-perl:arm64 (1.76-1) ... 142s Setting up libmro-compat-perl (0.15-2) ... 142s Setting up libgcc-14-dev:arm64 (14.2.0-7ubuntu1) ... 142s Setting up libstdc++-14-dev:arm64 (14.2.0-7ubuntu1) ... 142s Setting up libsub-exporter-perl (0.990-1) ... 142s Setting up libeval-closure-perl (0.14-3) ... 142s Setting up libparams-validationcompiler-perl (0.31-1) ... 142s Setting up postgresql-client (16+262) ... 142s Setting up po-debconf (1.0.21+nmu1) ... 142s Setting up libparams-classify-perl:arm64 (0.015-2build6) ... 142s Setting up cpp-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 142s Setting up libmodule-runtime-perl (0.016-2) ... 142s Setting up libstring-formatter-perl (1.235-1) ... 142s Setting up cpp-14 (14.2.0-7ubuntu1) ... 142s Setting up cpp (4:14.1.0-2ubuntu1) ... 142s Setting up gcc-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 142s Setting up gcc-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 142s Setting up g++-14-aarch64-linux-gnu (14.2.0-7ubuntu1) ... 142s Setting up libmodule-implementation-perl (0.09-2) ... 142s Setting up libpackage-stash-perl (0.40-1) ... 142s Setting up libimport-into-perl (1.002005-2) ... 142s Setting up libmoo-perl (2.005005-1) ... 142s Setting up gcc-14 (14.2.0-7ubuntu1) ... 142s Setting up libspecio-perl (0.48-1) ... 142s Setting up g++-aarch64-linux-gnu (4:14.1.0-2ubuntu1) ... 142s Setting up g++-14 (14.2.0-7ubuntu1) ... 142s Setting up libmoox-types-mooselike-perl (0.29-2) ... 142s Setting up libb-hooks-endofscope-perl (0.28-1) ... 142s Setting up libconfig-gitlike-perl (1.18-2) ... 142s Setting up libthrowable-perl (1.001-2) ... 142s Setting up libtool (2.4.7-7build1) ... 142s Setting up gcc (4:14.1.0-2ubuntu1) ... 142s Setting up dh-autoreconf (20) ... 142s Setting up libnamespace-clean-perl (0.27-2) ... 142s Setting up g++ (4:14.1.0-2ubuntu1) ... 142s update-alternatives: using /usr/bin/g++ to provide /usr/bin/c++ (c++) in auto mode 142s Setting up build-essential (12.10ubuntu1) ... 142s Setting up libnamespace-autoclean-perl (0.29-2) ... 142s Setting up libdatetime-locale-perl (1:1.41-1) ... 142s Setting up libdatetime-timezone-perl (1:2.62-1+2024a) ... 142s Setting up debhelper (13.20ubuntu1) ... 142s Setting up libdatetime-perl (2:1.65-1build3) ... 142s Setting up sqitch (1.4.1-1) ... 142s Setting up autopkgtest-satdep (0) ... 142s Processing triggers for man-db (2.12.1-3) ... 144s Processing triggers for install-info (7.1.1-1) ... 145s Processing triggers for libc-bin (2.40-1ubuntu3) ... 154s (Reading database ... 88125 files and directories currently installed.) 154s Removing autopkgtest-satdep (0) ... 155s autopkgtest [18:25:37]: test autodep8-perl-build-deps: /usr/share/pkg-perl-autopkgtest/runner build-deps 155s autopkgtest [18:25:37]: test autodep8-perl-build-deps: [----------------------- 157s t/add.t ............. 157s 1..243 157s ok 1 - Load a sqitch sqitch object 157s ok 2 - 'add command' isa 'App::Sqitch::Command::add' 157s ok 3 - App::Sqitch::Command::add->can(...) 157s ok 4 - App::Sqitch::Command::add does ContextCommand 157s ok 5 - Options should be set up 157s ok 6 - Should parse options 157s ok 7 - Options should not conflict with core options 157s ok 8 - Should have default configuration with no config or opts 157s ok 9 - Should have get requires and conflicts options 157s ok 10 - Should set up template directory option 157s ok 11 - Should set up change name option 157s ok 12 - Should die if --template-directory does not exist 157s ok 13 - Missing directory ident should be "add" 157s ok 14 - Missing directory error message should be correct 157s ok 15 - Should die if --template-directory does is not a dir 157s ok 16 - In alid directory ident should be "add" 157s ok 17 - Invalid directory error message should be correct 157s ok 18 - Should set up template name option 157s ok 19 - Should have get template options 157s ok 20 - Variables should by default not be loaded from config 157s ok 21 - --set should be merged with config variables 157s ok 22 - --set should be override config variables 157s ok 23 - Requires should be an arrayref 157s ok 24 - Conflicts should be an arrayref 157s ok 25 - Notes should be an arrayref 157s ok 26 - Varibles should be a hashref 157s ok 27 - Default dir should be undef 157s ok 28 - Default temlate_name should be undef 157s ok 29 - Default with_scripts should be all true 157s ok 30 - Default templates should be empty 157s ok 31 - '_check_script' isa 'CODE' 157s ok 32 - _check_script should be okay with script 157s ok 33 - _check_script should die on nonexistent file 157s ok 34 - Nonexistent file ident should be "add" 157s ok 35 - Nonexistent file error message should be correct 157s ok 36 - _check_script should die on directory 157s ok 37 - Directory error ident should be "add" 157s ok 38 - Directory error message should be correct 157s ok 39 - Load another sqitch sqitch object 157s ok 40 - Create add with template config 157s ok 41 - Should load the config templates 157s ok 42 - Add object with template directory 157s ok 43 - Template name should be undef 157s ok 44 - Should find all pg templates in directory 157s ok 45 - Should find all sqlite templates in directory 157s ok 46 - Add object with template name 157s ok 47 - Should find all templates in user directory 157s ok 48 - Add object with another template name 157s ok 49 - Should find all templates in systsem directory 157s ok 50 - Add object with temporary template directory 157s ok 51 - Template dir files should override others 157s ok 52 - Add object with configured templates 157s ok 53 - Template dir files should override others 157s ok 54 - Add object requiring deploy template 157s ok 55 - Should get error for missing deploy template 157s ok 56 - Missing deploy template ident should be "add" 157s ok 57 - Missing deploy template message should be correct 157s ok 58 - Add object requiring revert template 157s ok 59 - Should get error for missing revert template 157s ok 60 - Missing revert template ident should be "add" 157s ok 61 - Missing revert template message should be correct 157s ok 62 - Add object requiring verify template 157s ok 63 - Should get error for missing verify template 157s ok 64 - Missing verify template ident should be "add" 157s ok 65 - Missing verify template message should be correct 157s ok 66 - _slurp() should load a reference to file contents 157s ok 67 - test-add/sqitch_change_test.sql does not exist 157s ok 68 - Create add command 157s ok 69 - Write out a script 157s ok 70 - test-add/sqitch_change_test.sql exists 157s ok 71 - The template should have been evaluated 157s ok 72 - Info should show $out created 157s ok 73 - Create add cmd with requires and conflicts 157s ok 74 - Write out a script with requires and conflicts 157s ok 75 - Info should show $out created 157s ok 76 - The template should have been evaluated with requires and conflicts 157s ok 77 - Info should show $out created 157s ok 78 - Should have warned about double extension 157s ok 79 - test-add/sqitch_change_test.sql does not exist 157s ok 80 - Create add command 157s ok 81 - Write out a script 157s ok 82 - test-add/sqitch_change_test.sql exists 157s ok 83 - The template should have been evaluated 157s ok 84 - Info should show $out created 157s ok 85 - Create add cmd with requires and conflicts 157s ok 86 - Write out a script with requires and conflicts 157s ok 87 - Info should show $out created 157s ok 88 - The template should have been evaluated with requires and conflicts 157s ok 89 - Info should show $out created 157s ok 90 - Should have warned about double extension 157s ok 91 - Create add command 157s ok 92 - Should get an exception on TT syntax error 157s ok 93 - TT exception ident should be "add" 157s ok 94 - TT exception message should include the original error message 157s ok 95 - Create another add with template_directory 157s ok 96 - Should not have "widgets_table" in plan 157s ok 97 - dir test-add/deploy does not exist 157s ok 98 - dir test-add/revert does not exist 157s ok 99 - dir test-add/verify does not exist 157s ok 100 - Add change "widgets_table" 157s ok 101 - 'Added change' isa 'App::Sqitch::Plan::Change' 157s ok 102 - Change name should be set 157s ok 103 - It should have no requires 157s ok 104 - It should have no conflicts 157s ok 105 - It should have prompted for a note 157s ok 106 - test-add/deploy/widgets_table.sql exists 157s ok 107 - test-add/revert/widgets_table.sql exists 157s ok 108 - test-add/verify/widgets_table.sql exists 157s ok 109 - Deploy script should look right 157s ok 110 - Revert script should look right 157s ok 111 - Verify script should look right 157s ok 112 - Info should have reported file creation 157s ok 113 - Create another add with template_directory and no verify script 157s ok 114 - test-add/deploy/foo_table.sql exists 157s ok 115 - test-add/revert/foo_table.sql does not exist 157s ok 116 - test-add/ferify/foo_table.sql does not exist 157s ok 117 - Should not have "foo_table" in plan 157s ok 118 - Add change "foo_table" 157s ok 119 - test-add/deploy/foo_table.sql exists 157s ok 120 - test-add/revert/foo_table.sql exists 157s ok 121 - test-add/ferify/foo_table.sql does not exist 157s ok 122 - '"foo_table" change' isa 'App::Sqitch::Plan::Change' 157s ok 123 - It should have prompted for a note 157s ok 124 - Change name should be set to "foo_table" 157s ok 125 - It should have requires 157s ok 126 - It should have conflicts 157s ok 127 - It should have a comment 157s ok 128 - Info should report skipping file and include dependencies 157s ok 129 - Should get an error on unkonwn argument 157s ok 130 - Unkown argument error ident should be "add" 157s ok 131 - Unknown argument error message should be correct 157s ok 132 - Should get an error for conflict with target name 157s ok 133 - Conflicting target error ident should be "add" 157s ok 134 - Conflicting target error message should be correct 157s ok 135 - No name arg or option should yield usage 157s ok 136 - No args should be passed to usage 157s ok 137 - No name arg or option should yield usage 157s ok 138 - No args should be passed to usage 157s ok 139 - No name arg or option should yield usage 157s ok 140 - No args should be passed to usage 157s ok 141 - Create another add with open_editor 157s ok 142 - Should not have "open_editor" in plan 157s ok 143 - Add change "open_editor" 157s ok 144 - 'Added change' isa 'App::Sqitch::Plan::Change' 157s ok 145 - Change name should be set 157s ok 146 - It should have prompted to edit sql files 157s ok 147 - test-add/deploy/open_editor.sql exists 157s ok 148 - test-add/revert/open_editor.sql exists 157s ok 149 - test-add/verify/open_editor.sql exists 157s ok 150 - Deploy script should look right 157s ok 151 - Revert script should look right 157s ok 152 - Verify script should look right 157s ok 153 - Info should have reported file creation 157s ok 154 - Create another add with custom script and no verify 157s ok 155 - Add change "custom_script" 157s ok 156 - 'Added change' isa 'App::Sqitch::Plan::Change' 157s ok 157 - Change name should be set 157s ok 158 - It should have no requires 157s ok 159 - It should have no conflicts 157s ok 160 - It should have prompted for a note 157s ok 161 - test-add/deploy/custom_script.sql exists 157s ok 162 - test-add/revert/custom_script.sql exists 157s ok 163 - test-add/whatev/custom_script.sql exists 157s ok 164 - test-add/verify/custom_script.sql does not exist 157s ok 165 - Deploy script should look right 157s ok 166 - Revert script should look right 157s ok 167 - Whatev script should look right 157s ok 168 - Whatev script should be based on the MySQL verify script 157s ok 169 - Info should have reported file creation 157s ok 170 - 'Added change in reloaded plan' isa 'App::Sqitch::Plan::Change' 157s ok 171 - Create another add with custom multiplan config 157s ok 172 - Should have three targets 157s ok 173 - Add change "widgets" to all plans 157s ok 174 - Should have "widgets" in pg plan 157s ok 175 - Should have "widgets" in sqlite plan 157s ok 176 - Should have "widgets" in mysql plan 157s ok 177 - pg/deploy/widgets.sql exists 157s ok 178 - pg/revert/widgets.sql exists 157s ok 179 - pg/verify/widgets.sql exists 157s ok 180 - sqlite/deploy/widgets.sql exists 157s ok 181 - sqlite/revert/widgets.sql exists 157s ok 182 - sqlite/verify/widgets.sql exists 157s ok 183 - mysql/deploy/widgets.sql exists 157s ok 184 - mysql/revert/widgets.sql exists 157s ok 185 - mysql/verify/widgets.sql exists 157s ok 186 - Info should have reported all script creations and plan updates 157s ok 187 - Should get an error for --all and a target arg 157s ok 188 - Mixed arguments error ident should be "add" 157s ok 189 - Mixed arguments error message should be correct 157s ok 190 - Create yet another add with custom multiplan config 157s ok 191 - Add change "choc" to the sqlite plan 157s ok 192 - Should still have three targets 157s ok 193 - Should not have "choc" in the pg plan 157s ok 194 - Should not have "choc" in the mysql plan 157s ok 195 - Should have "choc" in the sqlite plan 157s ok 196 - sqlite/deploy/choc.sql exists 157s ok 197 - sqlite/revert/choc.sql exists 157s ok 198 - sqlite/verify/choc.sql exists 157s ok 199 - pg/deploy/choc.sql does not exist 157s ok 200 - pg/revert/choc.sql does not exist 157s ok 201 - pg/verify/choc.sql does not exist 157s ok 202 - mysql/deploy/choc.sql does not exist 157s ok 203 - mysql/revert/choc.sql does not exist 157s ok 204 - mysql/verify/choc.sql does not exist 157s ok 205 - Info should have reported sqlite choc script creations and plan updates 157s ok 206 - Create another add with single plan, multi-target config 157s ok 207 - Should have two targets 157s ok 208 - Targets should use the same plan file 157s ok 209 - Add change "widgets" to all plans 157s ok 210 - Should have "widgets" in the plan 157s ok 211 - pg/deploy/widgets.sql exists 157s ok 212 - pg/revert/widgets.sql exists 157s ok 213 - pg/verify/widgets.sql exists 157s ok 214 - sqlite/deploy/widgets.sql exists 157s ok 215 - sqlite/revert/widgets.sql exists 157s ok 216 - sqlite/verify/widgets.sql exists 157s ok 217 - Should have the proper files listed in the note promt 157s ok 218 - Info should have reported all script creations and one plan update 157s ok 219 - Create another add with two targets, one top dir 157s ok 220 - Should have two targets 157s ok 221 - First target plan should be in pg.plan 157s ok 222 - Second target plan should be in sqlite.plan 157s ok 223 - Add change "widgets" to all plans 157s ok 224 - Should have "widgets" in pg plan 157s ok 225 - Should have "widgets" in sqlite plan 157s ok 226 - deploy/widgets.sql exists 157s ok 227 - revert/widgets.sql exists 157s ok 228 - verify/widgets.sql exists 157s ok 229 - Should have the proper files listed in the note promt 157s ok 230 - Info should have script creations and skips 157s ok 231 - App::Sqitch::Command::add->can(...) 157s ok 232 - Create a App::Sqitch::Command::add object again 157s ok 233 - Base _parse_opts should return the script config 157s ok 234 - _parse_opts() hould use options spec 157s ok 235 - _parse_opts() should parse options spec 157s ok 236 - Args array should be cleared of options 157s ok 237 - _parse_opts() should parse --set options 157s ok 238 - Args array should be cleared of options 157s ok 239 - _parse_opts() should parse --set options with repeting key 157s ok 240 - Args array should be cleared of options 157s ok 241 - _parse_opts() should parse --with, --without, and --user 157s ok 242 - Args array should be cleared of options 157s ok 243 - no warnings 157s ok 157s t/base.t ............ 157s 1..208 157s ok 1 - use App::Sqitch; 157s ok 2 - App::Sqitch->can(...) 157s ok 3 - 'A configured object' isa 'App::Sqitch' 157s ok 4 - Configured verbosity should override default 157s ok 5 - 'A configured object' isa 'App::Sqitch' 157s ok 6 - Verbosity option should override configuration 157s ok 7 - 'A new object' isa 'App::Sqitch' 157s ok 8 - Default verbosity should be 1 157s ok 9 - Should have default sysuser from system 157s ok 10 - Default user_name should be set from system 157s ok 11 - Default user_email should be set from system 157s ok 12 - 'Another new object' isa 'App::Sqitch' 157s ok 13 - SQITCH_ORIG_SYSUER should override system username 157s ok 14 - SQITCH_ORIG_FULLNAME should override system user full name 157s ok 15 - SQITCH_ORIG_EMAIL should override system-derived email 157s ok 16 - 'Another new object' isa 'App::Sqitch' 157s ok 17 - SQITCH_FULLNAME should override originating host user full name 157s ok 18 - SQITCH_EMAIL should override originating host email 157s ok 19 - Should get 0 from go() 157s ok 20 - 'Command' isa 'App::Sqitch::Command::help' 157s ok 21 - Extra args should be passed to execute 157s ok 22 - An object of class 'App::Sqitch' isa 'App::Sqitch' 157s ok 23 - Get the Sqitch config 157s ok 24 - Should have local config overriding user 157s ok 25 - Should fall back on user config 157s ok 26 - Should have read user name from configuration 157s ok 27 - Should have read user email from configuration 157s ok 28 - Should have no options 157s ok 29 - Should get 0 from go() again 157s ok 30 - An object of class 'App::Sqitch' isa 'App::Sqitch' 157s ok 31 - Should have read user name from environment 157s ok 32 - Should have read user email from environment 157s ok 33 - Go should return 2 on Sqitch exception 157s ok 34 - The error should have been vented 157s ok 35 - Should have no info output 157s ok 36 - Should have no emitted output 157s ok 37 - The stack trace should have been sent to trace 157s ok 38 - Go should return exitval on another exception 157s ok 39 - Both the message and the trace should have been vented 157s ok 40 - Should still have no info output 157s ok 41 - Should still have no emitted output 157s ok 42 - Nothing should have been traced 157s ok 43 - Go should return exitval on non-fatal exception 157s ok 44 - Should not have vented 157s ok 45 - Should have sent the message to message 157s ok 46 - Should still have no emitted output 157s ok 47 - Nothing should have been traced 157s ok 48 - Go should return 2 on a third Sqitch exception 157s ok 49 - Should have one thing vented 157s ok 50 - And it should include our message 157s ok 51 - Should again have no info output 157s ok 52 - Should still have no emitted output 157s ok 53 - Nothing should have been traced 157s ok 54 - editor should use $EDITOR 157s ok 55 - editor should prefer $VISUAL over $EDITOR 157s ok 56 - editor should prefer core.editor over $VISUAL 157s ok 57 - editor should prefer $SQITCH_EDITOR over $VISUAL 157s ok 58 - editor should use use parameter regardless of environment 157s ok 59 - editor fall back on vi when not Windows 157s ok 60 - pager program should be picked up from PAGER when SQITCH_PAGER and core.pager are not set 157s ok 61 - 'morez pager' isa 'IO::Handle' 157s ok 62 - Should be able to page 157s ok 63 - Should have paged with say() 157s ok 64 - Should be able to page literal 157s ok 65 - Should have paged with print() 157s ok 66 - SQITCH_PAGER should take precedence over PAGER 157s ok 67 - 'less -myway' isa 'IO::Handle' 157s ok 68 - `core.pager' setting should take precedence over PAGER when SQITCH_PAGER is not set. 157s ok 69 - 'morezz pager' isa 'IO::Handle' 157s ok 70 - SQITCH_PAGER should take precedence over both PAGER and the `core.pager' setting. 157s ok 71 - 'less -rules' isa 'IO::Handle' 157s ok 72 - trace should work 157s ok 73 - Should get no trace output for verbosity 2 157s ok 74 - trace_literal should work 157s ok 75 - Should get no trace_literal output for verbosity 2 157s ok 76 - debug should work 157s ok 77 - Should get no debug output for verbosity 1 157s ok 78 - debug_literal should work 157s ok 79 - Should get no debug_literal output for verbosity 1 157s ok 80 - info should work 157s ok 81 - Should get no info output for verbosity 0 157s ok 82 - info_literal should work 157s ok 83 - Should get no info_literal output for verbosity 0 157s ok 84 - comment should work 157s ok 85 - comment should work with verbosity 0 157s ok 86 - comment_literal should work 157s ok 87 - comment_literal should work with verbosity 0 157s ok 88 - emit should work 157s ok 89 - emit should work even with verbosity 0 157s ok 90 - emit_literal should work 157s ok 91 - emit_literal should work even with verbosity 0 157s ok 92 - warn should work 157s ok 93 - warn_literal should work 157s ok 94 - vent should work 157s ok 95 - vent_literal should work 157s ok 96 - App::Sqitch->can('run') 157s ok 97 - Should get success back from run echo 157s ok 98 - The echo script should have run 157s ok 99 - Nothing should have gone to STDERR 157s ok 100 - run die should, well, die 157s ok 101 - The die script should have its STDOUT ummolested 157s ok 102 - The die script should have its STDERR unmolested 157s ok 103 - App::Sqitch->can('shell') 157s ok 104 - Should get success back from shell echo 157s ok 105 - The echo script should have shell 157s ok 106 - Nothing should have gone to STDERR 157s ok 107 - shell die should, well, die 157s ok 108 - The die script should have its STDOUT ummolested 157s ok 109 - The die script should have its STDERR unmolested 157s ok 110 - quote_shell should work 157s ok 111 - App::Sqitch->can('capture') 157s ok 112 - The echo script output should have been returned 157s ok 113 - Should get an error if the command errors out 157s ok 114 - The die script STDERR should have passed through 157s ok 115 - App::Sqitch->can('probe') 157s ok 116 - Should have just chomped first line of output 157s ok 117 - App::Sqitch->can('spool') 157s ok 118 - Spool to read.pl 157s ok 119 - Data should have been sent to STDOUT by read.pl 157s ok 120 - Spool to read.pl 157s ok 121 - All data should have been sent to STDOUT by read.pl 157s ok 122 - Should get error when die.pl dies 157s ok 123 - Error ident should be "io" 157s ok 124 - The error message should be one of the I/O messages 157s ok 125 - The die script STDERR should have passed through 157s ok 126 - Should get an error for a bad command 157s ok 127 - Error ident should be "io" 157s ok 128 - Error message should be about inability to exec 157s ok 129 - Should get error for no prompt message 157s ok 130 - No prompt ident should be "DEV" 157s ok 131 - No prompt error message should be correct 157s ok 132 - Prompt should return input 157s ok 133 - Prompt should prompt 157s ok 134 - Prompt with default should return input 157s ok 135 - Prompt should prompt with default 157s ok 136 - Prompt with undef default should return input 157s ok 137 - Prompt should prompt with bracket for undef default 157s ok 138 - Prompt should return default for undef input 157s ok 139 - Prompt should show default when undef input 157s ok 140 - Prompt should return input for empty input 157s ok 141 - Prompt should show default when empty input 157s ok 142 - Should get error when uattended and no default 157s ok 143 - Unattended error ident should be "io" 157s ok 144 - Unattended error message should be correct 157s ok 145 - Prompt should return input 157s ok 146 - Prompt should show default as selected when unattended 157s ok 147 - Should get error for no ask_yes_no message 157s ok 148 - No ask_yes_no ident should be "DEV" 157s ok 149 - No ask_yes_no error message should be correct 157s ok 150 - ask_yes_no() should return true for "Yes" input 157s ok 151 - ask_yes_no() should prompt for "Yes" 157s ok 152 - ask_yes_no() should return true for "yes" input 157s ok 153 - ask_yes_no() should prompt for "yes" 157s ok 154 - ask_yes_no() should return true for "YES" input 157s ok 155 - ask_yes_no() should prompt for "YES" 157s ok 156 - ask_yes_no() should return true for "y" input 157s ok 157 - ask_yes_no() should prompt for "y" 157s ok 158 - ask_yes_no() should return true for "Ye" input 157s ok 159 - ask_yes_no() should prompt for "Ye" 157s ok 160 - ask_yes_no() should return false for "No" input 157s ok 161 - ask_yes_no() should prompt for "No" 157s ok 162 - ask_yes_no() should return false for "no" input 157s ok 163 - ask_yes_no() should prompt for "no" 157s ok 164 - ask_yes_no() should return false for "NO" input 157s ok 165 - ask_yes_no() should prompt for "NO" 157s ok 166 - ask_yes_no() should return false for "n" input 157s ok 167 - ask_yes_no() should prompt for "n" 157s ok 168 - ask_yes_no() should return false for "No" input 157s ok 169 - ask_yes_no() should prompt for "No" 157s ok 170 - ask_yes_no() should return true for true default 157s ok 171 - ask_yes_no() should prompt and show default "Yes" 157s ok 172 - ask_yes_no() should return false for false default 157s ok 173 - ask_yes_no() should prompt and show default "No" 157s ok 174 - Should get error for bad answers 157s ok 175 - Bad answers ident should be "IO" 157s ok 176 - Bad answers message should be correct 157s ok 177 - Should get error for no ask_y_n message 157s ok 178 - No ask_y_n ident should be "DEV" 157s ok 179 - No ask_y_n error message should be correct 157s ok 180 - Should get a deprecation warning from ask_y_n 157s ok 181 - Should get error for invalid ask_y_n default 157s ok 182 - Invalid ask_y_n default ident should be "DEV" 157s ok 183 - Invalid ask_y_n default error message should be correct 157s ok 184 - ask_y_n should return true for "y" input 157s ok 185 - ask_y_n() should prompt 157s ok 186 - ask_y_n should return false for "n" input 157s ok 187 - ask_y_n() should prompt for no 157s ok 188 - ask_y_n should return false for "N" input 157s ok 189 - ask_y_n() should prompt for no 157s ok 190 - ask_y_n should return true for "YE" input 157s ok 191 - ask_y_n() should prompt for yes 157s ok 192 - ask_y_n should return true default "Yes" 157s ok 193 - ask_y_n() should prompt and show default "Yes" 157s ok 194 - ask_y_n should return false default "No" 157s ok 195 - ask_y_n() should prompt and show default "No" 157s ok 196 - Should get error for bad answers 157s ok 197 - Bad answers ident should be "IO" 157s ok 198 - Bad answers message should be correct 157s ok 199 - _readline should work 157s ok 200 - _readline should return undef when unattended 157s ok 201 - Localied string should be valid UTF-8 157s ok 202 - Localied string should be decoded 157s ok 203 - Localied string should be valid UTF-8 157s ok 204 - Localied string should be decoded 157s ok 205 - _is_interactive should not die 157s ok 206 - _is_unattended should not die 157s ok 207 - _bn should work 157s ok 208 - no warnings 157s ok 158s t/blank.t ........... 158s 1..34 158s ok 1 - require App::Sqitch::Plan::Blank; 158s ok 2 - App::Sqitch::Plan::Blank->can(...) 158s ok 3 - An object of class 'App::Sqitch::Plan::Blank' isa 'App::Sqitch::Plan::Blank' 158s ok 4 - An object of class 'App::Sqitch::Plan::Blank' isa 'App::Sqitch::Plan::Line' 158s ok 5 - Name should format as "" 158s ok 6 - should stringify to "" 158s ok 7 - Create tag with more stuff 158s ok 8 - It should stringify correctly 158s ok 9 - Create a blank with newlines and backslashes in the note 158s ok 10 - The newlines and backslashe should not be escaped 158s ok 11 - The newlines and backslahs should be escaped by format_note 158s ok 12 - Create a blank with escapes 158s ok 13 - Note shoud be unescaped 158s ok 14 - Should trim Leading newlines from note 158s ok 15 - Should trim Leading line feeds from note 158s ok 16 - Should trim Trailing newlines from note 158s ok 17 - Should trim trailing line feeds from note 158s ok 18 - Should trim Leading and trailing vertical space from note 158s ok 19 - Should trim Leading and trailing newlines and spaces from note 158s ok 20 - Should have localized not prompt 158s ok 21 - Shell command should start with editor 158s ok 22 - Temp file should exist 158s ok 23 - Temp file contents should include prompt 158s ok 24 - Should get exception for no note text 158s ok 25 - No note error ident should be "plan" 158s ok 26 - No note error message should be correct 158s ok 27 - Exit val should be 1 158s ok 28 - Shell command should start with editor 158s ok 29 - Temp file should exist 158s ok 30 - Temp file contents should include prompt 158s ok 31 - Request note 158s ok 32 - Should have the edited note 158s ok 33 - The request should not prompt again 158s ok 34 - no warnings 158s ok 159s t/bundle.t .......... 159s 1..301 159s ok 1 - Load a sqitch object 159s ok 2 - 'bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 3 - App::Sqitch::Command::bundle->can(...) 159s ok 4 - App::Sqitch::Command::bundle does ContextCommand 159s ok 5 - Should have dest_dir option 159s ok 6 - Should parse options 159s ok 7 - Options should not conflict with core options 159s ok 8 - Default dest_dir should be bundle/ 159s ok 9 - Should have dest top dir 159s ok 10 - Default config should be empty 159s ok 11 - --dest_dir should be converted to a path object by configure() 159s ok 12 - --from and --to should be passed through configure 159s ok 13 - Load a sqitch object with top_dir 159s ok 14 - bundle.dest_dir config should be converted to a path object by configure() 159s ok 15 - 'another bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 16 - dest_dir should be "_build/sql" 159s ok 17 - Dest top dir should be _build/sql/sql/ 159s ok 18 - Dest deploy dir should be _build/sql/sql/deploy 159s ok 19 - Dest revert dir should be _build/sql/sql/revert 159s ok 20 - Dest verify dir should be _build/sql/sql/verify 159s ok 21 - Load a sqitch object with engine top_dir 159s ok 22 - 'engine bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 23 - dest_dir should again be "_build/sql" 159s ok 24 - Dest deploy dir should be _build/sql/engine/deploy 159s ok 25 - Dest revert dir should be _build/sql/engine/revert 159s ok 26 - Dest verify dir should be _build/sql/engine/verify 159s ok 27 - File delete.me/deploy/roles.sql should not exist 159s ok 28 - Copy sql/deploy/roles.sql to delete.me/deploy/roles.sql 159s ok 29 - File delete.me/deploy/roles.sql should now exist 159s ok 30 - delete.me/deploy/roles.sql and sql/deploy/roles.sql contents are the same 159s ok 31 - The mkdir and copy info should have been output 159s ok 32 - Copy sql/deploy/roles.sql to delete.me/deploy/roles.sql again 159s ok 33 - File delete.me/deploy/roles.sql should still exist 159s ok 34 - delete.me/deploy/roles.sql and sql/deploy/roles.sql contents are the same 159s ok 35 - Should have no debugging output 159s ok 36 - Copy sql/deploy/roles.sql to old delete.me/deploy/roles.sql 159s ok 37 - File delete.me/deploy/roles.sql should still be there 159s ok 38 - delete.me/deploy/roles.sql and sql/deploy/roles.sql contents are the same 159s ok 39 - Only copy message should again have been emitted 159s ok 40 - Copy sql/deploy/users.sql to delete.me/deploy/roles.sql 159s ok 41 - File delete.me/deploy/roles.sql should now exist 159s ok 42 - delete.me/deploy/roles.sql and sql/deploy/users.sql contents are the same 159s ok 43 - Again only Copy message should have been emitted 159s ok 44 - Should get exception when source file does not exist 159s ok 45 - Nonexistent file error ident should be "bundle" 159s ok 46 - Nonexistent file error message should be correct 159s ok 47 - Should get exception when copy returns false 159s ok 48 - Copy fail ident should be "bundle" 159s ok 49 - Copy fail error message should be correct 159s ok 50 - _build/sql/sqitch.conf does not exist 159s ok 51 - Bundle the config file 159s ok 52 - _build/sql/sqitch.conf exists 159s ok 53 - _build/sql/sqitch.conf and sqitch.conf contents are the same 159s ok 54 - Should have config notice 159s ok 55 - _build/sql/engine/sqitch.plan does not exist 159s ok 56 - Bundle the default target plan file 159s ok 57 - _build/sql/engine/sqitch.plan exists 159s ok 58 - _build/sql/engine/sqitch.plan and engine/sqitch.plan contents are the same 159s ok 59 - Should have plan notice 159s ok 60 - '--from bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 61 - From should be "widgets" 159s ok 62 - Bundle the default target plan file with from arg 159s ok 63 - Statement of the bits written should have been emitted 159s ok 64 - Plan should contain only changes from "widgets" on 159s ok 65 - '--to bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 66 - To should be "users" 159s ok 67 - Bundle the default target plan file with to arg 159s ok 68 - Statement of the bits written should have been emitted 159s ok 69 - Plan should have written only "users" and its tags 159s ok 70 - _build/sql/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 71 - _build/sql/engine/reworked/revert/users@alpha.sql does not exist 159s ok 72 - _build/sql/engine/deploy/widgets.sql does not exist 159s ok 73 - _build/sql/engine/revert/widgets.sql does not exist 159s ok 74 - _build/sql/engine/deploy/func/add_user.sql does not exist 159s ok 75 - _build/sql/engine/revert/func/add_user.sql does not exist 159s ok 76 - _build/sql/engine/deploy/users.sql does not exist 159s ok 77 - _build/sql/engine/revert/users.sql does not exist 159s ok 78 - 'another bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 79 - Bundle default target scripts 159s ok 80 - _build/sql/engine/reworked/deploy/users@alpha.sql exists 159s ok 81 - _build/sql/engine/reworked/revert/users@alpha.sql exists 159s ok 82 - _build/sql/engine/deploy/widgets.sql exists 159s ok 83 - _build/sql/engine/revert/widgets.sql exists 159s ok 84 - _build/sql/engine/deploy/func/add_user.sql exists 159s ok 85 - _build/sql/engine/revert/func/add_user.sql exists 159s ok 86 - _build/sql/engine/deploy/users.sql exists 159s ok 87 - _build/sql/engine/revert/users.sql exists 159s ok 88 - Should have change notices 159s ok 89 - 'bundle from "widgets"' isa 'App::Sqitch::Command::bundle' 159s ok 90 - Bundle scripts 159s ok 91 - _build/sql/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 92 - _build/sql/engine/reworked/revert/users@alpha.sql does not exist 159s ok 93 - _build/sql/engine/deploy/widgets.sql exists 159s ok 94 - _build/sql/engine/revert/widgets.sql exists 159s ok 95 - Should have changes only from "widets" onward in notices 159s ok 96 - 'bundle to "users"' isa 'App::Sqitch::Command::bundle' 159s ok 97 - Bundle scripts 159s ok 98 - _build/sql/engine/reworked/deploy/users@alpha.sql exists 159s ok 99 - _build/sql/engine/reworked/revert/users@alpha.sql exists 159s ok 100 - _build/sql/engine/deploy/widgets.sql does not exist 159s ok 101 - _build/sql/engine/revert/widgets.sql does not exist 159s ok 102 - Should have only "users" in change notices 159s ok 103 - Should die on nonexistent from change 159s ok 104 - Nonexistent from change ident should be "bundle" 159s ok 105 - Nonexistent from message change should be correct 159s ok 106 - Should die on nonexistent to change 159s ok 107 - Nonexistent to change ident should be "bundle" 159s ok 108 - Nonexistent to message change should be correct 159s ok 109 - _build/sql/sqitch.conf does not exist 159s ok 110 - _build/sql/engine/sqitch.plan does not exist 159s ok 111 - _build/sql/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 112 - _build/sql/engine/reworked/revert/users@alpha.sql does not exist 159s ok 113 - _build/sql/engine/deploy/widgets.sql does not exist 159s ok 114 - _build/sql/engine/revert/widgets.sql does not exist 159s ok 115 - _build/sql/engine/deploy/func/add_user.sql does not exist 159s ok 116 - _build/sql/engine/revert/func/add_user.sql does not exist 159s ok 117 - _build/sql/engine/deploy/users.sql does not exist 159s ok 118 - _build/sql/engine/revert/users.sql does not exist 159s ok 119 - 'another bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 120 - Execute! 159s ok 121 - _build/sql/sqitch.conf exists 159s ok 122 - _build/sql/engine/sqitch.plan exists 159s ok 123 - _build/sql/engine/reworked/deploy/users@alpha.sql exists 159s ok 124 - _build/sql/engine/reworked/revert/users@alpha.sql exists 159s ok 125 - _build/sql/engine/deploy/widgets.sql exists 159s ok 126 - _build/sql/engine/revert/widgets.sql exists 159s ok 127 - _build/sql/engine/deploy/func/add_user.sql exists 159s ok 128 - _build/sql/engine/revert/func/add_user.sql exists 159s ok 129 - _build/sql/engine/deploy/users.sql exists 159s ok 130 - _build/sql/engine/revert/users.sql exists 159s ok 131 - Should have all notices 159s ok 132 - _build/multiplan.conf does not exist 159s ok 133 - _build/sql/sqitch.plan does not exist 159s ok 134 - _build/sql/deploy/roles.sql does not exist 159s ok 135 - _build/sql/deploy/users.sql does not exist 159s ok 136 - _build/sql/verify/users.sql does not exist 159s ok 137 - _build/sql/deploy/widgets.sql does not exist 159s ok 138 - _build/engine/sqitch.plan does not exist 159s ok 139 - _build/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 140 - _build/engine/reworked/revert/users@alpha.sql does not exist 159s ok 141 - _build/engine/deploy/widgets.sql does not exist 159s ok 142 - _build/engine/revert/widgets.sql does not exist 159s ok 143 - _build/engine/deploy/func/add_user.sql does not exist 159s ok 144 - _build/engine/revert/func/add_user.sql does not exist 159s ok 145 - _build/engine/deploy/users.sql does not exist 159s ok 146 - _build/engine/revert/users.sql does not exist 159s ok 147 - 'all multiplan bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 148 - Execute multi-target bundle! 159s ok 149 - _build/multiplan.conf exists 159s ok 150 - _build/sql/sqitch.plan exists 159s ok 151 - _build/sql/deploy/roles.sql exists 159s ok 152 - _build/sql/deploy/users.sql exists 159s ok 153 - _build/sql/verify/users.sql exists 159s ok 154 - _build/sql/deploy/widgets.sql exists 159s ok 155 - _build/engine/sqitch.plan exists 159s ok 156 - _build/engine/reworked/deploy/users@alpha.sql exists 159s ok 157 - _build/engine/reworked/revert/users@alpha.sql exists 159s ok 158 - _build/engine/deploy/widgets.sql exists 159s ok 159 - _build/engine/revert/widgets.sql exists 159s ok 160 - _build/engine/deploy/func/add_user.sql exists 159s ok 161 - _build/engine/revert/func/add_user.sql exists 159s ok 162 - _build/engine/deploy/users.sql exists 159s ok 163 - _build/engine/revert/users.sql exists 159s ok 164 - Should have a warning about --from and -too 159s ok 165 - Should get an error for --all and a target arg 159s ok 166 - Mixed arguments error ident should be "bundle" 159s ok 167 - Mixed arguments error message should be correct 159s ok 168 - 'multiplan bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 169 - Execute with no arg 159s ok 170 - _build/multiplan.conf exists 159s ok 171 - _build/engine/sqitch.plan exists 159s ok 172 - _build/engine/reworked/deploy/users@alpha.sql exists 159s ok 173 - _build/engine/reworked/revert/users@alpha.sql exists 159s ok 174 - _build/engine/deploy/widgets.sql exists 159s ok 175 - _build/engine/revert/widgets.sql exists 159s ok 176 - _build/engine/deploy/func/add_user.sql exists 159s ok 177 - _build/engine/revert/func/add_user.sql exists 159s ok 178 - _build/engine/deploy/users.sql exists 159s ok 179 - _build/engine/revert/users.sql exists 159s ok 180 - _build/sql/sqitch.plan does not exist 159s ok 181 - _build/sql/deploy/roles.sql does not exist 159s ok 182 - _build/sql/deploy/users.sql does not exist 159s ok 183 - _build/sql/verify/users.sql does not exist 159s ok 184 - _build/sql/deploy/widgets.sql does not exist 159s ok 185 - Execute with bundle.all config 159s ok 186 - _build/multiplan.conf exists 159s ok 187 - _build/engine/sqitch.plan exists 159s ok 188 - _build/engine/reworked/deploy/users@alpha.sql exists 159s ok 189 - _build/engine/reworked/revert/users@alpha.sql exists 159s ok 190 - _build/engine/deploy/widgets.sql exists 159s ok 191 - _build/engine/revert/widgets.sql exists 159s ok 192 - _build/engine/deploy/func/add_user.sql exists 159s ok 193 - _build/engine/revert/func/add_user.sql exists 159s ok 194 - _build/engine/deploy/users.sql exists 159s ok 195 - _build/engine/revert/users.sql exists 159s ok 196 - _build/sql/sqitch.plan exists 159s ok 197 - _build/sql/deploy/roles.sql exists 159s ok 198 - _build/sql/deploy/users.sql exists 159s ok 199 - _build/sql/verify/users.sql exists 159s ok 200 - _build/sql/deploy/widgets.sql exists 159s ok 201 - Execute with target arg "pg" 159s ok 202 - _build/multiplan.conf exists 159s ok 203 - _build/engine/sqitch.plan exists 159s ok 204 - _build/engine/reworked/deploy/users@alpha.sql exists 159s ok 205 - _build/engine/reworked/revert/users@alpha.sql exists 159s ok 206 - _build/engine/deploy/widgets.sql exists 159s ok 207 - _build/engine/revert/widgets.sql exists 159s ok 208 - _build/engine/deploy/func/add_user.sql exists 159s ok 209 - _build/engine/revert/func/add_user.sql exists 159s ok 210 - _build/engine/deploy/users.sql exists 159s ok 211 - _build/engine/revert/users.sql exists 159s ok 212 - _build/sql/sqitch.plan does not exist 159s ok 213 - _build/sql/deploy/roles.sql does not exist 159s ok 214 - _build/sql/deploy/users.sql does not exist 159s ok 215 - _build/sql/verify/users.sql does not exist 159s ok 216 - _build/sql/deploy/widgets.sql does not exist 159s ok 217 - Execute with plan file arg "engine/sqitch.plan" 159s ok 218 - _build/multiplan.conf exists 159s ok 219 - _build/engine/sqitch.plan exists 159s ok 220 - _build/engine/reworked/deploy/users@alpha.sql exists 159s ok 221 - _build/engine/reworked/revert/users@alpha.sql exists 159s ok 222 - _build/engine/deploy/widgets.sql exists 159s ok 223 - _build/engine/revert/widgets.sql exists 159s ok 224 - _build/engine/deploy/func/add_user.sql exists 159s ok 225 - _build/engine/revert/func/add_user.sql exists 159s ok 226 - _build/engine/deploy/users.sql exists 159s ok 227 - _build/engine/revert/users.sql exists 159s ok 228 - _build/sql/sqitch.plan does not exist 159s ok 229 - _build/sql/deploy/roles.sql does not exist 159s ok 230 - _build/sql/deploy/users.sql does not exist 159s ok 231 - _build/sql/verify/users.sql does not exist 159s ok 232 - _build/sql/deploy/widgets.sql does not exist 159s ok 233 - Execute with target arg "mysql" 159s ok 234 - _build/multiplan.conf exists 159s ok 235 - _build/sql/sqitch.plan exists 159s ok 236 - _build/sql/deploy/roles.sql exists 159s ok 237 - _build/sql/deploy/users.sql exists 159s ok 238 - _build/sql/verify/users.sql exists 159s ok 239 - _build/sql/deploy/widgets.sql exists 159s ok 240 - _build/engine/sqitch.plan does not exist 159s ok 241 - _build/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 242 - _build/engine/reworked/revert/users@alpha.sql does not exist 159s ok 243 - _build/engine/deploy/widgets.sql does not exist 159s ok 244 - _build/engine/revert/widgets.sql does not exist 159s ok 245 - _build/engine/deploy/func/add_user.sql does not exist 159s ok 246 - _build/engine/revert/func/add_user.sql does not exist 159s ok 247 - _build/engine/deploy/users.sql does not exist 159s ok 248 - _build/engine/revert/users.sql does not exist 159s ok 249 - Execute with plan file arg "sql/sqitch.plan" 159s ok 250 - _build/multiplan.conf exists 159s ok 251 - _build/sql/sqitch.plan exists 159s ok 252 - _build/sql/deploy/roles.sql exists 159s ok 253 - _build/sql/deploy/users.sql exists 159s ok 254 - _build/sql/verify/users.sql exists 159s ok 255 - _build/sql/deploy/widgets.sql exists 159s ok 256 - _build/engine/sqitch.plan does not exist 159s ok 257 - _build/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 258 - _build/engine/reworked/revert/users@alpha.sql does not exist 159s ok 259 - _build/engine/deploy/widgets.sql does not exist 159s ok 260 - _build/engine/revert/widgets.sql does not exist 159s ok 261 - _build/engine/deploy/func/add_user.sql does not exist 159s ok 262 - _build/engine/revert/func/add_user.sql does not exist 159s ok 263 - _build/engine/deploy/users.sql does not exist 159s ok 264 - _build/engine/revert/users.sql does not exist 159s ok 265 - 'to/from bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 266 - Execute to/from bundle! 159s ok 267 - _build/multiplan.conf exists 159s ok 268 - _build/engine/sqitch.plan exists 159s ok 269 - _build/engine/deploy/widgets.sql exists 159s ok 270 - _build/engine/revert/widgets.sql exists 159s ok 271 - _build/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 272 - _build/engine/reworked/revert/users@alpha.sql does not exist 159s ok 273 - _build/engine/deploy/func/add_user.sql does not exist 159s ok 274 - _build/engine/revert/func/add_user.sql does not exist 159s ok 275 - _build/engine/deploy/users.sql does not exist 159s ok 276 - _build/engine/revert/users.sql does not exist 159s ok 277 - Plan should have written only "widgets" 159s ok 278 - 'another bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 279 - Execute bundle with to/from args! 159s ok 280 - _build/multiplan.conf exists 159s ok 281 - _build/engine/sqitch.plan exists 159s ok 282 - _build/engine/deploy/widgets.sql exists 159s ok 283 - _build/engine/revert/widgets.sql exists 159s ok 284 - _build/engine/deploy/func/add_user.sql exists 159s ok 285 - _build/engine/revert/func/add_user.sql exists 159s ok 286 - _build/engine/deploy/users.sql exists 159s ok 287 - _build/engine/revert/users.sql exists 159s ok 288 - _build/engine/reworked/deploy/users@alpha.sql does not exist 159s ok 289 - _build/engine/reworked/revert/users@alpha.sql does not exist 159s ok 290 - Plan should have written "widgets" and "func/add_user" 159s ok 291 - Should get an exception for unknown argument 159s ok 292 - Unknown argument error ident shoud be "bundle" 159s ok 293 - Unknown argument error message should be correct 159s ok 294 - Should get an exception for unknown arguments 159s ok 295 - Unknown arguments error ident shoud be "bundle" 159s ok 296 - Unknown arguments error message should be correct 159s ok 297 - 'all multiplan bundle command' isa 'App::Sqitch::Command::bundle' 159s ok 298 - Should get an exception a change name and --from 159s ok 299 - Conflicting arguments error ident shoud be "bundle" 159s ok 300 - Conflicting arguments error message should be correct 159s ok 301 - no warnings 159s ok 160s t/change.t .......... 160s 1..92 160s ok 1 - require App::Sqitch::Plan::Change; 160s ok 2 - App::Sqitch::Plan::Change->can(...) 160s ok 3 - An object of class 'App::Sqitch::Plan::Change' isa 'App::Sqitch::Plan::Change' 160s ok 4 - An object of class 'App::Sqitch::Plan::Change' isa 'App::Sqitch::Plan::Line' 160s ok 5 - It should be a deploy change 160s ok 6 - It should not be a revert change 160s ok 7 - And it should say so 160s ok 8 - 'Timestamp' isa 'App::Sqitch::DateTime' 160s ok 9 - path_segments should have the file name 160s ok 10 - The deploy dir should be correct 160s ok 11 - The deploy file should be correct 160s ok 12 - The revert dir should be correct 160s ok 13 - The revert file should be correct 160s ok 14 - The verify dir should be correct 160s ok 15 - The verify file should be correct 160s ok 16 - The change should not be reworked 160s ok 17 - path_segments should not include suffix 160s ok 18 - Nonexistent deploy script hash should be undef 160s ok 19 - Deploy script hash should be correct 160s ok 20 - Tag-qualified name should be tagged with @HEAD 160s ok 21 - Add a rework tag 160s ok 22 - Reworked tag should be stored 160s ok 23 - The change should be reworked 160s ok 24 - path_segments should now include suffix 160s ok 25 - The change should not be reworked 160s ok 26 - Add two rework tags 160s ok 27 - The change should again be reworked 160s ok 28 - path_segments should now include the correct suffixc 160s ok 29 - Name should format as "foo" 160s ok 30 - Name should format with tags as "foo" 160s ok 31 - Tag-qualified Name should format as "foo@beta" 160s ok 32 - Dependencies should format as "" 160s ok 33 - Name should format with dependencies as "foo" 160s ok 34 - Name should format op without dependencies as "foo" 160s ok 35 - Change content should format correctly without dependencies 160s ok 36 - Planner name shoudld default to user name 160s ok 37 - Planner email shoudld default to user email 160s ok 38 - Planner name and email should format properly 160s ok 39 - should stringify to "foo" + planner 160s ok 40 - Since tag should be undef 160s ok 41 - Parent should be undef 160s ok 42 - Change info should be correct 160s ok 43 - Change ID should be correct 160s ok 44 - Create change with more stuff 160s ok 45 - It should stringify correctly 160s ok 46 - It should not be a deploy change 160s ok 47 - It should be a revert change 160s ok 48 - It should say so 160s ok 49 - It should have a since tag 160s ok 50 - It should have a parent 160s ok 51 - Info should include parent and dependencies 160s ok 52 - Should have no tags 160s ok 53 - Add a tag 160s ok 54 - Should have the tag 160s ok 55 - Should format name with tags 160s ok 56 - Should format tag-qualiified name 160s ok 57 - Add another tag 160s ok 58 - Should have both tags 160s ok 59 - Should format name with both tags 160s ok 60 - Should format tag-qualified name with first tag 160s ok 61 - Planner name and email should format properly 160s ok 62 - Dependencies should format as "[foo bar @baz !dr_evil]" 160s ok 63 - Name should format with dependencies as "yo/howdy [foo bar @baz !dr_evil]" 160s ok 64 - Name should format op with dependencies as "yo/howdy [foo bar @baz !dr_evil]" 160s ok 65 - Change content should format correctly with dependencies 160s ok 66 - path_segments should include directories 160s ok 67 - Deploy dir should be in rworked dir 160s ok 68 - Deploy file should be in rworked dir and include suffix 160s ok 69 - Revert dir should be in rworked dir 160s ok 70 - Revert file should be in rworked dir and include suffix 160s ok 71 - Verify dir should be in rworked dir 160s ok 72 - Verify file should be in rworked dir and include suffix 160s ok 73 - Create change "baz" 160s ok 74 - Create change "bar" 160s ok 75 - Get deploy handle 160s ok 76 - It should be the deploy file 160s ok 77 - Get revert handle 160s ok 78 - It should be the revert file 160s ok 79 - Get verify handle 160s ok 80 - It should be the verify file 160s ok 81 - Create a change with explicit requires and conflicts 160s ok 82 - requires should be set 160s ok 83 - conflicts should be set 160s ok 84 - Dependencies should include requires and conflicts 160s ok 85 - Should find changes for requires 160s ok 86 - Should find changes for conflicts 160s ok 87 - Create change with UTF-8 name 160s ok 88 - The name should be decoded text in info 160s ok 89 - Change ID should be hashed from encoded UTF-8 160s ok 90 - note_prompt() should work 160s ok 91 - note_prompt() should work 160s ok 92 - no warnings 160s ok 161s t/changelist.t ...... 161s 1..248 161s ok 1 - require App::Sqitch::Plan::ChangeList; 161s ok 2 - Count should be six 161s ok 3 - Changes should be in order 161s ok 4 - Items should be the same as changes 161s ok 5 - Tags should return the one tag 161s ok 6 - Should have foo at 0 161s ok 7 - Should have bar at 1 161s ok 8 - Should have yo1 at 2 161s ok 9 - Should have baz at 4 161s ok 10 - Should have yo2 at 5 161s ok 11 - Should not find "non" 161s ok 12 - Should not find "@non" 161s ok 13 - Should find foo at 0 161s ok 14 - Should find foo by ID at 0 161s ok 15 - Should find bar at 1 161s ok 16 - Should find bar^ at 0 161s ok 17 - Should find bar~ at 2 161s ok 18 - Should find bar~~ at 3 161s ok 19 - Should not find bar~~~ 161s ok 20 - Should find bar~2 at 3 161s ok 21 - Should find bar~3 at 4 161s ok 22 - Should find bar by ID at 1 161s ok 23 - Should find @alpha at 2 161s ok 24 - Should find @alpha^ at 1 161s ok 25 - Should find @alpha^^ at 1 161s ok 26 - Should not find @alpha^^^ 161s ok 27 - Should find @alpha by ID at 2 161s ok 28 - Should find baz at 3 161s ok 29 - Should find baz by ID at 3 161s ok 30 - Should not find baz^^^ 161s ok 31 - Should not find baz^3 at 0 161s ok 32 - Should not find baz^4 161s ok 33 - Should find baz by ID^ at 2 161s ok 34 - Should get multiple indexes error looking for index of "yo" 161s ok 35 - Multiple indexes error ident should be "plan" 161s ok 36 - Multiple indexes message should be correct 161s ok 37 - Should have output listing tag-qualified changes 161s ok 38 - Should unknown tag error for invalid tag 161s ok 39 - Unknown tag error ident should be "plan" 161s ok 40 - Unknown taf message should be correct 161s ok 41 - Should get 2 for yo@alpha 161s ok 42 - Should get 1 for yo@alpha^ 161s ok 43 - Should get 4 for yo@HEAD 161s ok 44 - Should get 3 for yo@HEAD^ 161s ok 45 - Should get undef for yo@HEAD~ 161s ok 46 - Should get undef for yo@HEAD~~ 161s ok 47 - Should get 0 for foo@alpha 161s ok 48 - Should get 0 for foo@HEAD 161s ok 49 - Should get 0 for foo@ROOT 161s ok 50 - Should get undef for baz@alpha 161s ok 51 - Should get 3 for baz@HEAD 161s ok 52 - Should get 4 for @HEAD 161s ok 53 - Should get 0 for @ROOT 161s ok 54 - Should get 3 for @HEAD^ 161s ok 55 - Should get undef for @HEAD~ 161s ok 56 - Should get 1 for @ROOT~ 161s ok 57 - Should get undef for @ROOT^ 161s ok 58 - Should get 4 for HEAD 161s ok 59 - Should get 0 for ROOT 161s ok 60 - Should get 3 for HEAD^ 161s ok 61 - Should get undef for HEAD~ 161s ok 62 - Should get 1 for ROOT~ 161s ok 63 - Should get undef for ROOT^ 161s ok 64 - Should get foo for "foo" 161s ok 65 - Should get bar for "foo~" 161s ok 66 - Should get foo by ID 161s ok 67 - Should get bar for "bar" 161s ok 68 - Should get foo for "bar^" 161s ok 69 - Should get yo1 for "bar~" 161s ok 70 - Should get baz for "bar~~" 161s ok 71 - Should get yo2 for "bar~3" 161s ok 72 - Should get bar by ID 161s ok 73 - Should get "yo" by the @alpha tag ID 161s ok 74 - Should get baz for "baz" 161s ok 75 - Should get baz by ID 161s ok 76 - Should get baz for "@HEAD^" 161s ok 77 - Should get yo1 for "@HEAD^^" 161s ok 78 - Should get bar for "@HEAD^3" 161s ok 79 - Should get foo for "@ROOT" 161s ok 80 - Should get baz for "HEAD^" 161s ok 81 - Should get yo1 for "HEAD^^" 161s ok 82 - Should get bar for "HEAD^3" 161s ok 83 - Should get foo for "ROOT" 161s ok 84 - Should get yo1 for yo@alpha 161s ok 85 - Should get yo2 for yo@HEAD 161s ok 86 - Should get foo for foo@alpha 161s ok 87 - Should get foo for foo@HEAD 161s ok 88 - Should get undef for baz@alpha 161s ok 89 - Should get baz for baz@HEAD 161s ok 90 - Should get yo2 for "yo@HEAD" 161s ok 91 - Should get foo for "foo@ROOT" 161s ok 92 - Should find yo1 with "yo" 161s ok 93 - Should find yo1 with "yo@alpha" 161s ok 94 - Should find yo2 with yo@HEAD 161s ok 95 - Should find foo for "foo" 161s ok 96 - Should find foo for "foo@alpha" 161s ok 97 - Should find foo for "foo@HEAD" 161s ok 98 - Should find bar with "yo^" 161s ok 99 - Should find foo with "yo^^" 161s ok 100 - Should find foo with "yo^2" 161s ok 101 - Should find baz with "yo~" 161s ok 102 - Should find yo2 with "yo~~" 161s ok 103 - Should find yo2 with "yo~2" 161s ok 104 - Should find bar with "yo@alpha^" 161s ok 105 - Should find baz with "yo@alpha^" 161s ok 106 - Should find baz with yo@HEAD^ 161s ok 107 - Should find baz with @HEAD^ 161s ok 108 - Should find bar with @ROOT~^ 161s ok 109 - Should find baz with HEAD^ 161s ok 110 - Should find bar with ROOT~^ 161s ok 111 - Should contain yo1 with "yo" 161s ok 112 - Should contain yo1 with "yo@alpha" 161s ok 113 - Should contain yo2 with yo@HEAD 161s ok 114 - Should contain foo for "foo" 161s ok 115 - Should contain foo for "foo@alpha" 161s ok 116 - Should contain foo for "foo@HEAD" 161s ok 117 - Should contain bar with "yo^" 161s ok 118 - Should contain foo with "yo^^" 161s ok 119 - Should contain foo with "yo^2" 161s ok 120 - Should contain baz with "yo~" 161s ok 121 - Should contain yo2 with "yo~~" 161s ok 122 - Should contain yo2 with "yo~2" 161s ok 123 - Should contain bar with "yo@alpha^" 161s ok 124 - Should contain baz with "yo@alpha^" 161s ok 125 - Should contain baz with yo@HEAD^ 161s ok 126 - Should contain baz with @HEAD^ 161s ok 127 - Should contain bar with @ROOT~^ 161s ok 128 - Should contain baz with HEAD^ 161s ok 129 - Should contain bar with ROOT~^ 161s ok 130 - Should get multiple indexes error looking for index of "yo" 161s ok 131 - Multiple indexes error ident should be "plan" 161s ok 132 - Multiple indexes message should be correct 161s ok 133 - Should have output listing tag-qualified changes 161s ok 134 - Should unknown tag error for invalid tag 161s ok 135 - Unknown tag error ident should be "plan" 161s ok 136 - Unknown taf message should be correct 161s ok 137 - Push hi 161s ok 138 - Count should now be six 161s ok 139 - Changes should be in order with $hi at the end 161s ok 140 - Should find "hi" at index 5 161s ok 141 - Should find "hi" by ID at index 5 161s ok 142 - Index of @ROOT should still be 0 161s ok 143 - Index of @HEAD should now be 5 161s ok 144 - Index of ROOT should still be 0 161s ok 145 - Index of HEAD should now be 5 161s ok 146 - First index of "non" should be undef 161s ok 147 - First index of "foo" should be 0 161s ok 148 - First index of "foo~" should be 1 161s ok 149 - First index of "foo~~" should be 2 161s ok 150 - First index of "foo~3" should be 3 161s ok 151 - Should not find first index of "foo~~~" 161s ok 152 - First index of "foo" since @ROOT should be undef 161s ok 153 - First index of "bar" should be 1 161s ok 154 - First index of "yo" should be 2 161s ok 155 - First index of "yo" since @ROOT should be 2 161s ok 156 - First index of "baz" should be 3 161s ok 157 - First index of "baz^" should be 2 161s ok 158 - First index of "baz^^" should be 1 161s ok 159 - First index of "baz^3" should be 0 161s ok 160 - Should not find first index of "baz^^^" 161s ok 161 - First index of "yo" since "@alpha" should be 4 161s ok 162 - First index of "yo" since "baz" should be 4 161s ok 163 - First index of "yo^" since "baz" should be 4 161s ok 164 - First index of "yo~" since "baz" should be 5 161s ok 165 - Should get an exception for an unknown change passed to first_index_of() 161s ok 166 - Unknown change error ident should be "plan" 161s ok 167 - Unknown change message should be correct 161s ok 168 - Push so and fu 161s ok 169 - Count should now be eight 161s ok 170 - Index of @ROOT should remain 0 161s ok 171 - Index of @HEAD should now be 7 161s ok 172 - Index of ROOT should remain 0 161s ok 173 - Index of HEAD should now be 7 161s ok 174 - Changes should be in order with $so and $fu at the end 161s ok 175 - Index beta 161s ok 176 - Should find @beta at index 4 161s ok 177 - Should find yo2 via @beta 161s ok 178 - Should find yo2 via @beta ID 161s ok 179 - Tags should return both tags 161s ok 180 - Should get 2 for last tagged index 161s ok 181 - Should find "yo" as last tagged 161s ok 182 - Should get 8 for count 161s ok 183 - Should find fu as last change 161s ok 184 - Should find last tagged index at 0 161s ok 185 - Should find last tagged at 0 161s ok 186 - Should get count 1 161s ok 187 - Should find last change at 0 161s ok 188 - Should find last tagged index at 1 161s ok 189 - Should find last tagged at 1 161s ok 190 - Should get count 2 161s ok 191 - Should find last change at 1 161s ok 192 - Should find last tagged index at 3 161s ok 193 - Should find last tagged at 3 161s ok 194 - Should get count 4 161s ok 195 - Should find last change at 3 161s ok 196 - Should find last tagged index at 4 161s ok 197 - Should find last tagged at 4 161s ok 198 - Should get count 5 161s ok 199 - Should find last change at 4 161s ok 200 - Should not find tag index in 0 changes 161s ok 201 - Should not find tag in 0 changes 161s ok 202 - Should find no change in empty plan 161s ok 203 - Should not find tag index in 2 changes 161s ok 204 - Should not find tag in 2 changes 161s ok 205 - Should not find tag index in 4 changes 161s ok 206 - Should not find tag in 4 changes 161s ok 207 - An object of class 'App::Sqitch::Plan::ChangeList' isa 'App::Sqitch::Plan::ChangeList' 161s ok 208 - Should not find index of "foo" in empty list 161s ok 209 - Should not find first index of "foo" in empty list 161s ok 210 - Should get undef for "foo" in empty list 161s ok 211 - Should not contain "foo" in empty list 161s ok 212 - Should find undef for "foo" in empty list 161s ok 213 - Should not find index of "bar" in empty list 161s ok 214 - Should not find first index of "bar" in empty list 161s ok 215 - Should get undef for "bar" in empty list 161s ok 216 - Should not contain "bar" in empty list 161s ok 217 - Should find undef for "bar" in empty list 161s ok 218 - Should not find index of "HEAD" in empty list 161s ok 219 - Should not find first index of "HEAD" in empty list 161s ok 220 - Should get undef for "HEAD" in empty list 161s ok 221 - Should not contain "HEAD" in empty list 161s ok 222 - Should find undef for "HEAD" in empty list 161s ok 223 - Should not find index of "@HEAD" in empty list 161s ok 224 - Should not find first index of "@HEAD" in empty list 161s ok 225 - Should get undef for "@HEAD" in empty list 161s ok 226 - Should not contain "@HEAD" in empty list 161s ok 227 - Should find undef for "@HEAD" in empty list 161s ok 228 - Should not find index of "ROOT" in empty list 161s ok 229 - Should not find first index of "ROOT" in empty list 161s ok 230 - Should get undef for "ROOT" in empty list 161s ok 231 - Should not contain "ROOT" in empty list 161s ok 232 - Should find undef for "ROOT" in empty list 161s ok 233 - Should not find index of "@ROOT" in empty list 161s ok 234 - Should not find first index of "@ROOT" in empty list 161s ok 235 - Should get undef for "@ROOT" in empty list 161s ok 236 - Should not contain "@ROOT" in empty list 161s ok 237 - Should find undef for "@ROOT" in empty list 161s ok 238 - Should not find index of "alpha" in empty list 161s ok 239 - Should not find first index of "alpha" in empty list 161s ok 240 - Should get undef for "alpha" in empty list 161s ok 241 - Should not contain "alpha" in empty list 161s ok 242 - Should find undef for "alpha" in empty list 161s ok 243 - Should not find index of "@alpha" in empty list 161s ok 244 - Should not find first index of "@alpha" in empty list 161s ok 245 - Should get undef for "@alpha" in empty list 161s ok 246 - Should not contain "@alpha" in empty list 161s ok 247 - Should find undef for "@alpha" in empty list 161s ok 248 - no warnings 161s ok 162s t/check.t ........... 162s ok 1 - require App::Sqitch::Command::check; 162s ok 2 - The class (or class-like) 'App::Sqitch::Command::check' isa 'App::Sqitch::Command' 162s ok 3 - App::Sqitch::Command::check->can(...) 162s ok 4 - App::Sqitch::Command::check does ContextCommand 162s ok 5 - App::Sqitch::Command::check does ConnectingCommand 162s ok 6 - Options should be correct 162s ok 7 - Should parse options 162s ok 8 - Options should not conflict with core options 162s ok 9 - Should have default configuration with no config or opts 162s ok 10 - Should have changes and variables from options 162s ok 11 - Should have no config if no options 162s ok 12 - 'new status with target' isa 'App::Sqitch::Command::check' 162s ok 13 - Should have target "foo" 162s ok 14 - An object of class 'App::Sqitch::Command::check' isa 'App::Sqitch::Command::check' 162s ok 15 - Default target should be undef 162s ok 16 - from_change should be undef 162s ok 17 - to_change should be undef 162s ok 18 - Should collect no variables 162s ok 19 - Should collect core vars 162s ok 20 - Should override core vars with deploy vars 162s ok 21 - Should override deploy vars with check vars 162s ok 22 - Should override check vars with engine vars 162s ok 23 - Should override engine vars with target vars 162s ok 24 - Should override target vars with --set variables 162s ok 25 - Execute with nothing. 162s ok 26 - Two undefs should be passed to the engine 162s ok 27 - Should have no warnings 162s ok 28 - Execute from "@alpha" 162s ok 29 - "@alpha" and undef should be passed to the engine 162s ok 30 - Should again have no warnings 162s ok 31 - Execute from "@alpha" to "@beta" 162s ok 32 - "@alpha" and "@beat" should be passed to the engine 162s ok 33 - Should still have no warnings 162s ok 34 - 'Object with from, to, and variables' isa 'App::Sqitch::Command::check' 162s ok 35 - Execute again 162s ok 36 - "foo" and "bar" should be passed to the engine 162s ok 37 - Vars should have been passed through to the engine 162s ok 38 - Still should have no warnings 162s ok 39 - Execute with command-line args 162s ok 40 - "foo" and "bar" should be passed to the engine 162s ok 41 - Vars should have been passed through to the engine 162s ok 42 - Should have warning about which roles are used 162s ok 43 - Execute with target arg 162s ok 44 - The target should have been passed to the engine 162s ok 45 - "foo" and "bar" should be passed to the engine 162s ok 46 - Vars should have been passed through to the engine 162s ok 47 - Should once again have no warnings 162s ok 48 - 'Object with target' isa 'App::Sqitch::Command::check' 162s ok 49 - Execute with no args 162s ok 50 - The target option should have been passed to the engine 162s ok 51 - Undefs should be passed to the engine 162s ok 52 - No vars should have been passed through to the engine 162s ok 53 - Should once again have no warnings 162s ok 54 - Execute with two targegs and two changes 162s ok 55 - The target option should have been passed to the engine 162s ok 56 - The two changes should be passed to the engine 162s ok 57 - No vars should have been passed through to the engine 162s ok 58 - Should have warning about too many targets 162s ok 59 - Should get an exception for unknown arg 162s ok 60 - Unknown arg ident should be "check" 162s ok 61 - Should get an exeption for two unknown arg 162s ok 62 - Should get an exception for unknown args 162s ok 63 - Unknown args ident should be "check" 162s ok 64 - Should get an exeption for two unknown args 162s 1..64 162s ok 163s t/checkout.t ........ 163s ok 1 - require App::Sqitch::Command::checkout; 163s ok 2 - The class (or class-like) 'App::Sqitch::Command::checkout' isa 'App::Sqitch::Command' 163s ok 3 - App::Sqitch::Command::checkout->can(...) 163s ok 4 - App::Sqitch::Command::checkout does RevertDeployCommand 163s ok 5 - App::Sqitch::Command::checkout does ConnectingCommand 163s ok 6 - App::Sqitch::Command::checkout does ContextCommand 163s ok 7 - Options should be correct 163s ok 8 - Should parse options 163s ok 9 - Options should not conflict with core options 163s ok 10 - Load a sqitch object 163s ok 11 - Check default configuration 163s ok 12 - Should have set option 163s ok 13 - Should have mode, deploy_variables, verify, no_prompt, log_only, & lock_timeout 163s ok 14 - Should have set_revert option and no_prompt false 163s ok 15 - set_deploy and set_revert should overrid set 163s ok 16 - set_deploy and set_revert should merge with set 163s ok 17 - set_revert should merge with set_deploy 163s ok 18 - Should have deploy configuration 163s ok 19 - Should have merged variables 163s ok 20 - Should have no_prompt and prompt_accept from revert config 163s ok 21 - Should have false log_only, verify, true prompt_accept from checkout config 163s ok 22 - Should have log_only, prompt_accept true from checkout and verify from deploy 163s ok 23 - Should have log_only false and mode all again 163s ok 24 - Should have log_only false for false config 163s ok 25 - Should have no_prompt true with -y 163s ok 26 - revert.strict should die 163s ok 27 - Strict err ident should be "checkout" 163s ok 28 - Should have corect strict error message 163s ok 29 - checkout.strict should die 163s ok 30 - Strict err ident should be "checkout" 163s ok 31 - Should have corect strict error message 163s ok 32 - App::Sqitch::X 163s ok 33 - Should collect no variables for deploy 163s ok 34 - Should collect no variables for revert 163s ok 35 - Should collect core deploy vars for deploy 163s ok 36 - Should collect core revert vars for revert 163s ok 37 - Should override core vars with deploy vars for deploy 163s ok 38 - Should override core vars with deploy vars for revert 163s ok 39 - Deploy vars should be unaffected by revert vars 163s ok 40 - Should override deploy vars with revert vars for revert 163s ok 41 - Should override deploy vars with engine vars for deploy 163s ok 42 - Should override checkout vars with engine vars for revert 163s ok 43 - Should override engine vars with deploy vars for deploy 163s ok 44 - Should override engine vars with target vars for revert 163s ok 45 - Should override target vars with --set vars for deploy 163s ok 46 - Should override target vars with --set variables for revert 163s ok 47 - Should override --set vars with --set-deploy variables for deploy 163s ok 48 - Should not override --set vars with --set-deploy variables for revert 163s ok 49 - Should not override --set vars with --set-revert variables for deploy 163s ok 50 - Should override --set vars with --set-revert variables for revert 163s ok 51 - 'checkout command' isa 'App::Sqitch::Command::checkout' 163s ok 52 - Should get an error current branch 163s ok 53 - Current branch error ident should be "checkout" 163s ok 54 - Should get proper error for current branch error 163s ok 55 - The proper args should have been passed to rev-parse 163s ok 56 - Should get an error for plans without a common change 163s ok 57 - The no common change error ident should be "checkout" 163s ok 58 - The no common change error message should be correct 163s ok 59 - No branch arg should yield usage 163s ok 60 - No args should be passed to usage 163s ok 61 - Empty branch arg should yield usage 163s ok 62 - No args should be passed to usage 163s ok 63 - 'Object with to and variables' isa 'App::Sqitch::Command::checkout' 163s ok 64 - Checkout main 163s ok 65 - The proper args should again have been passed to rev-parse 163s ok 66 - Should have requested the plan file contents as of main 163s ok 67 - Should have checked out other branch 163s ok 68 - Should have no warnings 163s ok 69 - Should have emitted info identifying the last common change 163s ok 70 - "users" ID and 1 should be passed to the engine revert 163s ok 71 - Should have had the current changes for revision 163s ok 72 - undef, "tag", and 1 should be passed to the engine deploy 163s ok 73 - Should have had the other branch changes (decoded) for deploy 163s ok 74 - Engine should verify 163s ok 75 - The engine should be set to log_only 163s ok 76 - The lock timeout should be set to 30 163s ok 77 - Variables should have been passed to the engine twice 163s ok 78 - The revert vars should have been passed first 163s ok 79 - The deploy vars should have been next 163s ok 80 - Checkout main with target 163s ok 81 - Target should be passed to engine 163s ok 82 - Should have no warnings 163s ok 83 - 'Object with to and variables' isa 'App::Sqitch::Command::checkout' 163s ok 84 - Checkout main again 163s ok 85 - Target should be passed to engine 163s ok 86 - Should have no warnings 163s ok 87 - The engine should not be set to log_only 163s ok 88 - The lock timeout should be set to the default 163s ok 89 - The engine should not be set with_verfy 163s ok 90 - undef, "tag", and 1 should be passed to the engine deploy again 163s ok 91 - Should have had the other branch changes (decoded) for deploy again 163s ok 92 - Variables should again have been passed to the engine twice 163s ok 93 - The revert vars should again have been passed first 163s ok 94 - The deploy vars should again have been next 163s ok 95 - Checkout main again with target 163s ok 96 - Target should be passed to engine 163s ok 97 - Should have warning about two targets 163s ok 98 - Should get an exception for unknown arg 163s ok 99 - Unknown arg ident should be "checkout" 163s ok 100 - Should get an exception for two unknown arg 163s ok 101 - Should get an exception for unknown args 163s ok 102 - Unknown args ident should be "checkout" 163s ok 103 - Should get an exception for two unknown args 163s ok 104 - Should rethrow confirm exception 163s ok 105 - Should rethrow fatal exception 163s ok 106 - Should rethrow unknown exception 163s 1..106 163s ok 163s t/cockroach.t ....... 163s ok 1 - require App::Sqitch::Engine::cockroach; 163s ok 2 - An object of class 'App::Sqitch::Engine::cockroach' isa 'App::Sqitch::Engine::cockroach' 163s ok 3 - Key should be "cockroach" 163s ok 4 - Name should be "CockroachDB" 163s ok 5 - Driver should be "DBD::Pg 2.0" 163s ok 6 - wait_lock should return 1 163s ok 7 - App::Sqitch::Engine::cockroach->can('_ts2char_format') 163s ok 8 - _ts2char_format should work 163s ok 9 - App::Sqitch::Engine::cockroach->can('_dt') 163s ok 10 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 163s ok 11 - DateTime year should be set 163s ok 12 - DateTime month should be set 163s ok 13 - DateTime day should be set 163s ok 14 - DateTime hour should be set 163s ok 15 - DateTime minute should be set 163s ok 16 - DateTime second should be set 163s ok 17 - DateTime TZ should be set 163s ok 18 - Should have no table error 163s ok 19 - Should have no column error 163s ok 20 - Should again have no table error 163s ok 21 - Should now have no column error 163s ok 22 - Should now have table error 163s ok 23 - Still should have no column error 163s ok 24 - Run the registry file 163s ok 25 - Shoud have deployed the original SQL file 163s ok 26 - The registry should have been added to the search path 163s ok 27 - App::Sqitch::Engine::cockroach->can(...) 163s # Subtest: live database 163s 1..0 # SKIP Unable to live-test CockroachDB engine: DBI connect('host=localhost;port=26257','root',...) failed: connection to server at "localhost" (::1), port 26257 failed: Connection refused 163s Is the server running on that host and accepting TCP/IP connections? 163s connection to server at "localhost" (127.0.0.1), port 26257 failed: Connection refused 163s Is the server running on that host and accepting TCP/IP connections? at t/cockroach.t line 142. 163s ok 28 # skip Unable to live-test CockroachDB engine: DBI connect('host=localhost;port=26257','root',...) failed: connection to server at "localhost" (::1), port 26257 failed: Connection refused 163s # Is the server running on that host and accepting TCP/IP connections? 163s # connection to server at "localhost" (127.0.0.1), port 26257 failed: Connection refused 163s # Is the server running on that host and accepting TCP/IP connections? at t/cockroach.t line 142. 163s # 163s 1..28 163s ok 165s t/command.t ......... 165s 1..199 165s ok 1 - use App::Sqitch::Command; 165s ok 2 - App::Sqitch::Command->can(...) 165s ok 3 - Load a sqitch object 165s ok 4 - Should get an exception for missing sqitch param 165s ok 5 - Should get an exception for array sqitch param 165s ok 6 - Should get an exception for string sqitch param 165s ok 7 - An object of class 'App::Sqitch::Command' isa 'App::Sqitch::Command' 165s ok 8 - Should get empty hash for no config or options 165s ok 9 - Should get config with no options 165s ok 10 - Options should override config 165s ok 11 - Options keys should have dashes changed to underscores 165s ok 12 - Should find class for "whu" 165s ok 13 - Should find class for "wah-hoo" 165s ok 14 - Should find class for "help" 165s ok 15 - Should find no class for "_nonesush" 165s ok 16 - Should have sent error to debug 165s ok 17 - ENGINES should include all engines 165s ok 18 - Load a sqitch object 165s ok 19 - Load a "whu" command 165s ok 20 - An object of class 'App::Sqitch::Command::whu' isa 'App::Sqitch::Command::whu' 165s ok 21 - The sqitch attribute should be set 165s ok 22 - The command method should return "whu" 165s ok 23 - Load a "whu" command with "foo" config 165s ok 24 - The "foo" attribute should be set 165s ok 25 - Should exit 165s ok 26 - Nonexistent command error ident should be "config" 165s ok 27 - Should get proper mesage for nonexistent command 165s ok 28 - Nonexistent command should yield exitval of 1 165s ok 29 - Should die on bad command 165s ok 30 - Bad command error ident should be "config" 165s ok 31 - Should get proper mesage for bad command 165s ok 32 - Bad command should yield exitval of 1 165s ok 33 - No command should yield usage 165s ok 34 - No args should be passed to usage 165s ok 35 - Should die on broken command module 165s ok 36 - Broken command error ident should be "config" 165s ok 37 - Should get proper mesage for broken command 165s ok 38 - Broken command should yield exitval of 1 165s ok 39 - Load a "whu" command with "--feathers" option 165s ok 40 - The "feathers" attribute should be set 165s ok 41 - Load a "wah-hoo" command 165s ok 42 - 'It' isa 'App::Sqitch::Command::wah_hoo' 165s ok 43 - command() should return hyphenated name 165s ok 44 - Create a "whu" command 165s ok 45 - An object of class 'App::Sqitch::Command::whu' isa 'App::Sqitch::Command::whu' 165s ok 46 - The sqitch attribute should be set 165s ok 47 - The command method should return "whu" 165s ok 48 - Create a "whu" command with "foo" config 165s ok 49 - The "foo" attribute should be set 165s ok 50 - Create a "whu" command with "--feathers" option 165s ok 51 - The "feathers" attribute should be set 165s ok 52 - Create an App::Sqitch::Command object 165s ok 53 - 'default target' isa 'App::Sqitch::Target' 165s ok 54 - Default target name should be "db:" 165s ok 55 - Default target URI should be "db:" 165s ok 56 - Create an App::Sqitch::Command object 165s ok 57 - 'default target' isa 'App::Sqitch::Target' 165s ok 58 - Default target name should be "db:sqlite:" 165s ok 59 - Default target URI should be "db:sqlite:" 165s ok 60 - Should have fetched config stuff 165s ok 61 - Create an App::Sqitch::Command object 165s ok 62 - 'default target' isa 'App::Sqitch::Target' 165s ok 63 - Default target name should be "db:pg:foo" 165s ok 64 - Default target URI should be "db:pg:foo" 165s ok 65 - Should have fetched config stuff again 165s ok 66 - App::Sqitch::Command->can('execute') 165s ok 67 - Create an App::Sqitch::Command object 165s ok 68 - Base class command should be "" 165s ok 69 - Base object command should be "" 165s ok 70 - Should get an error calling execute on command base class 165s ok 71 - Execute exception ident should be "DEV" 165s ok 72 - The execute() error message should be correct 165s ok 73 - Create a subclass command object 165s ok 74 - Subclass oject command should be "whu" 165s ok 75 - Subclass class command should be "whu" 165s ok 76 - Should get an error for un-overridden execute() method 165s ok 77 - Un-overidden execute() exception ident should be "DEV" 165s ok 78 - The unoverridden execute() error message should be correct 165s ok 79 - App::Sqitch::Command->can(...) 165s ok 80 - Create an App::Sqitch::Command object again 165s ok 81 - Base _parse_opts should return an empty hash 165s ok 82 - Create a subclass command object again 165s ok 83 - Subclass should return an empty hash for no args 165s ok 84 - Subclass should use options spec 165s ok 85 - Subclass should parse options spec 165s ok 86 - Args array should be cleared of options 165s ok 87 - Should get warning for unknown option 165s ok 88 - Should call _pod2usage on options parse failure 165s ok 89 - 'Good command object' isa 'App::Sqitch::Command::good' 165s ok 90 - Should get warning for unknown option when there are no options 165s ok 91 - Should call _pod2usage on no options parse failure 165s ok 92 - Should get sqitch param from target_params 165s ok 93 - Load Sqitch with config and plan 165s ok 94 - Load cmd with config and plan 165s ok 95 - Parsing no args should return default target 165s ok 96 - Single unknown arg raise an error 165s ok 97 - Unknown error ident should be "whu" 165s ok 98 - Unknown error message should be correct 165s ok 99 - Single invavlid fiile arg raise an error 165s ok 100 - Unknown error ident should be "whu" 165s ok 101 - Unknown file error message should be correct 165s ok 102 - Single change should be recognized as change 165s ok 103 - Single target should be recognized as target 165s ok 104 - URI target should be recognized as target, too 165s ok 105 - Target and change should be recognized 165s ok 106 - Change and target should be recognized 165s ok 107 - Alternate Target and change should be recognized 165s ok 108 - Change and alternate target should be recognized 165s ok 109 - Change, target, and unknown name should be recognized 165s ok 110 - Multiple changes, target, and unknown name should be recognized 165s ok 111 - Multiple names should be recognized 165s ok 112 - Should get an error with name and unknown 165s ok 113 - Unknown error ident should be "whu" 165s ok 114 - Unknown error message should be correct 165s ok 115 - Should get an error with name and two unknowns 165s ok 116 - Two unknowns error ident should be "whu" 165s ok 117 - Two unknowns error message should be correct 165s ok 118 - Load Sqitch with config 165s ok 119 - Load cmd with config 165s ok 120 - Change following target should be recognized from target plan 165s ok 121 - Passed target should always be returned 165s ok 122 - Passed and specified targets should always be returned 165s ok 123 - Change unknown to passed target should error 165s ok 124 - Change unknown error ident should be "whu" 165s ok 125 - Change unknown error message should be correct 165s ok 126 - Should get known changes from default target (t/sql/sqitch.plan) 165s ok 127 - Change seen after target should error if not in that target 165s ok 128 - Change after target error ident should be "whu" 165s ok 129 - Change after target error message should be correct 165s ok 130 - Should resolve plan file to a target 165s ok 131 - SHould resolve default plan file to target 165s ok 132 - Should resolve engine "pg" file to its target 165s ok 133 - Should resolve engine "sqlite" file to its target 165s ok 134 - Bad target should trigger error 165s ok 135 - Bad target error ident should be "target" 165s ok 136 - Should have bad target error message 165s ok 137 - Should recognize target when default target has no plan file 165s ok 138 - Load Sqitch without engine 165s ok 139 - Load cmd without engine 165s ok 140 - Should have error for no engine or target 165s ok 141 - Should have target ident 165s ok 142 - Should have message about no config 165s ok 143 - Engine arg should override core target error 165s ok 144 - Target arg should override core target error 165s ok 145 - Call _pod2usage on base object 165s ok 146 - Default params should be passed to Pod::Usage 165s ok 147 - Call _pod2usage on "whu" command object 165s ok 148 - Default params should be passed to Pod::Usage 165s ok 149 - 'Config command object' isa 'App::Sqitch::Command::config' 165s ok 150 - Call _pod2usage on "config" command object 165s ok 151 - Should find sqitch-config docs to pass to Pod::Usage 165s ok 152 - 'Good command object' isa 'App::Sqitch::Command::good' 165s ok 153 - Call _pod2usage on "good" command object 165s ok 154 - Should find App::Sqitch::Command::good docs to pass to Pod::Usage 165s ok 155 - App::Sqitch::Command::good->can('usage') 165s ok 156 - Should find App::Sqitch::Command::good docs to pass to Pod::Usage 165s ok 157 - App::Sqitch::Command->can('verbosity') 165s ok 158 - Verbosity should be from sqitch 165s ok 159 - Verbosity should change with sqitch 165s ok 160 - trace should work 165s ok 161 - Should get no trace output for verbosity 2 165s ok 162 - trace_literal should work 165s ok 163 - Should get no trace_literal output for verbosity 2 165s ok 164 - debug should work 165s ok 165 - Should get no debug output for verbosity 1 165s ok 166 - debug_literal should work 165s ok 167 - Should get no debug_literal output for verbosity 1 165s ok 168 - info should work 165s ok 169 - Should get no info output for verbosity 0 165s ok 170 - info_literal should work 165s ok 171 - Should get no info_literal output for verbosity 0 165s ok 172 - comment should work 165s ok 173 - comment should work with verbosity 0 165s ok 174 - comment_literal should work 165s ok 175 - comment_literal should work with verbosity 0 165s ok 176 - emit should work 165s ok 177 - emit should work even with verbosity 0 165s ok 178 - emit_literal should work 165s ok 179 - emit_literal should work even with verbosity 0 165s ok 180 - warn should work 165s ok 181 - warn_literal should work 165s ok 182 - threw Regexp ((?^:EXITED: 2)) 165s ok 183 - usage should work 165s ok 184 - threw Regexp ((?^:EXITED: 2)) 165s ok 185 - usage should prefer sqitch-$command-usage 165s ok 186 - Path delete.me should not exist 165s ok 187 - Create delete.me 165s ok 188 - Path delete.me should now exist 165s ok 189 - The mkdir info should have been output 165s ok 190 - Create delete.me again 165s ok 191 - Path delete.me should still exist 165s ok 192 - Nothing should have been emitted 165s ok 193 - Should fail on permission issue 165s ok 194 - Permission error should have ident "good" 165s ok 195 - The permission error should be formatted properly 165s ok 196 - Should fail on nonexistent file 165s ok 197 - Nonexistant path error should have ident "good" 165s ok 198 - Nonexistant path error should be the message 165s ok 199 - no warnings 165s ok 166s t/config.t .......... 166s 1..360 166s ok 1 - use App::Sqitch::Command::config; 166s ok 2 - Load a sqitch object 166s ok 3 - 'Config command' isa 'App::Sqitch::Command::config' 166s ok 4 - 'Config command' isa 'App::Sqitch::Command' 166s ok 5 - App::Sqitch::Command::config->can(...) 166s ok 6 - Options should be configured 166s ok 7 - Should parse options 166s ok 8 - Options should not conflict with core options 166s ok 9 - Construct with user and system 166s ok 10 - Should get error for multiple config files 166s ok 11 - Construct with user and local 166s ok 12 - Should get error for multiple config files 166s ok 13 - Construct with file and system 166s ok 14 - Should get another error for multiple config files 166s ok 15 - Construct with file and user 166s ok 16 - Should get a third error for multiple config files 166s ok 17 - Construct with file, system, and user 166s ok 18 - Should get one last error for multiple config files 166s ok 19 - Construct with bool and num 166s ok 20 - Should get error for multiple types 166s ok 21 - Construct with int and num 166s ok 22 - Should get another error for multiple types 166s ok 23 - Construct with int and bool 166s ok 24 - Should get a third error for multiple types 166s ok 25 - Construct with int, num, and bool 166s ok 26 - Should get one last error for multiple types 166s ok 27 - Construct with get & unset 166s ok 28 - Should get error for multiple actions 166s ok 29 - Construct with get & unset & edit 166s ok 30 - Should get error for multiple actions 166s ok 31 - Construct with get & unset & edit & list 166s ok 32 - Should get error for multiple actions 166s ok 33 - Construct with unset & edit 166s ok 34 - Should get error for multiple actions 166s ok 35 - Construct with unset & edit & list 166s ok 36 - Should get error for multiple actions 166s ok 37 - Construct with edit & list 166s ok 38 - Should get error for multiple actions 166s ok 39 - Construct with edit & add & list 166s ok 40 - Should get error for multiple actions 166s ok 41 - Construct with edit & add & list & get_all 166s ok 42 - Should get error for multiple actions 166s ok 43 - Construct with edit & add & list & get_regex 166s ok 44 - Should get error for multiple actions 166s ok 45 - Construct with edit & add & list & unset_all 166s ok 46 - Should get error for multiple actions 166s ok 47 - Construct with edit & add & list & get_all & unset_all 166s ok 48 - Should get error for multiple actions 166s ok 49 - Construct with edit & list & remove_section 166s ok 50 - Should get error for multiple actions 166s ok 51 - Construct with edit & list & remove_section & rename_section 166s ok 52 - Should get error for multiple actions 166s ok 53 - Default context should be local context 166s ok 54 - Default action should be undef 166s ok 55 - Default context should be undef 166s ok 56 - Local context should be local 166s ok 57 - User context should be user 166s ok 58 - System context should be system 166s ok 59 - Create config set command 166s ok 60 - Execute the set command 166s ok 61 - The set method should have been called 166s ok 62 - Execute the get command 166s ok 63 - The get method should have been called 166s ok 64 - Create config get_all command 166s ok 65 - An action with a dash should have triggered a method with an underscore 166s ok 66 - Create config get command 166s ok 67 - Get core.engine 166s ok 68 - Should have emitted the merged core.engine 166s ok 69 - Get engine.pg.registry 166s ok 70 - Should have emitted the merged engine.pg.registry 166s ok 71 - Get engine.pg.client 166s ok 72 - Should have emitted the merged engine.pg.client 166s ok 73 - Should get usage for missing get key 166s ok 74 - And the missing get key should trigger a usage message 166s ok 75 - Should get usage for invalid get key 166s ok 76 - And the invalid get key should trigger a usage message 166s ok 77 - Create config get int command 166s ok 78 - Get revert.count as int 166s ok 79 - Should have emitted the revert count 166s ok 80 - Get revert.revision as int 166s ok 81 - Should have emitted the revert revision as an int 166s ok 82 - Get bundle.tags_only as an int should fail 166s ok 83 - Int cast exception ident should be "config" 166s ok 84 - Create config get num command 166s ok 85 - Get revert.count as num 166s ok 86 - Should have emitted the revert count 166s ok 87 - Get revert.revision as num 166s ok 88 - Should have emitted the revert revision as an num 166s ok 89 - Get bundle.tags_only as an num should fail 166s ok 90 - Num cast exception ident should be "config" 166s ok 91 - Create config get bool command 166s ok 92 - Should get failure for invalid bool int 166s ok 93 - Bool int cast exception ident should be "config" 166s ok 94 - Should get failure for invalid bool num 166s ok 95 - Bool num cast exception ident should be "config" 166s ok 96 - Get bundle.tags_only as bool 166s ok 97 - Should have emitted bundle.tags_only as a bool 166s ok 98 - Create config get bool-or-int command 166s ok 99 - Get revert.count as bool-or-int 166s ok 100 - Should have emitted the revert count as an int 166s ok 101 - Get revert.revision as bool-or-int 166s ok 102 - Should have emitted the revert revision as an int 166s ok 103 - Get bundle.tags_only as bool-or-int 166s ok 104 - Should have emitted bundle.tags_only as a bool 166s ok 105 - Create system config get command 166s ok 106 - Get system core.engine 166s ok 107 - Should have emitted the system core.engine 166s ok 108 - Get system engine.pg.client 166s ok 109 - Should have emitted the system engine.pg.client 166s ok 110 - Attempt to get engine.pg.host should fail 166s ok 111 - Error ident should be "config" 166s ok 112 - Error Message should be empty 166s ok 113 - Error exitval should be 1 166s ok 114 - Nothing should have been emitted 166s ok 115 - Create user config get command 166s ok 116 - Get user engine.pg.registry 166s ok 117 - Should have emitted the user engine.pg.registry 166s ok 118 - Get user engine.pg.client 166s ok 119 - Should have emitted the user engine.pg.client 166s ok 120 - Create local config get command 166s ok 121 - Get local engine.pg.target 166s ok 122 - Should have emitted the local engine.pg.target 166s ok 123 - Get local core.engine 166s ok 124 - Should have emitted the local core.engine 166s ok 125 - Create another system config get command 166s ok 126 - There should be no system config file 166s ok 127 - Should fail when no system config file 166s ok 128 - Error ident should be "config" 166s ok 129 - Error Message should be empty 166s ok 130 - Error exitval should be 1 166s ok 131 - Create another user config get command 166s ok 132 - There should be no user config file 166s ok 133 - Should fail when no user config file 166s ok 134 - Error ident should be "config" 166s ok 135 - Error Message should be empty 166s ok 136 - Error exitval should be 1 166s ok 137 - Create another local config get command 166s ok 138 - There should be no local config file 166s ok 139 - Should fail when no local config file 166s ok 140 - Error ident should be "config" 166s ok 141 - Error Message should be empty 166s ok 142 - Error exitval should be 1 166s ok 143 - Create config list command 166s ok 144 - Execute the list action 166s ok 145 - Should have emitted the merged config 166s ok 146 - Create system config list command 166s ok 147 - List the system config 166s ok 148 - Should have emitted the system config list 166s ok 149 - Create user config list command 166s ok 150 - List the user config 166s ok 151 - Should only have emitted the user config list 166s ok 152 - Create local config list command 166s ok 153 - List the local config 166s ok 154 - Should only have emitted the local config list 166s ok 155 - Create system config list command with no file 166s ok 156 - List the system config 166s ok 157 - Nothing should have been emitted 166s ok 158 - Create user config list command with no file 166s ok 159 - List the user config 166s ok 160 - Nothing should have been emitted 166s ok 161 - Create system config set command 166s ok 162 - Write core.foo 166s ok 163 - The property should have been written 166s ok 164 - Write core.engine 166s ok 165 - Both settings should be saved 166s ok 166 - Write engine.pg.user 166s ok 167 - Both sections should be saved 166s ok 168 - Should set usage for missing set key 166s ok 169 - And the missing set key should trigger a usage message 166s ok 170 - Should set usage for invalid set key 166s ok 171 - And the invalid set key should trigger a usage message 166s ok 172 - Should set usage for missing set value 166s ok 173 - And the missing set value should trigger a usage message 166s ok 174 - Create system config add command 166s ok 175 - Add to core.foo 166s ok 176 - The value should have been added to the property 166s ok 177 - Should add usage for missing add key 166s ok 178 - And the missing add key should trigger a usage message 166s ok 179 - Should add usage for invalid add key 166s ok 180 - And the invalid add key should trigger a usage message 166s ok 181 - Should add usage for missing add value 166s ok 182 - And the missing add value should trigger a usage message 166s ok 183 - Create system config add command 166s ok 184 - Get core.engine with regex 166s ok 185 - Should have emitted value 166s ok 186 - Get core.foo with regex 166s ok 187 - Should have emitted value 166s ok 188 - Attempt to get core.foo with non-matching regex should fail 166s ok 189 - Error ident should be "config" 166s ok 190 - Error Message should be empty 166s ok 191 - Error exitval should be 1 166s ok 192 - Nothing should have been emitted 166s ok 193 - Create system config get_all command 166s ok 194 - Call get_all on core.engine 166s ok 195 - The engine should have been emitted 166s ok 196 - Get all core.engine with regex 166s ok 197 - Should have emitted value 166s ok 198 - Call get_all on core.foo 166s ok 199 - Both foos should have been emitted 166s ok 200 - Call get_all on core.foo with regex 166s ok 201 - Both foos should have been emitted 166s ok 202 - Call get_all on core.foo with limiting regex 166s ok 203 - Only the one foo should have been emitted 166s ok 204 - Attempt to get_all core.foo with non-matching regex should fail 166s ok 205 - Error ident should be "config" 166s ok 206 - Error Message should be empty 166s ok 207 - Error exitval should be 1 166s ok 208 - Nothing should have been emitted 166s ok 209 - Should get_all usage for missing get_all key 166s ok 210 - And the missing get_all key should trigger a usage message 166s ok 211 - Should get_all usage for invalid get_all key 166s ok 212 - And the invalid get_all key should trigger a usage message 166s ok 213 - Create config get_all int command 166s ok 214 - Get revert.count as int 166s ok 215 - Should have emitted the revert count 166s ok 216 - Get revert.revision as int 166s ok 217 - Should have emitted the revert revision as an int 166s ok 218 - Get bundle.tags_only as an int should fail 166s ok 219 - Int cast exception ident should be "config" 166s ok 220 - Create config get_all num command 166s ok 221 - Get revert.count as num 166s ok 222 - Should have emitted the revert count 166s ok 223 - Get revert.revision as num 166s ok 224 - Should have emitted the revert revision as an num 166s ok 225 - Get bundle.tags_only as an num should fail 166s ok 226 - Num cast exception ident should be "config" 166s ok 227 - Create config get_all bool command 166s ok 228 - Should get failure for invalid bool int 166s ok 229 - Bool int cast exception ident should be "config" 166s ok 230 - Should get failure for invalid bool num 166s ok 231 - Num int cast exception ident should be "config" 166s ok 232 - Get bundle.tags_only as bool 166s ok 233 - Should have emitted bundle.tags_only as a bool 166s ok 234 - Create config get_all bool-or-int command 166s ok 235 - Get revert.count as bool-or-int 166s ok 236 - Should have emitted the revert count as an int 166s ok 237 - Get revert.revision as bool-or-int 166s ok 238 - Should have emitted the revert revision as an int 166s ok 239 - Get bundle.tags_only as bool-or-int 166s ok 240 - Should have emitted bundle.tags_only as a bool 166s ok 241 - Create system config get_regex command 166s ok 242 - Call get_regex on core\..+ 166s ok 243 - Should match all core options 166s ok 244 - Call get_regex on engine\.pg\..+ 166s ok 245 - Should match all engine.pg options 166s ok 246 - Call get_regex on engine\.pg\..+ and value regex 166s ok 247 - Should match all engine.pg options that match 166s ok 248 - Call get_regex on foo\Bar\..+ and always-matching regex 166s ok 249 - Should include key with no value 166s ok 250 - Attempt to get_regex engine\.pg with non-matching regex should fail 166s ok 251 - Error ident should be "config" 166s ok 252 - Error Message should be empty 166s ok 253 - Error exitval should be 1 166s ok 254 - Nothing should have been emitted 166s ok 255 - Should get_regex usage for missing get_regex key 166s ok 256 - And the missing get_regex key should trigger a usage message 166s ok 257 - Should get_regex usage for invalid get_regex key 166s ok 258 - And the invalid get_regex key should trigger a usage message 166s ok 259 - Create config get_regex int command 166s ok 260 - Get revert.count as int 166s ok 261 - Should have emitted the revert count 166s ok 262 - Get revert.revision as int 166s ok 263 - Should have emitted the revert revision as an int 166s ok 264 - Get bundle.tags_only as an int should fail 166s ok 265 - Int cast exception ident should be "config" 166s ok 266 - Create config get_regexp num command 166s ok 267 - Get revert.count as num 166s ok 268 - Should have emitted the revert count 166s ok 269 - Get revert.revision as num 166s ok 270 - Should have emitted the revert revision as an num 166s ok 271 - Get bundle.tags_only as an num should fail 166s ok 272 - Num cast exception ident should be "config" 166s ok 273 - Create config get_regex bool command 166s ok 274 - Should get failure for invalid bool int 166s ok 275 - Bool int cast exception ident should be "config" 166s ok 276 - Should get failure for invalid bool num 166s ok 277 - Num int cast exception ident should be "config" 166s ok 278 - Get bundle.tags_only as bool 166s ok 279 - Should have emitted bundle.tags_only as a bool 166s ok 280 - Create config get_regex bool-or-int command 166s ok 281 - Get revert.count as bool-or-int 166s ok 282 - Should have emitted the revert count as an int 166s ok 283 - Get revert.revision as bool-or-int 166s ok 284 - Should have emitted the revert revision as an int 166s ok 285 - Get bundle.tags_only as bool-or-int 166s ok 286 - Should have emitted bundle.tags_only as a bool 166s ok 287 - Create system config unset command 166s ok 288 - Unset engine.pg.user 166s ok 289 - engine.pg.user should be gone 166s ok 290 - Unset core.engine 166s ok 291 - core.engine should have been removed 166s ok 292 - Should get failure trying to delete multivalue key 166s ok 293 - Multiple value exception ident should be "config" 166s ok 294 - And it should have the proper error message 166s ok 295 - Unset core.foo with a regex 166s ok 296 - The core.foo "baz" value should have been removed 166s ok 297 - Should unset usage for missing unset key 166s ok 298 - And the missing unset key should trigger a usage message 166s ok 299 - Should unset usage for invalid unset key 166s ok 300 - And the invalid unset key should trigger a usage message 166s ok 301 - Create system config unset_all command 166s ok 302 - unset_all core.foo 166s ok 303 - core.foo should have been removed 166s ok 304 - unset_all core.foo with regex 166s ok 305 - core.foo should have one value left 166s ok 306 - Should unset_all usage for missing unset_all key 166s ok 307 - And the missing unset_all key should trigger a usage message 166s ok 308 - Should unset_all usage for invalid unset_all key 166s ok 309 - And the invalid unset_all key should trigger a usage message 166s ok 310 - Create system config replace_all command 166s ok 311 - Replace all core.bar 166s ok 312 - core.bar should have all its values with one value 166s ok 313 - Replace all core.bar matching /^ba/ 166s ok 314 - core.foo should have had the matching values replaced 166s ok 315 - Create system config rename_section command 166s ok 316 - Rename "core" to "funk" 166s ok 317 - core.foo should have become funk.foo 166s ok 318 - Should fail with no new name 166s ok 319 - Message should be in the usage call 166s ok 320 - Should fail with bad old name 166s ok 321 - Message should be in the usage call 166s ok 322 - Should fail with bad new name 166s ok 323 - Message should be in the usage call 166s ok 324 - Should fail with invalid section 166s ok 325 - Invalid section exception ident should be "config" 166s ok 326 - Invalid section exception message should be set 166s ok 327 - Create system config remove_section command 166s ok 328 - Remove "func" section 166s ok 329 - The "funk" section should be gone 166s ok 330 - Should fail with no name 166s ok 331 - Message should be in the usage call 166s ok 332 - Should fail with invalid name 166s ok 333 - Invalid key name exception ident should be "config" 166s ok 334 - And the invalid key message should be set 166s ok 335 - Should fail fetching multi-value key 166s ok 336 - Multi-value key exception ident should be "config" 166s ok 337 - The multiple value error should be thrown 166s ok 338 - Should fail setting multi-value key 166s ok 339 - Multi-value key exception ident should be "config" 166s ok 340 - The multi-value key error should be thrown 166s ok 341 - Set should fail on App::Sqitch::Cofig error 166s ok 342 - Set exception ident should be "config" 166s ok 343 - Config set exception message should propagate 166s ok 344 - Unset should fail on App::Sqitch::Cofig error 166s ok 345 - Unset exception ident should be "config" 166s ok 346 - Config set exception message should propagate 166s ok 347 - Rename should fail on App::Sqitch::Cofig error 166s ok 348 - Rename exception ident should be "config" 166s ok 349 - Config rename exception message should propagate 166s ok 350 - Remove should fail on App::Sqitch::Cofig error 166s ok 351 - Remove exception ident should be "config" 166s ok 352 - Config remove exception message should propagate 166s ok 353 - Create system config edit command 166s ok 354 - Execute the edit comand 166s ok 355 - The editor should have been run 166s ok 356 - Load a new sqitch object 166s ok 357 - Create system config set command with subdirectory config file path 166s ok 358 - Set "my.foo" in subdirectory config file 166s ok 359 - The file should have been written 166s ok 360 - no warnings 166s ok 167s t/conn_cmd_role.t ... 167s ok 1 - use App::Sqitch::Role::ConnectingCommand; 167s ok 2 - App::Sqitch::Command::click->can('does') 167s ok 3 - App::Sqitch::Command::click does App::Sqitch::Role::ConnectingCommand 167s ok 4 - Options should include connection options 167s ok 5 - Should get no params for no options 167s ok 6 - Should get dbname for --db-name 167s ok 7 - Should collect existing but false params 167s ok 8 - Should collect params 167s ok 9 - An object of class 'App::Sqitch::Command::click' isa 'App::Sqitch::Command::click' 167s ok 10 - Should get connection params from target_params 167s 1..10 167s ok 167s t/cx_cmd_role.t ..... 167s ok 1 - use App::Sqitch::Role::ContextCommand; 167s ok 2 - App::Sqitch::Command::click->can('does') 167s ok 3 - App::Sqitch::Command::click does App::Sqitch::Role::ContextCommand 167s ok 4 - Options should include context options 167s ok 5 - Should get no params for no options 167s ok 6 - Should get no params for empty options 167s ok 7 - Should have no warning 167s ok 8 - Should get top_dir 167s ok 9 - Should have --top-dir deprecation warning 167s ok 10 - Should collect params 167s ok 11 - Should have --top-dir deprecation warning again 167s ok 12 - An object of class 'App::Sqitch::Command::click' isa 'App::Sqitch::Command::click' 167s ok 13 - Should get context params from target_params 167s 1..13 167s ok 168s t/datetime.t ........ 168s 1..33 168s ok 1 - require App::Sqitch::DateTime; 168s ok 2 - Construct a datetime object 168s ok 3 - as_string_formats should be correct 168s ok 4 - Date format "full" should yield "Friday, November 1, 2024, 11:25:50 AM America/Vancouver" 168s ok 5 - Format "full" should be valid 168s ok 6 - Date format "long" should yield "November 1, 2024, 11:25:50 AM PDT" 168s ok 7 - Format "long" should be valid 168s ok 8 - Date format "medium" should yield "Nov 1, 2024, 11:25:50 AM" 168s ok 9 - Format "medium" should be valid 168s ok 10 - Date format "short" should yield "11/1/24, 11:25 AM" 168s ok 11 - Format "short" should be valid 168s ok 12 - Date format "raw" should yield "2024-11-01T18:25:50Z" 168s ok 13 - Format "raw" should be valid 168s ok 14 - Date format "" should yield "2024-11-01T18:25:50Z" 168s ok 15 - Date format "iso" should yield "2024-11-01 11:25:50 -0700" 168s ok 16 - Format "iso" should be valid 168s ok 17 - Date format "iso8601" should yield "2024-11-01 11:25:50 -0700" 168s ok 18 - Format "iso8601" should be valid 168s ok 19 - Date format "rfc" should yield "Fri, 01 Nov 2024 11:25:50 -0700" 168s ok 20 - Format "rfc" should be valid 168s ok 21 - Date format "rfc2822" should yield "Fri, 01 Nov 2024 11:25:50 -0700" 168s ok 22 - Format "rfc2822" should be valid 168s ok 23 - Date format "cldr:HH'h' mm'm'" should yield "11h 25m" 168s ok 24 - Format "cldr:HH'h' mm'm'" should be valid 168s ok 25 - Date format "strftime:%a at %H:%M:%S" should yield "Fri at 11:25:50" 168s ok 26 - Format "strftime:%a at %H:%M:%S" should be valid 168s ok 27 - Should get error for invalid date format 168s ok 28 - Invalid date format error ident should be "datetime" 168s ok 29 - Invalid date format error message should be correct 168s ok 30 - Should get error for invalid as_string format param 168s ok 31 - Invalid date format error ident should be "datetime" 168s ok 32 - Invalid date format error message should be correct 168s ok 33 - no warnings 168s ok 168s t/dbiengine_role.t .. 168s 1..14 168s ok 1 - require App::Sqitch::Role::DBIEngine; 168s ok 2 - App::Sqitch::Role::DBIEngine->can(...) 168s ok 3 - _ts_default shoudld return DEFAULT 168s ok 4 - registry_version should propagate non-table error 168s ok 5 - registry_version should return false on no-table error 168s ok 6 - _cid should propagate non-table error 168s ok 7 - _cid should return false on no-table error and unititialized 168s ok 8 - curent_state should propagate _select_state error 168s ok 9 - Should have passed 1 to _select_state 168s ok 10 - curent_state should return false on no-table error 168s ok 11 - Should again have passed 1 to _select_state 168s ok 12 - curent_state should propagate second error on no-column error 168s ok 13 - Should again have passed 0 to _select_state 168s ok 14 - Should get undef from change_id_for when no useful params 168s ok 169s t/depend.t .......... 169s 1..326 169s ok 1 - require App::Sqitch::Plan::Depend; 169s ok 2 - Load a sqitch sqitch object 169s ok 3 - App::Sqitch::Plan::Depend->can(...) 169s ok 4 - Construct "foo" 169s ok 5 - Constructed should stringify as "foo" 169s ok 6 - Constructed should have key name "foo" 169s ok 7 - Constructed should plan stringify as "foo" 169s ok 8 - Parse "foo" 169s ok 9 - Parsed should plan stringify as "foo" 169s ok 10 - "foo" should be required 169s ok 11 - "foo" should not be conflicting 169s ok 12 - "foo" type should be "require" 169s ok 13 - Should not have got project from "foo" 169s ok 14 - Should have project "depend" for "foo" 169s ok 15 - "foo" should not be external 169s ok 16 - "foo" should be internal 169s ok 17 - Should not have got ID from "foo" 169s ok 18 - Construct "bar" 169s ok 19 - Constructed should stringify as "bar" 169s ok 20 - Constructed should have key name "bar" 169s ok 21 - Constructed should plan stringify as "bar" 169s ok 22 - Parse "bar" 169s ok 23 - Parsed should plan stringify as "bar" 169s ok 24 - "bar" should be required 169s ok 25 - "bar" should not be conflicting 169s ok 26 - "bar" type should be "require" 169s ok 27 - Should not have got project from "bar" 169s ok 28 - Should have project "depend" for "bar" 169s ok 29 - "bar" should not be external 169s ok 30 - "bar" should be internal 169s ok 31 - Should not have got ID from "bar" 169s ok 32 - Construct "@bar" 169s ok 33 - Constructed should stringify as "@bar" 169s ok 34 - Constructed should have key name "@bar" 169s ok 35 - Constructed should plan stringify as "@bar" 169s ok 36 - Parse "@bar" 169s ok 37 - Parsed should plan stringify as "@bar" 169s ok 38 - "@bar" should be required 169s ok 39 - "@bar" should not be conflicting 169s ok 40 - "@bar" type should be "require" 169s ok 41 - Should not have got project from "@bar" 169s ok 42 - Should have project "depend" for "@bar" 169s ok 43 - "@bar" should not be external 169s ok 44 - "@bar" should be internal 169s ok 45 - Should not have got ID from "@bar" 169s ok 46 - Construct "!foo" 169s ok 47 - Constructed should stringify as "foo" 169s ok 48 - Constructed should have key name "foo" 169s ok 49 - Constructed should plan stringify as "!foo" 169s ok 50 - Parse "!foo" 169s ok 51 - Parsed should plan stringify as "!foo" 169s ok 52 - "!foo" should be conflicting 169s ok 53 - "!foo" should not be required 169s ok 54 - "!foo" type should be "conflict" 169s ok 55 - Should not have got project from "!foo" 169s ok 56 - Should have project "depend" for "!foo" 169s ok 57 - "!foo" should not be external 169s ok 58 - "!foo" should be internal 169s ok 59 - Should not have got ID from "!foo" 169s ok 60 - Construct "!@bar" 169s ok 61 - Constructed should stringify as "@bar" 169s ok 62 - Constructed should have key name "@bar" 169s ok 63 - Constructed should plan stringify as "!@bar" 169s ok 64 - Parse "!@bar" 169s ok 65 - Parsed should plan stringify as "!@bar" 169s ok 66 - "!@bar" should be conflicting 169s ok 67 - "!@bar" should not be required 169s ok 68 - "!@bar" type should be "conflict" 169s ok 69 - Should not have got project from "!@bar" 169s ok 70 - Should have project "depend" for "!@bar" 169s ok 71 - "!@bar" should not be external 169s ok 72 - "!@bar" should be internal 169s ok 73 - Should not have got ID from "!@bar" 169s ok 74 - Construct "foo@bar" 169s ok 75 - Constructed should stringify as "foo@bar" 169s ok 76 - Constructed should have key name "foo@bar" 169s ok 77 - Constructed should plan stringify as "foo@bar" 169s ok 78 - Parse "foo@bar" 169s ok 79 - Parsed should plan stringify as "foo@bar" 169s ok 80 - "foo@bar" should be required 169s ok 81 - "foo@bar" should not be conflicting 169s ok 82 - "foo@bar" type should be "require" 169s ok 83 - Should not have got project from "foo@bar" 169s ok 84 - Should have project "depend" for "foo@bar" 169s ok 85 - "foo@bar" should not be external 169s ok 86 - "foo@bar" should be internal 169s ok 87 - Should not have got ID from "foo@bar" 169s ok 88 - Construct "!foo@bar" 169s ok 89 - Constructed should stringify as "foo@bar" 169s ok 90 - Constructed should have key name "foo@bar" 169s ok 91 - Constructed should plan stringify as "!foo@bar" 169s ok 92 - Parse "!foo@bar" 169s ok 93 - Parsed should plan stringify as "!foo@bar" 169s ok 94 - "!foo@bar" should be conflicting 169s ok 95 - "!foo@bar" should not be required 169s ok 96 - "!foo@bar" type should be "conflict" 169s ok 97 - Should not have got project from "!foo@bar" 169s ok 98 - Should have project "depend" for "!foo@bar" 169s ok 99 - "!foo@bar" should not be external 169s ok 100 - "!foo@bar" should be internal 169s ok 101 - Should not have got ID from "!foo@bar" 169s ok 102 - Construct "proj:foo" 169s ok 103 - Constructed should stringify as "proj:foo" 169s ok 104 - Constructed should have key name "foo" 169s ok 105 - Constructed should plan stringify as "proj:foo" 169s ok 106 - Parse "proj:foo" 169s ok 107 - Parsed should plan stringify as "proj:foo" 169s ok 108 - "proj:foo" should be required 169s ok 109 - "proj:foo" should not be conflicting 169s ok 110 - "proj:foo" type should be "require" 169s ok 111 - Should have got project from "proj:foo" 169s ok 112 - Should have project "proj" for "proj:foo" 169s ok 113 - "proj:foo" should be external 169s ok 114 - "proj:foo" should not be internal 169s ok 115 - Should not have got ID from "proj:foo" 169s ok 116 - Construct "!proj:foo" 169s ok 117 - Constructed should stringify as "proj:foo" 169s ok 118 - Constructed should have key name "foo" 169s ok 119 - Constructed should plan stringify as "!proj:foo" 169s ok 120 - Parse "!proj:foo" 169s ok 121 - Parsed should plan stringify as "!proj:foo" 169s ok 122 - "!proj:foo" should be conflicting 169s ok 123 - "!proj:foo" should not be required 169s ok 124 - "!proj:foo" type should be "conflict" 169s ok 125 - Should have got project from "!proj:foo" 169s ok 126 - Should have project "proj" for "!proj:foo" 169s ok 127 - "!proj:foo" should be external 169s ok 128 - "!proj:foo" should not be internal 169s ok 129 - Should not have got ID from "!proj:foo" 169s ok 130 - Construct "proj:@foo" 169s ok 131 - Constructed should stringify as "proj:@foo" 169s ok 132 - Constructed should have key name "@foo" 169s ok 133 - Constructed should plan stringify as "proj:@foo" 169s ok 134 - Parse "proj:@foo" 169s ok 135 - Parsed should plan stringify as "proj:@foo" 169s ok 136 - "proj:@foo" should be required 169s ok 137 - "proj:@foo" should not be conflicting 169s ok 138 - "proj:@foo" type should be "require" 169s ok 139 - Should have got project from "proj:@foo" 169s ok 140 - Should have project "proj" for "proj:@foo" 169s ok 141 - "proj:@foo" should be external 169s ok 142 - "proj:@foo" should not be internal 169s ok 143 - Should not have got ID from "proj:@foo" 169s ok 144 - Construct "!proj:@foo" 169s ok 145 - Constructed should stringify as "proj:@foo" 169s ok 146 - Constructed should have key name "@foo" 169s ok 147 - Constructed should plan stringify as "!proj:@foo" 169s ok 148 - Parse "!proj:@foo" 169s ok 149 - Parsed should plan stringify as "!proj:@foo" 169s ok 150 - "!proj:@foo" should be conflicting 169s ok 151 - "!proj:@foo" should not be required 169s ok 152 - "!proj:@foo" type should be "conflict" 169s ok 153 - Should have got project from "!proj:@foo" 169s ok 154 - Should have project "proj" for "!proj:@foo" 169s ok 155 - "!proj:@foo" should be external 169s ok 156 - "!proj:@foo" should not be internal 169s ok 157 - Should not have got ID from "!proj:@foo" 169s ok 158 - Construct "proj:foo@bar" 169s ok 159 - Constructed should stringify as "proj:foo@bar" 169s ok 160 - Constructed should have key name "foo@bar" 169s ok 161 - Constructed should plan stringify as "proj:foo@bar" 169s ok 162 - Parse "proj:foo@bar" 169s ok 163 - Parsed should plan stringify as "proj:foo@bar" 169s ok 164 - "proj:foo@bar" should be required 169s ok 165 - "proj:foo@bar" should not be conflicting 169s ok 166 - "proj:foo@bar" type should be "require" 169s ok 167 - Should have got project from "proj:foo@bar" 169s ok 168 - Should have project "proj" for "proj:foo@bar" 169s ok 169 - "proj:foo@bar" should be external 169s ok 170 - "proj:foo@bar" should not be internal 169s ok 171 - Should not have got ID from "proj:foo@bar" 169s ok 172 - Construct "!proj:foo@bar" 169s ok 173 - Constructed should stringify as "proj:foo@bar" 169s ok 174 - Constructed should have key name "foo@bar" 169s ok 175 - Constructed should plan stringify as "!proj:foo@bar" 169s ok 176 - Parse "!proj:foo@bar" 169s ok 177 - Parsed should plan stringify as "!proj:foo@bar" 169s ok 178 - "!proj:foo@bar" should be conflicting 169s ok 179 - "!proj:foo@bar" should not be required 169s ok 180 - "!proj:foo@bar" type should be "conflict" 169s ok 181 - Should have got project from "!proj:foo@bar" 169s ok 182 - Should have project "proj" for "!proj:foo@bar" 169s ok 183 - "!proj:foo@bar" should be external 169s ok 184 - "!proj:foo@bar" should not be internal 169s ok 185 - Should not have got ID from "!proj:foo@bar" 169s ok 186 - Construct "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 187 - Constructed should stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 188 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 189 - Constructed should plan stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 190 - Parse "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 191 - Parsed should plan stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 192 - "9ed961ad7902a67fe0804c8e49e8993719fd5065" should be required 169s ok 193 - "9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be conflicting 169s ok 194 - "9ed961ad7902a67fe0804c8e49e8993719fd5065" type should be "require" 169s ok 195 - Should not have got project from "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 196 - Should have undef project for "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 197 - "9ed961ad7902a67fe0804c8e49e8993719fd5065" should be external 169s ok 198 - "9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be internal 169s ok 199 - Should have got ID from "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 200 - Construct "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 201 - Constructed should stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 202 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 203 - Constructed should plan stringify as "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 204 - Parse "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 205 - Parsed should plan stringify as "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 206 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065" should be conflicting 169s ok 207 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be required 169s ok 208 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065" type should be "conflict" 169s ok 209 - Should not have got project from "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 210 - Should have undef project for "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 211 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065" should be external 169s ok 212 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be internal 169s ok 213 - Should have got ID from "!9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 214 - Construct "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 215 - Constructed should stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 216 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 217 - Constructed should plan stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 218 - Parse "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 219 - Parsed should plan stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 220 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should be required 169s ok 221 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be conflicting 169s ok 222 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" type should be "require" 169s ok 223 - Should have got project from "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 224 - Should have project "foo" for "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 225 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should be external 169s ok 226 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be internal 169s ok 227 - Should have got ID from "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 228 - Construct "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 229 - Constructed should stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 230 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 231 - Constructed should plan stringify as "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 232 - Parse "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 233 - Parsed should plan stringify as "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 234 - "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should be conflicting 169s ok 235 - "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be required 169s ok 236 - "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" type should be "conflict" 169s ok 237 - Should have got project from "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 238 - Should have project "foo" for "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 239 - "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should be external 169s ok 240 - "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" should not be internal 169s ok 241 - Should have got ID from "!foo:9ed961ad7902a67fe0804c8e49e8993719fd5065" 169s ok 242 - Construct "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 243 - Constructed should stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 244 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 245 - Constructed should plan stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 246 - Parse "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 247 - Parsed should plan stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 248 - "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be required 169s ok 249 - "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be conflicting 169s ok 250 - "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" type should be "require" 169s ok 251 - Should not have got project from "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 252 - Should have project "depend" for "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 253 - "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be external 169s ok 254 - "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be internal 169s ok 255 - Should not have got ID from "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 256 - Construct "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 257 - Constructed should stringify as "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 258 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 259 - Constructed should plan stringify as "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 260 - Parse "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 261 - Parsed should plan stringify as "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 262 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be conflicting 169s ok 263 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be required 169s ok 264 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" type should be "conflict" 169s ok 265 - Should not have got project from "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 266 - Should have project "depend" for "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 267 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be external 169s ok 268 - "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be internal 169s ok 269 - Should not have got ID from "!9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 270 - Construct "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 271 - Constructed should stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 272 - Constructed should have key name "9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 273 - Constructed should plan stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 274 - Parse "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 275 - Parsed should plan stringify as "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 276 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be required 169s ok 277 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be conflicting 169s ok 278 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" type should be "require" 169s ok 279 - Should have got project from "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 280 - Should have project "foo" for "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 281 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should be external 169s ok 282 - "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" should not be internal 169s ok 283 - Should not have got ID from "foo:9ed961ad7902a67fe0804c8e49e8993719fd5065@what" 169s ok 284 - Should fail to parse "foo bar" 169s ok 285 - Should fail to parse "foo+@bar" 169s ok 286 - Should fail to parse "foo:+bar" 169s ok 287 - Should fail to parse "foo@bar+" 169s ok 288 - Should fail to parse "proj:foo@bar+" 169s ok 289 - Should get exception for no change or tag 169s ok 290 - No change or tag error ident should be "DEV" 169s ok 291 - No change or tag error message should be correct 169s ok 292 - Should get an error for ID + change 169s ok 293 - ID + change error ident ident should be "DEV" 169s ok 294 - ID + change error message should be correct 169s ok 295 - Should get an error for ID + tag 169s ok 296 - ID + tag error ident ident should be "DEV" 169s ok 297 - ID + tag error message should be correct 169s ok 298 - Should get an error for ID + tag and change 169s ok 299 - ID + tag and change error ident ident should be "DEV" 169s ok 300 - ID + tag and change error message should be correct 169s ok 301 - Create "roles" dependency 169s ok 302 - Should find the "roles" ID in the plan 169s ok 303 - The "roles" change should not be external 169s ok 304 - The "roles" change should be internal 169s ok 305 - Create "elsewhere:roles" dependency 169s ok 306 - The "elsewhere:roles" id should be undef 169s ok 307 - The "elsewhere:roles" change should be external 169s ok 308 - The "elsewhere:roles" change should not be internal 169s ok 309 - Create depend using external ID 169s ok 310 - The external ID should be set 169s ok 311 - The external ID should register as external 169s ok 312 - The external ID should not register as internal 169s ok 313 - Create depend using "roles" ID 169s ok 314 - The "roles" ID should be set 169s ok 315 - The "roles" ID should not register as external 169s ok 316 - The "roles" ID should register as internal 169s ok 317 - Create "nonexistent" dependency 169s ok 318 - Should get error for nonexistent change 169s ok 319 - Nonexistent change error ident should be "plan" 169s ok 320 - Nonexistent change error message should be correct 169s ok 321 - Create depend without ID 169s ok 322 - Resolved ID should be undef 169s ok 323 - Set resolved ID 169s ok 324 - Resolved ID should be set 169s ok 325 - Unset resolved ID 169s ok 326 - Resolved ID should be undef again 169s ok 170s t/deploy.t .......... 170s ok 1 - require App::Sqitch::Command::deploy; 170s ok 2 - The class (or class-like) 'App::Sqitch::Command::deploy' isa 'App::Sqitch::Command' 170s ok 3 - App::Sqitch::Command::deploy->can(...) 170s ok 4 - App::Sqitch::Command::deploy does ContextCommand 170s ok 5 - App::Sqitch::Command::deploy does ConnectingCommand 170s ok 6 - Options should be correct 170s ok 7 - Should parse options 170s ok 8 - Options should not conflict with core options 170s ok 9 - Should have default configuration with no config or opts 170s ok 10 - Should have mode, verify, set, log-only, & lock-timeout options 170s ok 11 - Should have mode and verify configuration 170s ok 12 - 'new deploy with target' isa 'App::Sqitch::Command::deploy' 170s ok 13 - Should have target "foo" 170s ok 14 - An object of class 'App::Sqitch::Command::deploy' isa 'App::Sqitch::Command::deploy' 170s ok 15 - Should have undef default target 170s ok 16 - to_change should be undef 170s ok 17 - mode should be "all" 170s ok 18 - Should collect no variables 170s ok 19 - Should collect core vars 170s ok 20 - Should override core vars with deploy vars 170s ok 21 - Should override deploy vars with engine vars 170s ok 22 - Should override engine vars with target vars 170s ok 23 - Should override target vars with --set variables 170s ok 24 - Execute to "@alpha" 170s ok 25 - "@alpha" "all", and 0 should be passed to the engine 170s ok 26 - Should have a target 170s ok 27 - The engine should not be set log_only 170s ok 28 - The engine should have the default lock_timeout 170s ok 29 - Should have no warnings 170s ok 30 - Execute 170s ok 31 - undef and "all" should be passed to the engine 170s ok 32 - Should have no warnings 170s ok 33 - Execute with change 170s ok 34 - "widgets" and "all" should be passed to the engine 170s ok 35 - Should have no warnings 170s ok 36 - Execute with target 170s ok 37 - undef and "all" should be passed to the engine 170s ok 38 - The target should be as specified 170s ok 39 - Should have no warnings 170s ok 40 - Execute with change and target 170s ok 41 - "widgets" and "all" should be passed to the engine 170s ok 42 - The target should be as specified 170s ok 43 - Should have no warnings 170s ok 44 - Execute with target and change 170s ok 45 - "widgets" and "all" should be passed to the engine 170s ok 46 - The target should be as specified 170s ok 47 - Should have no warnings 170s ok 48 - 'Object with to, mode, log_only, and variables' isa 'App::Sqitch::Command::deploy' 170s ok 49 - Execute again 170s ok 50 - Engine should verify 170s ok 51 - The engine should be set log_only 170s ok 52 - The lock timeout should be set to 30 170s ok 53 - "foo", "tag", and 1 should be passed to the engine 170s ok 54 - Vars should have been passed through to the engine 170s ok 55 - The target name should be from the target option 170s ok 56 - Should have no warnings 170s ok 57 - Execute with change 170s ok 58 - Engine should verify 170s ok 59 - The engine should be set log_only 170s ok 60 - The lock timeout should be set to 30 170s ok 61 - "foo", "tag", and 1 should be passed to the engine 170s ok 62 - Vars should have been passed through to the engine 170s ok 63 - Should have too many changes warning 170s ok 64 - Execute with target again 170s ok 65 - Engine should verify 170s ok 66 - The engine should be set log_only 170s ok 67 - The lock timeout should be set to 30 170s ok 68 - "foo", "tag", and 1 should be passed to the engine 170s ok 69 - Vars should have been passed through to the engine 170s ok 70 - The target should be from the target option 170s ok 71 - Should have warning about too many targets 170s ok 72 - "all" should be a valid mode 170s ok 73 - "tag" should be a valid mode 170s ok 74 - "change" should be a valid mode 170s ok 75 - "foo" should not be a valid mode 170s ok 76 - "bad" should not be a valid mode 170s ok 77 - "gar" should not be a valid mode 170s ok 78 - Should get an exception for unknown arg 170s ok 79 - Unknown arg ident should be "deploy" 170s ok 80 - Should get an exeption for two unknown arg 170s ok 81 - Should get an exception for unknown args 170s ok 82 - Unknown args ident should be "deploy" 170s ok 83 - Should get an exeption for two unknown args 170s 1..83 170s ok 171s t/engine.t .......... 171s 1..781 171s ok 1 - use App::Sqitch::Engine; 171s ok 2 - App::Sqitch::Engine->can(...) 171s ok 3 - Load a sqitch sqitch object 171s ok 4 - Should get an exception for missing sqitch param 171s ok 5 - Should get an exception for missing sqitch param 171s ok 6 - Should get an exception for array sqitch param 171s ok 7 - Should get an exception for array target param 171s ok 8 - Should get an exception for string sqitch param 171s ok 9 - Should get an exception for string target param 171s ok 10 - 'Engine' isa 'App::Sqitch::Engine' 171s ok 11 - Load an engine 171s ok 12 - An object of class 'App::Sqitch::Engine::whu' isa 'App::Sqitch::Engine::whu' 171s ok 13 - The sqitch attribute should be set 171s ok 14 - Should die on unknown target 171s ok 15 - Should get load error message 171s ok 16 - Should have relevant previoius exception 171s ok 17 - No target should die 171s ok 18 - It should be the expected message 171s ok 19 - Should die on bad engine module 171s ok 20 - Should get another load error message 171s ok 21 - Should have relevant previoius exception from the bad module 171s ok 22 - App::Sqitch::Engine->can('name') 171s ok 23 - Create a App::Sqitch::Engine object 171s ok 24 - Should get error from base engine name 171s ok 25 - Name error ident should be "engine" 171s ok 26 - Name error message should be correct 171s ok 27 - Create a subclass name object 171s ok 28 - Subclass oject name should be "whu" 171s ok 29 - Subclass class name should be "whu" 171s ok 30 - App::Sqitch::Engine->can('config_vars') 171s ok 31 - Should have database and client in engine base class 171s ok 32 - App::Sqitch::Engine->can(...) 171s ok 33 - Should have no variables 171s ok 34 - Add a variable 171s ok 35 - Should have the variable 171s ok 36 - Set more variables 171s ok 37 - Should have all of the variables 171s ok 38 - Should again have no variables 171s ok 39 - Load engine 171s ok 40 - Target should be as passed 171s ok 41 - Load engine with URI with password 171s ok 42 - 'target attribute' isa 'App::Sqitch::Target' 171s ok 43 - Load engine 171s ok 44 - Destination should be URI string 171s ok 45 - Rgistry destination should be the same as destination 171s ok 46 - Load engine with URI with password 171s ok 47 - Destination should not include password 171s ok 48 - Registry destination should again be the same as destination 171s ok 49 - App::Sqitch::Engine::whu->can('_check_registry') 171s ok 50 - Registry should be fine at current version 171s ok 51 - Should get error for non-existent registry 171s ok 52 - Non-existent registry error ident should be "engine" 171s ok 53 - Non-existent registry error message should be correct 171s ok 54 - Should get error from revert 171s ok 55 - revert registry error ident should be "engine" 171s ok 56 - revert registry error message should be correct 171s ok 57 - Should get error from verify 171s ok 58 - verify registry error ident should be "engine" 171s ok 59 - verify registry error message should be correct 171s ok 60 - Should get error for out-of-date registry 171s ok 61 - Out-of-date registry error ident should be "engine" 171s ok 62 - Out-of-date registry error message should be correct 171s ok 63 - Should get error for future registry 171s ok 64 - Future registry error ident should be "engine" 171s ok 65 - Future registry error message should be correct 171s ok 66 - Create a App::Sqitch::Engine object again 171s ok 67 - Should get an unimplemented exception from initialized() 171s ok 68 - Should get an unimplemented exception from initialize() 171s ok 69 - Should get an unimplemented exception from register_project() 171s ok 70 - Should get an unimplemented exception from run_file() 171s ok 71 - Should get an unimplemented exception from run_handle() 171s ok 72 - Should get an unimplemented exception from log_deploy_change() 171s ok 73 - Should get an unimplemented exception from log_fail_change() 171s ok 74 - Should get an unimplemented exception from log_revert_change() 171s ok 75 - Should get an unimplemented exception from log_new_tags() 171s ok 76 - Should get an unimplemented exception from is_deployed_tag() 171s ok 77 - Should get an unimplemented exception from is_deployed_change() 171s ok 78 - Should get an unimplemented exception from are_deployed_changes() 171s ok 79 - Should get an unimplemented exception from change_id_for() 171s ok 80 - Should get an unimplemented exception from changes_requiring_change() 171s ok 81 - Should get an unimplemented exception from earliest_change_id() 171s ok 82 - Should get an unimplemented exception from latest_change_id() 171s ok 83 - Should get an unimplemented exception from deployed_changes() 171s ok 84 - Should get an unimplemented exception from deployed_changes_since() 171s ok 85 - Should get an unimplemented exception from load_change() 171s ok 86 - Should get an unimplemented exception from name_for_change_id() 171s ok 87 - Should get an unimplemented exception from current_state() 171s ok 88 - Should get an unimplemented exception from current_changes() 171s ok 89 - Should get an unimplemented exception from current_tags() 171s ok 90 - Should get an unimplemented exception from search_events() 171s ok 91 - Should get an unimplemented exception from registered_projects() 171s ok 92 - Should get an unimplemented exception from change_offset_from_id() 171s ok 93 - Should get an unimplemented exception from change_id_offset_from_id() 171s ok 94 - Should get an unimplemented exception from wait_lock() 171s ok 95 - Should get an unimplemented exception from registry_version() 171s ok 96 - Should get an unimplemented exception from _update_script_hashes() 171s ok 97 - App::Sqitch::Engine->can('_load_changes') 171s ok 98 - Should load changes with no change 171s ok 99 - Should load changes with undef 171s ok 100 - Should load changes with no tags 171s ok 101 - Should load changes with multiple hashes with no tags 171s ok 102 - Should load changes with tags 171s ok 103 - Should load changes with tags with leading @ 171s ok 104 - Should load changes with multiple hashes with tags 171s ok 105 - Should load changes with reworked change 171s ok 106 - Should load changes with reworked change & multiple tags 171s ok 107 - Should load changes with doubly reworked change 171s ok 108 - Rework change "you" 171s ok 109 - Tag @beta1 171s ok 110 - Should load changes with Unplanned change 171s ok 111 - Should load changes with reworked change without reworked version deployed 171s ok 112 - Should load changes with reworked change with reworked version deployed 171s ok 113 - Create a subclass name object again 171s ok 114 - App::Sqitch::Engine::whu->can(...) 171s ok 115 - Deploy a change 171s ok 116 - deploy_change should have called the proper methods 171s ok 117 - Output should reflect the deployment 171s ok 118 - Output should reflect success 171s ok 119 - Only log a change 171s ok 120 - log-only deploy_change should not have called run_file 171s ok 121 - Output should reflect the logging 171s ok 122 - Output should reflect deploy success 171s ok 123 - Enable verification 171s ok 124 - Deploy a change to be verified 171s ok 125 - deploy_change with verification should run the verify file 171s ok 126 - Output should reflect the logging 171s ok 127 - Output should reflect deploy success 171s ok 128 - Enable log_only 171s ok 129 - Verify and log a change 171s ok 130 - deploy_change with verification and log-only should not run deploy 171s ok 131 - Output should reflect the logging 171s ok 132 - Output should reflect deploy success 171s ok 133 - Deploy change with error 171s ok 134 - Error should be from run_file 171s ok 135 - Should have logged change failure 171s ok 136 - Output should reflect the deployment, even with failure 171s ok 137 - Output should reflect deploy failure 171s ok 138 - Deploy change with failed verification 171s ok 139 - Error should be from deploy_change 171s ok 140 - Should have logged verify failure 171s ok 141 - Output should reflect the deployment, even with verify failure 171s ok 142 - Output should reflect deploy failure 171s ok 143 - Verify error should have been vented 171s ok 144 - Enable log_only 171s ok 145 - Deploy change with log-only and failed verification 171s ok 146 - Error should be from deploy_change 171s ok 147 - Should have logged verify failure but not reverted 171s ok 148 - Output should reflect the deployment, even with verify failure 171s ok 149 - Output should reflect deploy failure 171s ok 150 - Verify error should have been vented 171s ok 151 - Deploy a change with no verify script 171s ok 152 - deploy_change with no verify file should not run it 171s ok 153 - Output should reflect the logging 171s ok 154 - Output should reflect deploy success 171s ok 155 - A warning about no verify file should have been emitted 171s ok 156 - Revert a change 171s ok 157 - revert_change should have called the proper methods 171s ok 158 - Output should reflect reversion 171s ok 159 - Output should acknowldge revert success 171s ok 160 - Enable log_only 171s ok 161 - Revert a change with log-only 171s ok 162 - Log-only revert_change should not have run the change script 171s ok 163 - Output should reflect logged reversion 171s ok 164 - Output should acknowldge revert success 171s ok 165 - Should die on unknown revert logging error 171s ok 166 - Sould have revert ident error 171s ok 167 - Should get revert failure error message 171s ok 168 - Log failure should not have seen log_rever_change 171s ok 169 - Output should reflect reversion 171s ok 170 - Output should acknowldge success failure 171s ok 171 - The logging error should have been vented 171s ok 172 - Engine with sqitch with plan file 171s ok 173 - Should get proper change from latest_change() 171s ok 174 - Latest change ID should have been called with no arg 171s ok 175 - Should again get proper change from latest_change() 171s ok 176 - Latest change ID should have been called with offset arg 171s ok 177 - Should get proper change from earliest_change() 171s ok 178 - Earliest change ID should have been called with no arg 171s ok 179 - Should again get proper change from earliest_change() 171s ok 180 - Earliest change ID should have been called with offset arg 171s ok 181 - App::Sqitch::Engine->can('_sync_plan') 171s ok 182 - Plan should start at position -1 171s ok 183 - start_at should be undef 171s ok 184 - Sync the plan 171s ok 185 - Plan should still be at position -1 171s ok 186 - start_at should still be undef 171s ok 187 - Should not have updated IDs or hashes 171s ok 188 - Sync the plan again 171s ok 189 - Plan should again be at position -1 171s ok 190 - start_at should again be undef 171s ok 191 - Still should not have updated IDs or hashes 171s ok 192 - Sync the plan to a tag 171s ok 193 - Plan should now be at position 2 171s ok 194 - start_at should now be widgets@beta 171s ok 195 - Should have updated IDs 171s ok 196 - Sync the plan with a random script hash 171s ok 197 - Plan should now be at position 1 171s ok 198 - start_at should now be widgets@beta 171s ok 199 - Should have updated IDs but not hashes 171s ok 200 - Sync the plan with a random script hash 171s ok 201 - Plan should now be at position 1 171s ok 202 - start_at should now be widgets@beta 171s ok 203 - Should have updated IDs and hashes 171s ok 204 - Sync the plan 171s ok 205 - Plan should be at position 1 171s ok 206 - start_at should be users@alpha 171s ok 207 - Should have updated hashes but not IDs 171s ok 208 - Sync the plan with no script hash 171s ok 209 - Plan should now be at position 1 171s ok 210 - start_at should still be users@alpha 171s ok 211 - Should have ugpraded the registry 171s ok 212 - The script hash should have been set to the change ID 171s ok 213 - Sync the plan with no registry 171s ok 214 - Plan should start at position -1 171s ok 215 - App::Sqitch::Engine->can('deploy') 171s ok 216 - Deploy to @alpha 171s ok 217 - Plan should be at position 1 171s ok 218 - Should have deployed through @alpha 171s ok 219 - Should have called _deploy_all() 171s ok 220 - Should have seen the output of the deploy to @alpha 171s ok 221 - Both change names should be output 171s ok 222 - Enable log_only 171s ok 223 - Log-only deploy in $mode mode to @alpha 171s ok 224 - Plan should be at position 1 171s ok 225 - Should have deployed through @alpha without running files 171s ok 226 - Should have called _deploy_by_change() 171s ok 227 - Should have seen the output of the deploy to @alpha 171s ok 228 - Both change names should be output 171s ok 229 - Enable log_only 171s ok 230 - Log-only deploy in $mode mode to @alpha 171s ok 231 - Plan should be at position 1 171s ok 232 - Should have deployed through @alpha without running files 171s ok 233 - Should have called _deploy_by_tag() 171s ok 234 - Should have seen the output of the deploy to @alpha 171s ok 235 - Both change names should be output 171s ok 236 - Enable log_only 171s ok 237 - Log-only deploy in $mode mode to @alpha 171s ok 238 - Plan should be at position 1 171s ok 239 - Should have deployed through @alpha without running files 171s ok 240 - Should have called _deploy_all() 171s ok 241 - Should have seen the output of the deploy to @alpha 171s ok 242 - Both change names should be output 171s ok 243 - Deploy to @alpha with tag mode 171s ok 244 - Plan should again be at position 1 171s ok 245 - Should have deployed through @alpha without initialization 171s ok 246 - Should have called _deploy_by_tag() 171s ok 247 - Should have seen the output of the deploy to @alpha 171s ok 248 - Both change names should be output 171s ok 249 - Should get an error for an unknown change 171s ok 250 - The exception should report the unknown change 171s ok 251 - Only latest_item() should have been called 171s ok 252 - Deploy to alpha thrice 171s ok 253 - Only latest_item() should have been called 171s ok 254 - Should notify user that already at @alpha 171s ok 255 - Should fail deploying older change 171s ok 256 - Should be a "deploy" error 171s ok 257 - It should suggest using "revert" 171s ok 258 - Should have called latest_item() and latest_tag() 171s ok 259 - Deploy to from index 1 171s ok 260 - Plan should be at position 2 171s ok 261 - Should have deployed to change 2 171s ok 262 - Should have emitted deploy announcement and successes 171s ok 263 - Deploy everything by change 171s ok 264 - Plan should be at position 3 171s ok 265 - Should have deployed everything 171s ok 266 - Should have called _deploy_by_change() 171s ok 267 - Should have emitted deploy announcement and successes 171s ok 268 - Should have seen the output of the deploy to the end 171s ok 269 - Debug output should show what will be deployed 171s ok 270 - Should return success for deploy to up-to-date DB 171s ok 271 - Should have emitted deploy announcement and successes 171s ok 272 - It should have just fetched the latest change ID 171s ok 273 - Should fail on invalid mode 171s ok 274 - Should be a "deploy" error 171s ok 275 - And the message should reflect the unknown mode 171s ok 276 - It should have check for initialization 171s ok 277 - Should have announced destination 171s ok 278 - Engine with sqitch with no file 171s ok 279 - Should die with no changes 171s ok 280 - Should have the localized message 171s ok 281 - It should have checked for the latest item 171s ok 282 - Deploy changewise to index 1 171s ok 283 - Should changewise deploy to index 2 171s ok 284 - Should have seen output of each change 171s ok 285 - Output should reflect deploy successes 171s ok 286 - Deploy changewise to index 2 171s ok 287 - Should changewise deploy to from index 2 to index 3 171s ok 288 - Should have seen output of changes 2-3 171s ok 289 - Output should reflect deploy successes 171s ok 290 - Die in _deploy_by_change 171s ok 291 - It should have died in run_file 171s ok 292 - It should have logged the failure 171s ok 293 - Should have seen output for first change 171s ok 294 - Output should reflect deploy failure 171s ok 295 - Deploy tagwise to index 1 171s ok 296 - Should tagwise deploy to index 1 171s ok 297 - Should have seen output of each change 171s ok 298 - Output should reflect deploy successes 171s ok 299 - Deploy tagwise to index 3 171s ok 300 - Should tagwise deploy from index 2 to index 3 171s ok 301 - Should have seen output of changes 3-3 171s ok 302 - Output should reflect deploy successes 171s ok 303 - Die in log_deploy_change 171s ok 304 - Should get final deploy failure message 171s ok 305 - It should have reverted back to the last deployed tag 171s ok 306 - Should have seen deploy and revert messages (excluding curry revert) 171s ok 307 - Output should reflect deploy successes and failure 171s ok 308 - The original error should have been vented 171s ok 309 - Enable log_only 171s ok 310 - Die in log_deploy_change log-only 171s ok 311 - Should get final deploy failure message 171s ok 312 - It should have run no deploy or revert scripts 171s ok 313 - Should have seen deploy and revert messages (excluding curry revert) 171s ok 314 - Output should reflect deploy successes and failure 171s ok 315 - The original error should have been vented 171s ok 316 - Die in _deploy_by_tag again 171s ok 317 - Should again get final deploy failure message 171s ok 318 - Should have logged back to the beginning 171s ok 319 - Should have seen deploy and revert messages 171s ok 320 - Output should reflect deploy successes and failure 171s ok 321 - Should have one vented message 171s ok 322 - And it should be the underlying error 171s ok 323 - And it should had notified that all changes were reverted 171s ok 324 - Die in _deploy_by_tag yet again 171s ok 325 - Should die "Deploy failed" again 171s ok 326 - Should have reverted back to last tag 171s ok 327 - Should have user change reversion messages 171s ok 328 - Output should reflect deploy successes and failure 171s ok 329 - Should see underlying error and reversion message 171s ok 330 - Die in _deploy_by_tag again 171s ok 331 - Should once again get final deploy failure message 171s ok 332 - Should have tried to revert one change 171s ok 333 - Should have seen revert message 171s ok 334 - Output should reflect deploy successes and failure 171s ok 335 - Should get reversion failure message 171s ok 336 - Deploy all to index 1 171s ok 337 - Should tagwise deploy to index 1 171s ok 338 - Should have seen output of each change 171s ok 339 - Output should reflect deploy successes 171s ok 340 - Deploy tagwise to index 2 171s ok 341 - Should tagwise deploy to from index 1 to index 2 171s ok 342 - Should have seen output of changes 3-4 171s ok 343 - Output should reflect deploy successe 171s ok 344 - Die in _deploy_all 171s ok 345 - Should get final deploy failure message 171s ok 346 - It should have logged up to the failure 171s ok 347 - Should have seen deploy and revert messages excluding revert for failed logging 171s ok 348 - Output should reflect deploy successes and failures 171s ok 349 - The original error should have been vented 171s ok 350 - Enable log_only 171s ok 351 - Die in log-only _deploy_all 171s ok 352 - Should get final deploy failure message 171s ok 353 - It should have run no deploys or reverts 171s ok 354 - Should have seen deploy and revert messages excluding revert for failed logging 171s ok 355 - Output should reflect deploy successes and failures 171s ok 356 - The original error should have been vented 171s ok 357 - Die in _deploy_all again 171s ok 358 - Should again get final deploy failure message 171s ok 359 - Should have reveted all changes and tags 171s ok 360 - Should see all changes revert 171s ok 361 - Output should reflect deploy successes and failures 171s ok 362 - Should notifiy user of error and rollback 171s ok 363 - Die in _deploy_all on the last change 171s ok 364 - Should once again get final deploy failure message 171s ok 365 - Should have deployed to dr_evil and revered down to @alpha 171s ok 366 - Should see changes revert back to @alpha 171s ok 367 - Output should reflect deploy successes and failures 171s ok 368 - Should notifiy user of error and rollback to @alpha 171s ok 369 - Die in _deploy_all on the last change 171s ok 370 - Should once again get final deploy failure message 171s ok 371 - Should have deployed to dr_evil and revered down to @alpha 171s ok 372 - Should see changes revert back to @alpha 171s ok 373 - Output should reflect deploy successes and failures 171s ok 374 - Should have two vented items 171s ok 375 - First vented should be the error 171s ok 376 - Should notifiy user of rollback to @alpha 171s ok 377 - Test is_deployed(tag) 171s ok 378 - It should have called is_deployed_tag() 171s ok 379 - Test is_deployed(change) 171s ok 380 - It should have called is_deployed_change() 171s ok 381 - App::Sqitch::Engine::whu->can('deploy_change') 171s ok 382 - Deploy a change 171s ok 383 - It should have been deployed 171s ok 384 - Should have shown change name 171s ok 385 - Output should reflect deploy success 171s ok 386 - Deploying change should die on logging failure 171s ok 387 - Should have privat ident 171s ok 388 - Should have failure message 171s ok 389 - It should have been deployed and reverted 171s ok 390 - Should have shown change name 171s ok 391 - Output should reflect deploy failure 171s ok 392 - Vent should reflect deployment error 171s ok 393 - Deploying change should die on logging failure 171s ok 394 - Should have privat ident 171s ok 395 - Should have failure message 171s ok 396 - It should have been deployed but not reverted 171s ok 397 - Should have shown change name 171s ok 398 - Output should reflect deploy failure 171s ok 399 - Vent should reflect deployment and reversion errors 171s ok 400 - Shuld die on deploy failure 171s ok 401 - Should be told the deploy failed 171s ok 402 - It should failed to have been deployed 171s ok 403 - Should have vented the original error 171s ok 404 - Should have shown change name 171s ok 405 - Output should reflect deploy failure 171s ok 406 - App::Sqitch::Engine::whu->can('revert_change') 171s ok 407 - Revert the change 171s ok 408 - It should have been reverted 171s ok 409 - Should have shown reverted change name 171s ok 410 - And the revert failure should be "ok" 171s ok 411 - App::Sqitch::Engine::whu->can('revert') 171s ok 412 - Should return success for no changes to revert 171s ok 413 - Should have notified that there is nothing to revert 171s ok 414 - It should only have called deployed_changes() 171s ok 415 - Nothing should have been output 171s ok 416 - Should get warning omitting required arguments 171s ok 417 - Should have notified that there is nothing to revert 171s ok 418 - It should only have called deployed_changes() 171s ok 419 - Nothing should have been output 171s ok 420 - Revert should die on unknown change 171s ok 421 - Should be another "revert" error 171s ok 422 - The message should mention it is an unknown change 171s ok 423 - Should have called change_id_for() with change name 171s ok 424 - Nothing should have been output 171s ok 425 - Revert should die on unknown change ID 171s ok 426 - Should be another "revert" error 171s ok 427 - The message should mention it is an unknown change 171s ok 428 - Should have called change_id_for() with change ID 171s ok 429 - Nothing should have been output 171s ok 430 - Revert should die on undeployed change 171s ok 431 - Should be another "revert" error 171s ok 432 - The message should mention that the change is not deployed 171s ok 433 - change_id_for 171s ok 434 - Nothing should have been output 171s ok 435 - Should return success for revert even with no changes 171s ok 436 - No subsequent change error message should be correct 171s ok 437 - Should have called change_id_for and deployed_changes_since 171s ok 438 - Should return success for known but undeployed change 171s ok 439 - No changes message should be correct 171s ok 440 - Should have called deployed_changes 171s ok 441 - Revert all changes 171s ok 442 - Should have reverted the changes in reverse order 171s ok 443 - Should have prompted to revert all changes 171s ok 444 - It should have said it was reverting all changes and listed them 171s ok 445 - Output should show what would be reverted 171s ok 446 - And the revert successes should be emitted 171s ok 447 - Enable log_only 171s ok 448 - Revert all changes log-only 171s ok 449 - Log-only Should have reverted the changes in reverse order 171s ok 450 - Log-only should have prompted to revert all changes 171s ok 451 - It should have said it was reverting all changes and listed them 171s ok 452 - Output should show what would be reverted 171s ok 453 - And the revert successes should be emitted 171s ok 454 - Should abort declined revert 171s ok 455 - Declined revert ident should be "revert" 171s ok 456 - Should have exited with value 1 171s ok 457 - Should have exited with proper message 171s ok 458 - Should have called deployed_changes only 171s ok 459 - Should have prompt to revert all changes 171s ok 460 - Output should show what would be reverted 171s ok 461 - Revert all changes with no prompt 171s ok 462 - Should have reverted the changes in reverse order 171s ok 463 - Should have no prompt 171s ok 464 - It should have said it was reverting all changes and listed them 171s ok 465 - And the revert successes should be emitted 171s ok 466 - Output should show what will be reverted 171s ok 467 - Revert to @alpha 171s ok 468 - Should have reverted only changes after @alpha 171s ok 469 - Should have prompt to revert to change 171s ok 470 - Output should show what it reverts to 171s ok 471 - Output should show what would be reverted 171s ok 472 - And the revert successes should be emitted 171s ok 473 - Should abort declined revert to @alpha 171s ok 474 - Declined revert ident should be "revert:confirm" 171s ok 475 - Should have exited with value 1 171s ok 476 - Should have exited with proper message 171s ok 477 - Should have called revert methods 171s ok 478 - Should have prompt to revert to @alpha 171s ok 479 - Should emit a detailed prompt. 171s ok 480 - Revert to @HEAD^ 171s ok 481 - Should have reverted one changes for @HEAD^ 171s ok 482 - Should have no prompt 171s ok 483 - Output should show what it reverts to 171s ok 484 - And the header and "ok" should be emitted 171s ok 485 - Output should show what will be reverted 171s ok 486 - App::Sqitch::Engine->can('change_id_for_depend') 171s ok 487 - Should get error from change_id_for_depend when change not in plan 171s ok 488 - Should get ident "plan" from change_id_for_depend 171s ok 489 - Should have proper message from change_id_for_depend error 171s ok 490 - Should get error from change_id_for_depend when no ID 171s ok 491 - Should get ident "engine" when no ID 171s ok 492 - Should have proper messag from change_id_for_depend error 171s ok 493 - Get a change id 171s ok 494 - Should have passed dependency params to change_id_for() 171s ok 495 - App::Sqitch::Engine->can('find_change') 171s ok 496 - find_change() should work 171s ok 497 - Its parameters should have been passed to change_id_for and change_offset_from_id 171s ok 498 - find_change() should work 171s ok 499 - Project and offset should have been passed off 171s ok 500 - App::Sqitch::Engine->can('find_change_id') 171s ok 501 - find_change_id() should work 171s ok 502 - Its parameters should have been passed to change_id_for and change_offset_from_id 171s ok 503 - find_change_id() should work 171s ok 504 - Project and offset should have been passed off 171s ok 505 - App::Sqitch::Engine->can('verify_change') 171s ok 506 - Verify a change 171s ok 507 - The change file should have been run 171s ok 508 - Should have no info output 171s ok 509 - Should throw error on verify failure 171s ok 510 - Verify error ident should be "verify" 171s ok 511 - Previous exception should be captured 171s ok 512 - Verify error message should be correct 171s ok 513 - Should have seen not method calls 171s ok 514 - Should have no info output 171s ok 515 - Verify a change with no verify script. 171s ok 516 - No abstract methods should be called 171s ok 517 - Should have no info output 171s ok 518 - A warning about no verify file should have been emitted 171s ok 519 - App::Sqitch::Engine::whu->can('check_deploy_dependencies') 171s ok 520 - All planned changes should be okay 171s ok 521 - Should have called are_deployed_changes 171s ok 522 - Should die when some changes deployed 171s ok 523 - Already deployed error ident should be "deploy" 171s ok 524 171s ok 525 - Should have called are_deployed_changes 171s ok 526 - Dependencies should check out even when within those to be deployed 171s ok 527 - Resolved ID should be populated 171s ok 528 - Conflict should throw exception 171s ok 529 - Should be a "deploy" error 171s ok 530 - Should have localized message about the local conflict 171s ok 531 - Conflict should throw exception 171s ok 532 - Should be a "deploy" error 171s ok 533 - Should have localized message about conflicts 171s ok 534 - Should have called change_id_for() twice 171s ok 535 - Conflicting dependencies should have no resolved IDs 171s ok 536 - Conflict should throw another exception 171s ok 537 - Should be a "deploy" error 171s ok 538 - Should have localized message about all three conflicts 171s ok 539 - Should have called change_id_for() twice 171s ok 540 - Conflicting dependencies should have no resolved IDs 171s ok 541 - Missing dependencies should throw exception 171s ok 542 - Should be another "deploy" error 171s ok 543 - Should have localized message missing dependencies without dupes 171s ok 544 - Should have called check_requires 171s ok 545 - Missing requirements should not have resolved 171s ok 546 - Missing dependencies should throw exception 171s ok 547 - Should be another "deploy" error 171s ok 548 - Should have localized conflicts and required error messages 171s ok 549 - Should have called check_requires 171s ok 550 - Missing requirements should not have resolved 171s ok 551 - App::Sqitch::Engine::whu->can('check_revert_dependencies') 171s ok 552 - Should get no error with no dependencies 171s ok 553 - It should have check for requiring changes 171s ok 554 - Should get error reverting change another depend on 171s ok 555 - Dependent error ident should be "revert" 171s ok 556 - Dependent error message should be correct 171s ok 557 - It should have check for requiring changes 171s ok 558 - Should get error reverting change others depend on 171s ok 559 - Dependent error ident should be "revert" 171s ok 560 - Dependent error message should be correct 171s ok 561 - It should have check for requiring changes 171s ok 562 - Should get error reverting change others depend on 171s ok 563 - Dependent error ident should be "revert" 171s ok 564 - Dependent error message should be correct 171s ok 565 - It should have checked twice for requiring changes 171s ok 566 - App::Sqitch::Engine::whu->can('_trim_to') 171s ok 567 - _trim_to should complain about a nonexistent change key 171s ok 568 - _trim_to nonexistent key error ident should be "foo" 171s ok 569 - _trim_to nonexistent key error message should be correct 171s ok 570 - It should have passed the change name and ROOT tag to change_id_for 171s ok 571 - _trim_to should complain about an undeployed change key 171s ok 572 - _trim_to undeployed change error ident should be "yep" 171s ok 573 - _trim_to undeployed change error message should be correct 171s ok 574 - It should have passed change "blah" change_id_for 171s ok 575 - _trim_to should complain about an unplanned change key 171s ok 576 - _trim_to unplanned change error ident should be "oop" 171s ok 577 - _trim_to unplanned change error message should be correct 171s ok 578 - It should have passed "whatever" to change_id_offset_from_id 171s ok 579 - _trim_to should find "roles" at index 0 171s ok 580 - Changes should be untrimmed 171s ok 581 - It should have passed change 0 ID to change_id_offset_from_id 171s ok 582 - _trim_to should find "widgets" at index 2 171s ok 583 - First two changes should be shifted off 171s ok 584 - It should have passed change 2 ID to change_id_offset_from_id 171s ok 585 - _trim_to should find "dr_evil" at last index 171s ok 586 - Changes should be untrimmed 171s ok 587 - It should have passed change -1 ID to change_id_offset_from_id 171s ok 588 - _trim_to should find "tacos" at index 4 171s ok 589 - Last two changes should be popped off 171s ok 590 - It should have passed change -3 ID to change_id_offset_from_id 171s ok 591 - _trim_to should find "lolz^" at index 4 171s ok 592 - Should pass change -3 ID and offset -1 to change_id_offset_from_id 171s ok 593 - _trim_to should find "curry~" at index 4 171s ok 594 - Should pass change -3 ID and offset 1 to change_id_offset_from_id 171s ok 595 - _trim_to should find "@HEAD" at index 2 171s ok 596 - First two changes should be shifted off 171s ok 597 - Should pass tag HEAD to change_id_for 171s ok 598 - _trim_to should find "HEAD" at index 2 171s ok 599 - First two changes should be shifted off 171s ok 600 - Should pass tag @HEAD to change_id_for 171s ok 601 - _trim_to should find "@ROOT" at index 2 171s ok 602 - All but First three changes should be popped off 171s ok 603 - Should pass tag ROOT to change_id_for 171s ok 604 - _trim_to should find "ROOT" at index 2 171s ok 605 - All but First three changes should be popped off 171s ok 606 - Should pass tag @ROOT to change_id_for 171s ok 607 - App::Sqitch::Engine::whu->can('_verify_changes') 171s ok 608 - Verify of a single change should return errcount 0 171s ok 609 - Declared output should list the change 171s ok 610 - Emitted Output should reflect the verification of the change 171s ok 611 - Should have no comments 171s ok 612 - The verify script should have been run 171s ok 613 - Verify of another single change should return errcount 0 171s ok 614 - Declared output should list the change 171s ok 615 - Emitted Output should reflect the verification of the change 171s ok 616 - Should have no comments 171s ok 617 - A warning about no verify file should have been emitted 171s ok 618 - The verify script should not have been run 171s ok 619 - Verify of two changes should return errcount 0 171s ok 620 - Declared output should list both changes 171s ok 621 - Emitted Output should reflect the verification of the changes 171s ok 622 - Should have no comments 171s ok 623 - A warning about no verify file should have been emitted 171s ok 624 - Only one verify script should have been run 171s ok 625 - Verify of two changes and show pending 171s ok 626 - Delcared output should list deployed changes 171s ok 627 - Emitted output should include list of pending changes 171s ok 628 - Should have no comments 171s ok 629 - A warning about no verify file should have been emitted 171s ok 630 - Only one verify script should have been run 171s ok 631 - Verify of a change not in the plan should return errcount 1 171s ok 632 - Declared Output should reflect the verification of the change 171s ok 633 - Emitted Output should reflect the failure of the verify 171s ok 634 - Should have a comment about the change missing from the plan 171s ok 635 - No verify script should have been run 171s ok 636 - Verify of an out-of-order change should return errcount 1 171s ok 637 - Declared output should reflect the verification of the change 171s ok 638 - Emitted Output should reflect the failure of the verify 171s ok 639 - Should have a comment about the out-of-order change 171s ok 640 - The verify script should have been run 171s ok 641 - Verify of a change with 2 issues should return 2 171s ok 642 - Declared output should reflect the verification of the change 171s ok 643 - Emitted Output should reflect the failure of the verify 171s ok 644 - Should have comment about the out-of-order change and script failure 171s ok 645 - No abstract methods should have been called 171s ok 646 - Verify of 2 changes with 2 issues each should return 4 171s ok 647 - Declraed output should reflect the verification of both changes 171s ok 648 - Emitted Output should reflect the failure of both verifies 171s ok 649 - Should have comment about the out-of-order changes and script failures 171s ok 650 - No abstract methods should have been called 171s ok 651 - _verify_changes with two undeployed changes should returne 2 171s ok 652 - Listed changes should be both deployed and undeployed 171s ok 653 - Emitted Output should reflect 1 pass 171s ok 654 - Should have comments for undeployed changes 171s ok 655 - No abstract methods should have been called 171s ok 656 - App::Sqitch::Engine::whu->can('verify') 171s ok 657 - Should return success for no deployed changes 171s ok 658 - Notification of the verify should be emitted 171s ok 659 - Should have called deployed_changes 171s ok 660 - Should return success for no changes 171s ok 661 - Notification of the verify should be emitted 171s ok 662 - Should have called deployed_changes 171s ok 663 - Should get error for no planned changes 171s ok 664 - No planned changes ident should be "verify" 171s ok 665 - No planned changes exitval should be 2 171s ok 666 - No planned changes message should be correct 171s ok 667 - Notification of the verify should be emitted 171s ok 668 - Should have called deployed_changes 171s ok 669 - Verify one change 171s ok 670 - Notification of the verify should be emitted 171s ok 671 - The one change name should be declared 171s ok 672 - Success should be emitted 171s ok 673 - Should have no comments 171s ok 674 - Should have run the verify file 171s ok 675 - Verify two changes 171s ok 676 - Notification of the verify should be emitted 171s ok 677 - The two change names should be declared 171s ok 678 - Both successes should be emitted 171s ok 679 - Should have no comments 171s ok 680 - Should have warning about missing verify script 171s ok 681 - Should have run the verify file again 171s ok 682 - Verify with a reworked change changes 171s ok 683 - Notification of the verify should be emitted 171s ok 684 - The two change names should be emitted 171s ok 685 - Both successes should be emitted 171s ok 686 - Should have no comments 171s ok 687 - Should have no warnings 171s ok 688 - Should not have run the verify file 171s ok 689 - Verify two specific changes 171s ok 690 - Notification of the verify should be emitted 171s ok 691 - The two change names should be emitted 171s ok 692 - Both successes should be emitted 171s ok 693 - Should have no comments 171s ok 694 - Should have warning about missing verify script 171s ok 695 - Should have searched offsets and run the verify file 171s ok 696 - Should get failure for failing verify scripts 171s ok 697 - Failed verify ident should be "verify" 171s ok 698 - Failed verify exitval should be 2 171s ok 699 - Faield verify message should be correct 171s ok 700 - Notification of the verify should be emitted 171s ok 701 - Both change names should be declared 171s ok 702 - Output should include the failure report 171s ok 703 - Should have the errors in comments 171s ok 704 - Nothing should have been vented 171s ok 705 - Should have searched offsets but not run the verify file 171s ok 706 - App::Sqitch::Engine::whu->can('check') 171s ok 707 - Should return success for no deployed changes 171s ok 708 - Notification of the check should be emitted 171s ok 709 - Should have called deployed_changes 171s ok 710 - Should return success for no changes 171s ok 711 - Notification of the verify should be emitted 171s ok 712 - Should have called deployed_changes 171s ok 713 - Should get error for no planned changes 171s ok 714 - Failed check ident should be "check" 171s ok 715 - No planned changes exitval should be 1 171s ok 716 - Failed check message should be correct 171s ok 717 - Notification of the check should be emitted 171s ok 718 - Divergent change info should be emitted 171s ok 719 - Should have called deployed_changes and latest_change_id 171s ok 720 - Check one change 171s ok 721 - Notification of the check should be emitted 171s ok 722 - Success should be emitted 171s ok 723 - Should have no comments 171s ok 724 - Should have called deployed_changes and latest_change_id 171s ok 725 - Should get error for one divergent script hash 171s ok 726 - Failed check ident should be "check" 171s ok 727 - No planned changes exitval should be 1 171s ok 728 - Failed check message should be correct 171s ok 729 - Notification of the check should be emitted 171s ok 730 - Divergent change info should be emitted 171s ok 731 - Should have called deployed_changes and latest_change_id 171s ok 732 - Should get error for one divergent script hash 171s ok 733 - Failed check ident should be "check" 171s ok 734 - No planned changes exitval should be 1 171s ok 735 - Failed check message should be correct 171s ok 736 - Notification of the check should be emitted 171s ok 737 - Divergent change info should be emitted 171s ok 738 - Should have called deployed_changes and latest_change_id 171s ok 739 - Check one change with to arg 171s ok 740 - Notification of the check should be emitted 171s ok 741 - Success should be emitted 171s ok 742 - Should have no comments 171s ok 743 - Should have searched offsets 171s ok 744 - Should get error for one divergent script hash with from arg 171s ok 745 - Failed check ident should be "check" 171s ok 746 - No planned changes exitval should be 1 171s ok 747 - Failed check message should be correct 171s ok 748 - Notification of the check should be emitted 171s ok 749 - Divergent change info should be emitted 171s ok 750 - Should have searched offsets and the latest change ID 171s ok 751 - App::Sqitch::Engine::whu->can('lock_destination') 171s ok 752 - Lock timeout should be 60 seconds 171s ok 753 - Lock destination 171s ok 754 - Should be locked 171s ok 755 - wait_lock should not have been called 171s ok 756 - Should have emitted no info 171s ok 757 - Lock destination 171s ok 758 - Should be locked again 171s ok 759 - wait_lock should have been called 171s ok 760 - Should have notified user of waiting for lock 171s ok 761 - Lock destination again 171s ok 762 - wait_lock should not have been called 171s ok 763 - Should again have emitted no info 171s ok 764 - Should get error for lock timeout 171s ok 765 - Lock timeout error ident should be "engine" 171s ok 766 - Lock timeout error exitval should be 2 171s ok 767 - Lock timeout error message should be correct 171s ok 768 - Should have notified user of waiting for lock 171s ok 769 - wait_lock should have been called 171s ok 770 - Should get last index when there is a latest change ID 171s ok 771 - Should die on too many IDs 171s ok 772 - Too many IDs ident should be "engine" 171s ok 773 - Too many IDs message should be correct 171s ok 774 - Too many IDs error should have been vented 171s ok 775 - Test planned_deployed_common_ancestor_id 171s ok 776 - Should have key 171s ok 777 - Driver should be the same as engine 171s ok 778 - Default try_lock should return true by default 171s ok 779 - Default begin_work should return self 171s ok 780 - Default finish_work should return self 171s ok 781 - no warnings 171s ok 173s t/engine_cmd.t ...... 173s 1..201 173s ok 1 - Load a sqitch sqitch object 173s ok 2 - 'Engine command' isa 'App::Sqitch::Command::engine' 173s ok 3 - 'Engine command' isa 'App::Sqitch::Command' 173s ok 4 - App::Sqitch::Command::engine->can(...) 173s ok 5 - App::Sqitch::Command::engine does TargetConfigCommand 173s ok 6 - Options should be correct 173s ok 7 - Should parse options 173s ok 8 - Options should not conflict with core options 173s ok 9 - Default config should contain empty properties 173s ok 10 - configure() should ignore config file 173s ok 11 - Get full config 173s ok 12 - Should have properties 173s ok 13 - 'plan_file file attribute' isa 'Path::Class::File' 173s ok 14 - 'top_dir directory attribute' isa 'Path::Class::Dir' 173s ok 15 - 'reworked_dir directory attribute' isa 'Path::Class::Dir' 173s ok 16 - 'deploy_dir directory attribute' isa 'Path::Class::Dir' 173s ok 17 - 'reworked_deploy_dir directory attribute' isa 'Path::Class::Dir' 173s ok 18 - 'revert_dir directory attribute' isa 'Path::Class::Dir' 173s ok 19 - 'reworked_revert_dir directory attribute' isa 'Path::Class::Dir' 173s ok 20 - 'verify_dir directory attribute' isa 'Path::Class::Dir' 173s ok 21 - 'reworked_verify_dir directory attribute' isa 'Path::Class::Dir' 173s ok 22 - Should fail on invalid directory name 173s ok 23 - Invalid directory ident should be "engine" 173s ok 24 - The invalid directory messsage should be correct 173s ok 25 - Should fail on invalid directory names 173s ok 26 - Invalid directories ident should be "engine" 173s ok 27 - The invalid properties messsage should be correct 173s ok 28 - Run list() 173s ok 29 - The list of engines should have been output 173s ok 30 - 'Verbose engine' isa 'App::Sqitch::Command::engine' 173s ok 31 - Run verbose list() 173s ok 32 - The list of engines and their targets should have been output 173s ok 33 - 'New engine' isa 'App::Sqitch::Command::engine' 173s ok 34 - Target should be undef 173s ok 35 - Target should fall back on passed name 173s ok 36 - Should get error for mismatched target engine 173s ok 37 - Mismatched target error ident should be "engine" 173s ok 38 - Mismatched target error message should be correct 173s ok 39 - Should get error for unknown target 173s ok 40 - Uknown target error ident should be "engine" 173s ok 41 - Unkonwn target error message should be correct 173s ok 42 - No name arg to add() should yield usage 173s ok 43 - No args should be passed to usage 173s ok 44 - Should get error for existing engine 173s ok 45 - Existing engine error ident should be "engine" 173s ok 46 - Existing engine error message should be correct 173s ok 47 - dir deploy does not exist 173s ok 48 - dir revert does not exist 173s ok 49 - dir verify does not exist 173s ok 50 - Add engine "vertica" 173s ok 51 - dir deploy exists 173s ok 52 - dir revert exists 173s ok 53 - dir verify exists 173s ok 54 - Engine "test" target should have been set 173s ok 55 - Engine "vertica" should have no client set 173s ok 56 - Engine "vertica" should have no registry set 173s ok 57 - Engine "vertica" should have no top_dir set 173s ok 58 - Engine "vertica" should have no plan_file set 173s ok 59 - Engine "vertica" should have no deploy_dir set 173s ok 60 - Engine "vertica" should have no revert_dir set 173s ok 61 - Engine "vertica" should have no verify_dir set 173s ok 62 - Engine "vertica" should have no extension set 173s ok 63 - Engine "vertica" should have no variables set 173s ok 64 - 'Engine with target property' isa 'App::Sqitch::Command::engine' 173s ok 65 - Should get error for engine/target mismatch 173s ok 66 - Target mismatch ident should be "engine" 173s ok 67 - Target mismatch message should be correct 173s ok 68 - 'Engine with all properties' isa 'App::Sqitch::Command::engine' 173s ok 69 - my.plan does not exist 173s ok 70 - dir top/deploy does not exist 173s ok 71 - dir top/revert does not exist 173s ok 72 - dir top/verify does not exist 173s ok 73 - dir r/d does not exist 173s ok 74 - dir r/revert does not exist 173s ok 75 - dir r/verify does not exist 173s ok 76 - Add engine "firebird" 173s ok 77 - dir top/deploy exists 173s ok 78 - dir top/revert exists 173s ok 79 - dir top/verify exists 173s ok 80 - dir r/d exists 173s ok 81 - dir r/revert exists 173s ok 82 - dir r/verify exists 173s ok 83 - my.plan exists 173s ok 84 - Engine "firebird" should have client set 173s ok 85 - Engine "firebird" should have reworked_dir set 173s ok 86 - Engine "firebird" should have extension set 173s ok 87 - Engine "firebird" should have top_dir set 173s ok 88 - Engine "firebird" should have target set 173s ok 89 - Engine "firebird" should have reworked_deploy_dir set 173s ok 90 - Engine "firebird" should have verify_dir set 173s ok 91 - Engine "firebird" should have variables 173s ok 92 - Engine "firebird" should have registry set 173s ok 93 - Engine "firebird" should have deploy_dir set 173s ok 94 - Engine "firebird" should have plan_file set 173s ok 95 - Engine "firebird" should have revert_dir set 173s ok 96 - 'Engine with no properties' isa 'App::Sqitch::Command::engine' 173s ok 97 - No name arg to add() should yield usage 173s ok 98 - No args should be passed to usage 173s ok 99 - Should get error from alter for nonexistent engine 173s ok 100 - Nonexistent engine error ident should be "engine" 173s ok 101 - Nonexistent engine error message should be correct 173s ok 102 - Should get error for missing engine 173s ok 103 - Missing engine error ident should be "engine" 173s ok 104 - Missing engine error message should be correct 173s ok 105 - 'Engine with more properties' isa 'App::Sqitch::Command::engine' 173s ok 106 - Alter engine "firebird" 173s ok 107 - Engine "firebird" should have reworked_deploy_dir set 173s ok 108 - Engine "firebird" should have extension set 173s ok 109 - Engine "firebird" should have top_dir set 173s ok 110 - Engine "firebird" should have target set 173s ok 111 - Engine "firebird" should have reworked_dir set 173s ok 112 - Engine "firebird" should have client set 173s ok 113 - Engine "firebird" should have plan_file set 173s ok 114 - Engine "firebird" should have revert_dir set 173s ok 115 - Engine "firebird" should have deploy_dir set 173s ok 116 - Engine "firebird" should have registry set 173s ok 117 - Engine "firebird" should have variables 173s ok 118 - Engine "firebird" should have verify_dir set 173s ok 119 - 'Engine with new top_dir property' isa 'App::Sqitch::Command::engine' 173s ok 120 - dir pg does not exist 173s ok 121 - dir pg/deploy does not exist 173s ok 122 - dir pg/revert does not exist 173s ok 123 - dir pg/verify does not exist 173s ok 124 - Alter engine "pg" 173s ok 125 - dir pg exists 173s ok 126 - dir pg/deploy exists 173s ok 127 - dir pg/revert exists 173s ok 128 - dir pg/verify exists 173s ok 129 - The pg top_dir should have been set 173s ok 130 - Should again get error for missing engine 173s ok 131 - Missing engine error ident should still be "engine" 173s ok 132 - Missing engine error message should include target property 173s ok 133 - 'Engine with target property' isa 'App::Sqitch::Command::engine' 173s ok 134 - Should get error for engine/target mismatch 173s ok 135 - Target mismatch ident should be "engine" 173s ok 136 - Target mismatch message should be correct 173s ok 137 - No name args to remove() should yield usage 173s ok 138 - No args should be passed to usage 173s ok 139 - Should get error for nonexistent engine 173s ok 140 - Nonexistent engine error ident should be "engine" 173s ok 141 - Nonexistent engine error message should be correct 173s ok 142 - Remove 173s ok 143 - Engine "mysql" should now be gone 173s ok 144 - Engine "mysql" should have no variables 173s ok 145 - 'Engein with variables' isa 'App::Sqitch::Command::engine' 173s ok 146 - Add engine "mysql" 173s ok 147 - Engine "mysql" should be back 173s ok 148 - Engine "mysql" should have variables 173s ok 149 - Remove 173s ok 150 - Engine "mysql" should be gone again 173s ok 151 - Engine "mysql" should have no variables 173s ok 152 - Run show() 173s ok 153 - Show with no names should emit the list of engines 173s ok 154 - Show sqlite 173s ok 155 - The full "sqlite" engine should have been shown 173s ok 156 - Show three engines 173s ok 157 - All three engines should have been shown 173s ok 158 - 'Simple engine' isa 'App::Sqitch::Command::engine' 173s ok 159 - Execute undef 173s ok 160 - list() should have been called 173s ok 161 - Execute undef with args 173s ok 162 - list() should have been passed args 173s ok 163 - Execute list 173s ok 164 - list() should have been called 173s ok 165 - Execute list with args 173s ok 166 - list() should have been passed args 173s ok 167 - Execute add 173s ok 168 - add() should have been called 173s ok 169 - Execute add with args 173s ok 170 - add() should have been passed args 173s ok 171 - Execute set-target 173s ok 172 - set_target() should have been called 173s ok 173 - Execute set-target with args 173s ok 174 - set_target() should have been passed args 173s ok 175 - Execute set-registry 173s ok 176 - set_registry() should have been called 173s ok 177 - Execute set-registry with args 173s ok 178 - set_registry() should have been passed args 173s ok 179 - Execute set-client 173s ok 180 - set_client() should have been called 173s ok 181 - Execute set-client with args 173s ok 182 - set_client() should have been passed args 173s ok 183 - Execute remove 173s ok 184 - remove() should have been called 173s ok 185 - Execute remove with args 173s ok 186 - remove() should have been passed args 173s ok 187 - Execute rm 173s ok 188 - remove() should have been called 173s ok 189 - Execute rm with args 173s ok 190 - remove() should have been passed args 173s ok 191 - Execute rename 173s ok 192 - rename() should have been called 173s ok 193 - Execute rename with args 173s ok 194 - rename() should have been passed args 173s ok 195 - Execute show 173s ok 196 - show() should have been called 173s ok 197 - Execute show with args 173s ok 198 - show() should have been passed args 173s ok 199 - Should get an exception for a nonexistent action 173s ok 200 - Nonexistent action message should be passed to usage 173s ok 201 - no warnings 173s ok 173s t/exasol.t .......... 173s ok 1 - require App::Sqitch::Engine::exasol; 173s ok 2 - config_vars should return three vars 173s ok 3 - An object of class 'App::Sqitch::Engine::exasol' isa 'App::Sqitch::Engine::exasol' 173s ok 4 - Key should be "exasol" 173s ok 5 - Name should be "Exasol" 173s ok 6 - client should default to exaplus 173s ok 7 - registry default should be "sqitch" 173s ok 8 - DB URI should be "db:exasol:" 173s ok 9 - Destination should default to "db:exasol:" 173s ok 10 - Registry destination should be the same as destination 173s ok 11 - exaplus command should be std opts-only 173s ok 12 - _script should work 173s ok 13 - Set some variables 173s ok 14 - _script should assemble variables 173s ok 15 - Should handle query SSLCertificate=SSL_VERIFY_NONE 173s ok 16 - Should handle query SSLCERTIFICATE=SSL_VERIFY_NONE 173s ok 17 - Should handle query SSLCERTIFICATE=xxx 173s ok 18 - Should handle query SSLCERTIFICATE=SSL_VERIFY_NONE&SSLCERTIFICATE=xyz 173s ok 19 - Should handle query AuthMethod=refreshtoken 173s ok 20 - Should handle query AUTHMETHOD=xyz 173s ok 21 - Should handle query SSLCertificate=SSL_VERIFY_NONE&AUTHMETHOD=xyz 173s ok 22 - Target name should NOT fall back on sysuser 173s ok 23 - Registry target should be the same as destination 173s ok 24 - Create another exasol 173s ok 25 - client should be as configured 173s ok 26 - uri should be as configured 173s ok 27 - registry should be as configured 173s ok 28 - exaplus command should be configured from URI config 173s ok 29 - _script should use registry from config settings 173s ok 30 - App::Sqitch::Engine::exasol->can(...) 173s ok 31 - Call _run 173s ok 32 - EXAplus command should be passed to spool() 173s ok 33 - The script should be spooled 173s ok 34 - Call _capture 173s ok 35 - Command and script should be passed to run3() 173s ok 36 - _capture should actually capture 173s ok 37 - _capture should die when exaplus dies 173s ok 38 - STDERR should be emitted by _capture 173s ok 39 - initialized() should rethrow unexpected DB error 173s ok 40 - _cid should rethrow unexpected DB error 173s ok 41 - App::Sqitch::Engine::exasol->can('_file_for_script') 173s ok 42 - File without special characters should be used directly 173s ok 43 - Double quotes should be SQL-escaped 173s ok 44 - Get temp dir 173s ok 45 - 'Temp dir' isa 'Path::Class::Dir' 173s ok 46 - File with special char should be aliased 173s ok 47 - Should get an error on failure to delete the alias 173s ok 48 - File deletion error ident should be "exasol" 173s ok 49 - File deletion error message should be correct 173s ok 50 - File with special char and quotes should be aliased 173s ok 51 - Run foo/bar.sql 173s ok 52 - File should be passed to capture() 173s ok 53 - Run foo/"bar".sql 173s ok 54 - Double quotes in file passed to capture() should be escaped 173s ok 55 - Spool a "file handle" 173s ok 56 - exaplus command should be passed to spool() 173s ok 57 - 'Array ove handles should be passed to spool' isa 'ARRAY' 173s ok 58 - First file handle should be script 173s ok 59 - Second should be the passed handle 173s ok 60 - Verify foo/bar.sql 173s ok 61 - Verify file should be passed to capture() 173s ok 62 - Verify foo/bar.sql again 173s ok 63 - Verify file should be passed to run() for high verbosity 173s ok 64 - App::Sqitch::Engine::exasol->can('_ts2char_format') 173s ok 65 - _ts2char should work 173s ok 66 - App::Sqitch::Engine::exasol->can('_dt') 173s ok 67 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 173s ok 68 - DateTime year should be set 173s ok 69 - DateTime month should be set 173s ok 70 - DateTime day should be set 173s ok 71 - DateTime hour should be set 173s ok 72 - DateTime minute should be set 173s ok 73 - DateTime second should be set 173s ok 74 - DateTime TZ should be set 173s ok 75 - _char2ts should present timestamp at UTC w/o tz identifier 173s ok 76 - Should have _listagg_format 173s ok 77 - Should have _ts_default 173s ok 78 - Should have _regex_op 173s ok 79 - Should have _simple_from 173s ok 80 - Should have _limit_default 173s ok 81 - Should have no table error 173s ok 82 - Should have no column error 173s ok 83 - Should now have table error 173s ok 84 - Should now have no column error 173s ok 85 - Unique constraints not supported by Exasol 173s ok 86 - Should get limit and offset 173s ok 87 - Should get limit and offset when offset only 173s ok 88 - Should get only limit with 0 offset 173s ok 89 - Should get only limit with noa offset 173s ok 90 - Should get no limit or offset for 0s 173s ok 91 - Should get no limit or offset for no args 173s ok 92 - Should use regexp_like and prepend wildcard to regex 173s ok 93 - Should use regexp_like and append wildcard to regex 173s ok 94 - Should not chande regex with both anchors 173s ok 95 - Should append wildcards to both ends without anchors 173s ok 96 - App::Sqitch::Engine::exasol->can(...) 173s # Subtest: live database 173s 1..0 # SKIP Unable to live-test Exasol engine: DBD::ODBC 1.59 required to manage Exasol at t/exasol.t line 437. 173s ok 97 # skip Unable to live-test Exasol engine: DBD::ODBC 1.59 required to manage Exasol at t/exasol.t line 437. 173s # 173s 1..97 173s ok 174s t/firebird.t ........ 174s ok 1 - require App::Sqitch::Engine::firebird; 174s ok 2 - config_vars should return three vars 174s ok 3 - An object of class 'App::Sqitch::Engine::firebird' isa 'App::Sqitch::Engine::firebird' 174s ok 4 - Key should be "firebird" 174s ok 5 - Name should be "Firebird" 174s ok 6 - Should have username from environment 174s ok 7 - Should have password from environment 174s ok 8 - Should have _limit_default 174s ok 9 - dbname should be filled in 174s ok 10 - registry dbname should be "sqitch.fdb" 174s ok 11 - registry_destination should be the same as registry URI 174s ok 12 - An object of class 'App::Sqitch::Engine::firebird' isa 'App::Sqitch::Engine::firebird' 174s ok 13 - Set some variables 174s ok 14 - Create a firebird with environment variables set 174s ok 15 - Should have username from environment 174s ok 16 - Should have password from environment 174s ok 17 - Create another firebird 174s ok 18 - client should be as configured 174s ok 19 - URI should be as configured 174s ok 20 - destination should default to URI without password 174s ok 21 - registry_destination should be URI with configured registry and no password 174s ok 22 - firebird command should be configured 174s ok 23 - App::Sqitch::Engine::firebird->can('connection_string') 174s ok 24 - Connection for db:firebird:foo.fdb 174s ok 25 - Connection for db:firebird:foo.com/foo.fdb 174s ok 26 - Connection for db:firebird:foo.com/foo.fdb:1234 174s ok 27 - Connection for db:firebird:/blah/hi.fdb 174s ok 28 - Connection for db:firebird:foo.com//blah/hi.fdb 174s ok 29 - Connection for db:firebird:foo.com//blah/hi.fdb:1234 174s ok 30 - Connection for db:firebird:C:/blah/hi.fdb 174s ok 31 - Connection for db:firebird:foo.com/C:/blah/hi.fdb 174s ok 32 - Connection for db:firebird:foo.com/C:/blah/hi.fdb:1234 174s ok 33 - Should get an exception for no db name 174s ok 34 - No dbname exception ident should be "firebird" 174s ok 35 - No dbname exception message should be correct 174s ok 36 - App::Sqitch::Engine::firebird->can(...) 174s ok 37 - ISC_PASSWORD should be "s3cr3t" 174s ok 38 - Call _run 174s ok 39 - Command should be passed to run() 174s ok 40 - ISC_PASSWORD should be "s3cr3t" 174s ok 41 - Call _spool 174s ok 42 - Command should be passed to spool() 174s ok 43 - ISC_PASSWORD should be "s3cr3t" 174s ok 44 - Call _capture 174s ok 45 - Command should be passed to capture() 174s ok 46 - Create a firebird with sqitch with no pw 174s ok 47 - ISC_PASSWORD should not exist 174s ok 48 - Call _run again 174s ok 49 - Command should be passed to run() again 174s ok 50 - ISC_PASSWORD should not exist 174s ok 51 - Call _spool again 174s ok 52 - Command should be passed to spool() again 174s ok 53 - ISC_PASSWORD should not exist 174s ok 54 - Call _capture again 174s ok 55 - Command should be passed to capture() again 174s ok 56 - ISC_PASSWORD should not exist 174s ok 57 - Run foo/bar.sql 174s ok 58 - File should be passed to run() 174s ok 59 - ISC_PASSWORD should not exist 174s ok 60 - Spool a "file handle" 174s ok 61 - Handle should be passed to spool() 174s ok 62 - ISC_PASSWORD should not exist 174s ok 63 - Verify foo/bar.sql 174s ok 64 - Verify file should be passed to capture() 174s ok 65 - ISC_PASSWORD should not exist 174s ok 66 - Verify foo/bar.sql again 174s ok 67 - Verify file should be passed to run() for high verbosity 174s ok 68 - App::Sqitch::Engine::firebird->can('_ts2char_format') 174s ok 69 - _ts2char_format should work 174s ok 70 - App::Sqitch::Engine::firebird->can('_dt') 174s ok 71 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 174s ok 72 - DateTime year should be set 174s ok 73 - DateTime month should be set 174s ok 74 - DateTime day should be set 174s ok 75 - DateTime hour should be set 174s ok 76 - DateTime minute should be set 174s ok 77 - DateTime second should be set 174s ok 78 - DateTime TZ should be set 174s ok 79 - Should have no table error 174s ok 80 - Should have no column error 174s ok 81 - Should now have table error 174s ok 82 - Still should have no column error 174s ok 83 - Should again have table error 174s ok 84 - Still should have no column error 174s ok 85 - Should again have no table error 174s ok 86 - Should now have no column error 174s ok 87 - Should get an error from initialize 174s ok 88 - No creattion exception ident should be "firebird" 174s ok 89 - Creation exception message should be correct 174s ok 90 - Run the upgrade 174s ok 91 - Should have disconnected 174s ok 92 - Should have cleared the database handle 174s ok 93 - Should have run a command 174s ok 94 - _cid should propagate unexpected error 174s ok 95 - _cid should just return on error code -902 174s ok 96 - current_state should return on no table error 174s ok 97 - current_state should propagate unexpected error 174s ok 98 - Should get undef from change_id_for when no useful params 174s ok 99 - Should get error when no client found 174s ok 100 - Client exception ident should be "firebird" 174s ok 101 - Client exception message should be correct 174s ok 102 - App::Sqitch::Engine::firebird->can(...) 174s # Subtest: live database 174s 1..0 # SKIP Unable to live-test Firebird engine: Unable to locate Firebird ISQL; set "engine.firebird.client" via sqitch config 174s ok 103 # skip Unable to live-test Firebird engine: Unable to locate Firebird ISQL; set "engine.firebird.client" via sqitch config 174s 1..103 174s ok 175s t/help.t ............ 175s 1..20 175s ok 1 - Load a sqitch sqitch object 175s ok 2 - 'Load help command' isa 'App::Sqitch::Command::help' 175s ok 3 - 'Help command' isa 'App::Sqitch::Command' 175s ok 4 - App::Sqitch::Command::help->can(...) 175s ok 5 - Options should be correct 175s ok 6 - Should parse options 175s ok 7 - Options should not conflict with core options 175s ok 8 - Execute help 175s ok 9 - Should show sqitch app docs 175s ok 10 - Execute "config" help 175s ok 11 - Should show "config" command docs 175s ok 12 - Execute "changes" help 175s ok 13 - Should show "changes" command docs 175s ok 14 - Execute "tutorial" help 175s ok 15 - Should show "tutorial" command docs 175s ok 16 - Should get an exception for "nonexistent" help 175s ok 17 - Exception ident should be "help" 175s ok 18 - Should get failure message for nonexistent command 175s ok 19 - Exception exit val should be 1 175s ok 20 - no warnings 175s ok 176s t/init.t ............ 176s 1..196 176s ok 1 - use App::Sqitch::Command::init; 176s ok 2 - 'App::Sqitch::Command::init' isa 'App::Sqitch::Command' 176s ok 3 - 'Init command' isa 'App::Sqitch::Command::init' 176s ok 4 - 'Init commmand' isa 'App::Sqitch::Command' 176s ok 5 - App::Sqitch::Command::init->can(...) 176s ok 6 - App::Sqitch::Command::init does TargetConfigCommand 176s ok 7 - Options should be correct 176s ok 8 - Should parse options 176s ok 9 - Options should not conflict with core options 176s ok 10 - Default config should contain empty properties 176s ok 11 - Should accept a URI in options 176s ok 12 - Get full config 176s ok 13 - 'uri propertiy' isa 'URI' 176s ok 14 - Should have properties 176s ok 15 - 'plan_file file attribute' isa 'Path::Class::File' 176s ok 16 - 'top_dir directory attribute' isa 'Path::Class::Dir' 176s ok 17 - 'reworked_dir directory attribute' isa 'Path::Class::Dir' 176s ok 18 - 'deploy_dir directory attribute' isa 'Path::Class::Dir' 176s ok 19 - 'reworked_deploy_dir directory attribute' isa 'Path::Class::Dir' 176s ok 20 - 'revert_dir directory attribute' isa 'Path::Class::Dir' 176s ok 21 - 'reworked_revert_dir directory attribute' isa 'Path::Class::Dir' 176s ok 22 - 'verify_dir directory attribute' isa 'Path::Class::Dir' 176s ok 23 - 'reworked_verify_dir directory attribute' isa 'Path::Class::Dir' 176s ok 24 - Should fail on invalid directory name 176s ok 25 - Invalid directory ident should be "init" 176s ok 26 - The invalid directory messsage should be correct 176s ok 27 - Should fail on invalid directory names 176s ok 28 - Invalid directories ident should be "init" 176s ok 29 - The invalid properties messsage should be correct 176s ok 30 - 'default target' isa 'App::Sqitch::Target' 176s ok 31 - App::Sqitch::Command::init->can('make_directories_for') 176s ok 32 - dir init.mkdir does not exist 176s ok 33 - dir init.mkdir/deploy does not exist 176s ok 34 - dir init.mkdir/revert does not exist 176s ok 35 - dir init.mkdir/verify does not exist 176s ok 36 - dir init.mkdir/reworked/deploy does not exist 176s ok 37 - dir init.mkdir/reworked/revert does not exist 176s ok 38 - dir init.mkdir/reworked/verify does not exist 176s ok 39 - Make the directories 176s ok 40 - dir init.mkdir/deploy exists 176s ok 41 - dir init.mkdir/revert exists 176s ok 42 - dir init.mkdir/verify exists 176s ok 43 - dir init.mkdir/reworked/deploy exists 176s ok 44 - dir init.mkdir/reworked/revert exists 176s ok 45 - dir init.mkdir/reworked/verify exists 176s ok 46 - Each should have been sent to info 176s ok 47 - Make the directories again 176s ok 48 - Nothing should have been sent to info 176s ok 49 - Make the directories once more 176s ok 50 - revert dir exists again 176s ok 51 - Should have noted creation of revert dir 176s ok 52 - Should fail on permission issue 176s ok 53 - Permission error should have ident "init" 176s ok 54 - The permission error should be formatted properly 176s ok 55 - App::Sqitch::Command::init->can('write_config') 176s ok 56 - Another init object 176s ok 57 - nonexistent.local does not exist 176s ok 58 - Write the config 176s ok 59 - nonexistent.local exists 176s ok 60 - The configuration file should have no variables 176s ok 61 - The creation should be sent to info 176s ok 62 - All in core section should be commented-out 176s ok 63 - Another init object 176s ok 64 - Write the config 176s ok 65 - nonexistent.local exists 176s ok 66 - The configuration should have been written with the one setting 176s ok 67 - The creation should be sent to info 176s ok 68 - Other settings should be commented-out 176s ok 69 - Write the config again 176s ok 70 - The configuration should be unchanged 176s ok 71 - Nothing should have been sent to info 176s ok 72 - Make an init object with user config 176s ok 73 - nonexistent.local does not exist 176s ok 74 - Write the config with a user conf 176s ok 75 - nonexistent.local exists 176s ok 76 - The configuration should just have core.top_dir 176s ok 77 - The creation should be sent to info again 176s ok 78 - Other settings should be commented-out 176s ok 79 - Make an init object with system config 176s ok 80 - Get target 176s ok 81 - nonexistent.local does not exist 176s ok 82 - Write the config with a system conf 176s ok 83 - nonexistent.local exists 176s ok 84 - The configuration should have local and system config 176s ok 85 - The creation should be sent to info again 176s ok 86 - Other settings should be commented-out 176s ok 87 - Create new init with sqitch non-default attributes 176s ok 88 - Write the config with core attrs 176s ok 89 - The creation should be sent to info once more 176s ok 90 - The configuration should have been written with core and engine values 176s ok 91 - Create new init with sqitch with default engine attributes 176s ok 92 - Write the config with engine attrs 176s ok 93 - The creation should be sent to info again again 176s ok 94 - The configuration should have been written with only the engine var 176s ok 95 - Engine section should be present but commented-out 176s ok 96 - Make an init with sqlite and user config 176s ok 97 - nonexistent.local does not exist 176s ok 98 - Write the config with sqlite config 176s ok 99 - The creation should be sent to info once more 176s ok 100 - New config should have been written with sqlite values 176s ok 101 - Configured client should be included in a comment 176s ok 102 - Configured target should be included in a comment 176s ok 103 - Configured registry should be included in a comment 176s ok 104 - Create new init with sqitch with more non-default engine attributes 176s ok 105 - Write the config with more engine attrs 176s ok 106 - The creation should be sent to info one more time 176s ok 107 - The configuration should have been written with client values 176s ok 108 - registry should be included in a comment 176s ok 109 - Create new init with sqitch with default engine attributes 176s ok 110 - Write the config with engine attrs 176s ok 111 - The creation should be sent to info again again again 176s ok 112 - The configuration should have been written with only the engine var 176s ok 113 - Engine section should be present but commented-out 176s ok 114 - Make an init with pg and user config 176s ok 115 - nonexistent.local does not exist 176s ok 116 - Write the config with pg config 176s ok 117 - The pg config creation should be sent to info 176s ok 118 - The configuration should have been written with pg options 176s ok 119 - Configured registry should be in a comment 176s ok 120 - Configured target should be in a comment 176s ok 121 - App::Sqitch::Command::init->can('write_plan') 176s ok 122 - Plan file should not yet exist 176s ok 123 - Write the plan file 176s ok 124 - The plan creation should be sent to info 176s ok 125 - Plan file should now exist 176s ok 126 - The contents should be correct 176s ok 127 - Write the plan file again 176s ok 128 - Plan file should still exist 176s ok 129 - The contents should be identical 176s ok 130 - Should get an error initialing a different project 176s ok 131 - Initialization error ident should be "init" 176s ok 132 - Initialzation error message should be correct 176s ok 133 - Should get an error initialzing a non-plan file 176s ok 134 - Non-plan file error ident should be "init" 176s ok 135 - Non-plan file error message should be correct 176s ok 136 - The file should not be overwritten 176s ok 137 - Create new init with sqitch with project and URI 176s ok 138 - Write the plan file again 176s ok 139 - The plan creation should be sent to info againq 176s ok 140 - Plan file should again exist 176s ok 141 - The plan should include the project and uri pragmas 176s ok 142 - App::Sqitch::Command::init->can('_validate_project') 176s ok 143 - No project should yield usage 176s ok 144 - No args should be passed to usage 176s ok 145 - Should get error for invalid project name "^foo" 176s ok 146 - Bad project "^foo" ident should be "init" 176s ok 147 - Bad project "^foo" error message should be correct 176s ok 148 - Should get error for invalid project name "foo^" 176s ok 149 - Bad project "foo^" ident should be "init" 176s ok 150 - Bad project "foo^" error message should be correct 176s ok 151 - Should get error for invalid project name "foo^6" 176s ok 152 - Bad project "foo^6" ident should be "init" 176s ok 153 - Bad project "foo^6" error message should be correct 176s ok 154 - Should get error for invalid project name "foo^666" 176s ok 155 - Bad project "foo^666" ident should be "init" 176s ok 156 - Bad project "foo^666" error message should be correct 176s ok 157 - Should get error for invalid project name "%hi" 176s ok 158 - Bad project "%hi" ident should be "init" 176s ok 159 - Bad project "%hi" error message should be correct 176s ok 160 - Should get error for invalid project name "hi!" 176s ok 161 - Bad project "hi!" ident should be "init" 176s ok 162 - Bad project "hi!" error message should be correct 176s ok 163 - Should get error for invalid project name "foo@bar" 176s ok 164 - Bad project "foo@bar" ident should be "init" 176s ok 165 - Bad project "foo@bar" error message should be correct 176s ok 166 - Should get error for invalid project name "foo:bar" 176s ok 167 - Bad project "foo:bar" ident should be "init" 176s ok 168 - Bad project "foo:bar" error message should be correct 176s ok 169 - Should get error for invalid project name "+foo" 176s ok 170 - Bad project "+foo" ident should be "init" 176s ok 171 - Bad project "+foo" error message should be correct 176s ok 172 - Should get error for invalid project name "-foo" 176s ok 173 - Bad project "-foo" ident should be "init" 176s ok 174 - Bad project "-foo" error message should be correct 176s ok 175 - Should get error for invalid project name "@foo" 176s ok 176 - Bad project "@foo" ident should be "init" 176s ok 177 - Bad project "@foo" error message should be correct 176s ok 178 - 'Custom URI target' isa 'App::Sqitch::Target' 176s ok 179 - Shoudl have the custom URI 176s ok 180 - Should have the custom name 176s ok 181 - Should fail on permission issue 176s ok 182 - Permission error should have ident "init" 176s ok 183 - The permission error should be formatted properly 176s ok 184 - Should fail on nonexistent dir name 176s ok 185 - Nonexistant path error should have ident "init" 176s ok 186 - Nonexistant path error should be the message 176s ok 187 - Execute! 176s ok 188 - dir plan.dir exists 176s ok 189 - dir plan.dir/deploy exists 176s ok 190 - dir plan.dir/revert exists 176s ok 191 - dir plan.dir/verify exists 176s ok 192 - nonexistent.local exists 176s ok 193 - plan.dir/sqitch.plan exists 176s ok 194 - Should have status messages 176s ok 195 - The plan should have the --project name 176s ok 196 - no warnings 176s ok 177s t/item_formatter.t .. 177s 1..172 177s ok 1 - require App::Sqitch::ItemFormatter; 177s ok 2 - App::Sqitch::ItemFormatter->can(...) 177s ok 3 - 'Instantiated object' isa 'App::Sqitch::ItemFormatter' 177s ok 4 - Should not be abbreviated by default 177s ok 5 - Default date format should be "iso" 177s ok 6 - Format "%e" should output "deploy" 177s ok 7 - Format "%e" should output "revert" 177s ok 8 - Format "%e" should output "fail" 177s ok 9 - Format "%L" should output "Deploy" 177s ok 10 - Format "%L" should output "Revert" 177s ok 11 - Format "%L" should output "Fail" 177s ok 12 - Format "%l" should output "deploy" 177s ok 13 - Format "%l" should output "revert" 177s ok 14 - Format "%l" should output "fail" 177s ok 15 - Format "%{event}_" should output "Event: " 177s ok 16 - Format "%{change}_" should output "Change: " 177s ok 17 - Format "%{committer}_" should output "Committer:" 177s ok 18 - Format "%{planner}_" should output "Planner: " 177s ok 19 - Format "%{by}_" should output "By: " 177s ok 20 - Format "%{date}_" should output "Date: " 177s ok 21 - Format "%{committed}_" should output "Committed:" 177s ok 22 - Format "%{planned}_" should output "Planned: " 177s ok 23 - Format "%{name}_" should output "Name: " 177s ok 24 - Format "%{email}_" should output "Email: " 177s ok 25 - Format "%{requires}_" should output "Requires: " 177s ok 26 - Format "%{conflicts}_" should output "Conflicts:" 177s ok 27 - Format "%H" should output "123456789" 177s ok 28 - Format "%h" should output "123456789" 177s ok 29 - Format "%{5}h" should output "12345" 177s ok 30 - Format "%{7}h" should output "1234567" 177s ok 31 - Format "%n" should output "foo" 177s ok 32 - Format "%n" should output "bar" 177s ok 33 - Format "%o" should output "foo" 177s ok 34 - Format "%o" should output "bar" 177s ok 35 - Format "%F" should output "deploy/change_file.sql" 177s ok 36 - Format "%F" should output "deploy/change_file_with_tag@tag.sql" 177s ok 37 - Format "%c" should output "larry " 177s ok 38 - Format "%{n}c" should output "damian" 177s ok 39 - Format "%{name}c" should output "chip" 177s ok 40 - Format "%{e}c" should output "larry@example.com" 177s ok 41 - Format "%{email}c" should output "damian@example.com" 177s ok 42 - Format "%{date}c" should output "2024-11-01 13:25:59 -0500" 177s ok 43 - Format "%{date:rfc}c" should output "Fri, 01 Nov 2024 13:25:59 -0500" 177s ok 44 - Format "%{d:long}c" should output "November 1, 2024, 1:25:59 PM CDT" 177s ok 45 - Format "%{d:cldr:HH'h' mm'm'}c" should output "13h 25m" 177s ok 46 - Format "%{d:strftime:%a at %H:%M:%S}c" should output "Fri at 13:25:59" 177s ok 47 - Format "%p" should output "larry " 177s ok 48 - Format "%{n}p" should output "damian" 177s ok 49 - Format "%{name}p" should output "chip" 177s ok 50 - Format "%{e}p" should output "larry@example.com" 177s ok 51 - Format "%{email}p" should output "damian@example.com" 177s ok 52 - Format "%{date}p" should output "2024-10-31 13:25:59 -0500" 177s ok 53 - Format "%{date:rfc}p" should output "Thu, 31 Oct 2024 13:25:59 -0500" 177s ok 54 - Format "%{d:long}p" should output "October 31, 2024, 1:25:59 PM CDT" 177s ok 55 - Format "%{d:cldr:HH'h' mm'm'}p" should output "13h 25m" 177s ok 56 - Format "%{d:strftime:%a at %H:%M:%S}p" should output "Thu at 13:25:59" 177s ok 57 - Format "%t" should output "" 177s ok 58 - Format "%t" should output " @foo" 177s ok 59 - Format "%t" should output " @foo, @bar" 177s ok 60 - Format "%{|}t" should output "" 177s ok 61 - Format "%{|}t" should output " @foo" 177s ok 62 - Format "%{|}t" should output " @foo|@bar" 177s ok 63 - Format "%{0}t" should output " @foo0@bar" 177s ok 64 - Format "%{}t" should output " @foo@bar" 177s ok 65 - Format "%T" should output "" 177s ok 66 - Format "%T" should output " (@foo)" 177s ok 67 - Format "%T" should output " (@foo, @bar)" 177s ok 68 - Format "%{|}T" should output "" 177s ok 69 - Format "%{|}T" should output " (@foo)" 177s ok 70 - Format "%{|}T" should output " (@foo|@bar)" 177s ok 71 - Format "%{0}T" should output " (@foo0@bar)" 177s ok 72 - Format "%{}T" should output " (@foo@bar)" 177s ok 73 - Format "%r" should output "" 177s ok 74 - Format "%r" should output " foo" 177s ok 75 - Format "%r" should output " foo, bar" 177s ok 76 - Format "%{|}r" should output "" 177s ok 77 - Format "%{|}r" should output " foo" 177s ok 78 - Format "%{|}r" should output " foo|bar" 177s ok 79 - Format "%{0}r" should output " foo0bar" 177s ok 80 - Format "%{}r" should output " foobar" 177s ok 81 - Format "%R" should output "" 177s ok 82 - Format "%R" should output "Requires: foo[newline]" 177s ok 83 - Format "%R" should output "Requires: foo, bar[newline]" 177s ok 84 - Format "%{|}R" should output "" 177s ok 85 - Format "%{|}R" should output "Requires: foo[newline]" 177s ok 86 - Format "%{|}R" should output "Requires: foo|bar[newline]" 177s ok 87 - Format "%{0}R" should output "Requires: foo0bar[newline]" 177s ok 88 - Format "%{}R" should output "Requires: foobar[newline]" 177s ok 89 - Format "%x" should output "" 177s ok 90 - Format "%x" should output " foo" 177s ok 91 - Format "%x" should output " foo, bax" 177s ok 92 - Format "%{|}x" should output "" 177s ok 93 - Format "%{|}x" should output " foo" 177s ok 94 - Format "%{|}x" should output " foo|bax" 177s ok 95 - Format "%{0}x" should output " foo0bax" 177s ok 96 - Format "%{}x" should output " foobax" 177s ok 97 - Format "%X" should output "" 177s ok 98 - Format "%X" should output "Conflicts: foo[newline]" 177s ok 99 - Format "%X" should output "Conflicts: foo, bar[newline]" 177s ok 100 - Format "%{|}X" should output "" 177s ok 101 - Format "%{|}X" should output "Conflicts: foo[newline]" 177s ok 102 - Format "%{|}X" should output "Conflicts: foo|bar[newline]" 177s ok 103 - Format "%{0}X" should output "Conflicts: foo0bar[newline]" 177s ok 104 - Format "%{}X" should output "Conflicts: foobar[newline]" 177s ok 105 - Format "%{yellow}C" should output "" 177s ok 106 - Format "%{:event}C" should output "" 177s ok 107 - Format "%v" should output "[newline]" 177s ok 108 - Format "%%" should output "%" 177s ok 109 - Format "%s" should output "hi there" 177s ok 110 - Format "%s" should output "hi there" 177s ok 111 - Format "%s" should output "subject line" 177s ok 112 - Format "%{ }s" should output " hi there" 177s ok 113 - Format "%{xx}s" should output "xxhi there" 177s ok 114 - Format "%b" should output "" 177s ok 115 - Format "%b" should output "yo" 177s ok 116 - Format "%b" should output "first graph[newline][newline]second graph[newline][newline]" 177s ok 117 - Format "%{ }b" should output "" 177s ok 118 - Format "%{xxx }b" should output "xxx yo" 177s ok 119 - Format "%{x}b" should output "xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 177s ok 120 - Format "%{ }b" should output " yo" 177s ok 121 - Format "%B" should output "hi there" 177s ok 122 - Format "%B" should output "hi there[newline]yo" 177s ok 123 - Format "%B" should output "subject line[newline][newline]first graph[newline][newline]second graph[newline][newline]" 177s ok 124 - Format "%{ }B" should output " hi there" 177s ok 125 - Format "%{xxx }B" should output "xxx hi there[newline]xxx yo" 177s ok 126 - Format "%{x}B" should output "xsubject line[newline]x[newline]xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 177s ok 127 - Format "%{ }B" should output " hi there [newline] yo" 177s ok 128 - Format "%{change}a" should output "change lolz[newline]" 177s ok 129 - Format "%{change_id}a" should output "change_id 000011112222333444[newline]" 177s ok 130 - Format "%{event}a" should output "event deploy[newline]" 177s ok 131 - Format "%{tags}a" should output "tags @beta, @gamma[newline]" 177s ok 132 - Format "%{requires}a" should output "requires foo, bar[newline]" 177s ok 133 - Format "%{conflicts}a" should output "" 177s ok 134 - Format "%{committer_name}a" should output "committer_name larry[newline]" 177s ok 135 - Format "%{committed_at}a" should output "committed_at 2024-11-01T18:25:59Z[newline]" 177s ok 136 - Should get exception for format "%_" 177s ok 137 - %_ error ident should be "format" 177s ok 138 - %_ error message should be correct 177s ok 139 - Should get exception for unknown label in format "%_" 177s ok 140 - Invalid %_ label error ident should be "format" 177s ok 141 - Invalid %_ label error message should be correct 177s ok 142 - Instantiate with abbrev => 4 177s ok 143 - %h should respect abbrev 177s ok 144 - %H should not respect abbrev 177s ok 145 - Instantiate with date_format => "rfc" 177s ok 146 - %{date}c should respect the date_format attribute 177s ok 147 - %{iso}c should override the date_format attribute 177s ok 148 - Should get exception for unknown attribute passed to %a 177s ok 149 - %a error ident should be "log" 177s ok 150 - %a error message should be correct 177s ok 151 - Construct with color "always" 177s ok 152 - Format "%{yellow}C" should output yellow 177s ok 153 - Format "%{red}C" should output red 177s ok 154 - Format "%{blue}C" should output blue 177s ok 155 - Format "%{cyan}C" should output cyan 177s ok 156 - Format "%{magenta}C" should output magenta 177s ok 157 - Format "%{:event}C" on "deploy" should output green 177s ok 158 - Format "%{:event}C" on "revert" should output blue 177s ok 159 - Format "%{:event}C" on "fail" should output red 177s ok 160 - Should get an error for an invalid color 177s ok 161 - Invalid color error ident should be "log" 177s ok 162 - Invalid color error message should be correct 177s ok 163 - Construct with color "never" 177s ok 164 - Format "%{yellow}C" should not output a color 177s ok 165 - Format "%{red}C" should not output a color 177s ok 166 - Format "%{blue}C" should not output a color 177s ok 167 - Format "%{cyan}C" should not output a color 177s ok 168 - Format "%{magenta}C" should not output a color 177s ok 169 - Should get an exception for a bad format code 177s ok 170 - bad format code format error ident should be "log" 177s ok 171 - bad format code format error message should be correct 177s ok 172 - no warnings 177s ok 177s t/linelist.t ........ 177s 1..28 177s ok 1 - require App::Sqitch::Plan::LineList; 177s ok 2 - Count should be six 177s ok 3 - Lines should be in order 177s ok 4 - Should have foo at 0 177s ok 5 - Should have bar at 1 177s ok 6 - Should have yo1 at 2 177s ok 7 - Should have @alpha at 3 177s ok 8 - Should have blank at 4 177s ok 9 - Should have baz at 5 177s ok 10 - Should have yo2 at 6 177s ok 11 - Should not find "non" 177s ok 12 - Should find foo at 0 177s ok 13 - Should find bar at 1 177s ok 14 - Should find yo1 at 2 177s ok 15 - Should find @alpha at 3 177s ok 16 - Should find blank at 4 177s ok 17 - Should find baz at 5 177s ok 18 - Should find yo2 at 6 177s ok 19 - Append hi 177s ok 20 - Count should now be eight 177s ok 21 - Lines should be in order with $hi at the end 177s ok 22 - Insert a change at index 3 177s ok 23 - Count should now be nine 177s ok 24 - Lines should be in order with $oy at index 3 177s ok 25 - Should find oy at 3 177s ok 26 - Should find @alpha at 4 177s ok 27 - Should find hi at 8 177s ok 28 - no warnings 177s ok 178s t/log.t ............. 178s 1..253 178s ok 1 - require App::Sqitch::Command::log; 178s ok 2 - Load a sqitch object 178s ok 3 - 'log command' isa 'App::Sqitch::Command::log' 178s ok 4 - App::Sqitch::Command::log->can(...) 178s ok 5 - App::Sqitch::Command::log does ConnectingCommand 178s ok 6 - Options should be correct 178s ok 7 - Default target should be undef 178s ok 8 - 'new status with target' isa 'App::Sqitch::Command::log' 178s ok 9 - Should have target "foo" 178s ok 10 - 'Formatter' isa 'App::Sqitch::ItemFormatter' 178s ok 11 - Should get empty hash for no config or options 178s ok 12 - Should get error for invalid date format in config 178s ok 13 - Invalid date format error ident should be "datetime" 178s ok 14 - Invalid date format error message should be correct 178s ok 15 - Should get error for invalid date format in optsions 178s ok 16 - Invalid date format error ident should be "log" 178s ok 17 - Invalid date format error message should be correct 178s ok 18 - Should get error for invalid format in config 178s ok 19 - Invalid format error ident should be "log" 178s ok 20 - Invalid format error message should be correct 178s ok 21 - Should get error for invalid format in optsions 178s ok 22 - Invalid format error ident should be "log" 178s ok 23 - Invalid format error message should be correct 178s ok 24 - Configuration should respect --no-color, setting "never" 178s ok 25 - --oneline should set format 178s ok 26 - --oneline should set abbrev to 6 178s ok 27 - --oneline should not override --format 178s ok 28 - --oneline should not overrride --abbrev 178s ok 29 - Configuration should respect --no-color even when configure is set 178s ok 30 - Configuration should respect color option 178s ok 31 - Configuration should respect color config 178s ok 32 - Configuration should respect color option 178s ok 33 - Configuration should respect color config 178s ok 34 - Configuration should respect color option 178s ok 35 - Configuration should respect color config 178s ok 36 - Configuration should respect color option 178s ok 37 - Configuration should respect color config 178s ok 38 - Instantiate with format "raw" 178s ok 39 - Format "raw" should output correctly 178s ok 40 - Format "raw" should output correctly without tags 178s ok 41 - Instantiate with format "full" 178s ok 42 - Format "full" should output correctly 178s ok 43 - Instantiate with format "full" and date format "rfc" 178s ok 44 - Format "full" and date format "rfc" should output correctly 178s ok 45 - Instantiate with format "full" and date format "long" 178s ok 46 - Format "full" and date format "long" should output correctly 178s ok 47 - Instantiate with format "full" and date format "medium" 178s ok 48 - Format "full" and date format "medium" should output correctly 178s ok 49 - Format "full" should output correctly without tags 178s ok 50 - Instantiate with format "long" 178s ok 51 - Format "long" should output correctly 178s ok 52 - Format "long" should output correctly without tags 178s ok 53 - Instantiate with format "medium" 178s ok 54 - Format "medium" should output correctly 178s ok 55 - Instantiate with format "medium" and date format "rfc" 178s ok 56 - Format "medium" and date format "rfc" should output correctly 178s ok 57 - Instantiate with format "medium" and date format "long" 178s ok 58 - Format "medium" and date format "long" should output correctly 178s ok 59 - Instantiate with format "medium" and date format "medium" 178s ok 60 - Format "medium" and date format "medium" should output correctly 178s ok 61 - Instantiate with format "short" 178s ok 62 - Format "short" should output correctly 178s ok 63 - Instantiate with format "oneline" 178s ok 64 - Format "oneline" should output correctly 178s ok 65 - Format "%e" should output "deploy" 178s ok 66 - Format "%e" should output "revert" 178s ok 67 - Format "%e" should output "fail" 178s ok 68 - Format "%L" should output "Deploy" 178s ok 69 - Format "%L" should output "Revert" 178s ok 70 - Format "%L" should output "Fail" 178s ok 71 - Format "%l" should output "deploy" 178s ok 72 - Format "%l" should output "revert" 178s ok 73 - Format "%l" should output "fail" 178s ok 74 - Format "%{event}_" should output "Event: " 178s ok 75 - Format "%{change}_" should output "Change: " 178s ok 76 - Format "%{committer}_" should output "Committer:" 178s ok 77 - Format "%{planner}_" should output "Planner: " 178s ok 78 - Format "%{by}_" should output "By: " 178s ok 79 - Format "%{date}_" should output "Date: " 178s ok 80 - Format "%{committed}_" should output "Committed:" 178s ok 81 - Format "%{planned}_" should output "Planned: " 178s ok 82 - Format "%{name}_" should output "Name: " 178s ok 83 - Format "%{email}_" should output "Email: " 178s ok 84 - Format "%{requires}_" should output "Requires: " 178s ok 85 - Format "%{conflicts}_" should output "Conflicts:" 178s ok 86 - Format "%H" should output "123456789" 178s ok 87 - Format "%h" should output "123456789" 178s ok 88 - Format "%{5}h" should output "12345" 178s ok 89 - Format "%{7}h" should output "1234567" 178s ok 90 - Format "%n" should output "foo" 178s ok 91 - Format "%n" should output "bar" 178s ok 92 - Format "%o" should output "foo" 178s ok 93 - Format "%o" should output "bar" 178s ok 94 - Format "%c" should output "larry " 178s ok 95 - Format "%{n}c" should output "damian" 178s ok 96 - Format "%{name}c" should output "chip" 178s ok 97 - Format "%{e}c" should output "larry@example.com" 178s ok 98 - Format "%{email}c" should output "damian@example.com" 178s ok 99 - Format "%{date}c" should output "2024-11-01 11:26:00 -0700" 178s ok 100 - Format "%{date:rfc}c" should output "Fri, 01 Nov 2024 11:26:00 -0700" 178s ok 101 - Format "%{d:long}c" should output "November 1, 2024, 11:26:00 AM PDT" 178s ok 102 - Format "%{d:cldr:HH'h' mm'm'}c" should output "11h 26m" 178s ok 103 - Format "%{d:strftime:%a at %H:%M:%S}c" should output "Fri at 11:26:00" 178s ok 104 - Format "%p" should output "larry " 178s ok 105 - Format "%{n}p" should output "damian" 178s ok 106 - Format "%{name}p" should output "chip" 178s ok 107 - Format "%{e}p" should output "larry@example.com" 178s ok 108 - Format "%{email}p" should output "damian@example.com" 178s ok 109 - Format "%{date}p" should output "2024-10-31 11:26:00 -0700" 178s ok 110 - Format "%{date:rfc}p" should output "Thu, 31 Oct 2024 11:26:00 -0700" 178s ok 111 - Format "%{d:long}p" should output "October 31, 2024, 11:26:00 AM PDT" 178s ok 112 - Format "%{d:cldr:HH'h' mm'm'}p" should output "11h 26m" 178s ok 113 - Format "%{d:strftime:%a at %H:%M:%S}p" should output "Thu at 11:26:00" 178s ok 114 - Format "%t" should output "" 178s ok 115 - Format "%t" should output " @foo" 178s ok 116 - Format "%t" should output " @foo, @bar" 178s ok 117 - Format "%{|}t" should output "" 178s ok 118 - Format "%{|}t" should output " @foo" 178s ok 119 - Format "%{|}t" should output " @foo|@bar" 178s ok 120 - Format "%T" should output "" 178s ok 121 - Format "%T" should output " (@foo)" 178s ok 122 - Format "%T" should output " (@foo, @bar)" 178s ok 123 - Format "%{|}T" should output "" 178s ok 124 - Format "%{|}T" should output " (@foo)" 178s ok 125 - Format "%{|}T" should output " (@foo|@bar)" 178s ok 126 - Format "%r" should output "" 178s ok 127 - Format "%r" should output " foo" 178s ok 128 - Format "%r" should output " foo, bar" 178s ok 129 - Format "%{|}r" should output "" 178s ok 130 - Format "%{|}r" should output " foo" 178s ok 131 - Format "%{|}r" should output " foo|bar" 178s ok 132 - Format "%R" should output "" 178s ok 133 - Format "%R" should output "Requires: foo[newline]" 178s ok 134 - Format "%R" should output "Requires: foo, bar[newline]" 178s ok 135 - Format "%{|}R" should output "" 178s ok 136 - Format "%{|}R" should output "Requires: foo[newline]" 178s ok 137 - Format "%{|}R" should output "Requires: foo|bar[newline]" 178s ok 138 - Format "%x" should output "" 178s ok 139 - Format "%x" should output " foo" 178s ok 140 - Format "%x" should output " foo, bax" 178s ok 141 - Format "%{|}x" should output "" 178s ok 142 - Format "%{|}x" should output " foo" 178s ok 143 - Format "%{|}x" should output " foo|bax" 178s ok 144 - Format "%X" should output "" 178s ok 145 - Format "%X" should output "Conflicts: foo[newline]" 178s ok 146 - Format "%X" should output "Conflicts: foo, bar[newline]" 178s ok 147 - Format "%{|}X" should output "" 178s ok 148 - Format "%{|}X" should output "Conflicts: foo[newline]" 178s ok 149 - Format "%{|}X" should output "Conflicts: foo|bar[newline]" 178s ok 150 - Format "%{yellow}C" should output "" 178s ok 151 - Format "%{:event}C" should output "" 178s ok 152 - Format "%v" should output "[newline]" 178s ok 153 - Format "%%" should output "%" 178s ok 154 - Format "%s" should output "hi there" 178s ok 155 - Format "%s" should output "hi there" 178s ok 156 - Format "%s" should output "subject line" 178s ok 157 - Format "%{ }s" should output " hi there" 178s ok 158 - Format "%{xx}s" should output "xxhi there" 178s ok 159 - Format "%b" should output "" 178s ok 160 - Format "%b" should output "yo" 178s ok 161 - Format "%b" should output "first graph[newline][newline]second graph[newline][newline]" 178s ok 162 - Format "%{ }b" should output "" 178s ok 163 - Format "%{xxx }b" should output "xxx yo" 178s ok 164 - Format "%{x}b" should output "xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 178s ok 165 - Format "%{ }b" should output " yo" 178s ok 166 - Format "%B" should output "hi there" 178s ok 167 - Format "%B" should output "hi there[newline]yo" 178s ok 168 - Format "%B" should output "subject line[newline][newline]first graph[newline][newline]second graph[newline][newline]" 178s ok 169 - Format "%{ }B" should output " hi there" 178s ok 170 - Format "%{xxx }B" should output "xxx hi there[newline]xxx yo" 178s ok 171 - Format "%{x}B" should output "xsubject line[newline]x[newline]xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 178s ok 172 - Format "%{ }B" should output " hi there [newline] yo" 178s ok 173 - Format "%{change}a" should output "change lolz[newline]" 178s ok 174 - Format "%{change_id}a" should output "change_id 000011112222333444[newline]" 178s ok 175 - Format "%{event}a" should output "event deploy[newline]" 178s ok 176 - Format "%{tags}a" should output "tags @beta, @gamma[newline]" 178s ok 177 - Format "%{requires}a" should output "requires foo, bar[newline]" 178s ok 178 - Format "%{conflicts}a" should output "" 178s ok 179 - Format "%{committer_name}a" should output "committer_name larry[newline]" 178s ok 180 - Format "%{committed_at}a" should output "committed_at 2024-11-01T18:26:00Z[newline]" 178s ok 181 - Should get exception for format "%_" 178s ok 182 - %_ error ident should be "format" 178s ok 183 - %_ error message should be correct 178s ok 184 - Should get exception for unknown label in format "%_" 178s ok 185 - Invalid %_ label error ident should be "format" 178s ok 186 - Invalid %_ label error message should be correct 178s ok 187 - Instantiate with abbrev => 4 178s ok 188 - %h should respect abbrev 178s ok 189 - %H should not respect abbrev 178s ok 190 - Instantiate with date_format => "rfc" 178s ok 191 - %{date}c should respect the date_format attribute 178s ok 192 - %{iso}c should override the date_format attribute 178s ok 193 - Should get exception for unknown attribute passed to %a 178s ok 194 - %a error ident should be "format" 178s ok 195 - %a error message should be correct 178s ok 196 - Format "%{yellow}C" should output yellow 178s ok 197 - Format "%{red}C" should output red 178s ok 198 - Format "%{blue}C" should output blue 178s ok 199 - Format "%{cyan}C" should output cyan 178s ok 200 - Format "%{magenta}C" should output magenta 178s ok 201 - Format "%{:event}C" on "deploy" should output green 178s ok 202 - Format "%{:event}C" on "revert" should output blue 178s ok 203 - Format "%{:event}C" on "fail" should output red 178s ok 204 - Instantiate with format "full" again 178s ok 205 - Format "full" should output correctly with color 178s ok 206 - Instantiate with format "long" again 178s ok 207 - Format "long" should output correctly with color 178s ok 208 - Instantiate with format "medium" again 178s ok 209 - Format "medium" should output correctly with color 178s ok 210 - Instantiate with format "short" again 178s ok 211 - Format "short" should output correctly with color 178s ok 212 - Instantiate with format "oneline" again 178s ok 213 - Format "oneline" should output correctly with color 178s ok 214 - Should get an error for an invalid color 178s ok 215 - Invalid color error ident should be "format" 178s ok 216 - Invalid color error message should be correct 178s ok 217 - Should get exception for unititialied db 178s ok 218 - Uninit db error ident should be "log" 178s ok 219 - Uninit db exit val should be 1 178s ok 220 - Uninit db error message should be correct 178s ok 221 - Should have passed undef to Target 178s ok 222 - Should get error for empty event table 178s ok 223 - no events error ident should be "log" 178s ok 224 - no events exit val should be 1 178s ok 225 - no events error message should be correct 178s ok 226 - Search should have been limited to one row 178s ok 227 - Should have passed undef to Target again 178s ok 228 - Execute log 178s ok 229 - Should have passed undef to Target once more 178s ok 230 - The proper args should have been passed to search_events 178s ok 231 - The change should have been paged 178s ok 232 - Execute with target arg 178s ok 233 - Target name should have been passed to Target 178s ok 234 - The proper args should have been passed to search_events 178s ok 235 - The change should have been paged 178s ok 236 - Execute with plan file arg 178s ok 237 - Default engine target should have been passed to Target 178s ok 238 - The proper args should have been passed to search_events 178s ok 239 - The change should have been paged 178s ok 240 - 'log with attributes' isa 'App::Sqitch::Command::log' 178s ok 241 - Execute log with attributes 178s ok 242 - Should have passed target name to Target 178s ok 243 - All params should have been passed to search_events 178s ok 244 - Both changes should have been paged with no headers 178s ok 245 - Execute log with attributes 178s ok 246 - Should have passed enginetarget to Target 178s ok 247 - Should have got warning for two targets 178s ok 248 - 'log with bad format' isa 'App::Sqitch::Command::log' 178s ok 249 - Should get an exception for a bad format code 178s ok 250 - bad format code format error ident should be "format" 178s ok 251 - bad format code format error message should be correct 178s ok 252 - Should have passed target name to Target 178s ok 253 - no warnings 178s ok 179s t/mooseless.t ....... 179s ok 1 - No moose in Debian::pkgperl::Foobar 179s 1..1 179s ok 179s t/mysql.t ........... 179s ok 1 - require App::Sqitch::Engine::mysql; 179s ok 2 - config_vars should return three vars 179s ok 3 - An object of class 'App::Sqitch::Engine::mysql' isa 'App::Sqitch::Engine::mysql' 179s ok 4 - Key should be "mysql" 179s ok 5 - Name should be "MySQL" 179s ok 6 - client should default to mysql 179s ok 7 - registry default should be "sqitch" 179s ok 8 - registry_uri should be correct 179s ok 9 - uri should be "db:mysql:mydb" 179s ok 10 - registry_destination should be the same as registry_uri 179s ok 11 - _lock_name should be correct 179s ok 12 - mysql command should be user and std opts-only 179s ok 13 - Should have emitted a warning for no database name 179s ok 14 - An object of class 'App::Sqitch::Engine::mysql' isa 'App::Sqitch::Engine::mysql' 179s ok 15 - Create engine with MYSQL_PWD set 179s ok 16 - Password should be set from environment 179s ok 17 - URI should reflect MYSQL_HOST 179s ok 18 - URI should reflect MYSQL_TCP_PORT 179s ok 19 - Create another mysql 179s ok 20 - client should be as configured 179s ok 21 - URI should be as configured 179s ok 22 - target name should be the URI without the password 179s ok 23 - destination should be the URI without the password 179s ok 24 - registry should be as configured 179s ok 25 - Sqitch DB URI should be the same as uri but with DB name "meta" 179s ok 26 - registry_destination should be the sqitch DB URL without the password 179s ok 27 - mysql command should be configured 179s ok 28 - Create a mysql with query params 179s ok 29 - mysql command should be configured with query vals 179s ok 30 - Create a mysql with disabled query params 179s ok 31 - mysql command should not have disabled param options 179s ok 32 - App::Sqitch::Engine::mysql->can(...) 179s ok 33 - Create a mysql with sqitch with options 179s ok 34 - MYSQL_PWD should be "s3cr3t" 179s ok 35 - Call _run 179s ok 36 - Command should be passed to run() 179s ok 37 - MYSQL_PWD should be "s3cr3t" 179s ok 38 - Call _spool 179s ok 39 - Command should be passed to spool() 179s ok 40 - MYSQL_PWD should be "s3cr3t" 179s ok 41 - Call _spool with variables 179s ok 42 - Get variables file handle 179s ok 43 - Command should be passed to spool() after variables handle 179s ok 44 - Variables should have been escaped and set 179s ok 45 - MYSQL_PWD should be "s3cr3t" 179s ok 46 - Call _capture 179s ok 47 - Command should be passed to capture() 179s ok 48 - Create a mysql with sqitch with no pw 179s ok 49 - MYSQL_PWD should not exist 179s ok 50 - Call _run again 179s ok 51 - Command should be passed to run() again 179s ok 52 - MYSQL_PWD should not exist 179s ok 53 - Call _spool again 179s ok 54 - Command should be passed to spool() again 179s ok 55 - MYSQL_PWD should not exist 179s ok 56 - Call _capture again 179s ok 57 - Command should be passed to capture() again 179s ok 58 - MYSQL_PWD should not exist 179s ok 59 - Run foo/bar.sql 179s ok 60 - File should be passed to run() 179s ok 61 - MYSQL_PWD should not exist 179s ok 62 - Spool a "file handle" 179s ok 63 - Handle should be passed to spool() 179s ok 64 - MYSQL_PWD should not exist 179s ok 65 - Verify foo/bar.sql 179s ok 66 - Verify file should be passed to capture() 179s ok 67 - MYSQL_PWD should not exist 179s ok 68 - Verify foo/bar.sql again 179s ok 69 - Verifile file should be passed to run() for high verbosity 179s ok 70 - MYSQL_PWD should not exist 179s ok 71 - Run foo/bar.sql with vars 179s ok 72 - Variabls and file should be passed to run() 179s ok 73 - MYSQL_PWD should not exist 179s ok 74 - Spool a "file handle" 179s ok 75 - Get variables file handle 179s ok 76 - File handle should be passed to spool() after variables handle 179s ok 77 - Variables should have been escaped and set 179s ok 78 - MYSQL_PWD should not exist 179s ok 79 - Verbosely verify foo/bar.sql with vars 179s ok 80 - Variables and verify file should be passed to run() 179s ok 81 - MYSQL_PWD should not exist 179s ok 82 - Verify foo/bar.sql with vars 179s ok 83 - Verify file should be passed to capture() 179s ok 84 - App::Sqitch::Engine::mysql->can('_ts2char_format') 179s ok 85 - _ts2char_format should work 179s ok 86 - App::Sqitch::Engine::mysql->can('_dt') 179s ok 87 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 179s ok 88 - DateTime year should be set 179s ok 89 - DateTime month should be set 179s ok 90 - DateTime day should be set 179s ok 91 - DateTime hour should be set 179s ok 92 - DateTime minute should be set 179s ok 93 - DateTime second should be set 179s ok 94 - DateTime TZ should be set 179s ok 95 - Should have _listagg_format 179s ok 96 - Should have _regex_op 179s ok 97 - Should have _simple_from 179s ok 98 - Should have _limit_default 179s ok 99 - Should have _ts_default with fractional seconds 179s ok 100 - Should have _ts_default without fractional seconds on 5.1 179s ok 101 - Should have _ts_default without fractional seconds on early mariadb 179s ok 102 - Should have _ts_default with fractional secondson mariadb 5.03.05 179s ok 103 - Should have no table error 179s ok 104 - Should have no column error 179s ok 105 - Should now have table error 179s ok 106 - Still should have no column error 179s ok 107 - Should again have table error 179s ok 108 - Still should have no column error 179s ok 109 - Should again have no table error 179s ok 110 - Should now have no column error 179s ok 111 - Should get limit and offset 179s ok 112 - Should get limit and offset when offset only 179s ok 113 - Should get only limit with 0 offset 179s ok 114 - Should get only limit with noa offset 179s ok 115 - Should get no limit or offset for 0s 179s ok 116 - Should get no limit or offset for no args 179s ok 117 - Should use REGEXP for regex expr 179s ok 118 - initialized() should rethrow unexpected DB error 179s ok 119 - _cid should rethrow unexpected DB error 179s ok 120 - Should just get self when fractional seconds supported 179s ok 121 - Should get no error from _prepare_to_log 179s ok 122 - Should have prepared the statement comparing times 179s ok 123 - Results should have been returned 179s ok 124 - Should have slept once 179s ok 125 - Run the upgrade 179s ok 126 - Should not have created a temp file 179s ok 127 - It should have run the unchanged file 179s ok 128 - Run the upgrade again 179s ok 129 - Should have created a temp file 179s ok 130 - It should have run the temp file 179s ok 131 - Should have removed datetime precision 179s ok 132 - Should not have removed MySQL 5.5-requiring block BEGIN 179s ok 133 - Should not have removed MySQL 5.5-requiring block END 179s ok 134 - Run the upgrade on 5.4 179s ok 135 - Should have created another temp file 179s ok 136 - It should have the new temp file 179s ok 137 - Should have removed MySQL 5.5-requiring block BEGIN 179s ok 138 - Should have removed MySQL 5.5-requiring block END 179s ok 139 - App::Sqitch::Engine::mysql->can(...) 179s # Subtest: live database 179s 1..0 # SKIP Unable to live-test MySQL engine: DBD::mysql 4.018 required to manage MySQL at t/mysql.t line 630. 179s ok 140 # skip Unable to live-test MySQL engine: DBD::mysql 4.018 required to manage MySQL at t/mysql.t line 630. 179s # 179s 1..140 179s ok 180s t/options.t ......... 180s ok 1 - use App::Sqitch; 180s ok 2 - Options should be correct 180s ok 3 - App::Sqitch->can('_find_cmd') 180s ok 4 - Should find no command for no args 180s ok 5 - Should have passed "sqitchcommands" to _pod2usage 180s ok 6 - Should have vented nothing 180s ok 7 - Should find no command for invalid command 180s ok 8 - Should have passed "sqitchcommands" to _pod2usage 180s ok 9 - Should have vented an invalid command message 180s ok 10 - Should find no command with option --foo 180s ok 11 - Should have passed "sqitchcommands" to _pod2usage 180s ok 12 - Should not have reported --foo as invalid command 180s ok 13 - Should find no command with option --client=psql 180s ok 14 - Should have passed "sqitchcommands" to _pod2usage 180s ok 15 - Should not have reported --client=psql as invalid command 180s ok 16 - Should find no command with option -R 180s ok 17 - Should have passed "sqitchcommands" to _pod2usage 180s ok 18 - Should not have reported -R as invalid command 180s ok 19 - Should find no command with option -X=yup 180s ok 20 - Should have passed "sqitchcommands" to _pod2usage 180s ok 21 - Should not have reported -X=yup as invalid command 180s ok 22 - Should find no command after -- 180s ok 23 - Should have passed "sqitchcommands" to _pod2usage 180s ok 24 - Should have vented nothing 180s ok 25 - Should find class for "bundle" 180s ok 26 - Should not have called _pod2usage 180s ok 27 - Should have vented nothing 180s ok 28 - Should have removed "bundle" from args 180s ok 29 - Should find class for "bundle" again 180s ok 30 - Should not have called _pod2usage 180s ok 31 - Should have vented nothing 180s ok 32 - Should have left subsequent valid command after "bundle" in args 180s ok 33 - Should find class for "config" 180s ok 34 - Should not have called _pod2usage 180s ok 35 - Should have vented nothing 180s ok 36 - Should have removed "config" from args 180s ok 37 - Should find class for "config" again 180s ok 38 - Should not have called _pod2usage 180s ok 39 - Should have vented nothing 180s ok 40 - Should have left subsequent valid command after "config" in args 180s ok 41 - Should find class for "help" 180s ok 42 - Should not have called _pod2usage 180s ok 43 - Should have vented nothing 180s ok 44 - Should have removed "help" from args 180s ok 45 - Should find class for "help" again 180s ok 46 - Should not have called _pod2usage 180s ok 47 - Should have vented nothing 180s ok 48 - Should have left subsequent valid command after "help" in args 180s ok 49 - Should find class for "plan" 180s ok 50 - Should not have called _pod2usage 180s ok 51 - Should have vented nothing 180s ok 52 - Should have removed "plan" from args 180s ok 53 - Should find class for "plan" again 180s ok 54 - Should not have called _pod2usage 180s ok 55 - Should have vented nothing 180s ok 56 - Should have left subsequent valid command after "plan" in args 180s ok 57 - Should find class for "show" 180s ok 58 - Should not have called _pod2usage 180s ok 59 - Should have vented nothing 180s ok 60 - Should have removed "show" from args 180s ok 61 - Should find class for "show" again 180s ok 62 - Should not have called _pod2usage 180s ok 63 - Should have vented nothing 180s ok 64 - Should have left subsequent valid command after "show" in args 180s ok 65 - Should find class for "tag" 180s ok 66 - Should not have called _pod2usage 180s ok 67 - Should have vented nothing 180s ok 68 - Should have removed "tag" from args 180s ok 69 - Should find class for "tag" again 180s ok 70 - Should not have called _pod2usage 180s ok 71 - Should have vented nothing 180s ok 72 - Should have left subsequent valid command after "tag" in args 180s ok 73 - App::Sqitch->can('_parse_core_opts') 180s ok 74 - Should have default config for no options 180s ok 75 - Ask for help 180s ok 76 - Should have been helped 180s ok 77 - Ask for man 180s ok 78 - Should have been manned 180s ok 79 - Should have exited on --version 180s ok 80 - Should have emitted the version 180s ok 81 - Should have exited on --etc-path 180s ok 82 - Should have emitted the etc path 180s ok 83 - Should parse lots of options 180s ok 84 - --quiet should trump verbosity. 180s ok 85 - Short options should work 180s ok 86 - Run _pod2usage 180s ok 87 - Proper args should have been passed to Pod::Usage 180s ok 88 - Parse --chdir 180s ok 89 - Should have changed to foo/bar 180s ok 90 - Should have preserved no opts 180s ok 91 - Parse --cd 180s ok 92 - Should have changed to go/dir 180s ok 93 - Should have preserved no opts 180s ok 94 - Parse -C 180s ok 95 - Should have changed to hi cramus 180s ok 96 - Should have preserved no opts 180s ok 97 - Should get error when chdir fails 180s ok 98 - Error ident should be "fs" 180s ok 99 - Error message should be correct 180s 1..99 180s ok 181s t/oracle.t .......... 181s ok 1 - require App::Sqitch::Engine::oracle; 181s ok 2 - config_vars should return three vars 181s ok 3 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 4 - Key should be "oracle" 181s ok 5 - Name should be "Oracle" 181s ok 6 - client should default to sqlplus 181s ok 7 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 8 - client should default to sqlplus 181s ok 9 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 10 - client should use $ORACLE_HOME 181s ok 11 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 12 - client should use $ORACLE_HOME/bin 181s ok 13 - registry default should be empty 181s ok 14 - Default URI should be "db:oracle" 181s ok 15 - Target name should be the uri stringified 181s ok 16 - Destination should fall back on environment variables 181s ok 17 - Registry target should be the same as target 181s ok 18 - sqlplus command should connect to /nolog 181s ok 19 - _script should work 181s ok 20 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 21 - _script should assemble connection string 181s ok 22 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 23 - _script should assemble connection string with host 181s ok 24 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 25 - Set some variables 181s ok 26 - _script should assemble connection string with host, port, and vars 181s ok 27 - Database-only URI should produce proper DSN 181s ok 28 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 29 - _script should assemble connection string with just dbname 181s ok 30 - Database and double-slash URI should produce proper DSN 181s ok 31 - An object of class 'App::Sqitch::Engine::oracle' isa 'App::Sqitch::Engine::oracle' 181s ok 32 - _script should assemble connection string with double-slash and dbname 181s ok 33 - Target name should not read $TWO_TASK 181s ok 34 - Destination should read $TWO_TASK 181s ok 35 - Registry destination should be the same as destination 181s ok 36 - Target name should not read $ORACLE_SID 181s ok 37 - Destination should read $ORACLE_SID 181s ok 38 - Registry destination should be the same as destination 181s ok 39 - Target should be the default 181s ok 40 - Destination should prefer $TWO_TASK to username 181s ok 41 - Registry destination should be the same as destination 181s ok 42 - Create another ora 181s ok 43 - client should be as configured 181s ok 44 - DB URI should be as configured 181s ok 45 - Target name should be the passwordless URI stringified 181s ok 46 - Destination should be the URI without the password 181s ok 47 - registry_destination should replace be the same URI 181s ok 48 - registry should be as configured 181s ok 49 - sqlplus command should be configured 181s ok 50 - Create yet another ora 181s ok 51 - client should be as configured 181s ok 52 - registry should be as configured 181s ok 53 - sqlplus command should be configured 181s ok 54 - App::Sqitch::Engine::oracle->can(...) 181s ok 55 - Call _run 181s ok 56 - SQLPlus command should be passed to spool() 181s ok 57 - The script should be spooled 181s ok 58 - Call _capture 181s ok 59 - Command and script should be passed to run3() 181s ok 60 - _capture should actually capture 181s ok 61 - _capture should die when sqlplus dies 181s ok 62 - STDERR should be emitted by _capture 181s ok 63 - App::Sqitch::Engine::oracle->can('_file_for_script') 181s ok 64 - File without special characters should be used directly 181s ok 65 - Double quotes should be SQL-escaped 181s ok 66 - Get temp dir 181s ok 67 - 'Temp dir' isa 'Path::Class::Dir' 181s ok 68 - File with special char should be aliased 181s ok 69 - Should get an error on failure to delete the alias 181s ok 70 - File deletion error ident should be "oracle" 181s ok 71 - File deletion error message should be correct 181s ok 72 - File with special char and quotes should be aliased 181s ok 73 - initialized() should rethrow unexpected DB error 181s ok 74 - _cid should rethrow unexpected DB error 181s ok 75 - Run foo/bar.sql 181s ok 76 - File should be passed to run() 181s ok 77 - Run foo/"bar".sql 181s ok 78 - Double quotes in file passed to run() should be escaped 181s ok 79 - Spool a "file handle" 181s ok 80 - sqlplus command should be passed to spool() 181s ok 81 - 'Array ove handles should be passed to spool' isa 'ARRAY' 181s ok 82 - First file handle should be script 181s ok 83 - Second should be the passed handle 181s ok 84 - Verify foo/bar.sql 181s ok 85 - Verify file should be passed to capture() 181s ok 86 - Verify foo/bar.sql again 181s ok 87 - Verifile file should be passed to run() for high verbosity 181s ok 88 - App::Sqitch::Engine::oracle->can('_ts2char_format') 181s ok 89 - _ts2char_format should work 181s ok 90 - App::Sqitch::Engine::oracle->can('_dt') 181s ok 91 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 181s ok 92 - DateTime year should be set 181s ok 93 - DateTime month should be set 181s ok 94 - DateTime day should be set 181s ok 95 - DateTime hour should be set 181s ok 96 - DateTime minute should be set 181s ok 97 - DateTime second should be set 181s ok 98 - DateTime TZ should be set 181s ok 99 - Should have _char2ts 181s ok 100 - Should have _listagg_format 181s ok 101 - Should have _regex_op 181s ok 102 - Should have _simple_from 181s ok 103 - Should have _limit_default 181s ok 104 - Should have _ts_default 181s ok 105 - Should have _can_limit false 181s ok 106 - Should get single expression from _multi_values 181s ok 107 - Should get double expression from _multi_values 181s ok 108 - Should get quadrupal expression from _multi_values 181s ok 109 - Should have no table error 181s ok 110 - Should have no column error 181s ok 111 - Should now have table error 181s ok 112 - Still should have no column error 181s ok 113 - Should again have no table error 181s ok 114 - Should now have no column error 181s ok 115 - _log_tags_param should format tags 181s ok 116 - _log_requires_param should format prereqs 181s ok 117 - _log_conflicts_param should format prereqs 181s ok 118 - App::Sqitch::Engine::oracle->can('_change_id_in') 181s ok 119 - Should get empty string for 0 change IDs 181s ok 120 - Should get single param for 1 change ID 181s ok 121 - Should get 3 params for 3 change IDs 181s ok 122 - Should get 10 params for 10 change IDs 181s ok 123 - Should get 32 params for 32 change IDs 181s ok 124 - Should get 50 params for 50 change IDs 181s ok 125 - Should get 200 params for 200 change IDs 181s ok 126 - Should get 250 params for 250 change IDs 181s ok 127 - Should get 250 and 1 groups for 251 IDs 181s ok 128 - Should get 250 and 3 groups for 253 IDs 181s ok 129 - Should get 250, 240, and 2 groups for 503 IDs 181s ok 130 - Should get 4 x 250 and 42 groups for 1042 IDs 181s ok 131 - App::Sqitch::Engine::oracle->can(...) 181s # Subtest: live database 181s 1..0 # SKIP Unable to live-test Oracle engine: DBD::Oracle 1.23 required to manage Oracle at t/oracle.t line 694. 181s ok 132 # skip Unable to live-test Oracle engine: DBD::Oracle 1.23 required to manage Oracle at t/oracle.t line 694. 181s # 181s 1..132 181s ok 182s t/pg.t .............. 182s ok 1 - require App::Sqitch::Engine::pg; 182s ok 2 - config_vars should return three vars 182s ok 3 - An object of class 'App::Sqitch::Engine::pg' isa 'App::Sqitch::Engine::pg' 182s ok 4 - Key should be "pg" 182s ok 5 - Name should be "PostgreSQL" 182s ok 6 - client should default to psqle 182s ok 7 - registry default should be "sqitch" 182s ok 8 - DB URI should be "db:pg:" 182s ok 9 - Destination should fall back on environment variables 182s ok 10 - Registry destination should be the same as destination 182s ok 11 - psql command should be conninfo, and std opts-only 182s ok 12 - An object of class 'App::Sqitch::Engine::pg' isa 'App::Sqitch::Engine::pg' 182s ok 13 - Set some variables 182s ok 14 - Variables should be passed to psql via --set 182s ok 15 - Target should not read $PGDATABASE 182s ok 16 - Registry target should be the same as destination 182s ok 17 - Target should not read $PGUSER 182s ok 18 - Registry target should be the same as destination 182s ok 19 - Target should not read $PGPASSWORD 182s ok 20 - Registry target should be the same as destination 182s ok 21 - Target should not fall back on sysuser 182s ok 22 - Registry target should be the same as destination 182s ok 23 - Target should be the default 182s ok 24 - Registry target should be the same as destination 182s ok 25 - Create another pg 182s ok 26 - client should be as configured 182s ok 27 - uri should be as configured 182s ok 28 - registry should be as configured 182s ok 29 - psql command should be configured from URI config 182s ok 30 - App::Sqitch::Engine::pg->can(...) 182s ok 31 - PGPASSWORD should be "s3cr3t" 182s ok 32 - Call _run 182s ok 33 - Command should be passed to run() 182s ok 34 - PGPASSWORD should be "s3cr3t" 182s ok 35 - Call _spool 182s ok 36 - Command should be passed to spool() 182s ok 37 - PGPASSWORD should be "s3cr3t" 182s ok 38 - Call _capture 182s ok 39 - Command should be passed to capture() 182s ok 40 - PGPASSWORD should be "s3cr3t" 182s ok 41 - Call _probe 182s ok 42 182s ok 43 - Create a pg with sqitch with no pw 182s ok 44 - PGPASSWORD should not exist 182s ok 45 - Call _run again 182s ok 46 - Command should be passed to run() again 182s ok 47 - PGPASSWORD should not exist 182s ok 48 - Call _spool again 182s ok 49 - Command should be passed to spool() again 182s ok 50 - PGPASSWORD should not exist 182s ok 51 - Call _capture again 182s ok 52 - Command should be passed to capture() again 182s ok 53 - PGPASSWORD should not exist 182s ok 54 - Call _probe again 182s ok 55 182s ok 56 - PGPASSWORD should not exist 182s ok 57 - Run foo/bar.sql 182s ok 58 - File should be passed to run() 182s ok 59 - PGPASSWORD should not exist 182s ok 60 - Spool a "file handle" 182s ok 61 - Handle should be passed to spool() 182s ok 62 - PGPASSWORD should not exist 182s ok 63 - Verify foo/bar.sql 182s ok 64 - Verify file should be passed to capture() 182s ok 65 - PGPASSWORD should not exist 182s ok 66 - Verify foo/bar.sql again 182s ok 67 - Verifile file should be passed to run() for high verbosity 182s ok 68 - App::Sqitch::Engine::pg->can('_ts2char_format') 182s ok 69 - _ts2char_format should work 182s ok 70 - App::Sqitch::Engine::pg->can('_dt') 182s ok 71 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 182s ok 72 - DateTime year should be set 182s ok 73 - DateTime month should be set 182s ok 74 - DateTime day should be set 182s ok 75 - DateTime hour should be set 182s ok 76 - DateTime minute should be set 182s ok 77 - DateTime second should be set 182s ok 78 - DateTime TZ should be set 182s ok 79 - Should find major version 11 in 11beta3 182s ok 80 - Should find major version 11 in 11.3 182s ok 81 - Should find major version 10 in 10 182s ok 82 - Should find major version 9 in 9.6.3 182s ok 83 - Should find major version 8 in 8.4.2 182s ok 84 - Should find major version 9 in 9.0.19 182s ok 85 - Should have no table error 182s ok 86 - Should have no column error 182s ok 87 - Should again have no table error 182s ok 88 - Should now have no column error 182s ok 89 - Should now have table error 182s ok 90 - Still should have no column error 182s ok 91 - No SQL should have been run 182s ok 92 - Should again have table error 182s ok 93 - Still should have no column error 182s ok 94 - Should have sent an error to the log 182s ok 95 - Should use array_remove and ORDER BY in listagg_format on v11 182s ok 96 - Should use array_remove and ORDER BY in listagg_format on v9.3 182s ok 97 - Should use ORDER BY in listagg_format on v9.2 182s ok 98 - Should use ORDER BY in listagg_format on v9.0 182s ok 99 - Should not use ORDER BY in listagg_format on v8.4 182s ok 100 - Run the registry file 182s ok 101 - Should have fetched the server version and checked for XC 182s ok 102 - Shoud have deployed the original SQL file 182s ok 103 - The registry should have been added to the search path 182s ok 104 - Should not have have called selectrow_array 182s ok 105 - Should have no temp file handle 182s ok 106 - Run the registry file again 182s ok 107 - Should have again fetched the server version and checked for XC 182s ok 108 - Should now have a temp file handle 182s ok 109 - Shoud have deployed the temp SQL file 182s ok 110 - Still hould not have have called selectrow_array 182s ok 111 - The registry should have been added to the search path again 182s ok 112 - Should have removed IF NOT EXISTS from CREATE SCHEMA 182s ok 113 - Run the registry file again 182s ok 114 - Should have again fetched the server version and checked for XC 182s ok 115 - Should now have a temp file handle 182s ok 116 - Shoud have deployed the temp SQL file 182s ok 117 - Should have have called quote_ident via selectrow_array 182s ok 118 - The registry should have been added to the search path again 182s ok 119 - Should not have removed IF NOT EXISTS from CREATE SCHEMA 182s ok 120 - Should have removed the :"registry" variable 182s ok 121 - App::Sqitch::Engine::pg->can(...) 182s # Subtest: live database 182s 1..0 # SKIP Unable to live-test PostgreSQL engine: DBI connect('dbname=template1','postgres',...) failed: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: No such file or directory 182s Is the server running locally and accepting connections on that socket? at t/pg.t line 511. 182s ok 122 # skip Unable to live-test PostgreSQL engine: DBI connect('dbname=template1','postgres',...) failed: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: No such file or directory 182s # Is the server running locally and accepting connections on that socket? at t/pg.t line 511. 182s # 182s 1..122 182s ok 183s t/plan.t ............ 183s ok 1 - use App::Sqitch::Plan; 183s ok 2 - App::Sqitch::Plan->can(...) 183s ok 3 - An object of class 'App::Sqitch::Plan' isa 'App::Sqitch::Plan' 183s ok 4 - File should be coopied from Target 183s ok 5 - Should parse simple "widgets.plan" 183s ok 6 - Should have sorted changes 183s ok 7 - 'changes' isa 'ARRAY' 183s ok 8 - 'lines' isa 'ARRAY' 183s ok 9 - All "widgets.plan" changes should be parsed 183s ok 10 - All "widgets.plan" lines should be parsed 183s ok 11 - Should parse multi-tagged "multi.plan" 183s ok 12 - Should have sorted changes twice 183s ok 13 - Should have captured the multi pragmas 183s ok 14 - Should have "multi.plan" lines and changes 183s ok 15 - Should read plan with no tags 183s ok 16 - Should have sorted changes 183s ok 17 - Should have captured the changes-only pragmas 183s ok 18 - Should have lines and changes for tagless plan 183s ok 19 - Should read plan with DOS line endings 183s ok 20 - Should have sorted changes 183s ok 21 - Should have captured the dos pragmas 183s ok 22 - Should die on plan with bad change name 183s ok 23 - Bad change name error ident should be "parse" 183s ok 24 - And the bad change name error message should be correct 183s ok 25 - Should not have sorted changes 183s ok 26 - Should die on plan with bad name "+^foo" 183s ok 27 - Exception ident should be "parse" 183s ok 28 - And "+^foo" should trigger the appropriate message 183s ok 29 - Should not have sorted changes 183s ok 30 - Should die on plan with bad name "@^foo" 183s ok 31 - Exception ident should be "parse" 183s ok 32 - And "@^foo" should trigger the appropriate message 183s ok 33 - Should not have sorted changes 183s ok 34 - Should die on plan with bad name "+foo^" 183s ok 35 - Exception ident should be "parse" 183s ok 36 - And "+foo^" should trigger the appropriate message 183s ok 37 - Should not have sorted changes 183s ok 38 - Should die on plan with bad name "@foo^" 183s ok 39 - Exception ident should be "parse" 183s ok 40 - And "@foo^" should trigger the appropriate message 183s ok 41 - Should not have sorted changes 183s ok 42 - Should die on plan with bad name "+foo^6" 183s ok 43 - Exception ident should be "parse" 183s ok 44 - And "+foo^6" should trigger the appropriate message 183s ok 45 - Should not have sorted changes 183s ok 46 - Should die on plan with bad name "@foo^6" 183s ok 47 - Exception ident should be "parse" 183s ok 48 - And "@foo^6" should trigger the appropriate message 183s ok 49 - Should not have sorted changes 183s ok 50 - Should die on plan with bad name "+foo^666" 183s ok 51 - Exception ident should be "parse" 183s ok 52 - And "+foo^666" should trigger the appropriate message 183s ok 53 - Should not have sorted changes 183s ok 54 - Should die on plan with bad name "@foo^666" 183s ok 55 - Exception ident should be "parse" 183s ok 56 - And "@foo^666" should trigger the appropriate message 183s ok 57 - Should not have sorted changes 183s ok 58 - Should die on plan with bad name "+%hi" 183s ok 59 - Exception ident should be "parse" 183s ok 60 - And "+%hi" should trigger the appropriate message 183s ok 61 - Should not have sorted changes 183s ok 62 - Should die on plan with bad name "@%hi" 183s ok 63 - Exception ident should be "parse" 183s ok 64 - And "@%hi" should trigger the appropriate message 183s ok 65 - Should not have sorted changes 183s ok 66 - Should die on plan with bad name "+hi!" 183s ok 67 - Exception ident should be "parse" 183s ok 68 - And "+hi!" should trigger the appropriate message 183s ok 69 - Should not have sorted changes 183s ok 70 - Should die on plan with bad name "@hi!" 183s ok 71 - Exception ident should be "parse" 183s ok 72 - And "@hi!" should trigger the appropriate message 183s ok 73 - Should not have sorted changes 183s ok 74 - Should die on plan with bad name "+foo@bar" 183s ok 75 - Exception ident should be "parse" 183s ok 76 - And "+foo@bar" should trigger the appropriate message 183s ok 77 - Should not have sorted changes 183s ok 78 - Should die on plan with bad name "@foo@bar" 183s ok 79 - Exception ident should be "parse" 183s ok 80 - And "@foo@bar" should trigger the appropriate message 183s ok 81 - Should not have sorted changes 183s ok 82 - Should die on plan with bad name "+foo:bar" 183s ok 83 - Exception ident should be "parse" 183s ok 84 - And "+foo:bar" should trigger the appropriate message 183s ok 85 - Should not have sorted changes 183s ok 86 - Should die on plan with bad name "@foo:bar" 183s ok 87 - Exception ident should be "parse" 183s ok 88 - And "@foo:bar" should trigger the appropriate message 183s ok 89 - Should not have sorted changes 183s ok 90 - Should die on plan with bad name "+foo\bar" 183s ok 91 - Exception ident should be "parse" 183s ok 92 - And "+foo\bar" should trigger the appropriate message 183s ok 93 - Should not have sorted changes 183s ok 94 - Should die on plan with bad name "@foo\bar" 183s ok 95 - Exception ident should be "parse" 183s ok 96 - And "@foo\bar" should trigger the appropriate message 183s ok 97 - Should not have sorted changes 183s ok 98 - Should die on plan with bad name "++foo" 183s ok 99 - Exception ident should be "parse" 183s ok 100 - And "++foo" should trigger the appropriate message 183s ok 101 - Should not have sorted changes 183s ok 102 - Should die on plan with bad name "@+foo" 183s ok 103 - Exception ident should be "parse" 183s ok 104 - And "@+foo" should trigger the appropriate message 183s ok 105 - Should not have sorted changes 183s ok 106 - Should die on plan with bad name "+-foo" 183s ok 107 - Exception ident should be "parse" 183s ok 108 - And "+-foo" should trigger the appropriate message 183s ok 109 - Should not have sorted changes 183s ok 110 - Should die on plan with bad name "@-foo" 183s ok 111 - Exception ident should be "parse" 183s ok 112 - And "@-foo" should trigger the appropriate message 183s ok 113 - Should not have sorted changes 183s ok 114 - Should die on plan with bad name "+@foo" 183s ok 115 - Exception ident should be "parse" 183s ok 116 - And "+@foo" should trigger the appropriate message 183s ok 117 - Should not have sorted changes 183s ok 118 - Should die on plan with bad name "@@foo" 183s ok 119 - Exception ident should be "parse" 183s ok 120 - And "@@foo" should trigger the appropriate message 183s ok 121 - Should not have sorted changes 183s ok 122 - Should die on plan with bad name "@foo/bar 2012-07-16T17:25:07Z X " 183s ok 123 - Exception ident should be "parse" 183s ok 124 - And "foo/bar" should trigger the appropriate message 183s ok 125 - Should not have sorted changes 183s ok 126 - Should parse "foo" 183s ok 127 - Should have captured the foo pragmas 183s ok 128 - Should have pragmas in plan with change "foo" 183s ok 129 - Should parse "@foo" 183s ok 130 - Should have pragmas in plan with tag "foo" 183s ok 131 - Should have line and change for "@foo" 183s ok 132 - Should parse "12" 183s ok 133 - Should have captured the 12 pragmas 183s ok 134 - Should have pragmas in plan with change "12" 183s ok 135 - Should parse "@12" 183s ok 136 - Should have pragmas in plan with tag "12" 183s ok 137 - Should have line and change for "@12" 183s ok 138 - Should parse "t" 183s ok 139 - Should have captured the t pragmas 183s ok 140 - Should have pragmas in plan with change "t" 183s ok 141 - Should parse "@t" 183s ok 142 - Should have pragmas in plan with tag "t" 183s ok 143 - Should have line and change for "@t" 183s ok 144 - Should parse "6" 183s ok 145 - Should have captured the 6 pragmas 183s ok 146 - Should have pragmas in plan with change "6" 183s ok 147 - Should parse "@6" 183s ok 148 - Should have pragmas in plan with tag "6" 183s ok 149 - Should have line and change for "@6" 183s ok 150 - Should parse "阱阪阬" 183s ok 151 - Should have captured the 阱阪阬 pragmas 183s ok 152 - Should have pragmas in plan with change "阱阪阬" 183s ok 153 - Should parse "@阱阪阬" 183s ok 154 - Should have pragmas in plan with tag "阱阪阬" 183s ok 155 - Should have line and change for "@阱阪阬" 183s ok 156 - Should parse "foo,bar" 183s ok 157 - Should have captured the foo,bar pragmas 183s ok 158 - Should have pragmas in plan with change "foo,bar" 183s ok 159 - Should parse "@foo,bar" 183s ok 160 - Should have pragmas in plan with tag "foo,bar" 183s ok 161 - Should have line and change for "@foo,bar" 183s ok 162 - Should parse "beta1" 183s ok 163 - Should have captured the beta1 pragmas 183s ok 164 - Should have pragmas in plan with change "beta1" 183s ok 165 - Should parse "@beta1" 183s ok 166 - Should have pragmas in plan with tag "beta1" 183s ok 167 - Should have line and change for "@beta1" 183s ok 168 - Should parse "foo_" 183s ok 169 - Should have captured the foo_ pragmas 183s ok 170 - Should have pragmas in plan with change "foo_" 183s ok 171 - Should parse "@foo_" 183s ok 172 - Should have pragmas in plan with tag "foo_" 183s ok 173 - Should have line and change for "@foo_" 183s ok 174 - Should parse "_foo" 183s ok 175 - Should have captured the _foo pragmas 183s ok 176 - Should have pragmas in plan with change "_foo" 183s ok 177 - Should parse "@_foo" 183s ok 178 - Should have pragmas in plan with tag "_foo" 183s ok 179 - Should have line and change for "@_foo" 183s ok 180 - Should parse "v1.0-1b" 183s ok 181 - Should have captured the v1.0-1b pragmas 183s ok 182 - Should have pragmas in plan with change "v1.0-1b" 183s ok 183 - Should parse "@v1.0-1b" 183s ok 184 - Should have pragmas in plan with tag "v1.0-1b" 183s ok 185 - Should have line and change for "@v1.0-1b" 183s ok 186 - Should parse "v1.2-1" 183s ok 187 - Should have captured the v1.2-1 pragmas 183s ok 188 - Should have pragmas in plan with change "v1.2-1" 183s ok 189 - Should parse "@v1.2-1" 183s ok 190 - Should have pragmas in plan with tag "v1.2-1" 183s ok 191 - Should have line and change for "@v1.2-1" 183s ok 192 - Should parse "v1.2+1" 183s ok 193 - Should have captured the v1.2+1 pragmas 183s ok 194 - Should have pragmas in plan with change "v1.2+1" 183s ok 195 - Should parse "@v1.2+1" 183s ok 196 - Should have pragmas in plan with tag "v1.2+1" 183s ok 197 - Should have line and change for "@v1.2+1" 183s ok 198 - Should parse "v1.2_1" 183s ok 199 - Should have captured the v1.2_1 pragmas 183s ok 200 - Should have pragmas in plan with change "v1.2_1" 183s ok 201 - Should parse "@v1.2_1" 183s ok 202 - Should have pragmas in plan with tag "v1.2_1" 183s ok 203 - Should have line and change for "@v1.2_1" 183s ok 204 - Should have sorted changes 26 times 183s ok 205 - Should die on plan with reserved tag "@HEAD" 183s ok 206 - @HEAD exception should have ident "plan" 183s ok 207 - And the @HEAD error message should be correct 183s ok 208 - Should have sorted @HEAD changes nonce 183s ok 209 - Should die on plan with reserved tag "@ROOT" 183s ok 210 - @ROOT exception should have ident "plan" 183s ok 211 - And the @ROOT error message should be correct 183s ok 212 - Should have sorted @ROOT changes nonce 183s ok 213 - Should die on plan with SHA1 change name 183s ok 214 - The SHA1 error ident should be "parse" 183s ok 215 - And the SHA1 error message should be correct 183s ok 216 - Should have sorted changes nonce 183s ok 217 - Should die on plan with tag but no preceding change 183s ok 218 - The missing change error ident should be "parse" 183s ok 219 - And the missing change error message should be correct 183s ok 220 - Should have sorted changes nonce 183s ok 221 - Should die on plan with dupe tag 183s ok 222 - The dupe tag error ident should be "parse" 183s ok 223 - And the missing change error message should be correct 183s ok 224 - Should have sorted changes twice 183s ok 225 - Should die on plan with dupe change 183s ok 226 - The dupe change error ident should be "parse" 183s ok 227 - And the dupe change error message should be correct 183s ok 228 - Should have sorted changes once 183s ok 229 - Should die on invalid dependency 183s ok 230 - The invalid dependency error ident should be "parse" 183s ok 231 - And the invalid dependency error message should be correct 183s ok 232 - Should have sorted changes nonce 183s ok 233 - Should die on dupe dependency 183s ok 234 - The dupe dependency error ident should be "parse" 183s ok 235 - And the dupe dependency error message should be correct 183s ok 236 - Should have sorted changes nonce 183s ok 237 - Should die on change with no timestamp 183s ok 238 - The missing timestamp error ident should be "parse" 183s ok 239 - And the missing timestamp error message should be correct 183s ok 240 - Should have sorted changes nonce 183s ok 241 - Should die on change with no planner 183s ok 242 - The missing parsener error ident should be "parse" 183s ok 243 - And the missing planner error message should be correct 183s ok 244 - Should have sorted changes nonce 183s ok 245 - Should die on change with no timestamp or planner 183s ok 246 - The missing timestamp or parsener error ident should be "parse" 183s ok 247 - And the missing timestamp or planner error message should be correct 183s ok 248 - Should have sorted changes nonce 183s ok 249 - Should parse plan with pragmas" 183s ok 250 - Should have sorted changes once 183s ok 251 - Should have captured all of the pragmas 183s ok 252 - Should have "multi.plan" lines and changes 183s ok 253 - Should parse plan with deploy and revert operators 183s ok 254 - Should have sorted changes twice 183s ok 255 - Should have captured the deploy-and-revert pragmas 183s ok 256 - Should have "deploy-and-revert.plan" lines and changes 183s ok 257 - Should get exception for nonexistent plan file 183s ok 258 - Nonexistent plan file ident should be "plan" 183s ok 259 - Nonexistent plan file message should be correct 183s ok 260 - 'Plan with sqitch with plan file with dependencies' isa 'App::Sqitch::Plan' 183s ok 261 - File should be coopied from Sqitch 183s ok 262 - Load plan with dependencies file 183s ok 263 - The changes should include the dependencies 183s ok 264 - Should have sorted changes twice 183s ok 265 - 'Plan with sqitch with plan file with project deps' isa 'App::Sqitch::Plan' 183s ok 266 - File should be coopied from Sqitch 183s ok 267 - Load plan with project deps file 183s ok 268 - The changes should include the cross-project deps 183s ok 269 - Should have sorted changes twice 183s ok 270 - 'Plan with sqitch with plan with tag dependencies' isa 'App::Sqitch::Plan' 183s ok 271 - File should be coopied from Sqitch 183s ok 272 - Should get an exception for tag with dependencies 183s ok 273 - The tag dependencies error ident should be "plan" 183s ok 274 - And the tag dependencies error message should be correct 183s ok 275 - 'Plan with sqitch with plan file' isa 'App::Sqitch::Plan' 183s ok 276 - File should be coopied from Sqitch 183s ok 277 - Lines should be parsed from file 183s ok 278 - Changes should be parsed from file 183s ok 279 - Should get all tags from tags() 183s ok 280 - Should have sorted changes twice 183s ok 281 - Load should parse plan from file 183s ok 282 - Should have captured the multi pragmas 183s ok 283 - And the parsed file should have lines and changes 183s ok 284 - Should have sorted changes twice 183s ok 285 - App::Sqitch::Plan->can(...) 183s ok 286 - Position should start at -1 183s ok 287 - Current should be undef 183s ok 288 - Get next change 183s ok 289 - 'First change' isa 'App::Sqitch::Plan::Change' 183s ok 290 - It should be the first change 183s ok 291 - Position should be at 0 183s ok 292 - Count should be 4 183s ok 293 - Current should be current 183s ok 294 - Should get first change from change_at(0) 183s ok 295 - Peek to next change 183s ok 296 - 'Peeked change' isa 'App::Sqitch::Plan::Change' 183s ok 297 - Peeked change should be second change 183s ok 298 - last() should return last change 183s ok 299 - Current should still be current 183s ok 300 - Peek should still be next 183s ok 301 - Next should be the second change 183s ok 302 - Position should be at 1 183s ok 303 - Should get second change from change_at(1) 183s ok 304 - Peek should return an object 183s ok 305 - 'Third change' isa 'App::Sqitch::Plan::Change' 183s ok 306 - It should be the foo tag 183s ok 307 - Current should be the second change 183s ok 308 - Should get third change next 183s ok 309 - Position should be at 2 183s ok 310 - Current should be third change 183s ok 311 - Should get third change from change_at(1) 183s ok 312 - Get fourth change 183s ok 313 - 'Fourth change' isa 'App::Sqitch::Plan::Change' 183s ok 314 - Fourth change should be "hey-there" 183s ok 315 - Position should be at 3 183s ok 316 - Peek should return undef 183s ok 317 - Next should return undef 183s ok 318 - Position should be at 7 183s ok 319 - Next should still return undef 183s ok 320 - Position should still be at 7 183s ok 321 - Reset the plan 183s ok 322 - Position should be back at -1 183s ok 323 - Current should still be undef 183s ok 324 - Next should return the first change again 183s ok 325 - Position should be at 0 again 183s ok 326 - Current should be first change 183s ok 327 - Index of change should be 0 183s ok 328 - Plan should contain change 183s ok 329 - Should be able to get change 0 by name 183s ok 330 - Should be able to find change 0 by name 183s ok 331 - Should be able to get change 0 by ID 183s ok 332 - Should be able to find change 0 by ID 183s ok 333 - Index of @bar should be 3 183s ok 334 - Plan should contain @bar 183s ok 335 - Should be able to get hey-there via @bar 183s ok 336 - Should be able to get hey-there via @bar ID 183s ok 337 - Should be able to find hey-there via @bar 183s ok 338 - Should be able to find hey-there via @bar ID 183s ok 339 - Seek to the "@bar" change 183s ok 340 - Position should be at 3 again 183s ok 341 - Current should be fourth again 183s ok 342 - Index of you should be 1 183s ok 343 - Plan should contain "you" 183s ok 344 - Should be able to get change 1 by name 183s ok 345 - Should be able to find change 1 by name 183s ok 346 - Seek to the "you" change 183s ok 347 - Position should be at 1 again 183s ok 348 - Current should be second again 183s ok 349 - Index of baz should be undef 183s ok 350 - Plan should not contain "baz" 183s ok 351 - Index of @baz should be 3 183s ok 352 - Plan should contain @baz 183s ok 353 - Seek to the "baz" change 183s ok 354 - Position should be at 3 again 183s ok 355 - Current should be fourth again 183s ok 356 - Should still get first change from change_at(0) 183s ok 357 - Should still get second change from change_at(1) 183s ok 358 - Should still get third change from change_at(1) 183s ok 359 - Should die seeking invalid change 183s ok 360 - Invalid seek change error ident should be "plan" 183s ok 361 - And the failure message should be correct 183s ok 362 - All should return all changes 183s ok 363 - Reset the plan again 183s ok 364 - Change hey should be passed to do sub 183s ok 365 - Change hey should be the topic in do sub 183s ok 366 - Change you should be passed to do sub 183s ok 367 - Change you should be the topic in do sub 183s ok 368 - Change this/rocks should be passed to do sub 183s ok 369 - Change this/rocks should be the topic in do sub 183s ok 370 - Change hey-there should be passed to do sub 183s ok 371 - Change hey-there should be the topic in do sub 183s ok 372 - 'search_changes() should return a code ref' isa 'CODE' 183s ok 373 - All the changes should be returned in the proper order 183s ok 374 - Direction "DESC" should work 183s ok 375 - Should get error for invalid direction 183s ok 376 - Invalid direction error ident should be "DEV" 183s ok 377 - Invalid direction error message should be correct 183s ok 378 - Direction "asc" should work 183s ok 379 - Search by change name should work 183s ok 380 - Search by change name should work as a regex 183s ok 381 - Search by change name should with a character class 183s ok 382 - Search by planner should work 183s ok 383 - Search by planner should work as a regex 183s ok 384 - Search by operation "deploy" should work 183s ok 385 - Search by operation "rever" should return nothing 183s ok 386 - Search by operation "DEPLOY" should now return two changes 183s ok 387 - Search by operation "REVERT" should return the other two 183s ok 388 - Should get an error for unknown operation 183s ok 389 - Unknown operation error ident should be "DEV" 183s ok 390 - Unknown operation error message should be correct 183s ok 391 - Search with offset 2 should work 183s ok 392 - Search with offset 2, limit 1 should work 183s ok 393 - Search with offset 3 and direction "desc" should work 183s ok 394 - Search with offset 2, limit 1, direction "desc" should work 183s ok 395 - Search with limit 3, direction "desc" should work 183s ok 396 - App::Sqitch::Plan->can('write_to') 183s ok 397 - plan.out does not exist 183s ok 398 - Write out the file 183s ok 399 - plan.out exists 183s ok 400 - The contents should look right 183s ok 401 - Write out the file from "this/rocks" 183s ok 402 - Plan should have been written from "this/rocks" through tags at end 183s ok 403 - Write the file up to "you" 183s ok 404 - Plan should have been written through "you" and its tags 183s ok 405 - Write from "@foo" to "this/rocks" 183s ok 406 - Plan should have been written from "@foo" to "this/rocks" 183s ok 407 - Write from "hey" to "@foo" 183s ok 408 - Plan should have been written from "hey" through "@foo" 183s ok 409 - App::Sqitch::Plan->can('_is_valid') 183s ok 410 - Should find "^foo" invalid 183s ok 411 - Invalid name "^foo" error ident should be "plan" 183s ok 412 - And the "^foo" error message should be correct 183s ok 413 - Should find "foo^" invalid 183s ok 414 - Invalid name "foo^" error ident should be "plan" 183s ok 415 - And the "foo^" error message should be correct 183s ok 416 - Should find "foo^6" invalid 183s ok 417 - Invalid name "foo^6" error ident should be "plan" 183s ok 418 - And the "foo^6" error message should be correct 183s ok 419 - Should find "foo^666" invalid 183s ok 420 - Invalid name "foo^666" error ident should be "plan" 183s ok 421 - And the "foo^666" error message should be correct 183s ok 422 - Should find "%hi" invalid 183s ok 423 - Invalid name "%hi" error ident should be "plan" 183s ok 424 - And the "%hi" error message should be correct 183s ok 425 - Should find "hi!" invalid 183s ok 426 - Invalid name "hi!" error ident should be "plan" 183s ok 427 - And the "hi!" error message should be correct 183s ok 428 - Should find "foo@bar" invalid 183s ok 429 - Invalid name "foo@bar" error ident should be "plan" 183s ok 430 - And the "foo@bar" error message should be correct 183s ok 431 - Should find "foo:bar" invalid 183s ok 432 - Invalid name "foo:bar" error ident should be "plan" 183s ok 433 - And the "foo:bar" error message should be correct 183s ok 434 - Should find "foo\bar" invalid 183s ok 435 - Invalid name "foo\bar" error ident should be "plan" 183s ok 436 - And the "foo\bar" error message should be correct 183s ok 437 - Should find "+foo" invalid 183s ok 438 - Invalid name "+foo" error ident should be "plan" 183s ok 439 - And the "+foo" error message should be correct 183s ok 440 - Should find "-foo" invalid 183s ok 441 - Invalid name "-foo" error ident should be "plan" 183s ok 442 - And the "-foo" error message should be correct 183s ok 443 - Should find "@foo" invalid 183s ok 444 - Invalid name "@foo" error ident should be "plan" 183s ok 445 - And the "@foo" error message should be correct 183s ok 446 - Name "foo" should be valid 183s ok 447 - Name "12" should be valid 183s ok 448 - Name "t" should be valid 183s ok 449 - Name "6" should be valid 183s ok 450 - Name "阱阪阬" should be valid 183s ok 451 - Name "foo/bar" should be valid 183s ok 452 - Name "beta1" should be valid 183s ok 453 - Name "v1.2-1" should be valid 183s ok 454 - Name "v1.2+1" should be valid 183s ok 455 - Name "v1.2_1" should be valid 183s ok 456 - Add tag "w00t" 183s ok 457 - Should have 4 changes 183s ok 458 - Should find "@w00t" in plan 183s ok 459 - Should find "@w00t" at index 3 183s ok 460 - Last change should be "hey-there" 183s ok 461 - The w00t tag should be on the last change 183s ok 462 - An object of class 'App::Sqitch::Plan::Tag' isa 'App::Sqitch::Plan::Tag' 183s ok 463 - The returned tag should be @w00t 183s ok 464 - The @w00t change should be the last change 183s ok 465 - Write out the file again 183s ok 466 - The contents should include the "w00t" tag 183s ok 467 - Add tag "@alpha" 183s ok 468 - Should find "@alpha" in plan 183s ok 469 - Should find "@alpha" at index 3 183s ok 470 - The returned tag should be @alpha 183s ok 471 - The @alpha change should be the last change 183s ok 472 - Tag change "you" 183s ok 473 - Should still have 4 changes 183s ok 474 - Should find "@blarney" in plan 183s ok 475 - Should find "@blarney" at index 1 183s ok 476 - The blarney tag should be on the second change 183s ok 477 - An object of class 'App::Sqitch::Plan::Tag' isa 'App::Sqitch::Plan::Tag' 183s ok 478 - The returned tag should be @blarney 183s ok 479 - The @blarney change should be the second change 183s ok 480 - Should get error trying to add duplicate tag 183s ok 481 - Duplicate tag error ident should be "plan" 183s ok 482 - And the error message should report it as a dupe 183s ok 483 - Should get error for invalid tag "^foo" 183s ok 484 - Invalid name "^foo" error ident should be "plan" 183s ok 485 - And the "^foo" error message should be correct 183s ok 486 - Should get error for invalid tag "foo^" 183s ok 487 - Invalid name "foo^" error ident should be "plan" 183s ok 488 - And the "foo^" error message should be correct 183s ok 489 - Should get error for invalid tag "foo^6" 183s ok 490 - Invalid name "foo^6" error ident should be "plan" 183s ok 491 - And the "foo^6" error message should be correct 183s ok 492 - Should get error for invalid tag "foo^666" 183s ok 493 - Invalid name "foo^666" error ident should be "plan" 183s ok 494 - And the "foo^666" error message should be correct 183s ok 495 - Should get error for invalid tag "%hi" 183s ok 496 - Invalid name "%hi" error ident should be "plan" 183s ok 497 - And the "%hi" error message should be correct 183s ok 498 - Should get error for invalid tag "hi!" 183s ok 499 - Invalid name "hi!" error ident should be "plan" 183s ok 500 - And the "hi!" error message should be correct 183s ok 501 - Should get error for invalid tag "foo@bar" 183s ok 502 - Invalid name "foo@bar" error ident should be "plan" 183s ok 503 - And the "foo@bar" error message should be correct 183s ok 504 - Should get error for invalid tag "foo:bar" 183s ok 505 - Invalid name "foo:bar" error ident should be "plan" 183s ok 506 - And the "foo:bar" error message should be correct 183s ok 507 - Should get error for invalid tag "foo\bar" 183s ok 508 - Invalid name "foo\bar" error ident should be "plan" 183s ok 509 - And the "foo\bar" error message should be correct 183s ok 510 - Should get error for invalid tag "+foo" 183s ok 511 - Invalid name "+foo" error ident should be "plan" 183s ok 512 - And the "+foo" error message should be correct 183s ok 513 - Should get error for invalid tag "-foo" 183s ok 514 - Invalid name "-foo" error ident should be "plan" 183s ok 515 - And the "-foo" error message should be correct 183s ok 516 - Should get error for invalid tag "foo\#bar" 183s ok 517 - Invalid name "foo\#bar" error ident should be "plan" 183s ok 518 - And the "foo\#bar" error message should be correct 183s ok 519 - Should get error for invalid tag "foo/bar" 183s ok 520 - Invalid name "foo/bar" error ident should be "plan" 183s ok 521 - And the "foo/bar" error message should be correct 183s ok 522 - Should get error for reserved tag "HEAD" 183s ok 523 - Reserved tag "HEAD" error ident should be "plan" 183s ok 524 - And the reserved tag "HEAD" message should be correct 183s ok 525 - Should get error for reserved tag "ROOT" 183s ok 526 - Reserved tag "ROOT" error ident should be "plan" 183s ok 527 - And the reserved tag "ROOT" message should be correct 183s ok 528 - Should get error for a SHA1 tag 183s ok 529 - SHA1 tag error ident should be "plan" 183s ok 530 - And the reserved name error should be output 183s ok 531 - Add change "booyah" 183s ok 532 - Should have 5 changes 183s ok 533 - Should find "booyah" in plan 183s ok 534 - Should find "booyah" at index 4 183s ok 535 - Last change should be "booyah" 183s ok 536 - An object of class 'App::Sqitch::Plan::Change' isa 'App::Sqitch::Plan::Change' 183s ok 537 - Should have plain stringification of "booya" 183s ok 538 - Write out the file again 183s ok 539 - The contents should include the "booyah" change 183s ok 540 - Add change "blow" 183s ok 541 - Should have 6 changes 183s ok 542 - Should find "blow" in plan 183s ok 543 - Should find "blow" at index 5 183s ok 544 - Last change should be "blow" 183s ok 545 - Should have nice stringification of "blow [booyah]" 183s ok 546 - The new change should have been appended to the lines, too 183s ok 547 - Add change "jive" with dupe dependency 183s ok 548 - Should have 7 changes 183s ok 549 - Should find "jive" in plan 183s ok 550 - Should find "jive" at index 6 183s ok 551 - jive change should be "jive" 183s ok 552 - Should have dependency "blow" 183s ok 553 - Should have nice stringification of "jive [blow]" 183s ok 554 - The new change should have been appended to the lines, too 183s ok 555 - Add change "moo" with dupe dependencies 183s ok 556 - Should have 8 changes 183s ok 557 - Should find "moo" in plan 183s ok 558 - Should find "moo" at index 7 183s ok 559 - moo change should be "moo" 183s ok 560 - Should require "ext:whu" 183s ok 561 - Should conflict with "blow" and "ext:whu" 183s ok 562 - Should have nice stringification of "moo [ext:foo !blow !ext:whu]" 183s ok 563 - The new change should have been appended to the lines, too 183s ok 564 - Should get error trying to add duplicate change 183s ok 565 - Duplicate change error ident should be "plan" 183s ok 566 - And the error message should suggest "rework" 183s ok 567 - Should get error for invalid change "^foo" 183s ok 568 - Invalid name "^foo" error ident should be "plan" 183s ok 569 - And the "^foo" error message should be correct 183s ok 570 - Should get error for invalid change "foo^" 183s ok 571 - Invalid name "foo^" error ident should be "plan" 183s ok 572 - And the "foo^" error message should be correct 183s ok 573 - Should get error for invalid change "foo^6" 183s ok 574 - Invalid name "foo^6" error ident should be "plan" 183s ok 575 - And the "foo^6" error message should be correct 183s ok 576 - Should get error for invalid change "foo^666" 183s ok 577 - Invalid name "foo^666" error ident should be "plan" 183s ok 578 - And the "foo^666" error message should be correct 183s ok 579 - Should get error for invalid change "%hi" 183s ok 580 - Invalid name "%hi" error ident should be "plan" 183s ok 581 - And the "%hi" error message should be correct 183s ok 582 - Should get error for invalid change "hi!" 183s ok 583 - Invalid name "hi!" error ident should be "plan" 183s ok 584 - And the "hi!" error message should be correct 183s ok 585 - Should get error for invalid change "foo@bar" 183s ok 586 - Invalid name "foo@bar" error ident should be "plan" 183s ok 587 - And the "foo@bar" error message should be correct 183s ok 588 - Should get error for invalid change "foo:bar" 183s ok 589 - Invalid name "foo:bar" error ident should be "plan" 183s ok 590 - And the "foo:bar" error message should be correct 183s ok 591 - Should get error for invalid change "foo\bar" 183s ok 592 - Invalid name "foo\bar" error ident should be "plan" 183s ok 593 - And the "foo\bar" error message should be correct 183s ok 594 - Should get error for invalid change "+foo" 183s ok 595 - Invalid name "+foo" error ident should be "plan" 183s ok 596 - And the "+foo" error message should be correct 183s ok 597 - Should get error for invalid change "-foo" 183s ok 598 - Invalid name "-foo" error ident should be "plan" 183s ok 599 - And the "-foo" error message should be correct 183s ok 600 - Should get error for invalid change "@foo" 183s ok 601 - Invalid name "@foo" error ident should be "plan" 183s ok 602 - And the "@foo" error message should be correct 183s ok 603 - Should get error for reserved name "HEAD" 183s ok 604 - Reserved name "HEAD" error ident should be "plan" 183s ok 605 - And the reserved name "HEAD" message should be correct 183s ok 606 - Should get error for reserved name "ROOT" 183s ok 607 - Reserved name "ROOT" error ident should be "plan" 183s ok 608 - And the reserved name "ROOT" message should be correct 183s ok 609 - Should get failure for failed dependency 183s ok 610 - Dependency error ident should be "plan" 183s ok 611 - The dependency error should be correct 183s ok 612 - Should get failure for invalid dependency 183s ok 613 - Invalid dependency error ident should be "plan" 183s ok 614 - The invalid dependency error should be correct 183s ok 615 - Should get failure for invalid conflict 183s ok 616 - Invalid conflict error ident should be "plan" 183s ok 617 - The invalid conflict error should be correct 183s ok 618 - Should get failure for failed tag dependency 183s ok 619 - Tag dependency error ident should be "plan" 183s ok 620 - The tag dependency error should be correct 183s ok 621 - Should get error for a SHA1 change 183s ok 622 - SHA1 tag error ident should be "plan" 183s ok 623 - And the reserved name error should be output 183s ok 624 - App::Sqitch::Plan->can('rework') 183s ok 625 - Rework change "you" 183s ok 626 - An object of class 'App::Sqitch::Plan::Change' isa 'App::Sqitch::Plan::Change' 183s ok 627 - Reworked change should be "you" 183s ok 628 - Get original "you" change 183s ok 629 - It should also be named "you" 183s ok 630 - And it should have the one rework tag 183s ok 631 - The original file should now be named you@bar.sql 183s ok 632 - It should require the previous "you" change 183s ok 633 - The new "you" should have been appended to the lines, too 183s ok 634 - Should find "you@HEAD" in plan 183s ok 635 - It should be at position 8 183s ok 636 - The plan count should be 9 183s ok 637 - Tag @beta1 183s ok 638 - Rework change "you" again 183s ok 639 - An object of class 'App::Sqitch::Plan::Change' isa 'App::Sqitch::Plan::Change' 183s ok 640 - New reworked change should be "you" 183s ok 641 - Get original "you" change again 183s ok 642 - It should still be named "you" 183s ok 643 - And it should have the one rework tag 183s ok 644 - Get you@beta1 183s ok 645 - The second "you" should be named that 183s ok 646 - And the second change should have the rework_tag "@beta1" 183s ok 647 - But the new reworked change should have no rework tags 183s ok 648 - It should require the previous "you" change 183s ok 649 - The new reworking should have been appended to the lines 183s ok 650 - Should find "you@HEAD" in plan 183s ok 651 - It should be at position 9 183s ok 652 - The plan count should be 10 183s ok 653 - rework should die on nonexistent change 183s ok 654 - Nonexistent change error ident should be "plan" 183s ok 655 - And the error should suggest "sqitch add" 183s ok 656 - rework_stpe should die on lack of intervening tag 183s ok 657 - Missing tag error ident should be "plan" 183s ok 658 - And the error should suggest "sqitch tag" 183s ok 659 - rework should die on failed dependency 183s ok 660 - Rework dependency error ident should be "plan" 183s ok 661 - The rework dependency error should be correct 183s ok 662 - Should get failure for invalid dependency 183s ok 663 - Invalid dependency error ident should be "plan" 183s ok 664 - The invalid dependency error should be correct 183s ok 665 - Should get failure for invalid conflict 183s ok 666 - Invalid conflict error ident should be "plan" 183s ok 667 - The invalid conflict error should be correct 183s ok 668 - 'Plan shoud work plan with dupe change across tags' isa 'App::Sqitch::Plan' 183s ok 669 - File should be coopied from Sqitch 183s ok 670 - Project name should be set 183s ok 671 - Lines with dupe change should be read from file 183s ok 672 - Noes with dupe change should be read from file 183s ok 673 - Should have sorted changes three times 183s ok 674 - Should find "whatever" in plan 183s ok 675 - Should get an error trying to find dupe key. 183s ok 676 - Dupe key error ident should be "plan" 183s ok 677 - Dupe key error message should be correct 183s ok 678 - Should have output listing tag-qualified changes 183s ok 679 - Should get 3 for whatever@HEAD 183s ok 680 - Should get 0 for whatever@bar 183s ok 681 - Should get an error seeking dupe key. 183s ok 682 - Dupe key error ident should be "plan" 183s ok 683 - Dupe key error message should be correct 183s ok 684 - Should have output listing tag-qualified changes 183s ok 685 - Should find whatever@HEAD at index 3 183s ok 686 - Should find whatever@HEAD at index 0 183s ok 687 - Should find first instance of whatever at index 0 183s ok 688 - Should find first instance of whatever after @bar at index 5 183s ok 689 - Seek whatever@HEAD 183s ok 690 - Position should be 3 183s ok 691 - Seek whatever@bar 183s ok 692 - Position should be 0 183s ok 693 - Last tagged change should be "hi" 183s ok 694 - App::Sqitch::Plan->can('open_script') 183s ok 695 - Open bar.sql 183s ok 696 - It should be the right file 183s ok 697 - Open baz.sql 183s ok 698 - It should be empty 183s ok 699 - open_script() should die on nonexistent file 183s ok 700 - Nonexistent file error ident should be "io" 183s ok 701 - Nonexistent file error message should be correct 183s ok 702 - App::Sqitch::Plan->can('check_changes') 183s ok 703 - Should get original order when no dependencies 183s ok 704 - Should get original order when no prepreqs 183s ok 705 - Should get original order when that requires this 183s ok 706 - Should get original order when other requires that 183s ok 707 - Should get error for out-of-order dependency 183s ok 708 - Unordered dependency error ident should be "parse" 183s ok 709 - And the unordered dependency error message should be correct 183s ok 710 - Should get error for multiple dependency errors 183s ok 711 - Multiple dependency error ident should be "parse" 183s ok 712 - And the multiple dependency error message should be correct 183s ok 713 - Should get original order when requiring a tag 183s ok 714 - Should get original order when requiring a step as-of a tag 183s ok 715 - Should get failure for a step after a tag 183s ok 716 - Step after tag error ident should be "parse" 183s ok 717 - And we the unknown change as-of a tag message should be correct 183s ok 718 - Should get failure for a cycle 183s ok 719 - Cycle error ident should be "parse" 183s ok 720 - The cycle error message should be correct 183s ok 721 - Should get failure for a two-hop cycle 183s ok 722 - Two-hope cycle error ident should be "parse" 183s ok 723 - The two-hop cycle error message should be correct 183s ok 724 - Should get original order with earlier dependency 183s ok 725 - Should get error with misordered and seen dependencies 183s ok 726 - Misorderd and seen error ident should be "parse" 183s ok 727 - And the misordered and seen error message should be correct 183s ok 728 - Should die on unknown dependency 183s ok 729 - Unknown dependency error ident should be "parse" 183s ok 730 - And the error should point to the offending change 183s ok 731 - Should die on unknown tag dependency 183s ok 732 - Unknown tag dependency error ident should be "parse" 183s ok 733 - And the error should point to the offending change 183s ok 734 - Should get original order with external dependency 183s ok 735 - Should die on self dependency 183s ok 736 - Self dependency error ident should be "parse" 183s ok 737 - And the self dependency error should be correct 183s ok 738 - Should get original order with cascading dependencies 183s ok 739 - Should get original order with multiple cascading dependencies 183s ok 740 - App::Sqitch::Plan->can('_check_dependencies') 183s ok 741 - Depend "hi" should be in project "dupe_change_diff_tag" 183s ok 742 - Dependency on "hi" should succeed 183s ok 743 - Depend "greets" should be in project "dupe_change_diff_tag" 183s ok 744 - Dependency on "greets" should succeed 183s ok 745 - Depend "whatever" should be in project "dupe_change_diff_tag" 183s ok 746 - Dependency on "whatever" should succeed 183s ok 747 - Depend "@foo" should be in project "dupe_change_diff_tag" 183s ok 748 - Dependency on "@foo" should succeed 183s ok 749 - Depend "whatever@foo" should be in project "dupe_change_diff_tag" 183s ok 750 - Dependency on "whatever@foo" should succeed 183s ok 751 - Depend "ext:larry" should be in project "ext" 183s ok 752 - Dependency on "ext:larry" should succeed 183s ok 753 - Depend "ext:greets" should be in project "ext" 183s ok 754 - Dependency on "ext:greets" should succeed 183s ok 755 - Should get error trying to depend on "wanker" 183s ok 756 - Dependency "req" error ident should be "plan" 183s ok 757 - And should get unknown dependency message for "wanker" 183s ok 758 - Should get error trying to depend on "@blah" 183s ok 759 - Dependency "req" error ident should be "plan" 183s ok 760 - And should get unknown dependency message for "@blah" 183s ok 761 - Should get error trying to depend on "greets@foo" 183s ok 762 - Dependency "req" error ident should be "plan" 183s ok 763 - And should get unknown dependency message for "greets@foo" 183s ok 764 - Should have undef URI when no pragma 183s ok 765 - 'Plan with sqitch with plan file with dependencies' isa 'App::Sqitch::Plan' 183s ok 766 - File should be coopied from Sqitch 183s ok 767 - syntax_version should be set 183s ok 768 - Project should be set 183s ok 769 - Should have URI from pragma 183s ok 770 - 'It' isa 'URI' 183s ok 771 - Should die on plan with no project pragma 183s ok 772 - Missing prorject error ident should be "parse" 183s ok 773 - The missing project error message should be correct 183s ok 774 - Should die on invalid project name "^foo" 183s ok 775 - Ident for bad proj "^foo" should be "parse" 183s ok 776 - Error message for bad project "^foo" should be correct 183s ok 777 - Should die on invalid project name "foo^" 183s ok 778 - Ident for bad proj "foo^" should be "parse" 183s ok 779 - Error message for bad project "foo^" should be correct 183s ok 780 - Should die on invalid project name "foo^6" 183s ok 781 - Ident for bad proj "foo^6" should be "parse" 183s ok 782 - Error message for bad project "foo^6" should be correct 183s ok 783 - Should die on invalid project name "foo^666" 183s ok 784 - Ident for bad proj "foo^666" should be "parse" 183s ok 785 - Error message for bad project "foo^666" should be correct 183s ok 786 - Should die on invalid project name "%hi" 183s ok 787 - Ident for bad proj "%hi" should be "parse" 183s ok 788 - Error message for bad project "%hi" should be correct 183s ok 789 - Should die on invalid project name "hi!" 183s ok 790 - Ident for bad proj "hi!" should be "parse" 183s ok 791 - Error message for bad project "hi!" should be correct 183s ok 792 - Should die on invalid project name "foo@bar" 183s ok 793 - Ident for bad proj "foo@bar" should be "parse" 183s ok 794 - Error message for bad project "foo@bar" should be correct 183s ok 795 - Should die on invalid project name "foo:bar" 183s ok 796 - Ident for bad proj "foo:bar" should be "parse" 183s ok 797 - Error message for bad project "foo:bar" should be correct 183s ok 798 - Should die on invalid project name "foo\bar" 183s ok 799 - Ident for bad proj "foo\bar" should be "parse" 183s ok 800 - Error message for bad project "foo\bar" should be correct 183s ok 801 - Should die on invalid project name "+foo" 183s ok 802 - Ident for bad proj "+foo" should be "parse" 183s ok 803 - Error message for bad project "+foo" should be correct 183s ok 804 - Should die on invalid project name "-foo" 183s ok 805 - Ident for bad proj "-foo" should be "parse" 183s ok 806 - Error message for bad project "-foo" should be correct 183s ok 807 - Should die on invalid project name "@foo" 183s ok 808 - Ident for bad proj "@foo" should be "parse" 183s ok 809 - Error message for bad project "@foo" should be correct 183s 1..809 183s ok 184s t/plan_cmd.t ........ 184s 1..234 184s ok 1 - require App::Sqitch::Command::plan; 184s ok 2 - Load a sqitch sqitch object 184s ok 3 - 'plan command' isa 'App::Sqitch::Command::plan' 184s ok 4 - App::Sqitch::Command::plan->can(...) 184s ok 5 - Options should be correct 184s ok 6 - Should parse options 184s ok 7 - Options should not conflict with core options 184s ok 8 - 'Formatter' isa 'App::Sqitch::ItemFormatter' 184s ok 9 - Should get empty hash for no config or options 184s ok 10 - Should get error for invalid date format in config 184s ok 11 - Invalid date format error ident should be "datetime" 184s ok 12 - Invalid date format error message should be correct 184s ok 13 - Should get error for invalid date format in optsions 184s ok 14 - Invalid date format error ident should be "plan" 184s ok 15 - Invalid date format error message should be correct 184s ok 16 - Should get error for invalid format in config 184s ok 17 - Invalid format error ident should be "plan" 184s ok 18 - Invalid format error message should be correct 184s ok 19 - Should get error for invalid format in optsions 184s ok 20 - Invalid format error ident should be "plan" 184s ok 21 - Invalid format error message should be correct 184s ok 22 - Configuration should respect --no-color, setting "never" 184s ok 23 - --oneline should set format 184s ok 24 - --oneline should set abbrev to 6 184s ok 25 - --oneline should not override --format 184s ok 26 - --oneline should not overrride --abbrev 184s ok 27 - Configuration should respect --no-color even when configure is set 184s ok 28 - Configuration should respect color option 184s ok 29 - Configuration should respect color config 184s ok 30 - Configuration should respect color option 184s ok 31 - Configuration should respect color config 184s ok 32 - Configuration should respect color option 184s ok 33 - Configuration should respect color config 184s ok 34 - Configuration should respect color option 184s ok 35 - Configuration should respect color config 184s ok 36 - Instantiate with format "raw" 184s ok 37 - Format "raw" should output correctly 184s ok 38 - Format "raw" should output correctly without tags 184s ok 39 - Instantiate with format "full" 184s ok 40 - Format "full" should output correctly 184s ok 41 - Instantiate with format "full" and date format "rfc" 184s ok 42 - Format "full" and date format "rfc" should output correctly 184s ok 43 - Instantiate with format "full" and date format "long" 184s ok 44 - Format "full" and date format "long" should output correctly 184s ok 45 - Instantiate with format "full" and date format "medium" 184s ok 46 - Format "full" and date format "medium" should output correctly 184s ok 47 - Format "full" should output correctly without tags 184s ok 48 - Instantiate with format "long" 184s ok 49 - Format "long" should output correctly 184s ok 50 - Format "long" should output correctly without tags 184s ok 51 - Instantiate with format "medium" 184s ok 52 - Format "medium" should output correctly 184s ok 53 - Instantiate with format "medium" and date format "rfc" 184s ok 54 - Format "medium" and date format "rfc" should output correctly 184s ok 55 - Instantiate with format "medium" and date format "long" 184s ok 56 - Format "medium" and date format "long" should output correctly 184s ok 57 - Instantiate with format "medium" and date format "medium" 184s ok 58 - Format "medium" and date format "medium" should output correctly 184s ok 59 - Instantiate with format "short" 184s ok 60 - Format "short" should output correctly 184s ok 61 - Instantiate with format "oneline" 184s ok 62 - Format "oneline" should output correctly 184s ok 63 - Format "oneline" should output correctly without tags 184s ok 64 - Format "%e" should output "deploy" 184s ok 65 - Format "%e" should output "revert" 184s ok 66 - Format "%e" should output "fail" 184s ok 67 - Format "%L" should output "Deploy" 184s ok 68 - Format "%L" should output "Revert" 184s ok 69 - Format "%L" should output "Fail" 184s ok 70 - Format "%l" should output "deploy" 184s ok 71 - Format "%l" should output "revert" 184s ok 72 - Format "%l" should output "fail" 184s ok 73 - Format "%{event}_" should output "Event: " 184s ok 74 - Format "%{change}_" should output "Change: " 184s ok 75 - Format "%{planner}_" should output "Planner: " 184s ok 76 - Format "%{by}_" should output "By: " 184s ok 77 - Format "%{date}_" should output "Date: " 184s ok 78 - Format "%{planned}_" should output "Planned: " 184s ok 79 - Format "%{name}_" should output "Name: " 184s ok 80 - Format "%{email}_" should output "Email: " 184s ok 81 - Format "%{requires}_" should output "Requires: " 184s ok 82 - Format "%{conflicts}_" should output "Conflicts:" 184s ok 83 - Format "%H" should output "123456789" 184s ok 84 - Format "%h" should output "123456789" 184s ok 85 - Format "%{5}h" should output "12345" 184s ok 86 - Format "%{7}h" should output "1234567" 184s ok 87 - Format "%n" should output "foo" 184s ok 88 - Format "%n" should output "bar" 184s ok 89 - Format "%o" should output "foo" 184s ok 90 - Format "%o" should output "bar" 184s ok 91 - Format "%F" should output "deploy/change_file.sql" 184s ok 92 - Format "%F" should output "deploy/change_file_with_tag@tag.sql" 184s ok 93 - Format "%p" should output "larry " 184s ok 94 - Format "%{n}p" should output "damian" 184s ok 95 - Format "%{name}p" should output "chip" 184s ok 96 - Format "%{e}p" should output "larry@example.com" 184s ok 97 - Format "%{email}p" should output "damian@example.com" 184s ok 98 - Format "%{date}p" should output "2024-11-01 03:26:06 +0900" 184s ok 99 - Format "%{date:rfc}p" should output "Fri, 01 Nov 2024 03:26:06 +0900" 184s ok 100 - Format "%{d:long}p" should output "November 1, 2024, 3:26:06 AM JST" 184s ok 101 - Format "%{d:cldr:HH'h' mm'm'}p" should output "03h 26m" 184s ok 102 - Format "%{d:strftime:%a at %H:%M:%S}p" should output "Fri at 03:26:06" 184s ok 103 - Format "%t" should output "" 184s ok 104 - Format "%t" should output " @foo" 184s ok 105 - Format "%t" should output " @foo, @bar" 184s ok 106 - Format "%{|}t" should output "" 184s ok 107 - Format "%{|}t" should output " @foo" 184s ok 108 - Format "%{|}t" should output " @foo|@bar" 184s ok 109 - Format "%T" should output "" 184s ok 110 - Format "%T" should output " (@foo)" 184s ok 111 - Format "%T" should output " (@foo, @bar)" 184s ok 112 - Format "%{|}T" should output "" 184s ok 113 - Format "%{|}T" should output " (@foo)" 184s ok 114 - Format "%{|}T" should output " (@foo|@bar)" 184s ok 115 - Format "%r" should output "" 184s ok 116 - Format "%r" should output " foo" 184s ok 117 - Format "%r" should output " foo, bar" 184s ok 118 - Format "%{|}r" should output "" 184s ok 119 - Format "%{|}r" should output " foo" 184s ok 120 - Format "%{|}r" should output " foo|bar" 184s ok 121 - Format "%R" should output "" 184s ok 122 - Format "%R" should output "Requires: foo[newline]" 184s ok 123 - Format "%R" should output "Requires: foo, bar[newline]" 184s ok 124 - Format "%{|}R" should output "" 184s ok 125 - Format "%{|}R" should output "Requires: foo[newline]" 184s ok 126 - Format "%{|}R" should output "Requires: foo|bar[newline]" 184s ok 127 - Format "%x" should output "" 184s ok 128 - Format "%x" should output " foo" 184s ok 129 - Format "%x" should output " foo, bax" 184s ok 130 - Format "%{|}x" should output "" 184s ok 131 - Format "%{|}x" should output " foo" 184s ok 132 - Format "%{|}x" should output " foo|bax" 184s ok 133 - Format "%X" should output "" 184s ok 134 - Format "%X" should output "Conflicts: foo[newline]" 184s ok 135 - Format "%X" should output "Conflicts: foo, bar[newline]" 184s ok 136 - Format "%{|}X" should output "" 184s ok 137 - Format "%{|}X" should output "Conflicts: foo[newline]" 184s ok 138 - Format "%{|}X" should output "Conflicts: foo|bar[newline]" 184s ok 139 - Format "%{yellow}C" should output "" 184s ok 140 - Format "%{:event}C" should output "" 184s ok 141 - Format "%v" should output "[newline]" 184s ok 142 - Format "%%" should output "%" 184s ok 143 - Format "%s" should output "hi there" 184s ok 144 - Format "%s" should output "hi there" 184s ok 145 - Format "%s" should output "subject line" 184s ok 146 - Format "%{ }s" should output " hi there" 184s ok 147 - Format "%{xx}s" should output "xxhi there" 184s ok 148 - Format "%b" should output "" 184s ok 149 - Format "%b" should output "yo" 184s ok 150 - Format "%b" should output "first graph[newline][newline]second graph[newline][newline]" 184s ok 151 - Format "%{ }b" should output "" 184s ok 152 - Format "%{xxx }b" should output "xxx yo" 184s ok 153 - Format "%{x}b" should output "xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 184s ok 154 - Format "%{ }b" should output " yo" 184s ok 155 - Format "%B" should output "hi there" 184s ok 156 - Format "%B" should output "hi there[newline]yo" 184s ok 157 - Format "%B" should output "subject line[newline][newline]first graph[newline][newline]second graph[newline][newline]" 184s ok 158 - Format "%{ }B" should output " hi there" 184s ok 159 - Format "%{xxx }B" should output "xxx hi there[newline]xxx yo" 184s ok 160 - Format "%{x}B" should output "xsubject line[newline]x[newline]xfirst graph[newline]x[newline]xsecond graph[newline]x[newline]" 184s ok 161 - Format "%{ }B" should output " hi there [newline] yo" 184s ok 162 - Format "%{change}a" should output "change lolz[newline]" 184s ok 163 - Format "%{change_id}a" should output "change_id 000011112222333444[newline]" 184s ok 164 - Format "%{event}a" should output "event deploy[newline]" 184s ok 165 - Format "%{tags}a" should output "tags @beta, @gamma[newline]" 184s ok 166 - Format "%{requires}a" should output "requires foo, bar[newline]" 184s ok 167 - Format "%{conflicts}a" should output "" 184s ok 168 - Should get exception for format "%_" 184s ok 169 - %_ error ident should be "format" 184s ok 170 - %_ error message should be correct 184s ok 171 - Should get exception for unknown label in format "%_" 184s ok 172 - Invalid %_ label error ident should be "format" 184s ok 173 - Invalid %_ label error message should be correct 184s ok 174 - Instantiate with abbrev => 4 184s ok 175 - %h should respect abbrev 184s ok 176 - %H should not respect abbrev 184s ok 177 - Instantiate with date_format => "rfc" 184s ok 178 - %{date}p should respect the date_format attribute 184s ok 179 - %{iso}p should override the date_format attribute 184s ok 180 - Should get exception for unknown attribute passed to %a 184s ok 181 - %a error ident should be "format" 184s ok 182 - %a error message should be correct 184s ok 183 - Format "%{yellow}C" should output yellow 184s ok 184 - Format "%{red}C" should output red 184s ok 185 - Format "%{blue}C" should output blue 184s ok 186 - Format "%{cyan}C" should output cyan 184s ok 187 - Format "%{magenta}C" should output magenta 184s ok 188 - Format "%{:event}C" on "deploy" should output green 184s ok 189 - Format "%{:event}C" on "revert" should output blue 184s ok 190 - Format "%{:event}C" on "fail" should output red 184s ok 191 - Instantiate with format "full" again 184s ok 192 - Format "full" should output correctly with color 184s ok 193 - Instantiate with format "long" again 184s ok 194 - Format "long" should output correctly with color 184s ok 195 - Instantiate with format "medium" again 184s ok 196 - Format "medium" should output correctly with color 184s ok 197 - Instantiate with format "short" again 184s ok 198 - Format "short" should output correctly with color 184s ok 199 - Instantiate with format "oneline" again 184s ok 200 - Format "oneline" should output correctly with color 184s ok 201 - Should get an error for an invalid color 184s ok 202 - Invalid color error ident should be "format" 184s ok 203 - Invalid color error message should be correct 184s ok 204 - Should get error for no changes 184s ok 205 - no changes error ident should be "plan" 184s ok 206 - no changes exit val should be 1 184s ok 207 - no changes error message should be correct 184s ok 208 - Execute plan 184s ok 209 - The proper args should have been passed to search_events 184s ok 210 - The event should have been paged 184s ok 211 - 'plan with attributes' isa 'App::Sqitch::Command::plan' 184s ok 212 - Execute plan with attributes 184s ok 213 - All params should have been passed to search_events 184s ok 214 - Both events should have been paged without headers 184s ok 215 - Create command with raw format 184s ok 216 - Execute plan with all changes 184s ok 217 - Should have paged all changes 184s ok 218 - 'plan with bad format' isa 'App::Sqitch::Command::plan' 184s ok 219 - Should get an exception for a bad format code 184s ok 220 - bad format code format error ident should be "format" 184s ok 221 - bad format code format error message should be correct 184s ok 222 - Create plan command with unknown target option 184s ok 223 - Should get error for unknown target 184s ok 224 - Unknown target error ident should be "plan" 184s ok 225 - Unknown target changes exit val should be 2 184s ok 226 - Unknown target error message should be correct 184s ok 227 - Should have passed target for parsing 184s ok 228 - Create plan command with target option 184s ok 229 - Execute with engine arg 184s ok 230 - Should have passed engine for parsing 184s ok 231 - Create plan command with target option 184s ok 232 - Execute with multiple targets 184s ok 233 - Should have got warning for two targets 184s ok 234 - no warnings 184s ok 185s t/pragma.t .......... 185s 1..10 185s ok 1 - require App::Sqitch::Plan::Pragma; 185s ok 2 - App::Sqitch::Plan::Pragma->can(...) 185s ok 3 - An object of class 'App::Sqitch::Plan::Pragma' isa 'App::Sqitch::Plan::Pragma' 185s ok 4 - An object of class 'App::Sqitch::Plan::Pragma' isa 'App::Sqitch::Plan::Line' 185s ok 5 - Name should format as "%foo" 185s ok 6 - Value should format as "" 185s ok 7 - should stringify to "%foo" 185s ok 8 - Create pragma with more stuff 185s ok 9 - It should stringify correctly 185s ok 10 - no warnings 185s ok 185s t/rebase.t .......... 185s ok 1 - require App::Sqitch::Command::rebase; 185s ok 2 - The class (or class-like) 'App::Sqitch::Command::rebase' isa 'App::Sqitch::Command' 185s ok 3 - App::Sqitch::Command::rebase->can(...) 185s ok 4 - App::Sqitch::Command::rebase does RevertDeployCommand 185s ok 5 - App::Sqitch::Command::rebase does ConnectingCommand 185s ok 6 - App::Sqitch::Command::rebase does ContextCommand 185s ok 7 - Options should be correct 185s ok 8 - Should parse options 185s ok 9 - Options should not conflict with core options 185s ok 10 - Load a sqitch sqitch object 185s ok 11 - Should have empty default configuration with no config or opts 185s ok 12 - Should have set option 185s ok 13 - Should have mode, deploy_variables, verify, no_prompt, log_only, & lock_timeout 185s ok 14 - Should have set_revert option and no_prompt false 185s ok 15 - set_deploy and set_revert should overrid set 185s ok 16 - set_deploy and set_revert should merge with set 185s ok 17 - set_revert should merge with set_deploy 185s ok 18 - Should have deploy configuration 185s ok 19 - Should have merged variables 185s ok 20 - Should have no warnings 185s ok 21 - Should have no_prompt true 185s ok 22 - Should have false no_prompt, verify, and true prompt_accept from rebase config 185s ok 23 - Should have true no_prompt, verify, and false prompt_accept from rebase from deploy 185s ok 24 - Should have no_prompt, prompt_accept false and mode all again 185s ok 25 - Should have no_prompt false and prompt_accept true for revert config 185s ok 26 - Should have no_prompt true with -y 185s ok 27 - revert.strict should die 185s ok 28 - Strict err ident should be "rebase" 185s ok 29 - Should have corect strict error message 185s ok 30 - rebase.strict should die 185s ok 31 - Strict err ident should be "rebase" 185s ok 32 - Should have corect strict error message 185s ok 33 - App::Sqitch::X 185s ok 34 - 'new status with target' isa 'App::Sqitch::Command::rebase' 185s ok 35 - Should have target "foo" 185s ok 36 - An object of class 'App::Sqitch::Command::rebase' isa 'App::Sqitch::Command::rebase' 185s ok 37 - Should have undef target 185s ok 38 - onto_change should be undef 185s ok 39 - upto_change should be undef 185s ok 40 - modified should be false 185s ok 41 - Should collect no variables for deploy 185s ok 42 - Should collect no variables for revert 185s ok 43 - Should collect core deploy vars for deploy 185s ok 44 - Should collect core revert vars for revert 185s ok 45 - Should override core vars with deploy vars for deploy 185s ok 46 - Should override core vars with deploy vars for revert 185s ok 47 - Deploy vars should be unaffected by revert vars 185s ok 48 - Should override deploy vars with revert vars for revert 185s ok 49 - Should override deploy vars with engine vars for deploy 185s ok 50 - Should override rebase vars with engine vars for revert 185s ok 51 - Should override engine vars with deploy vars for deploy 185s ok 52 - Should override engine vars with target vars for revert 185s ok 53 - Should override target vars with --set vars for deploy 185s ok 54 - Should override target vars with --set variables for revert 185s ok 55 - Should override --set vars with --set-deploy variables for deploy 185s ok 56 - Should not override --set vars with --set-deploy variables for revert 185s ok 57 - Should not override --set vars with --set-revert variables for deploy 185s ok 58 - Should override --set vars with --set-revert variables for revert 185s ok 59 - Execute to "@alpha" 185s ok 60 - undef, and "all" should be passed to the engine deploy 185s ok 61 - No vars should have been passed through to the engine 185s ok 62 - "@alpha" should be passed to the engine revert 185s ok 63 - Engine should no be log only 185s ok 64 - The lock timeout should be set to the default 185s ok 65 - Should have no warnings 185s ok 66 - Execute with target 185s ok 67 - undef, and "all" should be passed to the engine deploy 185s ok 68 - undef should be passed to the engine revert 185s ok 69 - No vars should have been passed through to the engine 185s ok 70 - Engine should no be log only 185s ok 71 - The lock timeout should be set to the default 185s ok 72 - The target name should be as passed 185s ok 73 - Should have no warnings 185s ok 74 - Execute with onto and target 185s ok 75 - undef, and "all" should be passed to the engine deploy 185s ok 76 - "widgets" should be passed to the engine revert 185s ok 77 - No vars should have been passed through to the engine 185s ok 78 - Engine should no be log only 185s ok 79 - The lock timeout should be set to the default 185s ok 80 - The target name should be as passed 185s ok 81 - Should have no warnings 185s ok 82 - Execute with three args 185s ok 83 - "widgets", and "all" should be passed to the engine deploy 185s ok 84 - "roles" should be passed to the engine revert 185s ok 85 - No vars should have been passed through to the engine 185s ok 86 - Engine should no be log only 185s ok 87 - The lock timeout should be set to the default 185s ok 88 - The target name should be as passed 185s ok 89 - Should have no warnings 185s ok 90 - Execute 185s ok 91 - undef and "all" should be passed to the engine deploy 185s ok 92 - undef and = should be passed to the engine revert 185s ok 93 - No vars should have been passed through to the engine 185s ok 94 - Should have no warnings 185s ok 95 - 'Object with to and variables' isa 'App::Sqitch::Command::rebase' 185s ok 96 - Execute again 185s ok 97 - Target name should be from option 185s ok 98 - Engine should be log_only 185s ok 99 - The lock timeout should be set to 30 185s ok 100 - Engine should verify 185s ok 101 - the common ancestor id should be passed to the engine revert 185s ok 102 - 'Object with to and variables' isa 'App::Sqitch::Command::rebase' 185s ok 103 - Execute again 185s ok 104 - Target name should be from option 185s ok 105 - Engine should be log_only 185s ok 106 - The lock timeout should be set to 30 185s ok 107 - Engine should verify 185s ok 108 - "bar", "tag", and 1 should be passed to the engine deploy 185s ok 109 - "foo" should be passed to the engine revert 185s ok 110 - Variables should have been passed to the engine twice 185s ok 111 - The revert vars should have been passed first 185s ok 112 - The deploy vars should have been next 185s ok 113 - Should have no warnings 185s ok 114 - Execute with three args 185s ok 115 - Target name should be from option 185s ok 116 - Engine should be log_only 185s ok 117 - The lock timeout should be set to 30 185s ok 118 - Engine should verify 185s ok 119 - "bar", "tag", and 1 should be passed to the engine deploy 185s ok 120 - "foo" should be passed to the engine revert 185s ok 121 - Variables should have been passed to the engine twice 185s ok 122 - The revert vars should have been passed first 185s ok 123 - The deploy vars should have been next 185s ok 124 - Should have two warnings 185s ok 125 - Should get an exception for unknown arg 185s ok 126 - Unknown arg ident should be "rebase" 185s ok 127 - Should get an exception for two unknown arg 185s ok 128 - Should get an exception for unknown args 185s ok 129 - Unknown args ident should be "rebase" 185s ok 130 - Should get an exception for two unknown args 185s ok 131 - Execute once more 185s ok 132 - "bar", "tag", and 1 should be passed to the engine deploy 185s ok 133 - Variables should have been passed to the engine twice 185s ok 134 - The revert vars should have been passed first 185s ok 135 - The deploy vars should have been next 185s ok 136 - Should have emitted info for non-fatal revert exception 185s ok 137 - Should rethrow confirm exception 185s ok 138 - Should rethrow fatal exception 185s ok 139 - Should rethrow unknown exception 185s 1..139 185s ok 186s t/revert.t .......... 186s ok 1 - require App::Sqitch::Command::revert; 186s ok 2 - The class (or class-like) 'App::Sqitch::Command::revert' isa 'App::Sqitch::Command' 186s ok 3 - App::Sqitch::Command::revert->can(...) 186s ok 4 - App::Sqitch::Command::revert does ContextCommand 186s ok 5 - App::Sqitch::Command::revert does ConnectingCommand 186s ok 6 - Options should be correct 186s ok 7 - Should parse options 186s ok 8 - Options should not conflict with core options 186s ok 9 - Should have empty default configuration with no config or opts 186s ok 10 - Should have set option 186s ok 11 - Should have no_prompt false, prompt_accept true 186s ok 12 - Should have no_prompt true, prompt_accept false 186s ok 13 - Should have no_prompt false again 186s ok 14 - Should have no_prompt false for false config 186s ok 15 - Should have no_prompt true with -y 186s ok 16 - 'new revert with target' isa 'App::Sqitch::Command::revert' 186s ok 17 - Should have target "foo" 186s ok 18 - to_change should be undef 186s ok 19 - modified should be false 186s ok 20 - An object of class 'App::Sqitch::Command::revert' isa 'App::Sqitch::Command::revert' 186s ok 21 - Should have undef default target 186s ok 22 - to_change should be undef 186s ok 23 - modified should be false 186s ok 24 - Should collect no variables 186s ok 25 - Should collect core vars 186s ok 26 - Should override core vars with deploy vars 186s ok 27 - Should override deploy vars with revert vars 186s ok 28 - Should override revert vars with engine vars 186s ok 29 - Should override engine vars with target vars 186s ok 30 - Should override target vars with --set variables 186s ok 31 - Execute to "@alpha" 186s ok 32 - Engine should not be log_only 186s ok 33 - The engine should have the default lock_timeout 186s ok 34 - "@alpha" should be passed to the engine 186s ok 35 - Should have no warnings 186s ok 36 - Execute 186s ok 37 - undef should be passed to the engine 186s ok 38 - No vars should have been passed through to the engine 186s ok 39 - Should still have no warnings 186s ok 40 - Execute to target 186s ok 41 - Engine should not be log_only 186s ok 42 - undef" should be passed to the engine 186s ok 43 - Target name should be as passed 186s ok 44 - Should have no warnings 186s ok 45 - Execute with change and target 186s ok 46 - Engine should not be log_only 186s ok 47 - "widgets" should be passed to the engine 186s ok 48 - Target name should be as passed 186s ok 49 - Should have no warnings 186s ok 50 - Execute with target and change 186s ok 51 - Engine should not be log_only 186s ok 52 - "widgets" should be passed to the engine 186s ok 53 - Target name should be as passed 186s ok 54 - Should have no warnings 186s ok 55 - 'Object with to and variables' isa 'App::Sqitch::Command::revert' 186s ok 56 - Execute again 186s ok 57 - Engine should be log_only 186s ok 58 - The lock timeout should be set to 30 186s ok 59 - "foo" and 1 should be passed to the engine 186s ok 60 - Vars should have been passed through to the engine 186s ok 61 - Target name should be from option 186s ok 62 - Should have no warnings 186s ok 63 - Execute with options and args 186s ok 64 - Engine should be log_only 186s ok 65 - The lock timeout should be set to 30 186s ok 66 - "foo" and 1 should be passed to the engine 186s ok 67 - Vars should have been passed through to the engine 186s ok 68 - Target name should be from option 186s ok 69 - Should have two warnings 186s ok 70 - Should get an exception for unknown arg 186s ok 71 - Unknown arg ident should be "revert" 186s ok 72 - Should get an exeption for two unknown arg 186s ok 73 - Should get an exception for unknown args 186s ok 74 - Unknown args ident should be "revert" 186s ok 75 - Should get an exeption for two unknown args 186s ok 76 - 'Object with to and variables' isa 'App::Sqitch::Command::revert' 186s ok 77 - modified should be true 186s ok 78 - Execute again 186s ok 79 - Target name should be from option 186s ok 80 - the common ancestor id should be passed to the engine revert 186s ok 81 - 'new revert with target' isa 'App::Sqitch::Command::revert' 186s ok 82 - In strict mode, cannot revert without a specified change 186s ok 83 - No change in strict mode ident should be "revert:strict" 186s ok 84 - Should have expected message for no changes in strict mode error 186s ok 85 - In strict mode, too many targets is fatal 186s ok 86 - Too many targets ident should be "revert:strict" 186s ok 87 - Should have expected message for too many targets error 186s 1..87 186s ok 187s t/rework.t .......... 187s 1..256 187s ok 1 - Load a sqitch object 187s ok 2 - 'rework command' isa 'App::Sqitch::Command::rework' 187s ok 3 - App::Sqitch::Command::rework->can(...) 187s ok 4 - App::Sqitch::Command::rework does ContextCommand 187s ok 5 - Options should be set up 187s ok 6 - Should parse options 187s ok 7 - Options should not conflict with core options 187s ok 8 - Should have default configuration with no config or opts 187s ok 9 - Should have get requires, conflicts, and note options 187s ok 10 - Grabs nothing from config 187s ok 11 - Load Sqitch project 187s ok 12 - 'rework command' isa 'App::Sqitch::Command::rework' 187s ok 13 - Coerces rework.open_editor from config string boolean 187s ok 14 - Requires should be an arrayref 187s ok 15 - Conflicts should be an arrayref 187s ok 16 - Note should be an arrayref 187s ok 17 - Should get an example for nonexistent change 187s ok 18 - Nonexistent change error ident should be "plan" 187s ok 19 - Fail message should say the step does not exist 187s ok 20 - Create another add with template_directory 187s ok 21 - test-rework/deploy/foo.sql does not exist 187s ok 22 - test-rework/revert/foo.sql does not exist 187s ok 23 - test-rework/verify/foo.sql does not exist 187s ok 24 - Execute with the --change option 187s ok 25 - test-rework/deploy/foo.sql exists 187s ok 26 - test-rework/revert/foo.sql exists 187s ok 27 - test-rework/verify/foo.sql exists 187s ok 28 - Get the "foo" change 187s ok 29 - Should get an example for duplicate change 187s ok 30 - Duplicate change error ident should be "plan" 187s ok 31 - Fail message should say a tag is needed 187s ok 32 - Tag it 187s ok 33 - test-rework/deploy/foo@alpha.sql does not exist 187s ok 34 - test-rework/revert/foo@alpha.sql does not exist 187s ok 35 - test-rework/verify/foo@alpha.sql does not exist 187s ok 36 - Rework "foo" 187s ok 37 - test-rework/deploy/foo.sql exists 187s ok 38 - test-rework/revert/foo.sql exists 187s ok 39 - test-rework/verify/foo.sql exists 187s ok 40 - test-rework/deploy/foo@alpha.sql exists 187s ok 41 - test-rework/revert/foo@alpha.sql exists 187s ok 42 - test-rework/verify/foo@alpha.sql exists 187s ok 43 - test-rework/deploy/foo@alpha.sql and test-rework/deploy/foo.sql contents are the same 187s ok 44 - test-rework/verify/foo@alpha.sql and test-rework/verify/foo.sql contents are the same 187s ok 45 - test-rework/revert/foo.sql and test-rework/deploy/foo.sql contents are the same 187s ok 46 - New revert should revert 187s ok 47 - It should have prompted for a note 187s ok 48 - Reload the plan file 187s ok 49 - Get the steps 187s ok 50 - Should have two steps 187s ok 51 - First step should be "foo" 187s ok 52 - Second step should also be "foo" 187s ok 53 - Reworked step should require the previous step 187s ok 54 - And the info message should suggest editing the old files 187s ok 55 - Debug should show file copying 187s ok 56 - Create another add with template_directory 187s ok 57 - test-rework/deploy/bar.sql does not exist 187s ok 58 - test-rework/revert/bar.sql does not exist 187s ok 59 - test-rework/verify/bar.sql does not exist 187s ok 60 - test-rework/deploy/bar.sql exists 187s ok 61 - test-rework/revert/bar.sql does not exist 187s ok 62 - test-rework/verify/bar.sql does not exist 187s ok 63 - Tag it with @beta 187s ok 64 - 'rework command with requirements and conflicts' isa 'App::Sqitch::Command::rework' 187s ok 65 - test-rework/deploy/bar@beta.sql does not exist 187s ok 66 - test-rework/revert/bar@beta.sql does not exist 187s ok 67 - test-rework/verify/bar@beta.sql does not exist 187s ok 68 - Rework "bar" 187s ok 69 - test-rework/deploy/bar.sql exists 187s ok 70 - test-rework/revert/bar.sql does not exist 187s ok 71 - test-rework/verify/bar.sql does not exist 187s ok 72 - test-rework/deploy/bar@beta.sql exists 187s ok 73 - test-rework/revert/bar@beta.sql does not exist 187s ok 74 - test-rework/verify/bar@beta.sql does not exist 187s ok 75 - It should have prompted for a note 187s ok 76 - Reload the plan file again 187s ok 77 - Get the steps 187s ok 78 - Should have four steps 187s ok 79 - First step should be "foo" 187s ok 80 - Second step should also be "foo" 187s ok 81 - First step should be "bar" 187s ok 82 - Second step should also be "bar" 187s ok 83 - Requires should have been passed to reworked change 187s ok 84 - Conflicts should have been passed to reworked change 187s ok 85 - Note should have been passed as comment 187s ok 86 - And the info message should show only the one file to modify 187s ok 87 - Should have debug oputput for missing files 187s ok 88 - Create another add with open_editor 187s ok 89 - Tag it 187s ok 90 - test-rework/deploy/bar@gamma.sql does not exist 187s ok 91 - test-rework/revert/bar@gamma.sql does not exist 187s ok 92 - test-rework/verify/bar@gamma.sql does not exist 187s ok 93 - Rework "bar" 187s ok 94 - test-rework/deploy/bar.sql exists 187s ok 95 - test-rework/deploy/bar@gamma.sql exists 187s ok 96 - test-rework/revert/bar@gamma.sql does not exist 187s ok 97 - test-rework/verify/bar@gamma.sql does not exist 187s ok 98 - It should have prompted to edit sql files 187s ok 99 - And the info message should suggest editing the old files 187s ok 100 - deploy/gadgets.sql exists 187s ok 101 - revert/gadgets.sql exists 187s ok 102 - verify/gadgets.sql exists 187s ok 103 - _reworked does not exist 187s ok 104 - _reworked/deploy/gadgets@foo.sql does not exist 187s ok 105 - _reworked/revert/gadgets@foo.sql does not exist 187s ok 106 - _reworked/verify/gadgets@foo.sql does not exist 187s ok 107 - Create another rework with custom reworked_dir config 187s ok 108 - Rework change "gadgets" 187s ok 109 - Get gadgets@HEAD from the plan 187s ok 110 - Get gadgets@foo from the plan 187s ok 111 - The two gadgets should be different changes 187s ok 112 - _reworked exists 187s ok 113 - deploy/gadgets.sql exists 187s ok 114 - revert/gadgets.sql exists 187s ok 115 - verify/gadgets.sql exists 187s ok 116 - _reworked/deploy/gadgets@foo.sql exists 187s ok 117 - _reworked/revert/gadgets@foo.sql exists 187s ok 118 - _reworked/verify/gadgets@foo.sql exists 187s ok 119 - Should have listed scripts in the note prompt 187s ok 120 - And the info message should suggest editing the old files 187s ok 121 - Debug should show directory creation and file copying 187s ok 122 - Create another rework with custom multiplan config 187s ok 123 - Should have three targets 187s ok 124 - Rework change "widgets" in all plans 187s ok 125 - Get widgets@HEAD from the pg plan 187s ok 126 - Get widgets@foo from the pg plan 187s ok 127 - The two pg widgets should be different changes 187s ok 128 - Get widgets@HEAD from the sqlite plan 187s ok 129 - Get widgets@foo from the sqlite plan 187s ok 130 - The two sqlite widgets should be different changes 187s ok 131 - Get widgets@HEAD from the mysql plan 187s ok 132 - Get widgets@foo from the mysql plan 187s ok 133 - The two mysql widgets should be different changes 187s ok 134 - mysql/deploy/widgets.sql exists 187s ok 135 - mysql/revert/widgets.sql exists 187s ok 136 - mysql/verify/widgets.sql exists 187s ok 137 - mysql/deploy/widgets@foo.sql exists 187s ok 138 - mysql/revert/widgets@foo.sql exists 187s ok 139 - mysql/verify/widgets@foo.sql exists 187s ok 140 - mysql/deploy/widgets.sql and mysql/deploy/widgets@foo.sql contents are the same 187s ok 141 - mysql/verify/widgets.sql and mysql/verify/widgets@foo.sql contents are the same 187s ok 142 - mysql/revert/widgets.sql and mysql/deploy/widgets@foo.sql contents are the same 187s ok 143 - pg/deploy/widgets.sql exists 187s ok 144 - pg/revert/widgets.sql exists 187s ok 145 - pg/verify/widgets.sql exists 187s ok 146 - pg/deploy/widgets@foo.sql exists 187s ok 147 - pg/revert/widgets@foo.sql exists 187s ok 148 - pg/verify/widgets@foo.sql exists 187s ok 149 - pg/deploy/widgets.sql and pg/deploy/widgets@foo.sql contents are the same 187s ok 150 - pg/verify/widgets.sql and pg/verify/widgets@foo.sql contents are the same 187s ok 151 - pg/revert/widgets.sql and pg/deploy/widgets@foo.sql contents are the same 187s ok 152 - sqlite/deploy/widgets.sql exists 187s ok 153 - sqlite/revert/widgets.sql exists 187s ok 154 - sqlite/verify/widgets.sql exists 187s ok 155 - sqlite/deploy/widgets@foo.sql exists 187s ok 156 - sqlite/revert/widgets@foo.sql exists 187s ok 157 - sqlite/verify/widgets@foo.sql exists 187s ok 158 - sqlite/deploy/widgets.sql and sqlite/deploy/widgets@foo.sql contents are the same 187s ok 159 - sqlite/verify/widgets.sql and sqlite/verify/widgets@foo.sql contents are the same 187s ok 160 - sqlite/revert/widgets.sql and sqlite/deploy/widgets@foo.sql contents are the same 187s ok 161 - Should have listed the files in the note prompt 187s ok 162 - And the info message should show the two files to modify 187s ok 163 - Should have debug oputput for all copied files 187s ok 164 - Should get an error for --all and a target arg 187s ok 165 - Mixed arguments error ident should be "rework" 187s ok 166 - Mixed arguments error message should be correct 187s ok 167 - Create yet another rework with custom multiplan config 187s ok 168 - Rework change "gadgets" in the sqlite plan 187s ok 169 - Should still have three targets 187s ok 170 - Get gadgets@HEAD from the pg plan 187s ok 171 - Get gadgets@foo from the pg plan 187s ok 172 - The two pg gadgets should be the same change 187s ok 173 - Get gadgets@HEAD from the mysql plan 187s ok 174 - Get gadgets@foo from the mysql plan 187s ok 175 - The two mysql gadgets should be the same change 187s ok 176 - Get gadgets@HEAD from the sqlite plan 187s ok 177 - Get gadgets@foo from the sqlite plan 187s ok 178 - The two sqlite gadgets should be different changes 187s ok 179 - pg/deploy/gadgets.sql exists 187s ok 180 - pg/revert/gadgets.sql exists 187s ok 181 - pg/verify/gadgets.sql exists 187s ok 182 - mysql/deploy/gadgets.sql exists 187s ok 183 - mysql/revert/gadgets.sql exists 187s ok 184 - mysql/verify/gadgets.sql exists 187s ok 185 - sqlite/deploy/gadgets.sql exists 187s ok 186 - sqlite/revert/gadgets.sql exists 187s ok 187 - sqlite/verify/gadgets.sql exists 187s ok 188 - sqlite/deploy/gadgets@foo.sql exists 187s ok 189 - sqlite/revert/gadgets@foo.sql exists 187s ok 190 - sqlite/verify/gadgets@foo.sql exists 187s ok 191 - sqlite/deploy/gadgets.sql and sqlite/deploy/gadgets@foo.sql contents are the same 187s ok 192 - sqlite/verify/gadgets.sql and sqlite/verify/gadgets@foo.sql contents are the same 187s ok 193 - sqlite/revert/gadgets.sql and sqlite/deploy/gadgets@foo.sql contents are the same 187s ok 194 - Should have listed SQLite scripts in the note prompt 187s ok 195 - Create another rework with custom multiplan config 187s ok 196 - Should have two targets 187s ok 197 - Targets should use the same plan file 187s ok 198 - Rework change "widgets" in all plans 187s ok 199 - Get widgets@HEAD from the plan 187s ok 200 - Get widgets@foo from the plan 187s ok 201 - The two widgets should be different changes 187s ok 202 - pg/deploy/widgets.sql exists 187s ok 203 - pg/revert/widgets.sql exists 187s ok 204 - pg/verify/widgets.sql exists 187s ok 205 - pg/deploy/widgets@foo.sql exists 187s ok 206 - pg/revert/widgets@foo.sql exists 187s ok 207 - pg/verify/widgets@foo.sql exists 187s ok 208 - pg/deploy/widgets.sql and pg/deploy/widgets@foo.sql contents are the same 187s ok 209 - pg/verify/widgets.sql and pg/verify/widgets@foo.sql contents are the same 187s ok 210 - pg/revert/widgets.sql and pg/deploy/widgets@foo.sql contents are the same 187s ok 211 - sqlite/deploy/widgets.sql exists 187s ok 212 - sqlite/revert/widgets.sql exists 187s ok 213 - sqlite/verify/widgets.sql exists 187s ok 214 - sqlite/deploy/widgets@foo.sql exists 187s ok 215 - sqlite/revert/widgets@foo.sql exists 187s ok 216 - sqlite/verify/widgets@foo.sql exists 187s ok 217 - sqlite/deploy/widgets.sql and sqlite/deploy/widgets@foo.sql contents are the same 187s ok 218 - sqlite/verify/widgets.sql and sqlite/verify/widgets@foo.sql contents are the same 187s ok 219 - sqlite/revert/widgets.sql and sqlite/deploy/widgets@foo.sql contents are the same 187s ok 220 - Should have listed all the files to edit in the note prompt 187s ok 221 - And the info message should show the two files to modify 187s ok 222 - Should have debug oputput for all copied files 187s ok 223 - Create another rework with custom multiplan config 187s ok 224 - Should have two targets 187s ok 225 - Rework change "widgets" in all plans 187s ok 226 - Get widgets@HEAD from the pg plan 187s ok 227 - Get widgets@foo from the pg plan 187s ok 228 - The two pg widgets should be different changes 187s ok 229 - Get widgets@HEAD from the sqlite plan 187s ok 230 - Get widgets@bar from the sqlite plan 187s ok 231 - The two sqlite widgets should be different changes 187s ok 232 - Should have listed all the files to edit in the note prompt 187s ok 233 - And the info message should show the two files to modify 187s ok 234 - Should have debug oputput for all copied files 187s ok 235 - Create another rework with custom multiplan config 187s ok 236 - Should have two targets 187s ok 237 - Rework change "widgets" in all plans 187s ok 238 - Get widgets@HEAD from the pg plan 187s ok 239 - Get widgets@foo from the pg plan 187s ok 240 - The two pg widgets should be different changes 187s ok 241 - Get widgets@HEAD from the sqlite plan 187s ok 242 - Get widgets@foo from the sqlite plan 187s ok 243 - The two sqlite widgets should be different changes 187s ok 244 - deploy/widgets.sql exists 187s ok 245 - revert/widgets.sql exists 187s ok 246 - verify/widgets.sql exists 187s ok 247 - deploy/widgets@foo.sql exists 187s ok 248 - revert/widgets@foo.sql exists 187s ok 249 - verify/widgets@foo.sql exists 187s ok 250 - deploy/widgets.sql and deploy/widgets@foo.sql contents are the same 187s ok 251 - verify/widgets.sql and verify/widgets@foo.sql contents are the same 187s ok 252 - revert/widgets.sql and deploy/widgets@foo.sql contents are the same 187s ok 253 - Should have listed the files to edit in the note prompt 187s ok 254 - And the info message should show the two files to modify 187s ok 255 - Should have debug oputput for all copied files 187s ok 256 - no warnings 187s ok 187s t/show.t ............ 187s ok 1 - require App::Sqitch::Command::show; 187s ok 2 - The class (or class-like) 'App::Sqitch::Command::show' isa 'App::Sqitch::Command' 187s ok 3 - App::Sqitch::Command::show->can(...) 187s ok 4 - App::Sqitch::Command::show does ContextCommand 187s ok 5 - Options should be correct 187s ok 6 - Should parse options 187s ok 7 - Options should not conflict with core options 187s ok 8 - An object of class 'App::Sqitch::Command::show' isa 'App::Sqitch::Command::show' 187s ok 9 - exists_only should be false by default 187s ok 10 - Construct with exists_only 187s ok 11 - exists_only should be set 187s ok 12 - Should get empty hash for no config or options 187s ok 13 - Should get exists_only => 1 for exist in options 187s ok 14 - Get a change 187s ok 15 - Find change by id 187s ok 16 - The change info should have been emitted 187s ok 17 - Find change by name 187s ok 18 - The change info should have been emitted again 187s ok 19 - Should get an error for an unknown change 187s ok 20 - Unknown change error ident should be "show" 187s ok 21 - Should get proper error for unknown change 187s ok 22 - Should return false for uknown change and exists_only 187s ok 23 - Nothing should have been emitted 187s ok 24 - Find change by tag id 187s ok 25 - The change info should have been emitted 187s ok 26 - Find change by tag 187s ok 27 - The change info should have been emitted 187s ok 28 - Run exists with ID 187s ok 29 - There should be no output 187s ok 30 - Find tag by id 187s ok 31 - The tag info should have been emitted 187s ok 32 - Find tag by id with exists_only 187s ok 33 - Nothing should have been emitted 187s ok 34 - Find tag by name 187s ok 35 - The tag info should have been emitted 187s ok 36 - Find tag by formatted name 187s ok 37 - The tag info should have been emitted 187s ok 38 - Should get error for non-existent tag 187s ok 39 - Unknown tag error ident should be "show" 187s ok 40 - Should get proper error for unknown tag 187s ok 41 - Should return false for non-existent tag and exists_only 187s ok 42 - Nothing should have been emitted 187s ok 43 - Should get error for non-existent tag ID 187s ok 44 - Unknown tag ID error ident should be "show" 187s ok 45 - Should get proper error for unknown tag ID 187s ok 46 - Show a deploy file 187s ok 47 - The deploy file should have been emitted 187s ok 48 - Show a deploy file with exists_only 187s ok 49 - Nothing should have been emitted 187s ok 50 - Show a revert file 187s ok 51 - The revert file should have been emitted 187s ok 52 - Should get error for nonexistent varify file 187s ok 53 - Nonexistent file error ident should be "show" 187s ok 54 - Should get proper error for nonexistent file 187s ok 55 - Should return false for nonexistent file 187s ok 56 - Nothing should have been emitted 187s ok 57 - Should get error for uknown type 187s ok 58 - Unknown type error ident should be "show" 187s ok 59 - Should get proper error for unknown type 187s ok 60 - Get a change 187s ok 61 - An object of class 'App::Sqitch::Command::show' isa 'App::Sqitch::Command::show' 187s ok 62 - Target should be set 187s ok 63 - Find change by id 187s ok 64 - The change info should have been emitted 187s ok 65 - Should get usage for missing params 187s ok 66 - Nothing should have been passed to usage 187s 1..66 187s ok 188s t/snowflake.t ....... 188s ok 1 - require App::Sqitch::Engine::snowflake; 188s ok 2 - config_vars should return three vars 188s ok 3 - An object of class 'App::Sqitch::Engine::snowflake' isa 'App::Sqitch::Engine::snowflake' 188s ok 4 - Username should be sysuser 188s ok 5 - Password should be undef 188s ok 6 - Key should be "snowflake" 188s ok 7 - Name should be "Snowflake" 188s ok 8 - Driver should be DBD::ODBC 188s ok 9 - Default client should be snowsql 188s ok 10 - client should default to snowsql 188s ok 11 - Registry default should be "sqitch" 188s ok 12 - DB URI should be filled in 188s ok 13 - Destination should be URI string 188s ok 14 - Registry destination should be the same as destination 188s ok 15 - Should build URI from environment 188s ok 16 - Should read username from environment 188s ok 17 - Should read password from environment 188s ok 18 - Should read account from host 188s ok 19 - Should read warehouse from environment 188s ok 20 - Should build URI host from account and region environment vars 188s ok 21 - Should read account and region from environment 188s ok 22 - Target password should be from SQITCH_PASSWORD 188s ok 23 - Should prefer password from SQITCH_PASSWORD 188s ok 24 - An object of class 'App::Sqitch::Engine::snowflake' isa 'App::Sqitch::Engine::snowflake' 188s ok 25 - Destination should be target name 188s ok 26 - Registry destination should be the same as destination 188s ok 27 - snowsql command should be std opts-only 188s ok 28 - An object of class 'App::Sqitch::Engine::snowflake' isa 'App::Sqitch::Engine::snowflake' 188s ok 29 - Set some variables 188s ok 30 - Variables should be passed to snowsql via --set 188s ok 31 - Target name should not read $SNOWSQL_DATABASE 188s ok 32 - Registry target should be the same as destination 188s ok 33 - Target name should not read $SNOWSQL_USER 188s ok 34 - Registry target should be the same as destination 188s ok 35 - Target name should not fall back on sysuser 188s ok 36 - Registry target should be the same as destination 188s ok 37 - Target name should be the default 188s ok 38 - Registry target should be the same as destination 188s ok 39 - Should have read config from file 188s ok 40 - Should have read config from file 188s ok 41 - Should have read config from file 188s ok 42 - Should read username fron snowsql config file 188s ok 43 - Should read password fron snowsql config file 188s ok 44 - Should read accountname fron snowsql config file 188s ok 45 - Should read dbname from snowsql config file 188s ok 46 - Should read warehousename fron snowsql config file 188s ok 47 - Should read rolename fron snowsql config file 188s ok 48 - Should derive host name from config file accounte name 188s ok 49 - Create another snowflake 188s ok 50 - Should extract account from URI 188s ok 51 - Should extract username from URI 188s ok 52 - Should extract password from URI 188s ok 53 - Should extract warehouse from URI 188s ok 54 - Should extract role from URI 188s ok 55 - registry should be as configured 188s ok 56 - URI should be as configured with full domain name 188s ok 57 - Destination should omit password 188s ok 58 - client should be as configured 188s ok 59 - snowsql command should be configured from URI config 188s ok 60 - Should have _listagg_format 188s ok 61 - Should have _ts_default 188s ok 62 - Should have _regex_op 188s ok 63 - Should have _simple_from 188s ok 64 - Should have _limit_default 188s ok 65 - Should have no table error 188s ok 66 - Should have no column error 188s ok 67 - Should now have table error 188s ok 68 - Still should have no column error 188s ok 69 - Should again have no table error 188s ok 70 - Should now have no column error 188s ok 71 - Unique constraints not supported by Snowflake 188s ok 72 - Should get limit and offset 188s ok 73 - Should get limit and offset when offset only 188s ok 74 - Should get only limit with 0 offset 188s ok 75 - Should get only limit with noa offset 188s ok 76 - Should get no limit or offset for 0s 188s ok 77 - Should get no limit or offset for no args 188s ok 78 - Should use regexp_substr IS NOT NULL for regex expr 188s ok 79 - initialized() should rethrow unexpected DB error 188s ok 80 - _cid should rethrow unexpected DB error 188s ok 81 - App::Sqitch::Engine::snowflake->can(...) 188s ok 82 - Create a snowflake with sqitch with options 188s ok 83 - SNOWSQL_PWD should be "s3cr3t" 188s ok 84 - Call _run 188s ok 85 - Command should be passed to capture() 188s ok 86 - SNOWSQL_PWD should be "s3cr3t" 188s ok 87 - Call _spool 188s ok 88 - Command should be passed to spool() 188s ok 89 - SNOWSQL_PWD should be "s3cr3t" 188s ok 90 - Call _capture 188s ok 91 - Command should be passed to capture() 188s ok 92 - SNOWSQL_PWD should be "s3cr3t" 188s ok 93 - Call _probe 188s ok 94 - Command should be passed to probe() 188s ok 95 - Create a snowflake with sqitch with no pw 188s ok 96 - SNOWSQL_PWD should not exist 188s ok 97 - Call _run again 188s ok 98 - Command should be passed to capture() again 188s ok 99 - SNOWSQL_PWD should not exist 188s ok 100 - Call _spool again 188s ok 101 - Command should be passed to spool() again 188s ok 102 - SNOWSQL_PWD should not exist 188s ok 103 - Call _capture again 188s ok 104 - Command should be passed to capture() again 188s ok 105 - SNOWSQL_PWD should not exist 188s ok 106 - Call _probe again 188s ok 107 - Command should be passed to probe() again 188s ok 108 - SNOWSQL_PWD should not exist 188s ok 109 - Run foo/bar.sql 188s ok 110 - File should be passed to capture() 188s ok 111 - SNOWSQL_PWD should not exist 188s ok 112 - Spool a "file handle" 188s ok 113 - Handle should be passed to spool() 188s ok 114 - SNOWSQL_PWD should not exist 188s ok 115 - Verify foo/bar.sql again 188s ok 116 - Verifile file should be passed to run() for high verbosity 188s ok 117 - App::Sqitch::Engine::snowflake->can('_ts2char_format') 188s ok 118 - _ts2char_format should work 188s ok 119 - App::Sqitch::Engine::snowflake->can('_dt') 188s ok 120 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 188s ok 121 - DateTime year should be set 188s ok 122 - DateTime month should be set 188s ok 123 - DateTime day should be set 188s ok 124 - DateTime hour should be set 188s ok 125 - DateTime minute should be set 188s ok 126 - DateTime second should be set 188s ok 127 - DateTime TZ should be set 188s ok 128 - Construct a datetime object 188s ok 129 - Should get ISO output from _char2ts 188s ok 130 - App::Sqitch::Engine::snowflake->can(...) 188s # Subtest: live database 188s 1..0 # SKIP Unable to live-test Snowflake engine: DBD::ODBC 1.59 required to manage Snowflake at t/snowflake.t line 560. 188s ok 131 # skip Unable to live-test Snowflake engine: DBD::ODBC 1.59 required to manage Snowflake at t/snowflake.t line 560. 188s # 188s 1..131 188s ok 191s t/sqlite.t .......... 191s ok 1 - require App::Sqitch::Engine::sqlite; 191s ok 2 - config_vars should return three vars 191s ok 3 - An object of class 'App::Sqitch::Engine::sqlite' isa 'App::Sqitch::Engine::sqlite' 191s ok 4 - Key should be "sqlite" 191s ok 5 - Name should be "SQLite" 191s ok 6 - client should default to sqlite3 191s ok 7 - dbname should be filled in 191s ok 8 - Target attribute should be specified target 191s ok 9 - Destination should be uri stringified 191s ok 10 - Registry target should be registry_uri stringified 191s ok 11 - sqlite3 command should have the proper opts 191s ok 12 - Create another sqlite 191s ok 13 - client should fall back on config 191s ok 14 - dbname should fall back on config 191s ok 15 - Target should be as specified 191s ok 16 - Destination should be configured target name 191s ok 17 - registry_uri should fall back on config 191s ok 18 - Registry target should be configured registry_uri stringified 191s ok 19 - Create another sqlite 191s ok 20 - dbname should fall back on config with no extension 191s ok 21 - Target should be as specified 191s ok 22 - Destination should be configured target name 191s ok 23 - registry_uri should fall back on config wth extension 191s ok 24 - Registry target should be configured registry_uri stringified 191s ok 25 - Create another sqlite 191s ok 26 - dbname should fall back on config with no extension 191s ok 27 - Target should be as specified 191s ok 28 - Destination should be configured target name 191s ok 29 - registry_uri should fall back on config wth extension 191s ok 30 - Registry target should be configured registry_uri without password 191s ok 31 - Create another sqlite 191s ok 32 - dbname should fall back on config with no extension 191s ok 33 - Target should be as specified 191s ok 34 - Destination should be configured target name 191s ok 35 - registry_uri should fall back on config wth extension 191s ok 36 - Registry target should be configured registry_uri stringified 191s ok 37 - Instantiate with a temporary database file 191s ok 38 - App::Sqitch::Engine::sqlite->can('_read') 191s ok 39 - _read() should work 191s ok 40 - _read() should SQL-quote the file name 191s ok 41 - _read() should SQL-quote quotes, too 191s ok 42 - App::Sqitch::Engine::sqlite->can(...) 191s ok 43 - Call _run 191s ok 44 - Command should be passed to run() 191s ok 45 - Call _spool 191s ok 46 - Command should be passed to spool() 191s ok 47 - Call _capture 191s ok 48 - Command should be passed to capture() 191s ok 49 - Run foo/bar.sql 191s ok 50 - File should be passed to run() 191s ok 51 - Spool a "file handle" 191s ok 52 - Handle should be passed to spool() 191s ok 53 - Verify foo/bar.sql 191s ok 54 - Verify file should be passed to capture() 191s ok 55 - Verify foo/bar.sql again 191s ok 56 - Verifile file should be passed to run() for high verbosity 191s ok 57 - App::Sqitch::Engine::sqlite->can('_ts2char_format') 191s ok 58 - _ts2char should work 191s ok 59 - App::Sqitch::Engine::sqlite->can('_dt') 191s ok 60 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 191s ok 61 - DateTime year should be set 191s ok 62 - DateTime month should be set 191s ok 63 - DateTime day should be set 191s ok 64 - DateTime hour should be set 191s ok 65 - DateTime minute should be set 191s ok 66 - DateTime second should be set 191s ok 67 - DateTime TZ should be set 191s ok 68 - Create command for v3.3.9 191s ok 69 - Should be okay with sqlite v3.3.9 191s ok 70 - Create command for v3.3.10 191s ok 71 - Should be okay with sqlite v3.3.10 191s ok 72 - Create command for v3.3.200 191s ok 73 - Should be okay with sqlite v3.3.200 191s ok 74 - Create command for v3.4.0 191s ok 75 - Should be okay with sqlite v3.4.0 191s ok 76 - Create command for v3.4.8 191s ok 77 - Should be okay with sqlite v3.4.8 191s ok 78 - Create command for v3.7.11 191s ok 79 - Should be okay with sqlite v3.7.11 191s ok 80 - Create command for v3.8.12 191s ok 81 - Should be okay with sqlite v3.8.12 191s ok 82 - Create command for v3.10.0 191s ok 83 - Should be okay with sqlite v3.10.0 191s ok 84 - Create command for v4.1.30 191s ok 85 - Should be okay with sqlite v4.1.30 191s ok 86 - Create command for v3.3.8 191s ok 87 - Should not be okay with v3.3.8 191s ok 88 - Should get ident "sqlite" for v3.3.8 191s ok 89 - Should get proper error message for v3.3.8 191s ok 90 - Create command for v3.3.0 191s ok 91 - Should not be okay with v3.3.0 191s ok 92 - Should get ident "sqlite" for v3.3.0 191s ok 93 - Should get proper error message for v3.3.0 191s ok 94 - Create command for v3.2.8 191s ok 95 - Should not be okay with v3.2.8 191s ok 96 - Should get ident "sqlite" for v3.2.8 191s ok 97 - Should get proper error message for v3.2.8 191s ok 98 - Create command for v3.0.1 191s ok 99 - Should not be okay with v3.0.1 191s ok 100 - Should get ident "sqlite" for v3.0.1 191s ok 101 - Should get proper error message for v3.0.1 191s ok 102 - Create command for v3.0.0 191s ok 103 - Should not be okay with v3.0.0 191s ok 104 - Should get ident "sqlite" for v3.0.0 191s ok 105 - Should get proper error message for v3.0.0 191s ok 106 - Create command for v2.8.1 191s ok 107 - Should not be okay with v2.8.1 191s ok 108 - Should get ident "sqlite" for v2.8.1 191s ok 109 - Should get proper error message for v2.8.1 191s ok 110 - Create command for v2.20.0 191s ok 111 - Should not be okay with v2.20.0 191s ok 112 - Should get ident "sqlite" for v2.20.0 191s ok 113 - Should get proper error message for v2.20.0 191s ok 114 - Create command for v1.0.0 191s ok 115 - Should not be okay with v1.0.0 191s ok 116 - Should get ident "sqlite" for v1.0.0 191s ok 117 - Should get proper error message for v1.0.0 191s ok 118 - Create command for v3.7.12 with newline 191s ok 119 - Should be okay with sqlite version v3.7.12 with newline 191s ok 120 - Should have no table error 191s ok 121 - Should have no column error 191s ok 122 - Should now have table error 191s ok 123 - Still should have no column error 191s ok 124 - Should again have no table error 191s ok 125 - Should now have no column error 191s ok 126 - App::Sqitch::Engine::sqlite->can(...) 191s # Subtest: live database 191s # Detected SQLite CLI 3.46.1 191s # Connected to SQLite 3.46.1 191s ok 1 - Engine instantiated 191s ok 2 - Database should not yet be initialized 191s ok 3 - Initialize the database 191s ok 4 - Database should now be initialized 191s ok 5 - Registry should not need upgrading 191s ok 6 - The release should be registered 191s ok 7 - Registry should need upgrading 191s ok 8 - Upgrade the registry 191s ok 9 - Should have info output for upgrade 191s ok 10 - Registry should no longer need upgrading 191s ok 11 - The release should be registered again 191s ok 12 - Create engine with alternate params 191s ok 13 - No init, earliest change 191s ok 14 - No init, no latest change 191s ok 15 - Database should no longer seem initialized 191s ok 16 - Initialize the database again 191s ok 17 - Database should be initialized again 191s ok 18 - Registry should not need upgrading 191s ok 19 - Still no earlist change 191s ok 20 - Still no latest changes 191s ok 21 - Should die on existing schema 191s ok 22 - Mode should be "engine" 191s ok 23 - And it should show the proper schema in the error message 191s ok 24 - Database error should be converted to Sqitch exception 191s ok 25 - Ident should be SQL error state 191s ok 26 - The message should be from the engine 191s ok 27 - The DBI error should be in preview_exception 191s ok 28 - Current state should be undef 191s ok 29 - Should have no current changes 191s ok 30 - Should have no current tags 191s ok 31 - Should have no events 191s ok 32 - The foreign_keys pragma should be enabled 191s ok 33 - App::Sqitch::Engine::sqlite->can('register_project') 191s ok 34 - App::Sqitch::Engine::sqlite->can('registered_projects') 191s ok 35 - Should have no registered projects 191s ok 36 - Register the project 191s ok 37 - Should have one registered project, "engine" 191s ok 38 - The project should be registered 191s ok 39 - Register the project again 191s ok 40 - Should still have one registered project, "engine" 191s ok 41 - The project should still be registered only once 191s ok 42 - Register a second project 191s ok 43 - Should have both registered projects 191s ok 44 - Both projects should now be registered 191s ok 45 - Should get an error for defined URI vs NULL registered URI 191s ok 46 - Defined URI error ident should be "engine" 191s ok 47 - Defined URI error message should be correct 191s ok 48 - Should get an error for different URIs 191s ok 49 - Different URI error ident should be "engine" 191s ok 50 - Different URI error message should be correct 191s ok 51 - Should get an error for NULL plan URI 191s ok 52 - NULL plan URI error ident should be "engine" 191s ok 53 - NULL plan uri error message should be correct 191s ok 54 - Register "groovy" again 191s ok 55 - Should still have two registered projects 191s ok 56 - Both projects should still be registered 191s ok 57 - Should get error for an project with the URI 191s ok 58 - Existing URI error ident should be "engine" 191s ok 59 - Exising URI error message should be correct 191s ok 60 - Should have "users" change 191s ok 61 - The change should not be deployed 191s ok 62 - The change should not be deployed 191s ok 63 - Deploy "users" change 191s ok 64 - The change should now be deployed 191s ok 65 - The change should now be deployed 191s ok 66 - Should get users ID for earliest change ID 191s ok 67 - Should get no change offset 1 from earliest 191s ok 68 - Should get users ID for latest change ID 191s ok 69 - Should get no change offset 1 from latest 191s ok 70 - A record should have been inserted into the changes table 191s ok 71 - Should have no dependencies 191s ok 72 - Change should not be required 191s ok 73 - A record should have been inserted into the events table 191s ok 74 - The tag should have been logged 191s ok 75 - name_for_change_id() should return the change name with tag 191s ok 76 - Get the current state 191s ok 77 - 'committed_at value' isa 'App::Sqitch::DateTime' 191s ok 78 - committed_at TZ should be UTC 191s ok 79 - The rest of the state should look right 191s ok 80 - Should have one current change 191s ok 81 - Should have no current chnages for nonexistent project 191s ok 82 - Should have one current tags 191s ok 83 - Should have no current tags for nonexistent project 191s ok 84 - Should have one event 191s ok 85 - Log new tags for "users" change 191s ok 86 - The tag should be the same 191s ok 87 - Should now have no tags 191s ok 88 - Log new tags for "users" change again 191s ok 89 - The tag should be back 191s ok 90 - Revert "users" change 191s ok 91 - The change should no longer be deployed 191s ok 92 - The change should no longer be deployed 191s ok 93 - Should get undef for earliest change 191s ok 94 - Should get undef for latest change 191s ok 95 - The record should have been deleted from the changes table 191s ok 96 - And the tag record should have been removed 191s ok 97 - Should still have no dependencies 191s ok 98 - Change should not be required 191s ok 99 - The revert event should have been logged 191s ok 100 - name_for_change_id() should no longer return the change name 191s ok 101 - Current state should be undef again 191s ok 102 - Should again have no current changes 191s ok 103 - Should again have no current tags 191s ok 104 - Should have two events 191s ok 105 - Fail "users" change 191s ok 106 - The change still should not be deployed 191s ok 107 - The change still should not be deployed 191s ok 108 - Should still get undef for earliest change 191s ok 109 - Should still get undef for latest change 191s ok 110 - Still should have not changes table record 191s ok 111 - Should still have no tag records 191s ok 112 - Should still have no dependencies 191s ok 113 - Change should not be required 191s ok 114 - The fail event should have been logged 191s ok 115 - Current state should still be undef 191s ok 116 - Should still have no current changes 191s ok 117 - Should still have no current tags 191s ok 118 - Should have 3 events 191s ok 119 - Deploy the change again 191s ok 120 - The tag again should be deployed 191s ok 121 - Should again get users ID for earliest change ID 191s ok 122 - Should still get no change offset 1 from earliest 191s ok 123 - Should again get users ID for latest change ID 191s ok 124 - Should still get no change offset 1 from latest 191s ok 125 - Get the second change 191s ok 126 - Only the first change should be deployed 191s ok 127 - Set resolved ID in required depend 191s ok 128 - Deploy second change 191s ok 129 - Should still get users ID for earliest change ID 191s ok 130 - Should get "widgets" offset 1 from earliest 191s ok 131 - Should get no change offset 2 from earliest 191s ok 132 - Should get "widgets" ID for latest change ID 191s ok 133 - Should get "user" offset 1 from earliest 191s ok 134 - Should get no change offset 2 from latest 191s ok 135 - Should have both changes and requires/conflcits deployed 191s ok 136 - Both changes should be deployed 191s ok 137 - Should still have no dependencies for "users" 191s ok 138 - Should have both dependencies for "widgets" 191s ok 139 - Change "users" should be required by "widgets" 191s ok 140 - Change "widgets" should not be required 191s ok 141 - The new change deploy should have been logged 191s ok 142 - name_for_change_id() should return name with symbolic tag @HEAD 191s ok 143 - Get the current state again 191s ok 144 - 'committed_at value' isa 'App::Sqitch::DateTime' 191s ok 145 - committed_at TZ should be UTC 191s ok 146 - The state should reference new change 191s ok 147 - Should have two current changes in reverse chronological order 191s ok 148 - Should again have one current tags 191s ok 149 - Should have 5 events 191s ok 150 - App::Sqitch::Engine::sqlite->can(...) 191s ok 151 - Should have two deployed changes 191s ok 152 - Should find one deployed since the first one 191s ok 153 - Should find none deployed since the second one 191s ok 154 - Should load change 1 191s ok 155 - Should load change 2 191s ok 156 - load() should return undef for uknown change ID 191s ok 157 - Should load change with no offset 191s ok 158 - Should load change with offset 0 191s ok 159 - Should get change ID with no offset 191s ok 160 - Should get change ID with offset 0 191s ok 161 - Should find change with offset 1 191s ok 162 - Should find change with offset -1 191s ok 163 - Should find undef change with offset 2 191s ok 164 - Should find change ID with offset 1 191s ok 165 - Should find change ID with offset -1 191s ok 166 - Should find undef change ID with offset 2 191s ok 167 - Revert "widgets" 191s ok 168 - Should now have one deployed change ID 191s ok 169 - Should find none deployed since that one 191s ok 170 - Log another change 191s ok 171 - Should have both deployed change IDs 191s ok 172 - Should find only the second after the first 191s ok 173 - Should find none after the second 191s ok 174 - Get the current state once more 191s ok 175 - 'committed_at value' isa 'App::Sqitch::DateTime' 191s ok 176 - committed_at TZ should be UTC 191s ok 177 - The new state should reference latest change 191s ok 178 - Should still have two current changes in reverse chronological order 191s ok 179 - Should still have one current tags 191s ok 180 - Should have 7 events 191s ok 181 - Get the "fred" change 191s ok 182 - Deploy "fred" 191s ok 183 - Get the "barney" change 191s ok 184 - Deploy "barney" 191s ok 185 - Earliest change should sill be "users" 191s ok 186 - Should still get "widgets" offset 1 from earliest 191s ok 187 - Should get "fred" offset 2 from earliest 191s ok 188 - Should get "barney" offset 3 from earliest 191s ok 189 - Latest change should be "barney" 191s ok 190 - Should get "fred" offset 1 from latest 191s ok 191 - Should get "widgets" offset 2 from latest 191s ok 192 - Should get "users" offset 3 from latest 191s ok 193 - Barney should be in the current state 191s ok 194 - Should have all four current changes in reverse chron order 191s ok 195 - Should now have three current tags in reverse chron order 191s ok 196 - Should have 9 events 191s ok 197 - The limit param to search_events should work 191s ok 198 - The offset param to search_events should work 191s ok 199 - The limit and offset params to search_events should work together 191s ok 200 - Should work to set direction "DESC" in search_events 191s ok 201 - Should work to set direction "desc" in search_events 191s ok 202 - Should work to set direction "descending" in search_events 191s ok 203 - Should work to set direction "ASC" in search_events 191s ok 204 - Should work to set direction "asc" in search_events 191s ok 205 - Should work to set direction "ascending" in search_events 191s ok 206 - Should catch exception for invalid search direction 191s ok 207 - Search direction error ident should be "DEV" 191s ok 208 - Search direction error message should be correct 191s ok 209 - The committer param to search_events should work 191s ok 210 - The committer param to search_events should work as a regex 191s ok 211 - Committer regex should fail to match with "Simpsonized$" 191s ok 212 - The change param to search_events should work with "users" 191s ok 213 - The change param to search_events should work with "widgets" 191s ok 214 - The change param to search_events should work with "fred" 191s ok 215 - The change param to search_events should return nothing for "fre$" 191s ok 216 - The change param to search_events should return match "(er|re)" 191s ok 217 - The event param should work with "deploy" 191s ok 218 - The event param should work with "revert" 191s ok 219 - The event param should work with "fail" 191s ok 220 - The event param should work with "revert" and "fail" 191s ok 221 - The event param should work with "deploy", "revert", and "fail" 191s ok 222 - The event param should return nothing for "foo" 191s ok 223 - Create external plan 191s ok 224 - Create external change 191s ok 225 - Log the external change 191s ok 226 - The project param to search_events should work 191s ok 227 - The project param to search_events should work with external project 191s ok 228 - The project param to search_events should match across projects 191s ok 229 - Project regex should fail to match with "nonexistent" 191s ok 230 - deployed_changes should not include external change 191s ok 231 - deployed_changes_since should not include external change 191s ok 232 - Earliest change should sill be "users" 191s ok 233 - Latest change ID should not be from external project 191s ok 234 - Should catch exception for invalid search param 191s ok 235 - Invalid search param error ident should be "DEV" 191s ok 236 - Invalid search param error message should be correct 191s ok 237 - Should catch exception for invalid search params 191s ok 238 - Invalid search params error ident should be "DEV" 191s ok 239 - Invalid search params error message should be correct 191s ok 240 - Get the "groovy" state 191s ok 241 - 'groofy committed_at value' isa 'App::Sqitch::DateTime' 191s ok 242 - groovy committed_at TZ should be UTC 191s ok 243 - The rest of the state should look right 191s ok 244 - Should find id for change_id only 191s ok 245 - Should find id for change only 191s ok 246 - Should find id for change + tag 191s ok 247 - Should find id for change@HEAD 191s ok 248 - Should find id for tag only 191s ok 249 - Should find id for ROOT 191s ok 250 - Should find id for HEAD 191s ok 251 - Should find id for project:ROOT 191s ok 252 - Should find id for project:HEAD 191s ok 253 - Should find nothing for unkonwn id 191s ok 254 - Should find nothing for unkonwn change 191s ok 255 - Should find nothing for unkonwn tag 191s ok 256 - Should find nothing for change + unkonwn tag 191s ok 257 - Should find nothing for change@ROOT 191s ok 258 - Should find nothing for change + different project 191s ok 259 - Should find nothing for tag + different project 191s ok 260 - Create internal id only change 191s ok 261 - Create internal id only dependency 191s ok 262 - Internal id only depencency should not be satisfied 191s ok 263 - Log internal id only change deployment 191s ok 264 - Internal id only depencency should now be satisfied 191s ok 265 - Log internal id only change reversion 191s ok 266 - Internal id only depencency should again be unsatisfied 191s ok 267 - Create external id only change 191s ok 268 - Create external id only dependency 191s ok 269 - External id only depencency should not be satisfied 191s ok 270 - Log external id only change deployment 191s ok 271 - External id only depencency should now be satisfied 191s ok 272 - Log external id only change reversion 191s ok 273 - External id only depencency should again be unsatisfied 191s ok 274 - Create internal change + tag change 191s ok 275 - Add tag internal @epsilon 191s ok 276 - Create internal change + tag dependency 191s ok 277 - Internal change + tag depencency should not be satisfied 191s ok 278 - Log internal change + tag change deployment 191s ok 279 - Internal change + tag depencency should now be satisfied 191s ok 280 - Log internal change + tag change reversion 191s ok 281 - Internal change + tag depencency should again be unsatisfied 191s ok 282 - Create external change + tag change 191s ok 283 - Add tag external @epsilon 191s ok 284 - Create external change + tag dependency 191s ok 285 - External change + tag depencency should not be satisfied 191s ok 286 - Log external change + tag change deployment 191s ok 287 - External change + tag depencency should now be satisfied 191s ok 288 - Log external change + tag change reversion 191s ok 289 - External change + tag depencency should again be unsatisfied 191s ok 290 - Create internal change only change 191s ok 291 - Create internal change only dependency 191s ok 292 - Internal change only depencency should not be satisfied 191s ok 293 - Log internal change only change deployment 191s ok 294 - Internal change only depencency should now be satisfied 191s ok 295 - Log internal change only change reversion 191s ok 296 - Internal change only depencency should again be unsatisfied 191s ok 297 - Create external change only change 191s ok 298 - Create external change only dependency 191s ok 299 - External change only depencency should not be satisfied 191s ok 300 - Log external change only change deployment 191s ok 301 - External change only depencency should now be satisfied 191s ok 302 - Log external change only change reversion 191s ok 303 - External change only depencency should again be unsatisfied 191s ok 304 - Create internal tag only change 191s ok 305 - Add tag internal @sigma 191s ok 306 - Create internal tag only dependency 191s ok 307 - Internal tag only depencency should not be satisfied 191s ok 308 - Log internal tag only change deployment 191s ok 309 - Internal tag only depencency should now be satisfied 191s ok 310 - Log internal tag only change reversion 191s ok 311 - Internal tag only depencency should again be unsatisfied 191s ok 312 - Create external tag only change 191s ok 313 - Add tag external @sigma 191s ok 314 - Create external tag only dependency 191s ok 315 - External tag only depencency should not be satisfied 191s ok 316 - Log external tag only change deployment 191s ok 317 - External tag only depencency should now be satisfied 191s ok 318 - Log external tag only change reversion 191s ok 319 - External tag only depencency should again be unsatisfied 191s ok 320 - Create another external change 191s ok 321 - Add tag external "meta" 191s ok 322 - Log the external change with tag 191s ok 323 - Delete the engine project tags 191s ok 324 - name_for_change_id() should return "widgets@HEAD" for its ID 191s ok 325 - name_for_change_id() should return "outside_in@meta" for its ID 191s ok 326 - Should have only the "engine" changes from current_changes 191s ok 327 - Should get only requestd project changes from current_changes 191s ok 328 - Should no longer have "engine" project tags 191s ok 329 - Should get groovy tags from current_chages() 191s ok 330 - Create change "hypercritial" in current plan 191s ok 331 - Log change "hyper" 191s ok 332 - No changes should require "hypercritical" 191s ok 333 - Change "hypercritical" should require "fred" 191s ok 334 - Change "hypercritical" should require "groovy:crazyman" 191s ok 335 - Create a third external change 191s ok 336 - Log change "elsewise" 191s ok 337 - Change "fred" should be required by changes in two projects 191s ok 338 - Change "groovy:crazyman" should be required by changes in two projects 191s ok 339 - App::Sqitch::Engine::sqlite->can(...) 191s ok 340 - Begin work 191s ok 341 - Should have started a transaction 191s ok 342 - Finish work 191s ok 343 - Should have committed a transaction 191s ok 344 - Begin work again 191s ok 345 - Should have started another transaction 191s ok 346 - Rollback work 191s ok 347 - Should have rolled back a transaction 191s ok 348 - Revert "elsewise" change 191s ok 349 - Revert "hypercritical" change 191s ok 350 - Revert "outside_in" change 191s ok 351 - Revert "crazyman" change 191s ok 352 - Revert "barney" change 191s ok 353 - Revert "fred" change 191s ok 354 - Revert "widgets" change 191s ok 355 - Revert "users" change 191s ok 356 - Deploy "users" change 191s ok 357 - Deploy "widgets" change 191s ok 358 - Deploy "fred" change 191s ok 359 - Deploy "barney" change 191s ok 360 - Deploy "crazyman" change 191s ok 361 - Deploy "outside_in" change 191s ok 362 - Deploy "hypercritical" change 191s ok 363 - Deploy "elsewise" change 191s ok 364 - Rework change "widgets" 191s ok 365 - It should have the same script hash 191s ok 366 - Should die on unchanged rework deploy script 191s ok 367 - Mode should be "engine" 191s ok 368 - And it should report the script is not unique 191s ok 369 - Should re-throw if not a unique erorr 191s ok 370 - Mode should be the error state 191s ok 371 - Should not have the underlying DB error 191s ok 372 - Back up deploy file 191s ok 373 - It should no longer have the same script hash 191s ok 374 - Deploy the reworked change 191s ok 375 - The deploy should not fail 191s ok 376 - Should die on ambiguous change spec 191s ok 377 - Mode should be "engine" 191s ok 378 - And it should report change lookup failure 191s ok 379 - Should have vented output for lookup failure 191s ok 380 - Should get ID for first of ambiguous change spec 191s ok 381 - Should now have first change id 191s ok 382 - change_id_for() should find the tag-qualified change ID 191s ok 383 - change_id_for() should find the reworked change ID @HEAD 191s ok 384 - Tag the plan "theta" 191s ok 385 - Log new tag 191s ok 386 - Rework change "widgets" again 191s ok 387 - Deploy the reworked change 191s ok 388 - Should not die deploying the reworked change 191s ok 389 - Should find id for beta instance of change 191s ok 390 - Should find id for HEAD instance of change 191s ok 391 - Should find id for second instance of change by tag 191s ok 392 - Update script hashes 191s ok 393 - Should have updated script hash for barney 191s ok 394 - Should have updated script hash for users 191s ok 395 - Should have updated script hash for widgets 191s ok 396 - Should have updated script hash for hypercritical 191s ok 397 - Should have updated script hash for widgets 191s ok 398 - Should have updated script hash for fred 191s ok 399 - Should have updated script hash for widgets 191s ok 400 - Change ID and script hash should be 603a1f 191s ok 401 - Change ID and script hash should be a600c3 191s ok 402 - Change ID and script hash should be 9474d7 191s 1..402 191s ok 127 - live database 191s 1..127 191s ok 191s t/status.t .......... 191s 1..124 191s ok 1 - require App::Sqitch::Command::status; 191s ok 2 - Load a sqitch object 191s ok 3 - 'status command' isa 'App::Sqitch::Command::status' 191s ok 4 - App::Sqitch::Command::status->can(...) 191s ok 5 - App::Sqitch::Command::status does ContextCommand 191s ok 6 - App::Sqitch::Command::status does ConnectingCommand 191s ok 7 - Options should be correct 191s ok 8 - Should parse options 191s ok 9 - Options should not conflict with core options 191s ok 10 - Should have error for uninitialized database 191s ok 11 - Uninitialized database error ident should be "status" 191s ok 12 - Uninitialized database error message should be correct 191s ok 13 - 'new status command' isa 'App::Sqitch::Command::status' 191s ok 14 - Should have project "foo" 191s ok 15 - Load a sqitch object with SQLite 191s ok 16 - Create another status command 191s ok 17 - Should get an error for uninitialized db 191s ok 18 - Uninitialized db error ident should be "status" 191s ok 19 - Uninitialized db error message should be correct 191s ok 20 - Should get an error for no registered projects 191s ok 21 - No projects error ident should be "status" 191s ok 22 - No projects error message should be correct 191s ok 23 - Should get an error for too many projects 191s ok 24 - Too many projects error ident should be "status" 191s ok 25 - Too many projects error message should be correct 191s ok 26 - Should find single project 191s ok 27 191s ok 28 - 'another status command' isa 'App::Sqitch::Command::status' 191s ok 29 - Should have plan project 191s ok 30 - Default target should be undef 191s ok 31 - 'new status with target' isa 'App::Sqitch::Command::status' 191s ok 32 - Should have target "foo" 191s ok 33 - Should get empty hash for no config or options 191s ok 34 - Should get error for invalid date format in config 191s ok 35 - Invalid date format error ident should be "datetime" 191s ok 36 - Invalid date format error message should be correct 191s ok 37 - Should get bool values set from config 191s ok 38 - Should get error for invalid date format in optsions 191s ok 39 - Invalid date format error ident should be "status" 191s ok 40 - Invalid date format error message should be correct 191s ok 41 - Emit the state 191s ok 42 - The state should have been emitted 191s ok 43 - Emit the state with a tag 191s ok 44 - The state should have been emitted with a tag 191s ok 45 - Emit the state with multiple tags 191s ok 46 - The state should have been emitted with multiple tags 191s ok 47 - Create status command with an engine 191s ok 48 - Try to emit changes 191s ok 49 - Should have emitted no changes 191s ok 50 - Create change-showing status command 191s ok 51 - Emit changes again 191s ok 52 - Project "foo" should have been passed to current_changes 191s ok 53 - Should have emitted one change 191s ok 54 - Emit changes thrice 191s ok 55 - Project "foo" again should have been passed to current_changes 191s ok 56 - Should have emitted three changes 191s ok 57 - Try to emit tags 191s ok 58 - No tags should have been emitted 191s ok 59 - Create tag-showing status command 191s ok 60 - Try to emit tags again 191s ok 61 - Project "bar" should be passed to current_tags() 191s ok 62 - Should have emitted a header for no tags 191s ok 63 - Emit tags 191s ok 64 - Project "bar" should again be passed to current_tags() 191s ok 65 - Should have emitted one tag 191s ok 66 - Emit tags again 191s ok 67 - Project "bar" should once more be passed to current_tags() 191s ok 68 - Should have emitted all three tags 191s ok 69 - Create status command with actual plan command 191s ok 70 - Emit status 191s ok 71 - Should have a blank comment line 191s ok 72 - Should emit up-to-date output 191s ok 73 - Emit status again 191s ok 74 - Should have a blank comment line 191s ok 75 - Should emit list of undeployed changes 191s ok 76 - Emit status thrice 191s ok 77 - Should have a blank comment line 191s ok 78 - Should emit list of undeployed changes 191s ok 79 - Die on invalid ID 191s ok 80 - Invalid ID error ident should be "status" 191s ok 81 - The invalid ID error message should be correct 191s ok 82 - Should have a blank comment line 191s ok 83 - Should have a message about inability to find the change 191s ok 84 - Recreate status command 191s ok 85 - Execute 191s ok 86 - The state should have been emitted 191s ok 87 - Should emit list of undeployed changes 191s ok 88 - No target name should have been passed to Target 191s ok 89 - Execute with target arg 191s ok 90 - The state should have been emitted 191s ok 91 - Should emit list of undeployed changes 191s ok 92 - Name "db:sqlite:" should have been passed to Target 191s ok 93 - Create status command with a target option 191s ok 94 - Execute with target attribute 191s ok 95 - The state should have been emitted 191s ok 96 - Should emit list of undeployed changes 191s ok 97 - Name "db:sqlite:" should have been passed to Target 191s ok 98 - Execute with target attribute and arg 191s ok 99 - The state should have been emitted 191s ok 100 - Should emit list of undeployed changes 191s ok 101 - Name "db:sqlite:" should have been passed to Target 191s ok 102 - Should have got warning for two targets 191s ok 103 - Create status command with no target option 191s ok 104 - Execute with plan file 191s ok 105 - The state should have been emitted 191s ok 106 - Should emit list of undeployed changes 191s ok 107 - Name "db:sqlite:" should have been passed to Target 191s ok 108 - Should have no warnings 191s ok 109 - Create status command with specified project 191s ok 110 - Execute for specified project 191s ok 111 - The specified project state should have been emitted 191s ok 112 - Should emit unknown status message for specified project 191s ok 113 - Create status command with external project 191s ok 114 - Execute for external project 191s ok 115 - The external project state should have been emitted 191s ok 116 - Should emit unknown status message for external project 191s ok 117 - Die on no state 191s ok 118 - No state error ident should be "status" 191s ok 119 - No state error message should be correct 191s ok 120 - The "On database" comment should have been emitted 191s ok 121 - Should get an error for uninitialized db 191s ok 122 - Uninitialized db error ident should be "status" 191s ok 123 - Uninitialized db error message should be correct 191s ok 124 - no warnings 191s ok 192s t/tag.t ............. 192s 1..22 192s ok 1 - require App::Sqitch::Plan::Tag; 192s ok 2 - App::Sqitch::Plan::Tag->can(...) 192s ok 3 - An object of class 'App::Sqitch::Plan::Tag' isa 'App::Sqitch::Plan::Tag' 192s ok 4 - An object of class 'App::Sqitch::Plan::Tag' isa 'App::Sqitch::Plan::Line' 192s ok 5 - Name should format as "@foo" 192s ok 6 - 'Timestamp' isa 'App::Sqitch::DateTime' 192s ok 7 - Planner name shoudld default to user name 192s ok 8 - Planner email shoudld default to user email 192s ok 9 - Planner name and email should format properly 192s ok 10 - Should as_string to "@foo" + timstamp + planner 192s ok 11 - Tag info should incldue the URI 192s ok 12 - Create tag with more stuff 192s ok 13 - It should as_string correctly 192s ok 14 - Change should be correct 192s ok 15 - Planner name and email should format properly 192s ok 16 - Change should be for previous change 192s ok 17 - Tag info should include the change 192s ok 18 - Tag ID should be correct 192s ok 19 - Create tag with UTF-8 name 192s ok 20 - The name should be decoded text in info 192s ok 21 - Tag ID should be hahsed from encoded UTF-8 192s ok 22 - no warnings 192s ok 192s t/tag_cmd.t ......... 192s 1..86 192s ok 1 - Load a sqitch sqitch object 192s ok 2 - 'tag command' isa 'App::Sqitch::Command::tag' 192s ok 3 - The all attribute should be false by default 192s ok 4 - App::Sqitch::Command::tag->can(...) 192s ok 5 - App::Sqitch::Command::tag does ContextCommand 192s ok 6 - Should have note option 192s ok 7 - Should parse options 192s ok 8 - Options should not conflict with core options 192s ok 9 - Should get empty hash for no config or options 192s ok 10 - Should not have fetched boolean tag.all config 192s ok 11 - Should get populated hash for no all options 192s ok 12 - Should not have fetched boolean tag.all config 192s ok 13 - Add change "foo" 192s ok 14 - 'new tag command' isa 'App::Sqitch::Command::tag' 192s ok 15 - Tag @alpha 192s ok 16 - Reload plan 192s ok 17 - Should have tagged "foo" 192s ok 18 - New tag should have been written 192s ok 19 - New tag should have empty note 192s ok 20 - Should have requested a note 192s ok 21 - The info message should be correct 192s ok 22 - Execute with no arg 192s ok 23 - The one tag should have been listed 192s ok 24 - Should have requested a note 192s ok 25 - Add tag @beta 192s ok 26 - Execute with no arg again 192s ok 27 - Both tags should have been listed 192s ok 28 - Should have requested a note 192s ok 29 - 'tag command with note' isa 'App::Sqitch::Command::tag' 192s ok 30 - Tag @gamma 192s ok 31 - Gamma tag should be on change "foo" 192s ok 32 - Gamma tag should have note 192s ok 33 - Reload plan 192s ok 34 - Gamma tag should have been written 192s ok 35 - Written tag should have note 192s ok 36 - Should have requested a note 192s ok 37 - The gamma note should be correct 192s ok 38 - 'tag command with note' isa 'App::Sqitch::Command::tag' 192s ok 39 - Add change "bar" 192s ok 40 - Add change "baz" 192s ok 41 - Tag change "bar" with @delta 192s ok 42 - Reload plan 192s ok 43 - Should have tagged "bar" 192s ok 44 - Reload plan 192s ok 45 - New tag should have been written 192s ok 46 - New tag should have the proper note 192s ok 47 - Should have requested a note 192s ok 48 - The info message should be correct 192s ok 49 - 'tag command with change name' isa 'App::Sqitch::Command::tag' 192s ok 50 - Tag change "bar" with @zeta 192s ok 51 - Should have tagged "bar" with @zeta 192s ok 52 - Reload plan 192s ok 53 - Tag @zeta should have been written 192s ok 54 - Tag @zeta should have the proper note 192s ok 55 - Should have requested a note 192s ok 56 - The zeta info message should be correct 192s ok 57 - Load another sqitch sqitch object 192s ok 58 - 'another tag command' isa 'App::Sqitch::Command::tag' 192s ok 59 - Tag with @whacko 192s ok 60 - Should have tagged "baz" with @whacko 192s ok 61 - The whacko info message should be correct 192s ok 62 - Should get an error for --all and a target arg 192s ok 63 - Mixed arguments error ident should be "tag" 192s ok 64 - Mixed arguments error message should be correct 192s ok 65 - Load another sqitch sqitch object 192s ok 66 - 'yet another tag command' isa 'App::Sqitch::Command::tag' 192s ok 67 - Tag with @dubdub 192s ok 68 - Should have two targets 192s ok 69 - Should have tagged pg plan change "pg_change" with @dubdub 192s ok 70 - Should have tagged sqlite plan change "sqlite_change" with @dubdub 192s ok 71 - The dubdub info message should show both plans tagged 192s ok 72 - Tag sqlite plan with @shoot 192s ok 73 - Should still have two targets 192s ok 74 - Should not have tagged pg plan change "sqlite_change" with @shoot 192s ok 75 - Should have tagged sqlite plan change "sqlite_change" with @shoot 192s ok 76 - The shoot info message should the sqlite plan getting tagged 192s ok 77 - 'yet another tag command' isa 'App::Sqitch::Command::tag' 192s ok 78 - Tag with @huwah 192s ok 79 - Should still have two targets 192s ok 80 - Should have tagged pg plan change "pg_change" with @huwah 192s ok 81 - Should not have tagged sqlite plan change "sqlite_change" with @huwah 192s ok 82 - The huwah info message should the pg plan getting tagged 192s ok 83 - Should get an error for conflict with target name 192s ok 84 - Conflicting target error ident should be "tag" 192s ok 85 - Conflicting target error message should be correct 192s ok 86 - no warnings 192s ok 193s t/target.t .......... 193s ok 1 - use App::Sqitch::Target; 193s ok 2 - Load a sqitch sqitch object 193s ok 3 - An object of class 'App::Sqitch::Target' isa 'App::Sqitch::Target' 193s ok 4 - App::Sqitch::Target->can(...) 193s ok 5 - Name should be "db:sqlite:" 193s ok 6 - Target should be alias for name 193s ok 7 - URI should be "db:sqlite:" 193s ok 8 - Sqitch should be as passed 193s ok 9 - Engine key should be "sqlite" 193s ok 10 - 'Engine' isa 'App::Sqitch::Engine::sqlite' 193s ok 11 - Should have default registry 193s ok 12 - Should have default client 193s ok 13 - Should have default top_dir 193s ok 14 - Should have default deploy_dir 193s ok 15 - Should have default revert_dir 193s ok 16 - Should have default verify_dir 193s ok 17 - Should have default reworked_dir 193s ok 18 - Should have default reworked_deploy_dir 193s ok 19 - Should have default reworked_revert_dir 193s ok 20 - Should have default reworked_verify_dir 193s ok 21 - Should have default extension 193s ok 22 - Should have default plan file 193s ok 23 - 'Should get plan' isa 'App::Sqitch::Plan' 193s ok 24 - Plan file should be copied from Target 193s ok 25 - DSN should be from URI 193s ok 26 - Username should be from URI 193s ok 27 - Password should be from URI 193s ok 28 - Variables should be empty 193s ok 29 - An object of class 'App::Sqitch::Target' isa 'App::Sqitch::Target' 193s ok 30 - Username should be from environment variable 193s ok 31 - Password should be from environment variable 193s ok 32 - Should get error for missing params 193s ok 33 - 'Target with name and URI' isa 'App::Sqitch::Target' 193s ok 34 - Name should be "foo" 193s ok 35 - Target should be alias for name 193s ok 36 - URI should be set as passed 193s ok 37 - Sqitch should be as passed 193s ok 38 - Engine key should be "pg" 193s ok 39 - 'Engine' isa 'App::Sqitch::Engine::pg' 193s ok 40 - DSN should be from URI 193s ok 41 - Username should be from URI 193s ok 42 - Password should be from environment 193s ok 43 - Variables should be set 193s ok 44 - 'Target with URI' isa 'App::Sqitch::Target' 193s ok 45 - Name should be URI without password 193s ok 46 - Target should be alias for name 193s ok 47 - Engine key should be "pg" 193s ok 48 - 'Engine' isa 'App::Sqitch::Engine::pg' 193s ok 49 - DSN should be from URI 193s ok 50 - Username should be from URI 193s ok 51 - Password should be from URI 193s ok 52 - 'Target from environment' isa 'App::Sqitch::Target' 193s ok 53 - Name should be set 193s ok 54 - URI should be set 193s ok 55 - Engine key should be "pg" 193s ok 56 - 'Engine' isa 'App::Sqitch::Engine::pg' 193s ok 57 - 'Default target' isa 'App::Sqitch::Target' 193s ok 58 - Name should be "db:sqlite:" 193s ok 59 - URI should be "db:sqlite:" 193s ok 60 - Should have tried to get engine target 193s ok 61 - 'Default target' isa 'App::Sqitch::Target' 193s ok 62 - Name should be "db:mysql:" 193s ok 63 - URI should be "db:mysql" 193s ok 64 - Should have tried to get core.target, core.engine and then the target 193s ok 65 - 'Target with URI in name' isa 'App::Sqitch::Target' 193s ok 66 - Name should be "db:pg:" 193s ok 67 - URI should be "db:pg" 193s ok 68 - Should have fetched no config 193s ok 69 - Should have error for no engine in URI 193s ok 70 - Should have target ident 193s ok 71 - Should have message about no engine-less URI 193s ok 72 - Should have error for no engine or target 193s ok 73 - Should have target ident 193s ok 74 - Should have message about no configuration 193s ok 75 - Should again have error for no engine or target 193s ok 76 - Should have target ident again 193s ok 77 - Should have message about no specified engine 193s ok 78 - 'Engineless target' isa 'App::Sqitch::Target' 193s ok 79 - Name should be "db:" 193s ok 80 - URI should be "db:" 193s ok 81 - Should not have tried to get engine target 193s ok 82 - Sqitch should be as passed 193s ok 83 - Engine key should be undef 193s ok 84 - Should get exception for no engine 193s ok 85 - Should have engine ident 193s ok 86 - Should have message about no engine 193s ok 87 - Should have default top_dir 193s ok 88 - Should have default deploy_dir 193s ok 89 - Should have default revert_dir 193s ok 90 - Should have default verify_dir 193s ok 91 - Should have default reworked_dir 193s ok 92 - Should have default reworked_deploy_dir 193s ok 93 - Should have default reworked_revert_dir 193s ok 94 - Should have default reworked_verify_dir 193s ok 95 - Should have default extension 193s ok 96 - Should have default plan file 193s ok 97 - 'Should get plan' isa 'App::Sqitch::Plan' 193s ok 98 - Plan file should be copied from Target 193s ok 99 - DSN should be empty 193s ok 100 - Username should be undef 193s ok 101 - Password should be undef 193s ok 102 - 'Engine URI target' isa 'App::Sqitch::Target' 193s ok 103 - Name should be "db:pg://a@foo/scat" 193s ok 104 - URI should be "db:pg://a:b@foo/scat" 193s ok 105 - Nothing should have been fetched from config 193s ok 106 - 'Engine URI core.target' isa 'App::Sqitch::Target' 193s ok 107 - Name should be "db:pg://s@ack/shi" 193s ok 108 - URI should be "db:pg://s:b@ack/shi" 193s ok 109 - Should have fetched core.target from config 193s ok 110 - 'Engine name core.target' isa 'App::Sqitch::Target' 193s ok 111 - Name should be "shout" 193s ok 112 - URI should be "db:pg:w:e@we/bar" 193s ok 113 - Should have fetched target.shout.uri from config 193s ok 114 - Should have exception for unknown named target 193s ok 115 - Unknown target error ident should be "target" 193s ok 116 - Unknown target error message should be correct 193s ok 117 - Should have requested target URI from config 193s ok 118 - Should have requested target.foo section 193s ok 119 - Should have exception for URL-less named target 193s ok 120 - URL-less target error ident should be "target" 193s ok 121 - URL-less target error message should be correct 193s ok 122 - Should have requested target URI from config 193s ok 123 - Should have requested target.foo section 193s ok 124 - 'Named target' isa 'App::Sqitch::Target' 193s ok 125 - Name should be "foo" 193s ok 126 - URI should be "db:pg:foo" 193s ok 127 - Should have requested target URI from config 193s ok 128 - Should not have requested deprecated pg section 193s ok 129 - 'Engine named target' isa 'App::Sqitch::Target' 193s ok 130 - Name should be "foo" 193s ok 131 - URI should be "db:sqlite:foo" 193s ok 132 - Should have requested engine target and target URI from config 193s ok 133 - Should have requested no section 193s ok 134 - 'Environment-named target' isa 'App::Sqitch::Target' 193s ok 135 - Name should be "bar" 193s ok 136 - URI should be "db:sqlite:bar" 193s ok 137 - Should have requested target URI from config 193s ok 138 - Should have requested no sections 193s ok 139 - 'URI-munged target' isa 'App::Sqitch::Target' 193s ok 140 - Should have requested no section 193s ok 141 - Name should be passwordless stringified URI 193s ok 142 - URI should be tweaked by URI params 193s ok 143 - 'Foo target' isa 'App::Sqitch::Target' 193s ok 144 - Should have requested target URI 193s ok 145 - Should have fetched no section 193s ok 146 - Name should be as passed 193s ok 147 - URI should be tweaked by URI params 193s ok 148 - 'URI target' isa 'App::Sqitch::Target' 193s ok 149 - Should have requested no config 193s ok 150 - Should have fetched no section 193s ok 151 - Name should tweaked by URI params 193s ok 152 - URI should be tweaked by URI params 193s ok 153 - Registry should be "myreg" 193s ok 154 - Client should be "pgsql" 193s ok 155 - Plan file should be "my.plan" 193s ok 156 - 'Plan file' isa 'Path::Class::File' 193s ok 157 - 'Plan' isa 'App::Sqitch::Plan' 193s ok 158 - Plan should use target plan file 193s ok 159 - Top dir should be "top" 193s ok 160 - 'Top dir' isa 'Path::Class::Dir' 193s ok 161 - Deploy dir should be "dep" 193s ok 162 - 'Deploy dir' isa 'Path::Class::Dir' 193s ok 163 - Revert dir should be "rev" 193s ok 164 - 'Revert dir' isa 'Path::Class::Dir' 193s ok 165 - Verify dir should be "ver" 193s ok 166 - 'Verify dir' isa 'Path::Class::Dir' 193s ok 167 - Reworked dir should be "wrk" 193s ok 168 - 'Reworked dir' isa 'Path::Class::Dir' 193s ok 169 - Reworked deploy dir should be "rdep" 193s ok 170 - 'Reworked deploy dir' isa 'Path::Class::Dir' 193s ok 171 - Reworked revert dir should be "rrev" 193s ok 172 - 'Reworked revert dir' isa 'Path::Class::Dir' 193s ok 173 - Reworked verify dir should be "rver" 193s ok 174 - 'Reworked verify dir' isa 'Path::Class::Dir' 193s ok 175 - Extension should be "ddl" 193s ok 176 - Should have no variables 193s ok 177 - Registry should be "yoreg" 193s ok 178 - Client should be "mycli" 193s ok 179 - Plan file should be "pg.plan" 193s ok 180 - 'Plan file' isa 'Path::Class::File' 193s ok 181 - 'Plan' isa 'App::Sqitch::Plan' 193s ok 182 - Plan should use target plan file 193s ok 183 - Top dir should be "pg" 193s ok 184 - 'Top dir' isa 'Path::Class::Dir' 193s ok 185 - Deploy dir should be "pgdep" 193s ok 186 - 'Deploy dir' isa 'Path::Class::Dir' 193s ok 187 - Revert dir should be "pgrev" 193s ok 188 - 'Revert dir' isa 'Path::Class::Dir' 193s ok 189 - Verify dir should be "pgver" 193s ok 190 - 'Verify dir' isa 'Path::Class::Dir' 193s ok 191 - Reworked dir should be "pg/r" 193s ok 192 - 'Reworked dir' isa 'Path::Class::Dir' 193s ok 193 - Reworked deploy dir should be "pgrdep" 193s ok 194 - 'Reworked deploy dir' isa 'Path::Class::Dir' 193s ok 195 - Reworked revert dir should be "pgrrev" 193s ok 196 - 'Reworked revert dir' isa 'Path::Class::Dir' 193s ok 197 - Reworked verify dir should be "pgrver" 193s ok 198 - 'Reworked verify dir' isa 'Path::Class::Dir' 193s ok 199 - Extension should be "pgddl" 193s ok 200 - Variables should be read from engine.variables 193s ok 201 - Registry should be "fooreg" 193s ok 202 - Client should be "foocli" 193s ok 203 - Plan file should be "foo.plan" 193s ok 204 - 'Plan file' isa 'Path::Class::File' 193s ok 205 - 'Plan' isa 'App::Sqitch::Plan' 193s ok 206 - Plan should use target plan file 193s ok 207 - Top dir should be "foo" 193s ok 208 - 'Top dir' isa 'Path::Class::Dir' 193s ok 209 - Deploy dir should be "foodep" 193s ok 210 - 'Deploy dir' isa 'Path::Class::Dir' 193s ok 211 - Revert dir should be "foorev" 193s ok 212 - 'Revert dir' isa 'Path::Class::Dir' 193s ok 213 - Verify dir should be "foover" 193s ok 214 - 'Verify dir' isa 'Path::Class::Dir' 193s ok 215 - Reworked dir should be "foo/r" 193s ok 216 - 'Reworked dir' isa 'Path::Class::Dir' 193s ok 217 - Reworked deploy dir should be "foodepr" 193s ok 218 - 'Reworked deploy dir' isa 'Path::Class::Dir' 193s ok 219 - Reworked revert dir should be "foorevr" 193s ok 220 - 'Reworked revert dir' isa 'Path::Class::Dir' 193s ok 221 - Reworked verify dir should be "fooverr" 193s ok 222 - 'Reworked verify dir' isa 'Path::Class::Dir' 193s ok 223 - Extension should be "fooddl" 193s ok 224 - Variables should be read from engine., and target.variables 193s ok 225 - Load all targets 193s ok 226 - Should have one target 193s ok 227 - It should be the generic core engine target 193s ok 228 - Load all targets with core target config 193s ok 229 - Should again have one target 193s ok 230 - It should be the named target 193s ok 231 - It should have no variables 193s ok 232 - Load all targets with core engine and target config 193s ok 233 - Should still have one target 193s ok 234 - It should again be the named target 193s ok 235 - It should have no variables 193s ok 236 - Load all user conf targets 193s ok 237 - Should have four user targets 193s ok 238 - Should have all the engine targets 193s ok 239 - MySQL target should have engine variables 193s ok 240 - Load all target conf targets 193s ok 241 - Should have three targets 193s ok 242 - Core engine should be default target 193s ok 243 - Should have the core target plus the named targets 193s ok 244 - Load all local conf targets 193s ok 245 - Should have two local targets 193s ok 246 - Core engine should be lead to default target 193s ok 247 - Should have the core target plus the named targets 193s ok 248 - Load all engine conf targets 193s ok 249 - Should have three engine conf targets 193s ok 250 - Should have the engine and target targets 193s ok 251 - Overload all engine conf targets 193s ok 252 - Should again have three engine conf targets 193s ok 253 - Should have set dbname on all target URIs 193s ok 254 - Should have set the registry on all targets. 193s 1..254 193s ok 194s t/target_cmd.t ...... 194s 1..243 194s ok 1 - Load a sqitch sqitch object 194s ok 2 - 'Target command' isa 'App::Sqitch::Command::target' 194s ok 3 - 'Target command' isa 'App::Sqitch::Command' 194s ok 4 - App::Sqitch::Command::target->can(...) 194s ok 5 - App::Sqitch::Command::target does TargetConfigCommand 194s ok 6 - Options should be correct 194s ok 7 - Should parse options 194s ok 8 - Options should not conflict with core options 194s ok 9 - Default properties should be empty 194s ok 10 - configure() should ignore config file 194s ok 11 - Get full config 194s ok 12 - Should have properties 194s ok 13 - 'plan_file file attribute' isa 'Path::Class::File' 194s ok 14 - 'top_dir directory attribute' isa 'Path::Class::Dir' 194s ok 15 - 'reworked_dir directory attribute' isa 'Path::Class::Dir' 194s ok 16 - 'deploy_dir directory attribute' isa 'Path::Class::Dir' 194s ok 17 - 'reworked_deploy_dir directory attribute' isa 'Path::Class::Dir' 194s ok 18 - 'revert_dir directory attribute' isa 'Path::Class::Dir' 194s ok 19 - 'reworked_revert_dir directory attribute' isa 'Path::Class::Dir' 194s ok 20 - 'verify_dir directory attribute' isa 'Path::Class::Dir' 194s ok 21 - 'reworked_verify_dir directory attribute' isa 'Path::Class::Dir' 194s ok 22 - Should fail on invalid directory name 194s ok 23 - Invalid directory ident should be "target" 194s ok 24 - The invalid directory messsage should be correct 194s ok 25 - Should fail on invalid directory names 194s ok 26 - Invalid directories ident should be "target" 194s ok 27 - The invalid properties messsage should be correct 194s ok 28 - Run list() 194s ok 29 - The list of targets should have been output 194s ok 30 - 'Verbose engine' isa 'App::Sqitch::Command::target' 194s ok 31 - Run verbose list() 194s ok 32 - The list of targets and their URIs should have been output 194s ok 33 - No name arg to add() should yield usage 194s ok 34 - No args should be passed to usage 194s ok 35 - No URI arg to add() should yield usage 194s ok 36 - No args should be passed to usage 194s ok 37 - Should get error for existing target 194s ok 38 - Existing target error ident should be "target" 194s ok 39 - Existing target error message should be correct 194s ok 40 - dir deploy does not exist 194s ok 41 - dir revert does not exist 194s ok 42 - dir verify does not exist 194s ok 43 - Add target "test" 194s ok 44 - dir deploy exists 194s ok 45 - dir revert exists 194s ok 46 - dir verify exists 194s ok 47 - Target "test" URI should have been set 194s ok 48 - Target "test" should have no client set 194s ok 49 - Target "test" should have no registry set 194s ok 50 - Target "test" should have no top_dir set 194s ok 51 - Target "test" should have no plan_file set 194s ok 52 - Target "test" should have no deploy_dir set 194s ok 53 - Target "test" should have no revert_dir set 194s ok 54 - Target "test" should have no verify_dir set 194s ok 55 - Target "test" should have no extension set 194s ok 56 - Target "test" should have no variables set 194s ok 57 - 'Target with registry' isa 'App::Sqitch::Command::target' 194s ok 58 - Add target "withreg" 194s ok 59 - Target "withreg" URI should have been set 194s ok 60 - Target "withreg" registry should have been set 194s ok 61 - Target "test" should have no client set 194s ok 62 - Target "test" should have no top_dir set 194s ok 63 - Target "test" should have no plan_file set 194s ok 64 - Target "test" should have no deploy_dir set 194s ok 65 - Target "test" should have no revert_dir set 194s ok 66 - Target "test" should have no verify_dir set 194s ok 67 - Target "test" should have no extension set 194s ok 68 - Target "withreg" should have no variables set 194s ok 69 - 'Target with client' isa 'App::Sqitch::Command::target' 194s ok 70 - Add target "withcli" 194s ok 71 - Target "withcli" URI should have been set 194s ok 72 - Target "withcli" should have client set 194s ok 73 - Target "withcli" should have no registry set 194s ok 74 - Target "withcli" should have no top_dir set 194s ok 75 - Target "withcli" should have no plan_file set 194s ok 76 - Target "withcli" should have no deploy_dir set 194s ok 77 - Target "withcli" should have no revert_dir set 194s ok 78 - Target "withcli" should have no verify_dir set 194s ok 79 - Target "withcli" should have no extension set 194s ok 80 - Target "withcli" should have no variables set 194s ok 81 - 'Target with client and registry' isa 'App::Sqitch::Command::target' 194s ok 82 - Add target "withboth" 194s ok 83 - Target "withboth" URI should have been set 194s ok 84 - Target "withboth" registry should have been set 194s ok 85 - Target "withboth" should have client set 194s ok 86 - Target "withboth" should have no top_dir set 194s ok 87 - Target "withboth" should have no plan_file set 194s ok 88 - Target "withboth" should have no deploy_dir set 194s ok 89 - Target "withboth" should have no revert_dir set 194s ok 90 - Target "withboth" should have no verify_dir set 194s ok 91 - Target "withboth" should have no extension set 194s ok 92 - Target "withboth" should have variables set 194s ok 93 - 'Target with all properties' isa 'App::Sqitch::Command::target' 194s ok 94 - my.plan does not exist 194s ok 95 - dir top/deploy does not exist 194s ok 96 - dir top/revert does not exist 194s ok 97 - dir top/verify does not exist 194s ok 98 - dir r/d does not exist 194s ok 99 - dir r/revert does not exist 194s ok 100 - dir r/verify does not exist 194s ok 101 - Add target "withall" 194s ok 102 - dir top/deploy exists 194s ok 103 - dir top/revert exists 194s ok 104 - dir top/verify exists 194s ok 105 - dir r/d exists 194s ok 106 - dir r/revert exists 194s ok 107 - dir r/verify exists 194s ok 108 - my.plan exists 194s ok 109 - Target "withall" should have uri set 194s ok 110 - Target "withall" should have revert_dir set 194s ok 111 - Target "withall" should have reworked_dir set 194s ok 112 - Target "withall" should have registry set 194s ok 113 - Target "withall" should have deploy_dir set 194s ok 114 - Target "withall" should have verify_dir set 194s ok 115 - Target "withall" should have reworked_deploy_dir set 194s ok 116 - Target "withall" should have top_dir set 194s ok 117 - Target "withall" should have extension set 194s ok 118 - Target "withall" should have client set 194s ok 119 - Target "withall" should have variables set 194s ok 120 - Target "withall" should have plan_file set 194s ok 121 - 'Target with no properties' isa 'App::Sqitch::Command::target' 194s ok 122 - No name arg to alter() should yield usage 194s ok 123 - No args should be passed to usage 194s ok 124 - Should get error for missing target 194s ok 125 - Missing target error ident should be "target" 194s ok 126 - Missing target error message should be correct 194s ok 127 - Should get error for missing target with URI 194s ok 128 - Missing target with URI error ident should be "target" 194s ok 129 - Missing target error message should include URI 194s ok 130 - 'Target with more properties' isa 'App::Sqitch::Command::target' 194s ok 131 - Alter target "withall" 194s ok 132 - Target "withall" should have plan_file set 194s ok 133 - Target "withall" should have client set 194s ok 134 - Target "withall" should have merged variables set 194s ok 135 - Target "withall" should have extension set 194s ok 136 - Target "withall" should have top_dir set 194s ok 137 - Target "withall" should have reworked_deploy_dir set 194s ok 138 - Target "withall" should have verify_dir set 194s ok 139 - Target "withall" should have deploy_dir set 194s ok 140 - Target "withall" should have uri set 194s ok 141 - Target "withall" should have registry set 194s ok 142 - Target "withall" should have reworked_dir set 194s ok 143 - Target "withall" should have revert_dir set 194s ok 144 - 'Target with new top_dir property' isa 'App::Sqitch::Command::target' 194s ok 145 - dir big does not exist 194s ok 146 - dir big/deploy does not exist 194s ok 147 - dir big/revert does not exist 194s ok 148 - dir big/verify does not exist 194s ok 149 - Alter target "withall" 194s ok 150 - dir big exists 194s ok 151 - dir big/deploy exists 194s ok 152 - dir big/revert exists 194s ok 153 - dir big/verify exists 194s ok 154 - The withall top_dir should have been set 194s ok 155 - No name args to rename() should yield usage 194s ok 156 - No args should be passed to usage 194s ok 157 - No second arg to rename() should yield usage 194s ok 158 - No args should be passed to usage 194s ok 159 - Should get error for nonexistent target 194s ok 160 - Nonexistent target error ident should be "target" 194s ok 161 - Nonexistent target error message should be correct 194s ok 162 - Rename 194s ok 163 - Target "àlafois" should now be present 194s ok 164 - Target "àlafois" variables should now be present 194s ok 165 - Target "withboth" should no longer be present 194s ok 166 - Target "withboth" variables should be gone 194s ok 167 - Target "àlafois" should have variables 194s ok 168 - Should get error renaming a target with dependencies 194s ok 169 - Dependency target error ident should be "target" 194s ok 170 - Dependency target error message should be correct 194s ok 171 - Rename "test" 194s ok 172 - Target "funky" should now be present 194s ok 173 - Target "test" should no longer be present 194s ok 174 - Target "funcky" should have no variables 194s ok 175 - No name args to remove() should yield usage 194s ok 176 - No args should be passed to usage 194s ok 177 - Should get error for nonexistent target 194s ok 178 - Nonexistent target error ident should be "target" 194s ok 179 - Nonexistent target error message should be correct 194s ok 180 - Remove 194s ok 181 - Target "àlafois" should now be gone 194s ok 182 - Target "àlafois" variables should be gone, too 194s ok 183 - Should get error removing a target with dependencies 194s ok 184 - Dependency target error ident should be "target" 194s ok 185 - Dependency target error message should be correct 194s ok 186 - Remove "funky" 194s ok 187 - Target "funky" should now be gone 194s ok 188 - Run show() 194s ok 189 - Show with no names should emit the list of targets 194s ok 190 - Show dev 194s ok 191 - The "dev" target should have been shown 194s ok 192 - Show withcli 194s ok 193 - The "with_cli" target should have been shown 194s ok 194 - Show withreg 194s ok 195 - The "withreg" target should have been shown 194s ok 196 - Show withall 194s ok 197 - The "withall" target should have been shown with variables 194s ok 198 - Show three targets 194s ok 199 - All three targets should have been shown 194s ok 200 - 'Simple target' isa 'App::Sqitch::Command::target' 194s ok 201 - Execute undef 194s ok 202 - list() should have been called 194s ok 203 - Execute undef with args 194s ok 204 - list() should have been passed args 194s ok 205 - Execute list 194s ok 206 - list() should have been called 194s ok 207 - Execute list with args 194s ok 208 - list() should have been passed args 194s ok 209 - Execute add 194s ok 210 - add() should have been called 194s ok 211 - Execute add with args 194s ok 212 - add() should have been passed args 194s ok 213 - Execute remove 194s ok 214 - remove() should have been called 194s ok 215 - Execute remove with args 194s ok 216 - remove() should have been passed args 194s ok 217 - Execute rm 194s ok 218 - remove() should have been called 194s ok 219 - Execute rm with args 194s ok 220 - remove() should have been passed args 194s ok 221 - Execute rename 194s ok 222 - rename() should have been called 194s ok 223 - Execute rename with args 194s ok 224 - rename() should have been passed args 194s ok 225 - Execute show 194s ok 226 - show() should have been called 194s ok 227 - Execute show with args 194s ok 228 - show() should have been passed args 194s ok 229 - Should get an exception for a nonexistent action 194s ok 230 - Nonexistent action message should be passed to usage 194s ok 231 - Invalid URI rock should throw an error 194s ok 232 - Invalid URI rock error ident should be "target" 194s ok 233 - Invalid URI rock error message should be correct 194s ok 234 - Invalid URI https://www.google.com/ should throw an error 194s ok 235 - Invalid URI https://www.google.com/ error ident should be "target" 194s ok 236 - Invalid URI https://www.google.com/ error message should be correct 194s ok 237 - Engineless URI should throw an error 194s ok 238 - Engineless URI error ident should be "target" 194s ok 239 - Engineless URI error message should be correct 194s ok 240 - Unknown engine URI should throw an error 194s ok 241 - Unknown engine URI error ident should be "target" 194s ok 242 - Unknown engine URI error message should be correct 194s ok 243 - no warnings 194s ok 195s t/upgrade.t ......... 195s 1..25 195s ok 1 - require App::Sqitch::Command::upgrade; 195s ok 2 - Load a sqitch object 195s ok 3 - 'upgrade command' isa 'App::Sqitch::Command::upgrade' 195s ok 4 - App::Sqitch::Command::upgrade->can(...) 195s ok 5 - App::Sqitch::Command::upgrade does ConnectingCommand 195s ok 6 - Options should be correct 195s ok 7 - Should parse options 195s ok 8 - Options should not conflict with core options 195s ok 9 - Execute upgrade 195s ok 10 - Upgrade should not have been called 195s ok 11 - Should get output for up-to-date registry 195s ok 12 - Execute upgrade with target 195s ok 13 - Upgrade should again not have been called 195s ok 14 - Should get output for up-to-date registry with target 195s ok 15 - Execute upgrade with engine 195s ok 16 - Upgrade should again not have been called 195s ok 17 - Should get output for up-to-date registry with target 195s ok 18 - 'upgrade command with target' isa 'App::Sqitch::Command::upgrade' 195s ok 19 - Execute upgrade with target option 195s ok 20 - Upgrade should still not have been called 195s ok 21 - Should get output for up-to-date registry with target option 195s ok 22 - Execute upgrade with out-of-date registry 195s ok 23 - Upgrade should now have been called 195s ok 24 - Should get output for the upgrade 195s ok 25 - no warnings 195s ok 195s t/verify.t .......... 195s ok 1 - require App::Sqitch::Command::verify; 195s ok 2 - The class (or class-like) 'App::Sqitch::Command::verify' isa 'App::Sqitch::Command' 195s ok 3 - App::Sqitch::Command::verify->can(...) 195s ok 4 - App::Sqitch::Command::verify does ContextCommand 195s ok 5 - App::Sqitch::Command::verify does ConnectingCommand 195s ok 6 - Options should be correct 195s ok 7 - Should parse options 195s ok 8 - Options should not conflict with core options 195s ok 9 - Should have default configuration with no config or opts 195s ok 10 - Should have changes and variables from options 195s ok 11 - Should have no config if no options 195s ok 12 - 'new status with target' isa 'App::Sqitch::Command::verify' 195s ok 13 - Should have target "foo" 195s ok 14 - An object of class 'App::Sqitch::Command::verify' isa 'App::Sqitch::Command::verify' 195s ok 15 - Default target should be undef 195s ok 16 - from_change should be undef 195s ok 17 - to_change should be undef 195s ok 18 - Should collect no variables 195s ok 19 - Should collect core vars 195s ok 20 - Should override core vars with deploy vars 195s ok 21 - Should override deploy vars with verify vars 195s ok 22 - Should override verify vars with engine vars 195s ok 23 - Should override engine vars with target vars 195s ok 24 - Should override target vars with --set variables 195s ok 25 - Execute with nothing. 195s ok 26 - Two undefs should be passed to the engine 195s ok 27 - Should have no warnings 195s ok 28 - Execute from "@alpha" 195s ok 29 - "@alpha" and undef should be passed to the engine 195s ok 30 - Should again have no warnings 195s ok 31 - Execute from "@alpha" to "@beta" 195s ok 32 - "@alpha" and "@beat" should be passed to the engine 195s ok 33 - Should still have no warnings 195s ok 34 - 'Object with from, to, and variables' isa 'App::Sqitch::Command::verify' 195s ok 35 - Execute again 195s ok 36 - "foo" and "bar" should be passed to the engine 195s ok 37 - Vars should have been passed through to the engine 195s ok 38 - Still should have no warnings 195s ok 39 - Execute with command-line args 195s ok 40 - "foo" and "bar" should be passed to the engine 195s ok 41 - Vars should have been passed through to the engine 195s ok 42 - Should have warning about which roles are used 195s ok 43 - Execute with target arg 195s ok 44 - The target should have been passed to the engine 195s ok 45 - "foo" and "bar" should be passed to the engine 195s ok 46 - Vars should have been passed through to the engine 195s ok 47 - Should once again have no warnings 195s ok 48 - 'Object with target' isa 'App::Sqitch::Command::verify' 195s ok 49 - Execute with no args 195s ok 50 - The target option should have been passed to the engine 195s ok 51 - Undefs should be passed to the engine 195s ok 52 - No vars should have been passed through to the engine 195s ok 53 - Should once again have no warnings 195s ok 54 - Execute with two targegs and two changes 195s ok 55 - The target option should have been passed to the engine 195s ok 56 - The two changes should be passed to the engine 195s ok 57 - No vars should have been passed through to the engine 195s ok 58 - Should have warning about too many targets 195s ok 59 - Should get an exception for unknown arg 195s ok 60 - Unknown arg ident should be "verify" 195s ok 61 - Should get an exeption for two unknown arg 195s ok 62 - Should get an exception for unknown args 195s ok 63 - Unknown args ident should be "verify" 195s ok 64 - Should get an exeption for two unknown args 195s 1..64 195s ok 196s t/vertica.t ......... 196s ok 1 - require App::Sqitch::Engine::vertica; 196s ok 2 - config_vars should return three vars 196s ok 3 - An object of class 'App::Sqitch::Engine::vertica' isa 'App::Sqitch::Engine::vertica' 196s ok 4 - Key should be "vertica" 196s ok 5 - Name should be "Vertica" 196s ok 6 - client should default to vsql 196s ok 7 - registry default should be "sqitch" 196s ok 8 - DB URI should be "db:vertica:" 196s ok 9 - Destination should fall back on environment variables 196s ok 10 - Registry destination should be the same as destination 196s ok 11 - vsql command should be username and std opts-only 196s ok 12 - An object of class 'App::Sqitch::Engine::vertica' isa 'App::Sqitch::Engine::vertica' 196s ok 13 - Set some variables 196s ok 14 - Variables should be passed to vsql via --set 196s ok 15 - Target name should not read $VSQL_DATABASE 196s ok 16 - Registry target should be the same as destination 196s ok 17 - Should have username when VSQL_DATABASE set 196s ok 18 - Should have password when VSQL_DATABASE set 196s ok 19 - Target name should not read $VSQL_USER 196s ok 20 - Registry target should be the same as destination 196s ok 21 - Should have username when VSQL_USER set 196s ok 22 - Should have password when VSQL_USER set 196s ok 23 - Target name should not read $VSQL_PASSWORD 196s ok 24 - Registry target should be the same as destination 196s ok 25 - Should have username when VSQL_PASSWORD set 196s ok 26 - Should have password when VSQL_PASSWORD set 196s ok 27 - Target name should not fall back on sysuser 196s ok 28 - Registry target should be the same as destination 196s ok 29 - Target name should be the default 196s ok 30 - Registry target should be the same as destination 196s ok 31 - Create another vertica 196s ok 32 - client should be as configured 196s ok 33 - uri should be as configured 196s ok 34 - registry should be as configured 196s ok 35 - vsql command should be configured from URI config 196s ok 36 - App::Sqitch::Engine::vertica->can(...) 196s ok 37 - VSQL_PASSWORD should be "s3cr3t" 196s ok 38 - Call _run 196s ok 39 - Command should be passed to run() 196s ok 40 - VSQL_PASSWORD should be "s3cr3t" 196s ok 41 - Call _spool 196s ok 42 - Command should be passed to spool() 196s ok 43 - VSQL_PASSWORD should be "s3cr3t" 196s ok 44 - Call _capture 196s ok 45 - Command should be passed to capture() 196s ok 46 - VSQL_PASSWORD should be "s3cr3t" 196s ok 47 - Call _probe 196s ok 48 - Should have expected arguments to _probe 196s ok 49 - Create a vertica with sqitch with no pw 196s ok 50 - VSQL_PASSWORD should not exist 196s ok 51 - Call _run again 196s ok 52 - Command should be passed to run() again 196s ok 53 - VSQL_PASSWORD should not exist 196s ok 54 - Call _spool again 196s ok 55 - Command should be passed to spool() again 196s ok 56 - VSQL_PASSWORD should not exist 196s ok 57 - Call _capture again 196s ok 58 - Command should be passed to capture() again 196s ok 59 - VSQL_PASSWORD should not exist 196s ok 60 - Call _probe again 196s ok 61 - Should again have expected arguments to _probe 196s ok 62 - VSQL_PASSWORD should not exist 196s ok 63 - Run foo/bar.sql 196s ok 64 - File should be passed to run() 196s ok 65 - VSQL_PASSWORD should not exist 196s ok 66 - Spool a "file handle" 196s ok 67 - Handle should be passed to spool() 196s ok 68 - VSQL_PASSWORD should not exist 196s ok 69 - Verify foo/bar.sql 196s ok 70 - Verify file should be passed to capture() 196s ok 71 - VSQL_PASSWORD should not exist 196s ok 72 - Verify foo/bar.sql again 196s ok 73 - Verifile file should be passed to run() for high verbosity 196s ok 74 - App::Sqitch::Engine::vertica->can('_ts2char_format') 196s ok 75 - _ts2char_format should work 196s ok 76 - App::Sqitch::Engine::vertica->can('_dt') 196s ok 77 - 'Return value of _dt()' isa 'App::Sqitch::DateTime' 196s ok 78 - DateTime year should be set 196s ok 79 - DateTime month should be set 196s ok 80 - DateTime day should be set 196s ok 81 - DateTime hour should be set 196s ok 82 - DateTime minute should be set 196s ok 83 - DateTime second should be set 196s ok 84 - DateTime TZ should be set 196s ok 85 - Should have no listagg format 196s ok 86 - Should have no table error 196s ok 87 - Should have no column error 196s ok 88 - Should now have table error 196s ok 89 - Still should have no column error 196s ok 90 - Should again have no table error 196s ok 91 - Should now have no column error 196s ok 92 - current_state should propagate an error when it's not a column error 196s ok 93 - _cid should propagate an error when it's not a table or column error 196s ok 94 - App::Sqitch::Engine::vertica->can(...) 196s # Subtest: live database 196s 1..0 # SKIP Unable to live-test Vertica engine: DBD::ODBC 1.59 required to manage Vertica at t/vertica.t line 372. 196s ok 95 # skip Unable to live-test Vertica engine: DBD::ODBC 1.59 required to manage Vertica at t/vertica.t line 372. 196s # 196s 1..95 196s ok 196s t/win32.t ........... 196s 1..2 196s ok 1 - Should have "MSWin32" 196s ok 2 - CAN_OUTPUT_COLOR should be set properly 196s ok 196s t/x.t ............... 196s ok 1 - require App::Sqitch::X; 196s ok 2 - 'X object' isa 'App::Sqitch::X' 196s ok 3 - X object does Throwable 196s ok 4 - X object does StackTrace::Auto 196s ok 5 - Create X without ident 196s ok 6 - Default ident should be "DEV" 196s ok 7 - threw App::Sqitch::X 196s ok 8 - 'Thrown object' isa 'App::Sqitch::X' 196s ok 9 - Ident should be "basic" 196s ok 10 - The message should have been passed 196s ok 11 - It should have a stack trace 196s ok 12 - Exit val should be 2 196s ok 13 - The trace should start in this file 196s ok 14 - threw App::Sqitch::X 196s ok 15 - 'Thrown object' isa 'App::Sqitch::X' 196s ok 16 - Ident should be "DEV" 196s ok 17 - The message should have been passed 196s ok 18 - Exit val should again be 2 196s ok 19 - Previous exception should have been passed 196s ok 20 - threw App::Sqitch::X 196s ok 21 - 'Thrown object' isa 'App::Sqitch::X' 196s ok 22 - The params should have been passed 196s ok 23 - Exit val should be 1 196s ok 24 - Stringification should work 196s ok 25 - Stringification should work 196s ok 26 - Should be an "io" exception 196s ok 27 - Should catch error called via &goto 196s 1..27 196s ok 196s All tests successful. 196s Files=50, Tests=7508, 41 wallclock secs ( 0.74 usr 0.27 sys + 31.53 cusr 7.69 csys = 40.23 CPU) 196s Result: PASS 197s autopkgtest [18:26:19]: test autodep8-perl-build-deps: -----------------------] 197s autodep8-perl-build-deps PASS 197s autopkgtest [18:26:19]: test autodep8-perl-build-deps: - - - - - - - - - - results - - - - - - - - - - 198s autopkgtest [18:26:20]: test autodep8-perl: preparing testbed 276s autopkgtest [18:27:38]: testbed dpkg architecture: arm64 277s autopkgtest [18:27:39]: testbed apt version: 2.9.8 277s autopkgtest [18:27:39]: @@@@@@@@@@@@@@@@@@@@ test bed setup 278s Get:1 http://ftpmaster.internal/ubuntu plucky-proposed InRelease [73.9 kB] 278s Get:2 http://ftpmaster.internal/ubuntu plucky-proposed/multiverse Sources [44.0 kB] 278s Get:3 http://ftpmaster.internal/ubuntu plucky-proposed/universe Sources [2775 kB] 278s Get:4 http://ftpmaster.internal/ubuntu plucky-proposed/main Sources [183 kB] 278s Get:5 http://ftpmaster.internal/ubuntu plucky-proposed/restricted Sources [7016 B] 278s Get:6 http://ftpmaster.internal/ubuntu plucky-proposed/main arm64 Packages [241 kB] 278s Get:7 http://ftpmaster.internal/ubuntu plucky-proposed/restricted arm64 Packages [50.3 kB] 278s Get:8 http://ftpmaster.internal/ubuntu plucky-proposed/universe arm64 Packages [2023 kB] 278s Get:9 http://ftpmaster.internal/ubuntu plucky-proposed/multiverse arm64 Packages [36.5 kB] 279s Fetched 5433 kB in 1s (4232 kB/s) 279s Reading package lists... 281s Reading package lists... 282s Building dependency tree... 282s Reading state information... 282s Calculating upgrade... 283s The following packages will be upgraded: 283s libevdev2 libftdi1-2 libinih1 nano python3-lazr.uri 283s 5 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 283s Need to get 374 kB of archives. 283s After this operation, 17.4 kB of additional disk space will be used. 283s Get:1 http://ftpmaster.internal/ubuntu plucky/main arm64 libevdev2 arm64 1.13.3+dfsg-1 [36.0 kB] 283s Get:2 http://ftpmaster.internal/ubuntu plucky/main arm64 nano arm64 8.2-1 [289 kB] 283s Get:3 http://ftpmaster.internal/ubuntu plucky/main arm64 libftdi1-2 arm64 1.5-7 [28.4 kB] 283s Get:4 http://ftpmaster.internal/ubuntu plucky/main arm64 libinih1 arm64 58-1ubuntu1 [7412 B] 283s Get:5 http://ftpmaster.internal/ubuntu plucky/main arm64 python3-lazr.uri all 1.0.6-4 [13.6 kB] 283s Fetched 374 kB in 0s (873 kB/s) 284s (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 ... 79705 files and directories currently installed.) 284s Preparing to unpack .../libevdev2_1.13.3+dfsg-1_arm64.deb ... 284s Unpacking libevdev2:arm64 (1.13.3+dfsg-1) over (1.13.2+dfsg-1) ... 284s Preparing to unpack .../archives/nano_8.2-1_arm64.deb ... 284s Unpacking nano (8.2-1) over (8.1-1) ... 284s Preparing to unpack .../libftdi1-2_1.5-7_arm64.deb ... 284s Unpacking libftdi1-2:arm64 (1.5-7) over (1.5-6build5) ... 284s Preparing to unpack .../libinih1_58-1ubuntu1_arm64.deb ... 284s Unpacking libinih1:arm64 (58-1ubuntu1) over (55-1ubuntu2) ... 284s Preparing to unpack .../python3-lazr.uri_1.0.6-4_all.deb ... 284s Unpacking python3-lazr.uri (1.0.6-4) over (1.0.6-3) ... 284s Setting up libinih1:arm64 (58-1ubuntu1) ... 284s Setting up python3-lazr.uri (1.0.6-4) ... 284s Setting up libftdi1-2:arm64 (1.5-7) ... 284s Setting up nano (8.2-1) ... 284s Setting up libevdev2:arm64 (1.13.3+dfsg-1) ... 284s Processing triggers for man-db (2.12.1-3) ... 285s Processing triggers for install-info (7.1.1-1) ... 285s Processing triggers for libc-bin (2.40-1ubuntu3) ... 285s Reading package lists... 286s Building dependency tree... 286s Reading state information... 286s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 287s Hit:1 http://ftpmaster.internal/ubuntu plucky-proposed InRelease 287s Hit:2 http://ftpmaster.internal/ubuntu plucky InRelease 287s Hit:3 http://ftpmaster.internal/ubuntu plucky-updates InRelease 287s Hit:4 http://ftpmaster.internal/ubuntu plucky-security InRelease 288s Reading package lists... 288s Reading package lists... 288s Building dependency tree... 288s Reading state information... 289s Calculating upgrade... 289s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 289s Reading package lists... 290s Building dependency tree... 290s Reading state information... 290s 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. 296s Reading package lists... 296s Building dependency tree... 296s Reading state information... 297s Starting pkgProblemResolver with broken count: 0 297s Starting 2 pkgProblemResolver with broken count: 0 297s Done 298s The following additional packages will be installed: 298s autodep8 dctrl-tools libalgorithm-backoff-perl libalgorithm-c3-perl 298s libb-hooks-endofscope-perl libb-hooks-op-check-perl libclass-c3-perl 298s libclass-data-inheritable-perl libclass-inspector-perl 298s libclass-method-modifiers-perl libclass-singleton-perl 298s libclass-xsaccessor-perl libclone-choose-perl libclone-perl 298s libconfig-gitlike-perl libdata-optlist-perl libdatetime-locale-perl 298s libdatetime-perl libdatetime-timezone-perl libdbd-pg-perl libdbi-perl 298s libdevel-callchecker-perl libdevel-stacktrace-perl 298s libdynaloader-functions-perl libencode-locale-perl libeval-closure-perl 298s libexception-class-perl libexporter-tiny-perl libfile-sharedir-perl 298s libfile-which-perl libhash-merge-perl libimport-into-perl libintl-perl 298s libio-pager-perl libipc-run3-perl libipc-system-simple-perl 298s liblist-moreutils-perl liblist-moreutils-xs-perl 298s libmodule-implementation-perl libmodule-runtime-perl libmoo-perl 298s libmoox-types-mooselike-perl libmro-compat-perl libnamespace-autoclean-perl 298s libnamespace-clean-perl libpackage-stash-perl libparams-classify-perl 298s libparams-util-perl libparams-validationcompiler-perl libpath-class-perl 298s libperlio-utf8-strict-perl libpod-parser-perl libpq5 librole-tiny-perl 298s libspecio-perl libstring-formatter-perl libstring-shellquote-perl 298s libsub-exporter-perl libsub-exporter-progressive-perl libsub-identify-perl 298s libsub-install-perl libsub-name-perl libsub-quote-perl libtemplate-tiny-perl 298s libterm-readkey-perl libthrowable-perl libtry-tiny-perl libtype-tiny-perl 298s liburi-db-perl liburi-nested-perl liburi-perl libvariable-magic-perl 298s libxstring-perl pkg-perl-autopkgtest postgresql-client postgresql-client-16 298s postgresql-client-common sqitch 298s Suggested packages: 298s debtags libmldbm-perl libnet-daemon-perl libsql-statement-perl 298s libmoox-types-mooselike-numeric-perl libmoox-types-setobject-perl 298s libscalar-number-perl libtest-fatal-perl libdevel-lexalias-perl 298s libbusiness-isbn-perl libregexp-ipv6-perl libwww-perl postgresql-16 298s postgresql-doc-16 298s Recommended packages: 298s libclass-c3-xs-perl libdevel-lexalias-perl libintl-xs-perl 298s libpackage-stash-xs-perl libref-util-perl libtype-tiny-xs-perl 298s libtemplate-perl 298s The following NEW packages will be installed: 298s autodep8 autopkgtest-satdep dctrl-tools libalgorithm-backoff-perl 298s libalgorithm-c3-perl libb-hooks-endofscope-perl libb-hooks-op-check-perl 298s libclass-c3-perl libclass-data-inheritable-perl libclass-inspector-perl 298s libclass-method-modifiers-perl libclass-singleton-perl 298s libclass-xsaccessor-perl libclone-choose-perl libclone-perl 298s libconfig-gitlike-perl libdata-optlist-perl libdatetime-locale-perl 298s libdatetime-perl libdatetime-timezone-perl libdbd-pg-perl libdbi-perl 298s libdevel-callchecker-perl libdevel-stacktrace-perl 298s libdynaloader-functions-perl libencode-locale-perl libeval-closure-perl 298s libexception-class-perl libexporter-tiny-perl libfile-sharedir-perl 298s libfile-which-perl libhash-merge-perl libimport-into-perl libintl-perl 298s libio-pager-perl libipc-run3-perl libipc-system-simple-perl 298s liblist-moreutils-perl liblist-moreutils-xs-perl 298s libmodule-implementation-perl libmodule-runtime-perl libmoo-perl 298s libmoox-types-mooselike-perl libmro-compat-perl libnamespace-autoclean-perl 298s libnamespace-clean-perl libpackage-stash-perl libparams-classify-perl 298s libparams-util-perl libparams-validationcompiler-perl libpath-class-perl 298s libperlio-utf8-strict-perl libpod-parser-perl libpq5 librole-tiny-perl 298s libspecio-perl libstring-formatter-perl libstring-shellquote-perl 298s libsub-exporter-perl libsub-exporter-progressive-perl libsub-identify-perl 298s libsub-install-perl libsub-name-perl libsub-quote-perl libtemplate-tiny-perl 298s libterm-readkey-perl libthrowable-perl libtry-tiny-perl libtype-tiny-perl 298s liburi-db-perl liburi-nested-perl liburi-perl libvariable-magic-perl 298s libxstring-perl pkg-perl-autopkgtest postgresql-client postgresql-client-16 298s postgresql-client-common sqitch 298s 0 upgraded, 79 newly installed, 0 to remove and 0 not upgraded. 298s Need to get 9402 kB/9402 kB of archives. 298s After this operation, 54.2 MB of additional disk space will be used. 298s Get:1 /tmp/autopkgtest.NaAPUz/2-autopkgtest-satdep.deb autopkgtest-satdep arm64 0 [712 B] 298s Get:2 http://ftpmaster.internal/ubuntu plucky/main arm64 dctrl-tools arm64 2.24-3build3 [103 kB] 298s Get:3 http://ftpmaster.internal/ubuntu plucky/main arm64 autodep8 all 0.28+nmu1ubuntu1 [13.7 kB] 298s Get:4 http://ftpmaster.internal/ubuntu plucky/universe arm64 libalgorithm-backoff-perl all 0.010-1 [37.3 kB] 298s Get:5 http://ftpmaster.internal/ubuntu plucky/universe arm64 libalgorithm-c3-perl all 0.11-2 [10.2 kB] 298s Get:6 http://ftpmaster.internal/ubuntu plucky/main arm64 libb-hooks-op-check-perl arm64 0.22-3build2 [9348 B] 298s Get:7 http://ftpmaster.internal/ubuntu plucky/main arm64 libdynaloader-functions-perl all 0.004-1 [11.4 kB] 298s Get:8 http://ftpmaster.internal/ubuntu plucky/main arm64 libdevel-callchecker-perl arm64 0.009-1build1 [14.0 kB] 298s Get:9 http://ftpmaster.internal/ubuntu plucky/main arm64 libparams-classify-perl arm64 0.015-2build6 [19.8 kB] 298s Get:10 http://ftpmaster.internal/ubuntu plucky/main arm64 libmodule-runtime-perl all 0.016-2 [16.4 kB] 298s Get:11 http://ftpmaster.internal/ubuntu plucky/main arm64 libtry-tiny-perl all 0.31-2 [20.8 kB] 298s Get:12 http://ftpmaster.internal/ubuntu plucky/main arm64 libmodule-implementation-perl all 0.09-2 [12.0 kB] 298s Get:13 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-exporter-progressive-perl all 0.001013-3 [6718 B] 298s Get:14 http://ftpmaster.internal/ubuntu plucky/main arm64 libvariable-magic-perl arm64 0.64-1build1 [35.3 kB] 298s Get:15 http://ftpmaster.internal/ubuntu plucky/main arm64 libb-hooks-endofscope-perl all 0.28-1 [15.8 kB] 298s Get:16 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclass-c3-perl all 0.35-2 [18.4 kB] 298s Get:17 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-data-inheritable-perl all 0.08-3 [8084 B] 298s Get:18 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-inspector-perl all 1.36-3 [15.4 kB] 298s Get:19 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-method-modifiers-perl all 2.15-1 [16.1 kB] 298s Get:20 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclass-singleton-perl all 1.6-2 [11.5 kB] 298s Get:21 http://ftpmaster.internal/ubuntu plucky/main arm64 libclass-xsaccessor-perl arm64 1.19-4build5 [32.7 kB] 298s Get:22 http://ftpmaster.internal/ubuntu plucky/universe arm64 libclone-choose-perl all 0.010-2 [7738 B] 298s Get:23 http://ftpmaster.internal/ubuntu plucky/main arm64 libclone-perl arm64 0.47-1 [10.4 kB] 298s Get:24 http://ftpmaster.internal/ubuntu plucky/main arm64 libimport-into-perl all 1.002005-2 [10.7 kB] 298s Get:25 http://ftpmaster.internal/ubuntu plucky/main arm64 librole-tiny-perl all 2.002004-1 [16.3 kB] 298s Get:26 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-quote-perl all 2.006008-1ubuntu1 [20.7 kB] 298s Get:27 http://ftpmaster.internal/ubuntu plucky/main arm64 libmoo-perl all 2.005005-1 [47.4 kB] 298s Get:28 http://ftpmaster.internal/ubuntu plucky/universe arm64 libmoox-types-mooselike-perl all 0.29-2 [16.7 kB] 298s Get:29 http://ftpmaster.internal/ubuntu plucky/universe arm64 libconfig-gitlike-perl all 1.18-2 [33.8 kB] 298s Get:30 http://ftpmaster.internal/ubuntu plucky/main arm64 libparams-util-perl arm64 1.102-3build1 [20.6 kB] 298s Get:31 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-install-perl all 0.929-1 [9764 B] 298s Get:32 http://ftpmaster.internal/ubuntu plucky/main arm64 libdata-optlist-perl all 0.114-1 [9708 B] 299s Get:33 http://ftpmaster.internal/ubuntu plucky/main arm64 libdbi-perl arm64 1.645-1 [826 kB] 299s Get:34 http://ftpmaster.internal/ubuntu plucky/main arm64 libpq5 arm64 17.0-1 [248 kB] 299s Get:35 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdbd-pg-perl arm64 3.18.0-1build4 [190 kB] 299s Get:36 http://ftpmaster.internal/ubuntu plucky/main arm64 libdevel-stacktrace-perl all 2.0500-1 [22.1 kB] 299s Get:37 http://ftpmaster.internal/ubuntu plucky/main arm64 libencode-locale-perl all 1.05-3 [11.6 kB] 299s Get:38 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-exporter-perl all 0.990-1 [49.0 kB] 299s Get:39 http://ftpmaster.internal/ubuntu plucky/universe arm64 libeval-closure-perl all 0.14-3 [10.1 kB] 299s Get:40 http://ftpmaster.internal/ubuntu plucky/main arm64 libexception-class-perl all 1.45-1 [28.6 kB] 299s Get:41 http://ftpmaster.internal/ubuntu plucky/main arm64 libexporter-tiny-perl all 1.006002-1 [36.8 kB] 299s Get:42 http://ftpmaster.internal/ubuntu plucky/main arm64 libfile-sharedir-perl all 1.118-3 [14.0 kB] 299s Get:43 http://ftpmaster.internal/ubuntu plucky/main arm64 libfile-which-perl all 1.27-2 [12.5 kB] 299s Get:44 http://ftpmaster.internal/ubuntu plucky/universe arm64 libhash-merge-perl all 0.302-1 [13.0 kB] 299s Get:45 http://ftpmaster.internal/ubuntu plucky/main arm64 libintl-perl all 1.33-1build4 [703 kB] 299s Get:46 http://ftpmaster.internal/ubuntu plucky/main arm64 libterm-readkey-perl arm64 2.38-2build5 [23.2 kB] 299s Get:47 http://ftpmaster.internal/ubuntu plucky/universe arm64 libio-pager-perl all 2.10-1 [50.5 kB] 299s Get:48 http://ftpmaster.internal/ubuntu plucky/main arm64 libipc-system-simple-perl all 1.30-2 [22.3 kB] 299s Get:49 http://ftpmaster.internal/ubuntu plucky/universe arm64 liblist-moreutils-xs-perl arm64 0.430-4build1 [39.9 kB] 299s Get:50 http://ftpmaster.internal/ubuntu plucky/universe arm64 liblist-moreutils-perl all 0.430-2 [38.2 kB] 299s Get:51 http://ftpmaster.internal/ubuntu plucky/universe arm64 libmro-compat-perl all 0.15-2 [10.1 kB] 299s Get:52 http://ftpmaster.internal/ubuntu plucky/main arm64 libpackage-stash-perl all 0.40-1 [19.5 kB] 299s Get:53 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-identify-perl arm64 0.14-3build4 [9762 B] 299s Get:54 http://ftpmaster.internal/ubuntu plucky/main arm64 libsub-name-perl arm64 0.27-1build4 [10.6 kB] 299s Get:55 http://ftpmaster.internal/ubuntu plucky/main arm64 libnamespace-clean-perl all 0.27-2 [14.0 kB] 299s Get:56 http://ftpmaster.internal/ubuntu plucky/universe arm64 libnamespace-autoclean-perl all 0.29-2 [11.7 kB] 299s Get:57 http://ftpmaster.internal/ubuntu plucky/universe arm64 libparams-validationcompiler-perl all 0.31-1 [28.3 kB] 299s Get:58 http://ftpmaster.internal/ubuntu plucky/universe arm64 libpath-class-perl all 0.37-4 [36.8 kB] 299s Get:59 http://ftpmaster.internal/ubuntu plucky/main arm64 libperlio-utf8-strict-perl arm64 0.010-1build4 [11.1 kB] 299s Get:60 http://ftpmaster.internal/ubuntu plucky/main arm64 libpod-parser-perl all 1.67-1 [80.6 kB] 299s Get:61 http://ftpmaster.internal/ubuntu plucky/universe arm64 libxstring-perl arm64 0.005-2build4 [7866 B] 299s Get:62 http://ftpmaster.internal/ubuntu plucky/universe arm64 libspecio-perl all 0.48-1 [137 kB] 299s Get:63 http://ftpmaster.internal/ubuntu plucky/universe arm64 libstring-formatter-perl all 1.235-1 [21.3 kB] 299s Get:64 http://ftpmaster.internal/ubuntu plucky/main arm64 libstring-shellquote-perl all 1.04-3 [11.3 kB] 299s Get:65 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtemplate-tiny-perl all 1.14-2 [11.0 kB] 299s Get:66 http://ftpmaster.internal/ubuntu plucky/universe arm64 libthrowable-perl all 1.001-2 [14.2 kB] 299s Get:67 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtype-tiny-perl all 2.004000-1 [354 kB] 299s Get:68 http://ftpmaster.internal/ubuntu plucky/main arm64 liburi-perl all 5.28-1 [88.1 kB] 299s Get:69 http://ftpmaster.internal/ubuntu plucky/universe arm64 liburi-nested-perl all 0.10-4 [7926 B] 299s Get:70 http://ftpmaster.internal/ubuntu plucky/universe arm64 liburi-db-perl all 0.22-1 [20.2 kB] 299s Get:71 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client-common all 262 [36.7 kB] 299s Get:72 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client-16 arm64 16.4-3 [1269 kB] 299s Get:73 http://ftpmaster.internal/ubuntu plucky/main arm64 postgresql-client all 16+262 [11.8 kB] 299s Get:74 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-locale-perl all 1:1.41-1 [3193 kB] 299s Get:75 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-timezone-perl all 1:2.62-1+2024a [262 kB] 299s Get:76 http://ftpmaster.internal/ubuntu plucky/universe arm64 libdatetime-perl arm64 2:1.65-1build3 [95.9 kB] 299s Get:77 http://ftpmaster.internal/ubuntu plucky/main arm64 libipc-run3-perl all 0.049-1 [28.8 kB] 299s Get:78 http://ftpmaster.internal/ubuntu plucky/universe arm64 sqitch all 1.4.1-1 [609 kB] 299s Get:79 http://ftpmaster.internal/ubuntu plucky/universe arm64 pkg-perl-autopkgtest all 0.79 [18.5 kB] 300s Fetched 9402 kB in 2s (5975 kB/s) 300s Selecting previously unselected package dctrl-tools. 300s (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 ... 79705 files and directories currently installed.) 300s Preparing to unpack .../00-dctrl-tools_2.24-3build3_arm64.deb ... 300s Unpacking dctrl-tools (2.24-3build3) ... 300s Selecting previously unselected package autodep8. 300s Preparing to unpack .../01-autodep8_0.28+nmu1ubuntu1_all.deb ... 300s Unpacking autodep8 (0.28+nmu1ubuntu1) ... 300s Selecting previously unselected package libalgorithm-backoff-perl. 300s Preparing to unpack .../02-libalgorithm-backoff-perl_0.010-1_all.deb ... 300s Unpacking libalgorithm-backoff-perl (0.010-1) ... 300s Selecting previously unselected package libalgorithm-c3-perl. 300s Preparing to unpack .../03-libalgorithm-c3-perl_0.11-2_all.deb ... 300s Unpacking libalgorithm-c3-perl (0.11-2) ... 300s Selecting previously unselected package libb-hooks-op-check-perl:arm64. 300s Preparing to unpack .../04-libb-hooks-op-check-perl_0.22-3build2_arm64.deb ... 300s Unpacking libb-hooks-op-check-perl:arm64 (0.22-3build2) ... 300s Selecting previously unselected package libdynaloader-functions-perl. 300s Preparing to unpack .../05-libdynaloader-functions-perl_0.004-1_all.deb ... 300s Unpacking libdynaloader-functions-perl (0.004-1) ... 300s Selecting previously unselected package libdevel-callchecker-perl:arm64. 300s Preparing to unpack .../06-libdevel-callchecker-perl_0.009-1build1_arm64.deb ... 300s Unpacking libdevel-callchecker-perl:arm64 (0.009-1build1) ... 300s Selecting previously unselected package libparams-classify-perl:arm64. 300s Preparing to unpack .../07-libparams-classify-perl_0.015-2build6_arm64.deb ... 300s Unpacking libparams-classify-perl:arm64 (0.015-2build6) ... 300s Selecting previously unselected package libmodule-runtime-perl. 300s Preparing to unpack .../08-libmodule-runtime-perl_0.016-2_all.deb ... 300s Unpacking libmodule-runtime-perl (0.016-2) ... 300s Selecting previously unselected package libtry-tiny-perl. 300s Preparing to unpack .../09-libtry-tiny-perl_0.31-2_all.deb ... 300s Unpacking libtry-tiny-perl (0.31-2) ... 300s Selecting previously unselected package libmodule-implementation-perl. 300s Preparing to unpack .../10-libmodule-implementation-perl_0.09-2_all.deb ... 300s Unpacking libmodule-implementation-perl (0.09-2) ... 300s Selecting previously unselected package libsub-exporter-progressive-perl. 300s Preparing to unpack .../11-libsub-exporter-progressive-perl_0.001013-3_all.deb ... 300s Unpacking libsub-exporter-progressive-perl (0.001013-3) ... 300s Selecting previously unselected package libvariable-magic-perl. 300s Preparing to unpack .../12-libvariable-magic-perl_0.64-1build1_arm64.deb ... 300s Unpacking libvariable-magic-perl (0.64-1build1) ... 300s Selecting previously unselected package libb-hooks-endofscope-perl. 300s Preparing to unpack .../13-libb-hooks-endofscope-perl_0.28-1_all.deb ... 300s Unpacking libb-hooks-endofscope-perl (0.28-1) ... 300s Selecting previously unselected package libclass-c3-perl. 300s Preparing to unpack .../14-libclass-c3-perl_0.35-2_all.deb ... 300s Unpacking libclass-c3-perl (0.35-2) ... 300s Selecting previously unselected package libclass-data-inheritable-perl. 300s Preparing to unpack .../15-libclass-data-inheritable-perl_0.08-3_all.deb ... 300s Unpacking libclass-data-inheritable-perl (0.08-3) ... 300s Selecting previously unselected package libclass-inspector-perl. 300s Preparing to unpack .../16-libclass-inspector-perl_1.36-3_all.deb ... 300s Unpacking libclass-inspector-perl (1.36-3) ... 300s Selecting previously unselected package libclass-method-modifiers-perl. 300s Preparing to unpack .../17-libclass-method-modifiers-perl_2.15-1_all.deb ... 300s Unpacking libclass-method-modifiers-perl (2.15-1) ... 300s Selecting previously unselected package libclass-singleton-perl. 300s Preparing to unpack .../18-libclass-singleton-perl_1.6-2_all.deb ... 300s Unpacking libclass-singleton-perl (1.6-2) ... 300s Selecting previously unselected package libclass-xsaccessor-perl. 301s Preparing to unpack .../19-libclass-xsaccessor-perl_1.19-4build5_arm64.deb ... 301s Unpacking libclass-xsaccessor-perl (1.19-4build5) ... 301s Selecting previously unselected package libclone-choose-perl. 301s Preparing to unpack .../20-libclone-choose-perl_0.010-2_all.deb ... 301s Unpacking libclone-choose-perl (0.010-2) ... 301s Selecting previously unselected package libclone-perl:arm64. 301s Preparing to unpack .../21-libclone-perl_0.47-1_arm64.deb ... 301s Unpacking libclone-perl:arm64 (0.47-1) ... 301s Selecting previously unselected package libimport-into-perl. 301s Preparing to unpack .../22-libimport-into-perl_1.002005-2_all.deb ... 301s Unpacking libimport-into-perl (1.002005-2) ... 301s Selecting previously unselected package librole-tiny-perl. 301s Preparing to unpack .../23-librole-tiny-perl_2.002004-1_all.deb ... 301s Unpacking librole-tiny-perl (2.002004-1) ... 301s Selecting previously unselected package libsub-quote-perl. 301s Preparing to unpack .../24-libsub-quote-perl_2.006008-1ubuntu1_all.deb ... 301s Unpacking libsub-quote-perl (2.006008-1ubuntu1) ... 301s Selecting previously unselected package libmoo-perl. 301s Preparing to unpack .../25-libmoo-perl_2.005005-1_all.deb ... 301s Unpacking libmoo-perl (2.005005-1) ... 301s Selecting previously unselected package libmoox-types-mooselike-perl. 301s Preparing to unpack .../26-libmoox-types-mooselike-perl_0.29-2_all.deb ... 301s Unpacking libmoox-types-mooselike-perl (0.29-2) ... 301s Selecting previously unselected package libconfig-gitlike-perl. 301s Preparing to unpack .../27-libconfig-gitlike-perl_1.18-2_all.deb ... 301s Unpacking libconfig-gitlike-perl (1.18-2) ... 301s Selecting previously unselected package libparams-util-perl. 301s Preparing to unpack .../28-libparams-util-perl_1.102-3build1_arm64.deb ... 301s Unpacking libparams-util-perl (1.102-3build1) ... 301s Selecting previously unselected package libsub-install-perl. 301s Preparing to unpack .../29-libsub-install-perl_0.929-1_all.deb ... 301s Unpacking libsub-install-perl (0.929-1) ... 301s Selecting previously unselected package libdata-optlist-perl. 301s Preparing to unpack .../30-libdata-optlist-perl_0.114-1_all.deb ... 301s Unpacking libdata-optlist-perl (0.114-1) ... 301s Selecting previously unselected package libdbi-perl:arm64. 301s Preparing to unpack .../31-libdbi-perl_1.645-1_arm64.deb ... 301s Unpacking libdbi-perl:arm64 (1.645-1) ... 301s Selecting previously unselected package libpq5:arm64. 301s Preparing to unpack .../32-libpq5_17.0-1_arm64.deb ... 301s Unpacking libpq5:arm64 (17.0-1) ... 301s Selecting previously unselected package libdbd-pg-perl. 301s Preparing to unpack .../33-libdbd-pg-perl_3.18.0-1build4_arm64.deb ... 301s Unpacking libdbd-pg-perl (3.18.0-1build4) ... 301s Selecting previously unselected package libdevel-stacktrace-perl. 301s Preparing to unpack .../34-libdevel-stacktrace-perl_2.0500-1_all.deb ... 301s Unpacking libdevel-stacktrace-perl (2.0500-1) ... 301s Selecting previously unselected package libencode-locale-perl. 301s Preparing to unpack .../35-libencode-locale-perl_1.05-3_all.deb ... 301s Unpacking libencode-locale-perl (1.05-3) ... 301s Selecting previously unselected package libsub-exporter-perl. 301s Preparing to unpack .../36-libsub-exporter-perl_0.990-1_all.deb ... 301s Unpacking libsub-exporter-perl (0.990-1) ... 301s Selecting previously unselected package libeval-closure-perl. 301s Preparing to unpack .../37-libeval-closure-perl_0.14-3_all.deb ... 301s Unpacking libeval-closure-perl (0.14-3) ... 301s Selecting previously unselected package libexception-class-perl. 301s Preparing to unpack .../38-libexception-class-perl_1.45-1_all.deb ... 301s Unpacking libexception-class-perl (1.45-1) ... 301s Selecting previously unselected package libexporter-tiny-perl. 301s Preparing to unpack .../39-libexporter-tiny-perl_1.006002-1_all.deb ... 301s Unpacking libexporter-tiny-perl (1.006002-1) ... 301s Selecting previously unselected package libfile-sharedir-perl. 301s Preparing to unpack .../40-libfile-sharedir-perl_1.118-3_all.deb ... 301s Unpacking libfile-sharedir-perl (1.118-3) ... 301s Selecting previously unselected package libfile-which-perl. 301s Preparing to unpack .../41-libfile-which-perl_1.27-2_all.deb ... 301s Unpacking libfile-which-perl (1.27-2) ... 301s Selecting previously unselected package libhash-merge-perl. 301s Preparing to unpack .../42-libhash-merge-perl_0.302-1_all.deb ... 301s Unpacking libhash-merge-perl (0.302-1) ... 301s Selecting previously unselected package libintl-perl. 302s Preparing to unpack .../43-libintl-perl_1.33-1build4_all.deb ... 302s Unpacking libintl-perl (1.33-1build4) ... 302s Selecting previously unselected package libterm-readkey-perl. 302s Preparing to unpack .../44-libterm-readkey-perl_2.38-2build5_arm64.deb ... 302s Unpacking libterm-readkey-perl (2.38-2build5) ... 302s Selecting previously unselected package libio-pager-perl. 302s Preparing to unpack .../45-libio-pager-perl_2.10-1_all.deb ... 302s Unpacking libio-pager-perl (2.10-1) ... 302s Selecting previously unselected package libipc-system-simple-perl. 302s Preparing to unpack .../46-libipc-system-simple-perl_1.30-2_all.deb ... 302s Unpacking libipc-system-simple-perl (1.30-2) ... 302s Selecting previously unselected package liblist-moreutils-xs-perl. 302s Preparing to unpack .../47-liblist-moreutils-xs-perl_0.430-4build1_arm64.deb ... 302s Unpacking liblist-moreutils-xs-perl (0.430-4build1) ... 302s Selecting previously unselected package liblist-moreutils-perl. 302s Preparing to unpack .../48-liblist-moreutils-perl_0.430-2_all.deb ... 302s Unpacking liblist-moreutils-perl (0.430-2) ... 302s Selecting previously unselected package libmro-compat-perl. 302s Preparing to unpack .../49-libmro-compat-perl_0.15-2_all.deb ... 302s Unpacking libmro-compat-perl (0.15-2) ... 302s Selecting previously unselected package libpackage-stash-perl. 302s Preparing to unpack .../50-libpackage-stash-perl_0.40-1_all.deb ... 302s Unpacking libpackage-stash-perl (0.40-1) ... 302s Selecting previously unselected package libsub-identify-perl. 302s Preparing to unpack .../51-libsub-identify-perl_0.14-3build4_arm64.deb ... 302s Unpacking libsub-identify-perl (0.14-3build4) ... 302s Selecting previously unselected package libsub-name-perl:arm64. 302s Preparing to unpack .../52-libsub-name-perl_0.27-1build4_arm64.deb ... 302s Unpacking libsub-name-perl:arm64 (0.27-1build4) ... 302s Selecting previously unselected package libnamespace-clean-perl. 302s Preparing to unpack .../53-libnamespace-clean-perl_0.27-2_all.deb ... 302s Unpacking libnamespace-clean-perl (0.27-2) ... 302s Selecting previously unselected package libnamespace-autoclean-perl. 302s Preparing to unpack .../54-libnamespace-autoclean-perl_0.29-2_all.deb ... 302s Unpacking libnamespace-autoclean-perl (0.29-2) ... 302s Selecting previously unselected package libparams-validationcompiler-perl. 302s Preparing to unpack .../55-libparams-validationcompiler-perl_0.31-1_all.deb ... 302s Unpacking libparams-validationcompiler-perl (0.31-1) ... 302s Selecting previously unselected package libpath-class-perl. 302s Preparing to unpack .../56-libpath-class-perl_0.37-4_all.deb ... 302s Unpacking libpath-class-perl (0.37-4) ... 302s Selecting previously unselected package libperlio-utf8-strict-perl. 302s Preparing to unpack .../57-libperlio-utf8-strict-perl_0.010-1build4_arm64.deb ... 302s Unpacking libperlio-utf8-strict-perl (0.010-1build4) ... 302s Selecting previously unselected package libpod-parser-perl. 302s Preparing to unpack .../58-libpod-parser-perl_1.67-1_all.deb ... 302s Adding 'diversion of /usr/bin/podselect to /usr/bin/podselect.bundled by libpod-parser-perl' 302s Adding 'diversion of /usr/share/man/man1/podselect.1.gz to /usr/share/man/man1/podselect.bundled.1.gz by libpod-parser-perl' 302s Unpacking libpod-parser-perl (1.67-1) ... 302s Selecting previously unselected package libxstring-perl:arm64. 302s Preparing to unpack .../59-libxstring-perl_0.005-2build4_arm64.deb ... 302s Unpacking libxstring-perl:arm64 (0.005-2build4) ... 302s Selecting previously unselected package libspecio-perl. 302s Preparing to unpack .../60-libspecio-perl_0.48-1_all.deb ... 302s Unpacking libspecio-perl (0.48-1) ... 302s Selecting previously unselected package libstring-formatter-perl. 302s Preparing to unpack .../61-libstring-formatter-perl_1.235-1_all.deb ... 302s Unpacking libstring-formatter-perl (1.235-1) ... 302s Selecting previously unselected package libstring-shellquote-perl. 302s Preparing to unpack .../62-libstring-shellquote-perl_1.04-3_all.deb ... 302s Unpacking libstring-shellquote-perl (1.04-3) ... 302s Selecting previously unselected package libtemplate-tiny-perl. 302s Preparing to unpack .../63-libtemplate-tiny-perl_1.14-2_all.deb ... 302s Unpacking libtemplate-tiny-perl (1.14-2) ... 302s Selecting previously unselected package libthrowable-perl. 302s Preparing to unpack .../64-libthrowable-perl_1.001-2_all.deb ... 302s Unpacking libthrowable-perl (1.001-2) ... 302s Selecting previously unselected package libtype-tiny-perl. 302s Preparing to unpack .../65-libtype-tiny-perl_2.004000-1_all.deb ... 302s Unpacking libtype-tiny-perl (2.004000-1) ... 303s Selecting previously unselected package liburi-perl. 303s Preparing to unpack .../66-liburi-perl_5.28-1_all.deb ... 303s Unpacking liburi-perl (5.28-1) ... 303s Selecting previously unselected package liburi-nested-perl. 303s Preparing to unpack .../67-liburi-nested-perl_0.10-4_all.deb ... 303s Unpacking liburi-nested-perl (0.10-4) ... 303s Selecting previously unselected package liburi-db-perl. 303s Preparing to unpack .../68-liburi-db-perl_0.22-1_all.deb ... 303s Unpacking liburi-db-perl (0.22-1) ... 303s Selecting previously unselected package postgresql-client-common. 303s Preparing to unpack .../69-postgresql-client-common_262_all.deb ... 303s Unpacking postgresql-client-common (262) ... 303s Selecting previously unselected package postgresql-client-16. 303s Preparing to unpack .../70-postgresql-client-16_16.4-3_arm64.deb ... 303s Unpacking postgresql-client-16 (16.4-3) ... 303s Selecting previously unselected package postgresql-client. 303s Preparing to unpack .../71-postgresql-client_16+262_all.deb ... 303s Unpacking postgresql-client (16+262) ... 303s Selecting previously unselected package libdatetime-locale-perl. 303s Preparing to unpack .../72-libdatetime-locale-perl_1%3a1.41-1_all.deb ... 303s Unpacking libdatetime-locale-perl (1:1.41-1) ... 303s Selecting previously unselected package libdatetime-timezone-perl. 303s Preparing to unpack .../73-libdatetime-timezone-perl_1%3a2.62-1+2024a_all.deb ... 303s Unpacking libdatetime-timezone-perl (1:2.62-1+2024a) ... 303s Selecting previously unselected package libdatetime-perl. 303s Preparing to unpack .../74-libdatetime-perl_2%3a1.65-1build3_arm64.deb ... 303s Unpacking libdatetime-perl (2:1.65-1build3) ... 303s Selecting previously unselected package libipc-run3-perl. 303s Preparing to unpack .../75-libipc-run3-perl_0.049-1_all.deb ... 303s Unpacking libipc-run3-perl (0.049-1) ... 303s Selecting previously unselected package sqitch. 303s Preparing to unpack .../76-sqitch_1.4.1-1_all.deb ... 303s Unpacking sqitch (1.4.1-1) ... 303s Selecting previously unselected package pkg-perl-autopkgtest. 303s Preparing to unpack .../77-pkg-perl-autopkgtest_0.79_all.deb ... 303s Unpacking pkg-perl-autopkgtest (0.79) ... 303s Selecting previously unselected package autopkgtest-satdep. 303s Preparing to unpack .../78-2-autopkgtest-satdep.deb ... 303s Unpacking autopkgtest-satdep (0) ... 304s Setting up postgresql-client-common (262) ... 304s Setting up libfile-which-perl (1.27-2) ... 304s Setting up libclass-inspector-perl (1.36-3) ... 304s Setting up libdynaloader-functions-perl (0.004-1) ... 304s Setting up libclass-method-modifiers-perl (2.15-1) ... 304s Setting up libpath-class-perl (0.37-4) ... 304s Setting up libclone-perl:arm64 (0.47-1) ... 304s Setting up libsub-identify-perl (0.14-3build4) ... 304s Setting up libalgorithm-backoff-perl (0.010-1) ... 304s Setting up libtry-tiny-perl (0.31-2) ... 304s Setting up libpq5:arm64 (17.0-1) ... 304s Setting up libclone-choose-perl (0.010-2) ... 304s Setting up libclass-singleton-perl (1.6-2) ... 304s Setting up libencode-locale-perl (1.05-3) ... 304s Setting up libxstring-perl:arm64 (0.005-2build4) ... 304s Setting up libstring-shellquote-perl (1.04-3) ... 304s Setting up libsub-install-perl (0.929-1) ... 304s Setting up libclass-data-inheritable-perl (0.08-3) ... 304s Setting up libalgorithm-c3-perl (0.11-2) ... 304s Setting up libipc-system-simple-perl (1.30-2) ... 304s Setting up libperlio-utf8-strict-perl (0.010-1build4) ... 304s Setting up libvariable-magic-perl (0.64-1build1) ... 304s Setting up libpod-parser-perl (1.67-1) ... 304s Setting up libb-hooks-op-check-perl:arm64 (0.22-3build2) ... 304s Setting up liblist-moreutils-xs-perl (0.430-4build1) ... 304s Setting up libparams-util-perl (1.102-3build1) ... 304s Setting up libsub-exporter-progressive-perl (0.001013-3) ... 304s Setting up libsub-name-perl:arm64 (0.27-1build4) ... 304s Setting up librole-tiny-perl (2.002004-1) ... 304s Setting up libintl-perl (1.33-1build4) ... 304s Setting up libipc-run3-perl (0.049-1) ... 304s Setting up libfile-sharedir-perl (1.118-3) ... 304s Setting up libsub-quote-perl (2.006008-1ubuntu1) ... 304s Setting up libdevel-stacktrace-perl (2.0500-1) ... 304s Setting up libclass-xsaccessor-perl (1.19-4build5) ... 304s Setting up libtemplate-tiny-perl (1.14-2) ... 304s Setting up libexporter-tiny-perl (1.006002-1) ... 304s Setting up libterm-readkey-perl (2.38-2build5) ... 304s Setting up liburi-perl (5.28-1) ... 304s Setting up libdbi-perl:arm64 (1.645-1) ... 304s Setting up dctrl-tools (2.24-3build3) ... 304s Setting up autodep8 (0.28+nmu1ubuntu1) ... 304s Setting up libio-pager-perl (2.10-1) ... 304s Setting up liblist-moreutils-perl (0.430-2) ... 304s Setting up postgresql-client-16 (16.4-3) ... 304s update-alternatives: using /usr/share/postgresql/16/man/man1/psql.1.gz to provide /usr/share/man/man1/psql.1.gz (psql.1.gz) in auto mode 304s Setting up libhash-merge-perl (0.302-1) ... 304s Setting up libtype-tiny-perl (2.004000-1) ... 304s Setting up liburi-nested-perl (0.10-4) ... 304s Setting up libdbd-pg-perl (3.18.0-1build4) ... 304s Setting up libexception-class-perl (1.45-1) ... 304s Setting up libclass-c3-perl (0.35-2) ... 304s Setting up libdevel-callchecker-perl:arm64 (0.009-1build1) ... 304s Setting up liburi-db-perl (0.22-1) ... 304s Setting up libdata-optlist-perl (0.114-1) ... 304s Setting up pkg-perl-autopkgtest (0.79) ... 304s Setting up libmro-compat-perl (0.15-2) ... 304s Setting up libsub-exporter-perl (0.990-1) ... 304s Setting up libeval-closure-perl (0.14-3) ... 304s Setting up libparams-validationcompiler-perl (0.31-1) ... 304s Setting up postgresql-client (16+262) ... 304s Setting up libparams-classify-perl:arm64 (0.015-2build6) ... 304s Setting up libmodule-runtime-perl (0.016-2) ... 304s Setting up libstring-formatter-perl (1.235-1) ... 304s Setting up libmodule-implementation-perl (0.09-2) ... 304s Setting up libpackage-stash-perl (0.40-1) ... 304s Setting up libimport-into-perl (1.002005-2) ... 304s Setting up libmoo-perl (2.005005-1) ... 304s Setting up libspecio-perl (0.48-1) ... 304s Setting up libmoox-types-mooselike-perl (0.29-2) ... 304s Setting up libb-hooks-endofscope-perl (0.28-1) ... 304s Setting up libconfig-gitlike-perl (1.18-2) ... 304s Setting up libthrowable-perl (1.001-2) ... 304s Setting up libnamespace-clean-perl (0.27-2) ... 304s Setting up libnamespace-autoclean-perl (0.29-2) ... 304s Setting up libdatetime-locale-perl (1:1.41-1) ... 304s Setting up libdatetime-timezone-perl (1:2.62-1+2024a) ... 304s Setting up libdatetime-perl (2:1.65-1build3) ... 304s Setting up sqitch (1.4.1-1) ... 304s Setting up autopkgtest-satdep (0) ... 304s Processing triggers for man-db (2.12.1-3) ... 306s Processing triggers for libc-bin (2.40-1ubuntu3) ... 311s (Reading database ... 85450 files and directories currently installed.) 311s Removing autopkgtest-satdep (0) ... 313s autopkgtest [18:28:15]: test autodep8-perl: /usr/share/pkg-perl-autopkgtest/runner runtime-deps 313s autopkgtest [18:28:15]: test autodep8-perl: [----------------------- 314s /usr/share/pkg-perl-autopkgtest/runtime-deps.d/use.t .. 314s 1..4 314s ok 1 - /usr/bin/perl -w -M"App::Sqitch" -e 1 2>&1 exited successfully 314s ok 2 - /usr/bin/perl -w -M"App::Sqitch" -e 1 2>&1 produced no (non-whitelisted) output 314s ok 3 - env PERL_DL_NONLAZY=1 /usr/bin/perl -w -M"App::Sqitch" -e 1 2>&1 exited successfully 314s ok 4 - env PERL_DL_NONLAZY=1 /usr/bin/perl -w -M"App::Sqitch" -e 1 2>&1 produced no (non-whitelisted) output 314s ok 314s All tests successful. 314s Files=1, Tests=4, 0 wallclock secs ( 0.02 usr 0.00 sys + 0.55 cusr 0.11 csys = 0.68 CPU) 314s Result: PASS 315s autopkgtest [18:28:17]: test autodep8-perl: -----------------------] 315s autodep8-perl PASS (superficial) 315s autopkgtest [18:28:17]: test autodep8-perl: - - - - - - - - - - results - - - - - - - - - - 316s autopkgtest [18:28:18]: test autodep8-perl-recommends: preparing testbed 317s Reading package lists... 317s Building dependency tree... 317s Reading state information... 318s Starting pkgProblemResolver with broken count: 0 318s Starting 2 pkgProblemResolver with broken count: 0 318s Done 319s The following additional packages will be installed: 319s libappconfig-perl libtemplate-perl libtype-tiny-xs-perl 319s Suggested packages: 319s libtemplate-plugin-gd-perl libtemplate-plugin-xml-perl 319s The following NEW packages will be installed: 319s autopkgtest-satdep libappconfig-perl libtemplate-perl libtype-tiny-xs-perl 319s 0 upgraded, 4 newly installed, 0 to remove and 0 not upgraded. 319s Need to get 587 kB/588 kB of archives. 319s After this operation, 1808 kB of additional disk space will be used. 319s Get:1 /tmp/autopkgtest.NaAPUz/3-autopkgtest-satdep.deb autopkgtest-satdep arm64 0 [752 B] 319s Get:2 http://ftpmaster.internal/ubuntu plucky/main arm64 libappconfig-perl all 1.71-2.3 [64.8 kB] 319s Get:3 http://ftpmaster.internal/ubuntu plucky/main arm64 libtemplate-perl arm64 2.27-1build11 [497 kB] 319s Get:4 http://ftpmaster.internal/ubuntu plucky/universe arm64 libtype-tiny-xs-perl arm64 0.025-2build1 [25.2 kB] 320s Fetched 587 kB in 1s (1034 kB/s) 320s Selecting previously unselected package libappconfig-perl. 320s (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 ... 85450 files and directories currently installed.) 320s Preparing to unpack .../libappconfig-perl_1.71-2.3_all.deb ... 320s Unpacking libappconfig-perl (1.71-2.3) ... 320s Selecting previously unselected package libtemplate-perl. 320s Preparing to unpack .../libtemplate-perl_2.27-1build11_arm64.deb ... 320s Unpacking libtemplate-perl (2.27-1build11) ... 320s Selecting previously unselected package libtype-tiny-xs-perl:arm64. 320s Preparing to unpack .../libtype-tiny-xs-perl_0.025-2build1_arm64.deb ... 320s Unpacking libtype-tiny-xs-perl:arm64 (0.025-2build1) ... 320s Selecting previously unselected package autopkgtest-satdep. 320s Preparing to unpack .../3-autopkgtest-satdep.deb ... 320s Unpacking autopkgtest-satdep (0) ... 320s Setting up libtype-tiny-xs-perl:arm64 (0.025-2build1) ... 320s Setting up libappconfig-perl (1.71-2.3) ... 320s Setting up libtemplate-perl (2.27-1build11) ... 320s Setting up autopkgtest-satdep (0) ... 320s Processing triggers for man-db (2.12.1-3) ... 323s (Reading database ... 85634 files and directories currently installed.) 323s Removing autopkgtest-satdep (0) ... 324s autopkgtest [18:28:26]: test autodep8-perl-recommends: /usr/share/pkg-perl-autopkgtest/runner runtime-deps-and-recommends 324s autopkgtest [18:28:26]: test autodep8-perl-recommends: [----------------------- 324s Test skipped 325s autopkgtest [18:28:27]: test autodep8-perl-recommends: -----------------------] 325s autopkgtest [18:28:27]: test autodep8-perl-recommends: - - - - - - - - - - results - - - - - - - - - - 325s autodep8-perl-recommends SKIP exit status 77 and marked as skippable 326s autopkgtest [18:28:28]: @@@@@@@@@@@@@@@@@@@@ summary 326s autodep8-perl-build-deps PASS 326s autodep8-perl PASS (superficial) 326s autodep8-perl-recommends SKIP exit status 77 and marked as skippable 341s nova [W] Skipping flock in bos03-arm64 341s Creating nova instance adt-plucky-arm64-sqitch-20241101-182301-juju-7f2275-prod-proposed-migration-environment-2-27160b3b-f700-41f0-a1a3-782a721947a1 from image adt/ubuntu-plucky-arm64-server-20241101.img (UUID 520a937f-514a-4e80-b76b-163a8c247e3e)... 341s nova [W] Skipping flock in bos03-arm64 341s Creating nova instance adt-plucky-arm64-sqitch-20241101-182301-juju-7f2275-prod-proposed-migration-environment-2-27160b3b-f700-41f0-a1a3-782a721947a1 from image adt/ubuntu-plucky-arm64-server-20241101.img (UUID 520a937f-514a-4e80-b76b-163a8c247e3e)...