Diff of the two buildlogs: -- --- b1/build.log 2024-12-20 18:25:21.309692688 +0000 +++ b2/build.log 2024-12-20 18:26:08.991517662 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Thu Jan 22 12:47:35 -12 2026 -I: pbuilder-time-stamp: 1769129255 +I: Current time: Sat Dec 21 08:25:24 +14 2024 +I: pbuilder-time-stamp: 1734719124 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -26,52 +26,84 @@ dpkg-source: info: unpacking ruby-tty-prompt_0.23.1-1.debian.tar.xz I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/601336/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/D01_modify_environment starting +debug: Running on codethink02-arm64. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Dec 20 18:25 /bin/sh -> /bin/bash +I: Setting pbuilder2's login shell to /bin/bash +I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build/reproducible-path' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='arm64' - DEBIAN_FRONTEND='noninteractive' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") + BASH_VERSION='5.2.37(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=arm64 + DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='arm64' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=aarch64 + HOST_ARCH=arm64 IFS=' ' - INVOCATION_ID='ef2dee2a28a94e9aac567ef99b275456' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - MAIL='/var/mail/root' - OPTIND='1' - PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' - PBCURRENTCOMMANDLINEOPERATION='build' - PBUILDER_OPERATION='build' - PBUILDER_PKGDATADIR='/usr/share/pbuilder' - PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' - PBUILDER_SYSCONFDIR='/etc' - PPID='601336' - PS1='# ' - PS2='> ' + INVOCATION_ID=2258231616844df4922c49a0be293a94 + LANG=C + LANGUAGE=nl_BE:nl + LC_ALL=C + MACHTYPE=aarch64-unknown-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=993729 PS4='+ ' - PWD='/' - SHELL='/bin/bash' - SHLVL='2' - SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.f46EiPPo/pbuilderrc_90hW --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.f46EiPPo/b1 --logfile b1/build.log ruby-tty-prompt_0.23.1-1.dsc' - SUDO_GID='109' - SUDO_UID='104' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://192.168.101.4:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.f46EiPPo/pbuilderrc_z1gz --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.f46EiPPo/b2 --logfile b2/build.log ruby-tty-prompt_0.23.1-1.dsc' + SUDO_GID=109 + SUDO_UID=104 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://192.168.101.4:3128 I: uname -a - Linux codethink01-arm64 6.1.0-28-cloud-arm64 #1 SMP Debian 6.1.119-1 (2024-11-22) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-28-cloud-arm64 #1 SMP Debian 6.1.119-1 (2024-11-22) aarch64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/601336/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -258,7 +290,7 @@ Get: 139 http://deb.debian.org/debian unstable/main arm64 ruby-tty-screen all 0.8.1-2 [8924 B] Get: 140 http://deb.debian.org/debian unstable/main arm64 ruby-wisper all 2.0.1-2 [12.7 kB] Get: 141 http://deb.debian.org/debian unstable/main arm64 ruby-tty-reader all 0.9.0-1 [18.1 kB] -Fetched 43.0 MB in 0s (123 MB/s) +Fetched 43.0 MB in 0s (150 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:arm64. (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 ... 20084 files and directories currently installed.) @@ -733,8 +765,8 @@ Setting up tzdata (2024b-4) ... Current default time zone: 'Etc/UTC' -Local time is now: Fri Jan 23 00:48:01 UTC 2026. -Universal Time is now: Fri Jan 23 00:48:01 UTC 2026. +Local time is now: Fri Dec 20 18:25:45 UTC 2024. +Universal Time is now: Fri Dec 20 18:25:45 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-tty-color (0.6.0-1) ... @@ -858,7 +890,11 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/reproducible-path/ruby-tty-prompt-0.23.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ruby-tty-prompt_0.23.1-1_source.changes +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/ruby-tty-prompt-0.23.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ruby-tty-prompt_0.23.1-1_source.changes dpkg-buildpackage: info: source package ruby-tty-prompt dpkg-buildpackage: info: source version 0.23.1-1 dpkg-buildpackage: info: source distribution unstable @@ -892,7 +928,7 @@ │ ruby-tty-prompt: Installing files and building extensions for ruby3.1 │ └──────────────────────────────────────────────────────────────────────────────┘ -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20260122-607698-l07cjo/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20241221-1000707-37rmpc/gemspec Failed to load /dev/null because it doesn't contain valid YAML hash WARNING: open-ended dependency on rake (>= 0, development) is not recommended use a bounded requirement, such as '~> x.y' @@ -904,7 +940,7 @@ Name: tty-prompt Version: 0.23.1 File: tty-prompt-0.23.1.gem -/usr/bin/ruby3.1 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-tty-prompt/usr/share/rubygems-integration/all /tmp/d20260122-607698-l07cjo/tty-prompt-0.23.1.gem +/usr/bin/ruby3.1 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-tty-prompt/usr/share/rubygems-integration/all /tmp/d20241221-1000707-37rmpc/tty-prompt-0.23.1.gem Failed to load /dev/null because it doesn't contain valid YAML hash /build/reproducible-path/ruby-tty-prompt-0.23.1/debian/ruby-tty-prompt/usr/share/rubygems-integration/all/gems/tty-prompt-0.23.1/lib/tty-prompt.rb /build/reproducible-path/ruby-tty-prompt-0.23.1/debian/ruby-tty-prompt/usr/share/rubygems-integration/all/gems/tty-prompt-0.23.1/lib/tty/prompt.rb @@ -973,707 +1009,707 @@ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-tty-prompt-0.23.1/debian/ruby-tty-prompt/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-tty-prompt-0.23.1/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.1.0:/var/lib/gems/3.1.0:/usr/local/lib/ruby/gems/3.1.0:/usr/lib/ruby/gems/3.1.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.1.0:/usr/share/rubygems-integration/3.1.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.1.0 ruby3.1 -S rake --rakelibdir /gem2deb-nonexistent -f debian/ruby-tests.rake /usr/bin/ruby3.1 -I/usr/share/rubygems-integration/all/gems/rspec-support-3.13.1/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation -Randomized with seed 26751 +Randomized with seed 3697 -TTY::Prompt::Question::Modifier#letter_case - nil (empty user input) - down returns nil - up returns nil - capitalize returns nil - string - changes to lower case - capitalizes text - changes to uppercase +TTY::Prompt#suggest + suggests a single match for two characters + suggests with different text and indentation + suggests a single match for one character + suggests few matches -TTY::Prompt::Question#in +TTY::Prompt::Evaluator + checks chained validation procs + checks chained validation objects + +TTY::Prompt::Choices#each + iterates over collection + +TTY::Prompt#expand + sets quiet mode through DSL + expands help option and then defaults + expands default option + fails to expand due to reserve key + changes default option + fails to expand due to duplicate key + specifies options through DSL and executes value + expands chosen option with extra information + specifies options through DSL + fails to expand due to wrong key length + informs about invalid input when automatically expanding hint + sets quiet mode + fails to expand due to lack of key attribute + automatically expands hint + +TTY::Prompt#say + prints an empty message + with tab or space + prints + with color + prints message with ansi color + prints message with ansi color without newline + without color + prints message without ansi + with new line + prints a message without newline + prints a message with newline within text and blank space + prints a message with newline + prints a message with implicit newline + prints a message with newline within text + +TTY::Prompt confirmation + #yes? No entry for terminal type "unknown"; using dumb terminal settings. No entry for terminal type "unknown"; using dumb terminal settings. No entry for terminal type "unknown"; using dumb terminal settings. - reads range from option - provides default error message when wrong input - reads number within string range - reads number within digit range - overwrites default error message when wrong input - reads letters within range + accepts regex conflicting characters as suffix + fails to infer default value from a word + customizes question through DSL + disagrees with question + changes default + defaults suffix and converter + assumes default true + infers default value from a word + customizes question through options + agrees with question + warns about invalid entry when using defaults + defaults positive and negative + obeys quiet mode + #no? + warns about invalid entry when using defaults + customizes question through DSL + changes default + disagrees with question + defaults suffix and converter + agrees with question + assumes default false -TTY::Prompt::Question#validate - deprecates :validation option - validates input with proc - validates input with regex - understands custom validation like :email - provides custom error message for wrong input - provides default error message for wrong input +TTY::Prompt::Paginator#paginate + paginates items not matching per_page count + ignores per_page when less items + starts with default selection + finds both start and end index for current selection + doesn't accept invalid pagination + ignores per_page when equal items + paginates items matching per_page count -TTY::Prompt::Timer - times out loop execution - registers a tick event +TTY::Prompt::Question#default + uses default value in block + uses default value -TTY::Prompt::Question convert to hash - converts answer to a hash - converts answer to a hash of integer values - converts answer to a hash of boolean values +TTY::Prompt::Choices#enabled + returns only choices which aren't disabled -TTY::Prompt::Choices#<< - adds choice to collection +TTY::Prompt + raises when default choice name is not found + selects default option when return pressed immediately + switches through pages with tab key + selects option through DSL with key and value + doesn't paginate short selections + changes global symbols + sets quiet mode + selects option through DSL + paginates long selections + selects default choice by name + changes global symbols through DSL + changes colors for selection, hint and error + doesn't cycle around by default + shows pages matching input + cycles around when configured to do so + sets choice value to nil through DSL + raises when default name matches a disabled choice + selects option by index from the list + displays error with unrecognized input + raises configuration error when default is higher than number of choices + sets quiet mode through DSL + with :disabled choice + finds first non-disabled index + fails when active item is also disabled + omits disabled choice when navigating with numbers + doesn't allow to choose disabled choice and defaults -TTY::Prompt::Question convert to array - converts answer to an array of integers - converts answer to an array - converts answer to an array of booleans +TTY::Prompt::BlockPaginator#paginate + starts with default selection + doesn't accept invalid pagination + finds both start and end index for current selection + paginates items matching per_page count + paginates items not matching per_page count + ignores per_page when less items + ignores per_page when equal items -TTY::Prompt#ok - changes color to cyan - prints multiple lines in green - prints text in green +TTY::Prompt#select + sets choice name & value through DSL + selects by default first option + verifies default index range + raises when default choice doesn't match any choices + sets prompt prefix + raises when default choice matches disabled choice + sets default option through hash syntax + sets choice name through DSL + changes to never show help + changes to always show help + sets choice value to proc and executes it + selects default choice by name + doesn't paginate short selections + verifies default index format + changes selected item color & marker + sets choice value to nil + configures quiet mode + changes help text through DSL + sets choices and single choice through DSL + changes help text + allows navigation using events without errors + sets quiet mode through DSL + sets choice name and value + sets choice name & value through DSL + when paginated + paginates long selections + paginates long selections through DSL + paginates choices as hash object + combines up/down navigation with left/right + navigates left and right + navigates pages up/down with disabled items + navigates unevenly paged output with right arrow until the end of selection + navigates pages left/right with disabled items + navigates evenly paged output with right arrow until end of selection + with filter + doesn't exit when there are no matching entries + filters and chooses the first of multiple matching entries + filters and chooses a uniquely matching entry, ignoring case + filters based on alphanumeric and punctuation characters + navigates left and right with filtered items + doesn't allow mixing enumeration and filter + cancels a selection + with :cycle option + cycles around disabled items + cycles around when configured to do so + cycles pages left/right with disabled items + cycles choices using left/right arrows + doesn't cycle by default + cycles filtered choices left and right + with :disabled choice + omits disabled choice when navigating menu + omits disabled choice when number key is pressed + prevents setting default to disabled choice + sets active to be first non-disabled choice + doesn't show disabled choice when filtering choices -TTY::Prompt::Evaluator - checks chained validation objects - checks chained validation procs +TTY::Prompt::Question::Validation#coerce + fails to coerce pattern into validation + coerces lambda into proc + doesn't coerce symbols + coerces into regex -TTY::Prompt::Statement.new - displays prompt message in color - forces newline after the prompt message +TTY::Prompt#mask + masks output with custom character + masks output by default + ignores mask if echo is off + masks with unicode character + validates input -TTY::Prompt::Question#echo - asks with echo off - asks with echo on +TTY::Prompt::Result + checks value to be invalid + checks value to be valid -TTY::Prompt#subscribe - subscribes to key events only for the current prompt +TTY::Prompt::Question#keypress + asks for a keypress with echo off + asks for a keypress with echo on + receives line feed with echo on + timeouts when no key provided + interrupts input -TTY::Prompt#ask - asks question - sets quiet mode - asks an empty question and returns nil if EOF is sent to stdin - overwrites global settings - asks a question with block - asks an empty question - changes question color - asks an empty question with prepopulated value - permits empty default parameter - asks question with prepopulated value - sets quiet mode through DSL - asks a question with a prefix [?] - permits nil default parameter +TTY::Prompt#warn + displays message with option + changes default yellow color to cyan + displays many messages + displays one message -TTY::Prompt#slider - specifies choices through DSL - mixes choices as values and via DSL and keeps ordering - specifies quiet mode through DSL - specifies choices instead of calculated range - changes all display symbols per instance - doesn't allow values outside of range - sets choice value to proc and executes it - changes all display symbols - changes display colors - specifies range through DSL - specifies choices through DSL - specifies ranges & step - changes to never show help - specifies default value - formats via proc - sets default choice by index number - changes to always show help - sets default choice by name - sets quiet mode +TTY::Prompt#decorate + doesn't decorate when disabled + doesn't decorate without additional arguments + doesn't decorate empty string + decorates with a proc + decorates with a callable object + decorates string with named colors TTY::Prompt::Distance.distance + when empty + is expected to eql 0 + when similar + is expected to eql 1 when unicode is expected to eql 1 - when prefix - is expected to eql 3 when similar is expected to eql 0 when end similar is expected to eql 3 + when prefix + is expected to eql 3 + when contain similar + is expected to eql 2 when similar - is expected to eql 1 - when empty - is expected to eql 0 - when single char is expected to eql 2 - when contain similar + when single char is expected to eql 2 with one non empty is expected to eql 3 - when similar - is expected to eql 2 when nil is expected to eql 0 -TTY::Prompt::Question convert char - reads single character - -TTY::Prompt::Question#multiline - uses defualt when no input - changes help text - reads no lines - sets quiet mode - reads multiple lines with empty lines +TTY::Prompt::Question convert to array + converts answer to an array of integers + converts answer to an array of booleans + converts answer to an array -TTY::Prompt#say - prints an empty message - with color - prints message with ansi color without newline - prints message with ansi color - without color - prints message without ansi - with new line - prints a message with newline - prints a message with newline within text - prints a message without newline - prints a message with newline within text and blank space - prints a message with implicit newline - with tab or space - prints +TTY::Prompt::Choices#pluck + plucks choice by key name TTY::Prompt - raises configuration error when default is higher than number of choices - raises when default choice name is not found - cycles around when configured to do so - selects option by index from the list - changes colors for selection, hint and error - paginates long selections - doesn't paginate short selections - shows pages matching input - switches through pages with tab key - raises when default name matches a disabled choice - displays error with unrecognized input - selects option through DSL - doesn't cycle around by default - sets quiet mode through DSL - sets quiet mode - selects option through DSL with key and value - changes global symbols through DSL - changes global symbols - selects default option when return pressed immediately - selects default choice by name + sets default options through hash syntax + sets default choices using names sets choice value to nil through DSL - with :disabled choice - finds first non-disabled index - doesn't allow to choose disabled choice and defaults - fails when active item is also disabled - omits disabled choice when navigating with numbers + sets choice name and value through DSL + selects item when space pressed but doesn't echo item if echo: false + sets default options through DSL syntax + raises error for defaults out of range + changes selected item color & marker + selects nothing when return pressed immediately + sets choice custom values + changes to never show help + selects item when space pressed + sets prompt prefix + sets prompt to quiet mode + changes help text and color + changes to always show help + with filter + doesn't lose the selection when switching between filters + with :max + disables Ctrl+a/Ctrl+r selection when :max option is specified + limits number of choices + with :cycle + cycles choices using left/right arrows + cycles filtered choices left and right + cycles when configured to do so + doesn't cycle by default + with :min + requires number of choices + with :disabled + adjusts active index to match first non-disabled choice + fails when default item is also disabled + omits disabled choice when nagivating menu + selects all non-disabled choices when ctrl+a is pressed + omits disabled choice when number key is pressed + when paginated + navigates evenly paged output with right arrow until end of selection + navigates unevenly paged output with right arrow until the end of selection + combines up/down navigation with left/right + reverts selection accross pages with Ctrl+r + paginates long selections through DSL + doesn't paginate short selections + paginates choices as hash object + navigates left and right + selects all paged choices with ctrl+a + paginates long selections -TTY::Prompt::Choices#pluck - plucks choice by key name +TTY::Prompt#ok + prints multiple lines in green + changes color to cyan + prints text in green -TTY::Prompt::Choices#each - iterates over collection +TTY::Prompt::Question convert char + reads single character -TTY::Prompt::Question convert range - converts with valid range - fails to convert to range +TTY::Prompt#ask + asks a question with block + asks an empty question and returns nil if EOF is sent to stdin + asks question + permits nil default parameter + asks an empty question + sets quiet mode + sets quiet mode through DSL + asks a question with a prefix [?] + asks question with prepopulated value + changes question color + permits empty default parameter + asks an empty question with prepopulated value + overwrites global settings TTY::Prompt#error - displays one message changes default red color to cyan - displays many messages + displays one message displays message with option + displays many messages TTY::Prompt::Question#modify + converts to upper case collapses whitespace + strips and collapses whitespace preserves answer for unkown modification trims whitespace - converts to upper case - strips and collapses whitespace - -TTY::Prompt::Question::Modifier#apply_to - doesn't apply modifiers - combines whitespace & letter case modifications - combines letter case & whitespace modifications - -TTY::Prompt::Question::Validation#call - validates with a proc - validates with custom name - fails validation when not maching pattern - validates successfully when the value matches pattern - validates nil input - -TTY::Prompt::Question convert path - converts pathname - -TTY::Prompt#collect - collects more than one answer - when receiving multiple answers - overrides a non-array key on multiple answers - collects as a list if values method used in chain - collects as a list if values method used in chain with block - with multiple keys - collects into the appropriate keys - -TTY::Prompt::Question#required - requires value to be present - uses required in validation check - requires value to be present with option - doesn't require value to be present - -TTY::Prompt::SelectedChoices - clears choices - initializes with selected choices - inserts choices by the index order - inserts and deletes choices - -TTY::Prompt::Choices#enabled - returns only choices which aren't disabled - -TTY::Prompt::BlockPaginator#paginate - paginates items matching per_page count - doesn't accept invalid pagination - paginates items not matching per_page count - starts with default selection - finds both start and end index for current selection - ignores per_page when less items - ignores per_page when equal items - -TTY::Prompt::Question#initialize - is expected to eq true - is expected to eq TTY::Prompt::Question::UndefinedSetting - is expected to eq [] -TTY::Prompt::Question convert file - converts to file - -TTY::Prompt::Question convert regexp - converts regex - -TTY::Prompt::Question#keypress - receives line feed with echo on - asks for a keypress with echo off - timeouts when no key provided - asks for a keypress with echo on - interrupts input - -TTY::Prompt::Question::Validation#coerce - fails to coerce pattern into validation - coerces lambda into proc - coerces into regex - doesn't coerce symbols - -TTY::Prompt::Question convert numbers - fails to convert float - fails to convert integer - converts float - converts integer - -TTY::Utils - #deep_copy - copies "" - copies ["foo", {:bar=>"baz"}, :fum, 11] - #blank? - detects blank of "foo" as false - detects blank of :foo as false - detects blank of "\n\t " as true - detects blank of " " as true - detects blank of "" as true - detects blank of nil as true - -TTY::Prompt::Choice#== - is true with the same name and value attributes - is false with non-choice object - is false with different name attribute - is false with different value attribute - is false with different key attribute - -TTY::Prompt#new - sets input stream - sets prefix - sets output stream - -TTY::Prompt::Question convert custom - converts response with custom conversion - -TTY::Prompt::Paginator#paginate - paginates items not matching per_page count - doesn't accept invalid pagination - ignores per_page when equal items - paginates items matching per_page count - finds both start and end index for current selection - ignores per_page when less items - starts with default selection +TTY::Prompt::Question convert to hash + converts answer to a hash of integer values + converts answer to a hash of boolean values + converts answer to a hash TTY::Prompt::Converters - :boolean - converts "y" to true - converts "true" to true - converts "1" to true - converts "FALSE" to false - converts "YES" to true - converts "0" to false - converts "t" to true - converts "unknown" to "undefined" - converts "no" to false - converts "f" to false - :time - converts "11:12:13" to 2026-01-22 11:12:13 -1200 - converts "unknown" to "undefined" - :integer - converts "12" to 12 - converts "unknown" to "undefined" - :char - converts "input" to "i" - converts "" to nil - :uri - converts "http://foobar.com" to # - :datetime - converts "2020/05/21 11:12:13" to # - converts "unknown" to "undefined" :hash/:map - converts "a:1 b:2 c:3" to {"a"=>1, "b"=>2, "c"=>3} - converts "a=1" to {:a=>"1"} + converts ["a:1", "b:2", "c:3"] to {:a=>"1", :b=>"2", :c=>"3"} converts "a:t b:f c:t" to {:a=>:t, :b=>:f, :c=>:t} + converts "a:1 b:2 c:3" to {:a=>1, :b=>2, :c=>3} + converts "a=1&b=2&a=3" to {:a=>["1", "3"], :b=>"2"} + converts "a:1 b:2 c:3" to {:a=>1, :b=>2, :c=>3} converts "a:t b:f c:t" to {:a=>true, :b=>false, :c=>true} - converts ["a=1", "b=2", "c=3"] to {:a=>"1", :b=>"2", :c=>"3"} - converts "a:1 b:2 c:3" to {:a=>1.0, :b=>2.0, :c=>3.0} converts "a:1 b:2 c:3" to {"a"=>1, "b"=>2, "c"=>3} - converts "a:1 b:2" to {:a=>"1", :b=>"2"} + converts "a=1&b=2" to {:a=>"1", :b=>"2"} converts "a:1 b:2 a:3" to {:a=>["1", "3"], :b=>"2"} + converts "a:1 b:2" to {:a=>"1", :b=>"2"} + converts "a=1" to {:a=>"1"} + converts "a:1 b:2 c:3" to {"a"=>1, "b"=>2, "c"=>3} + converts "a:1 b:2 c:3" to {:a=>1.0, :b=>2.0, :c=>3.0} converts "a=&b=2" to {:a=>"", :b=>"2"} - converts "a:t b:f c:t" to {:a=>true, :b=>false, :c=>true} - converts "a=1&b=2" to {:a=>"1", :b=>"2"} - converts ["a:1", "b:2", "c:3"] to {:a=>"1", :b=>"2", :c=>"3"} converts "" to {} + converts ["a=1", "b=2", "c=3"] to {:a=>"1", :b=>"2", :c=>"3"} converts "a:t b:f c:t" to {:a=>/t/, :b=>/f/, :c=>/t/} - converts "a:1 b:2 c:3" to {:a=>1, :b=>2, :c=>3} - converts "a:1 b:2 c:3" to {:a=>1, :b=>2, :c=>3} - converts "a=1&b=2&a=3" to {:a=>["1", "3"], :b=>"2"} + converts "a:t b:f c:t" to {:a=>true, :b=>false, :c=>true} + :boolean + converts "no" to false + converts "YES" to true + converts "unknown" to "undefined" + converts "0" to false + converts "f" to false + converts "1" to true + converts "y" to true + converts "FALSE" to false + converts "t" to true + converts "true" to true + :range + converts "1.2-5.0" to 1.2..5.0 + converts "a..z" to "a".."z" + converts "unknown" to "undefined" + converts "1...10" to 1...10 + converts "1-10" to 1..10 + converts "1 . . . 10" to 1...10 + converts "-5--1" to -5..-1 + converts "1.0" to 1.0..1.0 + converts "a . . . z" to "a"..."z" + converts 1..10 to 1..10 + converts "1 , 10" to 1..10 + converts "1..10" to 1..10 + converts "1" to 1..1 + :regexp + converts "\\d+" to /\d+/ + converts "unknown" to /unknown/ + :datetime + converts "unknown" to "undefined" + converts "2020/05/21 11:12:13" to # + :char + converts "" to nil + converts "input" to "i" :array/:list + converts ["a", "b", "c"] to ["a", "b", "c"] + converts "t,t,f" to [true, true, false] + converts "a,b,c" to [:a, :b, :c] + converts "1,2,3" to [1.0, 2.0, 3.0] + converts "a,b,c" to [/a/, /b/, /c/] + converts "a, , c" to ["a", "c"] + converts ",," to [] converts "a, b\\, c" to ["a", "b, c"] converts "t,t,f" to [true, true, false] - converts "1,2,3" to [1, 2, 3] - converts "1,2,3" to [1, 2, 3] converts "t,t,f" to [true, true, false] - converts ",b,c" to ["b", "c"] - converts "a,b,c" to [/a/, /b/, /c/] converts "a,b,c" to [:a, :b, :c] - converts ",," to [] - converts "a , b , c" to ["a", "b", "c"] converts "1,2,3" to [1, 2, 3] - converts "1,2,3" to [1.0, 2.0, 3.0] converts "a,b,c" to ["a", "b", "c"] - converts ["a", "b", "c"] to ["a", "b", "c"] - converts "t,t,f" to [true, true, false] + converts "1,2,3" to [1, 2, 3] converts "1,2,3" to [1.0, 2.0, 3.0] converts "1,2,3" to [1, 2, 3] - converts "a, , c" to ["a", "c"] - converts "a,b,c" to [:a, :b, :c] - :regexp - converts "unknown" to /unknown/ - converts "\\d+" to /\d+/ - :string - converts "input\n" to "input" - converts "" to "" + converts "1,2,3" to [1, 2, 3] + converts ",b,c" to ["b", "c"] + converts "a , b , c" to ["a", "b", "c"] + :integer + converts "12" to 12 + converts "unknown" to "undefined" :float converts "12.3" to 12.3 converts "unknown" to "undefined" - :range - converts 1..10 to 1..10 - converts "1.2-5.0" to 1.2..5.0 - converts "-5--1" to -5..-1 - converts "1 . . . 10" to 1...10 - converts "1-10" to 1..10 - converts "1 , 10" to 1..10 - converts "1..10" to 1..10 - converts "1.0" to 1.0..1.0 - converts "1" to 1..1 - converts "unknown" to "undefined" - converts "1...10" to 1...10 - converts "a..z" to "a".."z" - converts "a . . . z" to "a"..."z" - :path - converts "/foo/bar/baz" to # :date converts "unknown" to "undefined" converts "2020/05/21" to # + :string + converts "" to "" + converts "input\n" to "input" + :time + converts "unknown" to "undefined" + converts "11:12:13" to 2024-12-21 11:12:13 +1400 + :path + converts "/foo/bar/baz" to # + :uri + converts "http://foobar.com" to # -TTY::Prompt#suggest - suggests a single match for one character - suggests few matches - suggests a single match for two characters - suggests with different text and indentation +TTY::Prompt::Question convert string + converts string + converts symbol -TTY::Prompt::Result - checks value to be invalid - checks value to be valid +TTY::Prompt#slider + specifies ranges & step + specifies quiet mode through DSL + changes all display symbols + sets default choice by index number + mixes choices as values and via DSL and keeps ordering + doesn't allow values outside of range + specifies default value + changes to never show help + sets quiet mode + sets choice value to proc and executes it + specifies choices instead of calculated range + specifies range through DSL + formats via proc + sets default choice by name + specifies choices through DSL + changes all display symbols per instance + changes to always show help + changes display colors + specifies choices through DSL -TTY::Prompt::Question::Modifier#whitespace - string with whitespaces - trims whitespace - collapses text - removes whitespace - chomps whitespace - nil (empty user input) - trim returns nil - chomp returns nil - collapse returns nil - remove returns nil +TTY::Prompt::SelectedChoices + clears choices + initializes with selected choices + inserts choices by the index order + inserts and deletes choices -TTY::Prompt::Choices.new - creates choices collection +TTY::Prompt::Question#multiline + uses defualt when no input + sets quiet mode + changes help text + reads multiple lines with empty lines + reads no lines -TTY::Prompt::Choice#from - creates choice from a hash with name, value and key keys - creates choice from a hash with a value - creates disabled choice - creates choice from an array with a hash without value key - creates choice from an array with name and false value - creates choice from an array with name and a value - creates choice from an array with key-value pair - creates choice from an arbitrary object that responds to to_s call - creates choice from a symbol - creates choice from a string - creates choice from an array with name only and defaults value - creates choice from array with name and nil value - creates choice from an array with a hash with name and value keys - creates choice from a hash with a nil value - skips Choice instance +TTY::Prompt::Timer + registers a tick event + times out loop execution -TTY::Prompt::Question convert bool - converts negative boolean - converts single positive boolean - fails to convert boolean - converts positive boolean - handles default values - handles default values +TTY::Prompt::Question convert custom + converts response with custom conversion -TTY::Prompt::Question convert string - converts string - converts symbol +TTY::Prompt::Choices#<< + adds choice to collection -TTY::Prompt#expand - specifies options through DSL and executes value - expands chosen option with extra information - fails to expand due to reserve key - informs about invalid input when automatically expanding hint - expands help option and then defaults - specifies options through DSL - automatically expands hint - changes default option - sets quiet mode through DSL - sets quiet mode - fails to expand due to wrong key length - fails to expand due to duplicate key - expands default option - fails to expand due to lack of key attribute +TTY::Prompt#new + sets input stream + sets output stream + sets prefix -TTY::Prompt::Question#default - uses default value in block - uses default value +TTY::Prompt::Question convert numbers + converts integer + fails to convert float + converts float + fails to convert integer -TTY::Prompt#inspect - inspects instance attributes +TTY::Prompt::Question convert range + fails to convert to range + converts with valid range -TTY::Prompt#select - changes help text - sets choice name through DSL - sets default option through hash syntax - changes to always show help - sets choices and single choice through DSL - configures quiet mode - allows navigation using events without errors - raises when default choice matches disabled choice - changes help text through DSL - sets choice value to nil - sets quiet mode through DSL - verifies default index range - doesn't paginate short selections - sets choice name and value - changes selected item color & marker - raises when default choice doesn't match any choices - changes to never show help - sets choice value to proc and executes it - selects default choice by name - sets prompt prefix - selects by default first option - verifies default index format - sets choice name & value through DSL - sets choice name & value through DSL - with :disabled choice - sets active to be first non-disabled choice - doesn't show disabled choice when filtering choices - omits disabled choice when number key is pressed - prevents setting default to disabled choice - omits disabled choice when navigating menu - with :cycle option - cycles filtered choices left and right - doesn't cycle by default - cycles around when configured to do so - cycles around disabled items - cycles choices using left/right arrows - cycles pages left/right with disabled items - with filter - doesn't allow mixing enumeration and filter - doesn't exit when there are no matching entries - cancels a selection - filters and chooses a uniquely matching entry, ignoring case - navigates left and right with filtered items - filters and chooses the first of multiple matching entries - filters based on alphanumeric and punctuation characters - when paginated - paginates long selections through DSL - navigates left and right - paginates long selections - navigates pages up/down with disabled items - paginates choices as hash object - combines up/down navigation with left/right - navigates evenly paged output with right arrow until end of selection - navigates unevenly paged output with right arrow until the end of selection - navigates pages left/right with disabled items +TTY::Prompt::Question convert file + converts to file -TTY::Prompt#mask - validates input - masks with unicode character - masks output by default - ignores mask if echo is off - masks output with custom character +TTY::Prompt::Question convert path + converts pathname -TTY::Prompt#decorate - decorates with a proc - doesn't decorate when disabled - decorates with a callable object - doesn't decorate without additional arguments - decorates string with named colors - doesn't decorate empty string +TTY::Prompt::Question#required + doesn't require value to be present + requires value to be present with option + uses required in validation check + requires value to be present -TTY::Prompt::Question - passes required check - fails validation check with custom message - passes convert check - fails range check - fails validation check - passes validation check - fails required check - fails range check - passes range check - fails convert check with custom message - fails required check with custom message - fails convert check - fails validation check with inlined custom message +TTY::Prompt::Choice#== + is false with different name attribute + is false with different value attribute + is false with different key attribute + is true with the same name and value attributes + is false with non-choice object + +TTY::Prompt#subscribe + subscribes to key events only for the current prompt + +TTY::Prompt::Question convert regexp + converts regex + +TTY::Prompt::Question::Validation#call + validates nil input + validates with custom name + validates with a proc + validates successfully when the value matches pattern + fails validation when not maching pattern + +TTY::Prompt::Question#in + provides default error message when wrong input + reads letters within range + reads number within string range + reads number within digit range + reads range from option + overwrites default error message when wrong input + +TTY::Prompt::Question#initialize + is expected to eq TTY::Prompt::Question::UndefinedSetting + is expected to eq true + is expected to eq [] + +TTY::Prompt::Question#echo + asks with echo on + asks with echo off + +TTY::Prompt::Question#default + sets quiet mode TTY::Prompt::ConverterRegistry + contain + contains conversion + doesn't have conversion + checks conversion with object type fetch - retrieves converter from the registry fails to retrieve conversion + retrieves converter from the registry retrieves uppcase named converter register + registers new conversion under multiple names registers new conversion under single name fails to register conversion - registers new conversion under multiple names - contain - doesn't have conversion - checks conversion with object type - contains conversion -TTY::Prompt::Question convert date - converts datetime - converts date - fails to convert date +TTY::Prompt::Question#validate + understands custom validation like :email + provides custom error message for wrong input + provides default error message for wrong input + deprecates :validation option + validates input with regex + validates input with proc -TTY::Prompt#warn - displays message with option - changes default yellow color to cyan - displays many messages - displays one message +TTY::Prompt::Statement.new + displays prompt message in color + forces newline after the prompt message -TTY::Prompt - sets default choices using names - selects item when space pressed but doesn't echo item if echo: false - sets choice value to nil through DSL - sets choice custom values - selects item when space pressed - sets default options through hash syntax - sets prompt prefix - sets choice name and value through DSL - selects nothing when return pressed immediately - sets default options through DSL syntax - raises error for defaults out of range - sets prompt to quiet mode - changes to never show help - changes selected item color & marker - changes to always show help - changes help text and color - when paginated - reverts selection accross pages with Ctrl+r - doesn't paginate short selections - navigates left and right - navigates evenly paged output with right arrow until end of selection - paginates long selections - selects all paged choices with ctrl+a - navigates unevenly paged output with right arrow until the end of selection - paginates choices as hash object - paginates long selections through DSL - combines up/down navigation with left/right - with :min - requires number of choices - with :cycle - cycles filtered choices left and right - doesn't cycle by default - cycles when configured to do so - cycles choices using left/right arrows - with filter - doesn't lose the selection when switching between filters - with :max - limits number of choices - disables Ctrl+a/Ctrl+r selection when :max option is specified - with :disabled - adjusts active index to match first non-disabled choice - omits disabled choice when nagivating menu - selects all non-disabled choices when ctrl+a is pressed - fails when default item is also disabled - omits disabled choice when number key is pressed +TTY::Prompt::Question convert bool + converts single positive boolean + converts negative boolean + converts positive boolean + handles default values + handles default values + fails to convert boolean TTY::Prompt::Choices#find_by - finds a matching choice by :key key - finds no matching choice finds a matching choice by :name key + finds a matching choice by :key key finds a matching choice by :value key + finds no matching choice -TTY::Prompt confirmation - #yes? - changes default - agrees with question - obeys quiet mode - disagrees with question - defaults suffix and converter - fails to infer default value from a word - defaults positive and negative - customizes question through DSL - customizes question through options - accepts regex conflicting characters as suffix - assumes default true - infers default value from a word - warns about invalid entry when using defaults - #no? - changes default - agrees with question - defaults suffix and converter - customizes question through DSL - warns about invalid entry when using defaults - assumes default false - disagrees with question +TTY::Prompt::Question + passes range check + fails validation check with inlined custom message + fails required check + passes convert check + fails convert check + fails required check with custom message + fails range check + fails convert check with custom message + fails validation check + passes validation check + fails range check + fails validation check with custom message + passes required check -TTY::Prompt::Question#default - sets quiet mode +TTY::Prompt#inspect + inspects instance attributes + +TTY::Prompt::Choice#from + creates choice from an array with name only and defaults value + creates disabled choice + creates choice from a string + creates choice from a hash with a value + creates choice from an array with name and a value + creates choice from an array with name and false value + creates choice from an array with a hash without value key + creates choice from a hash with a nil value + creates choice from an array with key-value pair + creates choice from a symbol + creates choice from an arbitrary object that responds to to_s call + creates choice from array with name and nil value + creates choice from a hash with name, value and key keys + creates choice from an array with a hash with name and value keys + skips Choice instance + +TTY::Prompt::Question::Modifier#whitespace + nil (empty user input) + trim returns nil + chomp returns nil + remove returns nil + collapse returns nil + string with whitespaces + collapses text + chomps whitespace + removes whitespace + trims whitespace + +TTY::Prompt::Question::Modifier#apply_to + doesn't apply modifiers + combines letter case & whitespace modifications + combines whitespace & letter case modifications + +TTY::Prompt::Question convert date + converts datetime + fails to convert date + converts date + +TTY::Prompt#collect + collects more than one answer + when receiving multiple answers + collects as a list if values method used in chain with block + collects as a list if values method used in chain + overrides a non-array key on multiple answers + with multiple keys + collects into the appropriate keys + +TTY::Prompt::Choices.new + creates choices collection + +TTY::Prompt::Question::Modifier#letter_case + string + changes to lower case + capitalizes text + changes to uppercase + nil (empty user input) + down returns nil + capitalize returns nil + up returns nil + +TTY::Utils + #blank? + detects blank of nil as true + detects blank of "" as true + detects blank of :foo as false + detects blank of "foo" as false + detects blank of " " as true + detects blank of "\n\t " as true + #deep_copy + copies ["foo", {:bar=>"baz"}, :fum, 11] + copies "" -Top 2 slowest examples (0.06146 seconds, 13.1% of total time): +Top 2 slowest examples (0.06253 seconds, 11.9% of total time): TTY::Prompt::Timer times out loop execution - 0.03124 seconds ./spec/unit/timer_spec.rb:4 + 0.03144 seconds ./spec/unit/timer_spec.rb:4 TTY::Prompt::Timer registers a tick event - 0.03022 seconds ./spec/unit/timer_spec.rb:15 + 0.03108 seconds ./spec/unit/timer_spec.rb:15 Top 2 slowest example groups: TTY::Prompt::Timer - 0.03107 seconds average (0.06214 seconds / 2 examples) ./spec/unit/timer_spec.rb:3 - TTY::Prompt::Question#modify - 0.00673 seconds average (0.03363 seconds / 5 examples) ./spec/unit/question/modify_spec.rb:3 + 0.03146 seconds average (0.06292 seconds / 2 examples) ./spec/unit/timer_spec.rb:3 + TTY::Prompt#subscribe + 0.00617 seconds average (0.00617 seconds / 1 example) ./spec/unit/subscribe_spec.rb:3 -Finished in 0.46875 seconds (files took 0.28926 seconds to load) +Finished in 0.52671 seconds (files took 0.29955 seconds to load) 494 examples, 0 failures -Randomized with seed 26751 +Randomized with seed 3697 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -1706,12 +1742,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: including full source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/993729/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env -I: removing directory /srv/workspace/pbuilder/601336 and its subdirectories -I: Current time: Thu Jan 22 12:48:19 -12 2026 -I: pbuilder-time-stamp: 1769129299 +I: removing directory /srv/workspace/pbuilder/993729 and its subdirectories +I: Current time: Sat Dec 21 08:26:08 +14 2024 +I: pbuilder-time-stamp: 1734719168