Perl / perl5

🐪 The Perl programming language
https://dev.perl.org/perl5/
Other
1.92k stars 551 forks source link

BBC: Blead Breaks NEKOKAK/Test-Attribute-AutoLevel-0.06.tar.gz #19502

Open andk opened 2 years ago

andk commented 2 years ago

Description

The distribution's test suite started to fail with perl 5.35.9.

Bisect leads to v5.35.8-105-ghttps://github.com/Perl/perl5/commit/f6387cff9c (f6387cf), Subject 'Reapply squashed "avoid identical stack traces" patches'

Sample fail report: http://www.cpantesters.org/cpan/report/58001c80-9c3a-11ec-ad2d-24bc1561a567

Still failing on today's blead v5.35.9-84-gd1e771d8c5 ("Fix utf8_to_uvchr for non-core calls")

Matrix: http://matrix.cpantesters.org/?dist=Test-Attribute-AutoLevel+0.06

Steps to Reproduce

cpan -i NEKOKAK/Test-Attribute-AutoLevel-0.06.tar.gz

Expected behavior

Should successfully test and install the module

Perl configuration

# perl -V output goes here
Summary of my perl5 (revision 5 version 35 subversion 9) configuration:
  Commit id: a4f7faaf7e7c49fceb79725d6853abbd83bc8bd9
  Platform:
    osname=linux
    osvers=4.15.0-167-generic
    archname=x86_64-linux-thread-multi-ld
    uname='linux k93bionic 4.15.0-167-generic #175-ubuntu smp wed jan 5 01:56:07 utc 2022 x86_64 x86_64 x86_64 gnulinux '
    config_args='-Dprefix=/home/sand/src/perl/repoperls/installed-perls/host/k93bionic/v5.35.9/ebf1 -Dmyhostname=k93bionic -Dinstallusrbinperl=n -Uversiononly -Dusedevel -des -Ui_db -Dlibswanted=cl pthread socket inet nsl gdbm dbm malloc dl ld sun m crypt sec util c cposix posix ucb BSD gdbm_compat -Duseithreads -Duselongdouble -DEBUGGING=-g'
    hint=recommended
    useposix=true
    d_sigaction=define
    useithreads=define
    usemultiplicity=define
    use64bitint=define
    use64bitall=define
    uselongdouble=define
    usemymalloc=n
    default_inc_excludes_dot=define
  Compiler:
    cc='cc'
    ccflags ='-D_REENTRANT -D_GNU_SOURCE -fwrapv -fno-strict-aliasing -pipe -fstack-protector-strong -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64'
    optimize='-O2 -g'
    cppflags='-D_REENTRANT -D_GNU_SOURCE -fwrapv -fno-strict-aliasing -pipe -fstack-protector-strong -I/usr/local/include'
    ccversion=''
    gccversion='7.5.0'
    gccosandvers=''
    intsize=4
    longsize=8
    ptrsize=8
    doublesize=8
    byteorder=12345678
    doublekind=3
    d_longlong=define
    longlongsize=8
    d_longdbl=define
    longdblsize=16
    longdblkind=3
    ivtype='long'
    ivsize=8
    nvtype='long double'
    nvsize=16
    Off_t='off_t'
    lseeksize=8
    alignbytes=16
    prototype=define
  Linker and Libraries:
    ld='cc'
    ldflags =' -fstack-protector-strong -L/usr/local/lib'
    libpth=/usr/local/lib /usr/lib/x86_64-linux-gnu /usr/lib /lib/x86_64-linux-gnu /lib
    libs=-lpthread -lnsl -ldl -lm -lcrypt -lutil -lc
    perllibs=-lpthread -lnsl -ldl -lm -lcrypt -lutil -lc
    libc=libc-2.27.so
    so=so
    useshrplib=false
    libperl=libperl.a
    gnulibc_version='2.27'
  Dynamic Linking:
    dlsrc=dl_dlopen.xs
    dlext=so
    d_dlsymun=undef
    ccdlflags='-Wl,-E'
    cccdlflags='-fPIC'
    lddlflags='-shared -O2 -g -L/usr/local/lib -fstack-protector-strong'

Characteristics of this binary (from libperl): 
  Compile-time options:
    HAS_TIMES
    MULTIPLICITY
    PERLIO_LAYERS
    PERL_COPY_ON_WRITE
    PERL_DONT_CREATE_GVSV
    PERL_MALLOC_WRAP
    PERL_OP_PARENT
    PERL_PRESERVE_IVUV
    PERL_USE_DEVEL
    USE_64_BIT_ALL
    USE_64_BIT_INT
    USE_ITHREADS
    USE_LARGE_FILES
    USE_LOCALE
    USE_LOCALE_COLLATE
    USE_LOCALE_CTYPE
    USE_LOCALE_NUMERIC
    USE_LOCALE_TIME
    USE_LONG_DOUBLE
    USE_PERLIO
    USE_PERL_ATOF
    USE_REENTRANT_API
    USE_THREAD_SAFE_LOCALE
  Built under linux
  Compiled at Feb 20 2022 18:17:14
  %ENV:
    PERL5LIB="/tmp/loop_over_bdir-23447-q4XzrB/Lingua-BioYaTeA-0.11-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Lingua-BioYaTeA-0.11-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/OSDial-3.0.2.124-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/OSDial-3.0.2.124-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/App-nrun-v1.1.2-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/App-nrun-v1.1.2-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Business-Shipping-DataFiles-1.02-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Business-Shipping-DataFiles-1.02-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Net-OpenVPN-DDNS-0.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Net-OpenVPN-DDNS-0.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/downsexta-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/downsexta-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/MP3-PodcastFetch-1.05-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/MP3-PodcastFetch-1.05-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/CGI-Application-NetNewsIface-0.0204-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/CGI-Application-NetNewsIface-0.0204-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/dta-tokwrap-0.98-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/dta-tokwrap-0.98-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/RDF-NLP-SPARQLQuery-0.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/RDF-NLP-SPARQLQuery-0.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Simulation-Automate-1.0.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Simulation-Automate-1.0.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/LiquidWeb-Storm-CLI-1.03-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/LiquidWeb-Storm-CLI-1.03-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/EJBCA-CrlPublish-0.60-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/EJBCA-CrlPublish-0.60-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/makepp-1.19-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/makepp-1.19-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Device-Kiln-0.03-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Device-Kiln-0.03-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/HTML-Menu-TreeView-1.22-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/HTML-Menu-TreeView-1.22-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/NoZone-1.3-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/NoZone-1.3-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/App-oo_modulino_zsh_completion_helper-0.04-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/App-oo_modulino_zsh_completion_helper-0.04-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/DBIx-Migration-Directories-0.12-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/DBIx-Migration-Directories-0.12-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Net-Async-DigitalOcean-0.04-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Net-Async-DigitalOcean-0.04-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/ProjectBuilder-0.14.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/ProjectBuilder-0.14.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Captive-Portal-4.10-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Captive-Portal-4.10-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/App-rmcd-0.280-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/App-rmcd-0.280-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/AllKnowingDNS-1.7-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/AllKnowingDNS-1.7-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Debian-Packages-0.03-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Debian-Packages-0.03-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Lemonldap-NG-Cli-0.2-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Lemonldap-NG-Cli-0.2-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Devel-Required-0.16-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Devel-Required-0.16-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/mmds-1.902-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/mmds-1.902-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Lingua-YaTeA-0.626-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Lingua-YaTeA-0.626-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Net-ISP-Balance-1.31-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Net-ISP-Balance-1.31-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Linux-InitFS-0.2-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Linux-InitFS-0.2-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/Dpkg-1.21.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/Dpkg-1.21.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/perl-Hardware-UPS-Perl-0.43-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/perl-Hardware-UPS-Perl-0.43-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/shishi-0.0.1-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/shishi-0.0.1-0/blib/lib:/tmp/loop_over_bdir-23447-q4XzrB/triceps-2.1.0-0/blib/arch:/tmp/loop_over_bdir-23447-q4XzrB/triceps-2.1.0-0/blib/lib"
    PERL5OPT=""
    PERL5_CPANPLUS_IS_RUNNING="23460"
    PERL5_CPAN_IS_RUNNING="23460"
    PERL_CANARY_STABILITY_NOPROMPT="1"
    PERL_MM_USE_DEFAULT="1"
    PERL_USE_UNSAFE_INC="1"
  @INC:
    /tmp/loop_over_bdir-23447-q4XzrB/Lingua-BioYaTeA-0.11-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Lingua-BioYaTeA-0.11-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/OSDial-3.0.2.124-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/OSDial-3.0.2.124-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/App-nrun-v1.1.2-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/App-nrun-v1.1.2-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Business-Shipping-DataFiles-1.02-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Business-Shipping-DataFiles-1.02-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Net-OpenVPN-DDNS-0.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Net-OpenVPN-DDNS-0.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/downsexta-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/downsexta-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/MP3-PodcastFetch-1.05-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/MP3-PodcastFetch-1.05-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/CGI-Application-NetNewsIface-0.0204-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/CGI-Application-NetNewsIface-0.0204-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/dta-tokwrap-0.98-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/dta-tokwrap-0.98-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/RDF-NLP-SPARQLQuery-0.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/RDF-NLP-SPARQLQuery-0.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Simulation-Automate-1.0.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Simulation-Automate-1.0.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/LiquidWeb-Storm-CLI-1.03-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/LiquidWeb-Storm-CLI-1.03-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/EJBCA-CrlPublish-0.60-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/EJBCA-CrlPublish-0.60-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/makepp-1.19-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/makepp-1.19-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Device-Kiln-0.03-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Device-Kiln-0.03-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/HTML-Menu-TreeView-1.22-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/HTML-Menu-TreeView-1.22-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/NoZone-1.3-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/NoZone-1.3-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/App-oo_modulino_zsh_completion_helper-0.04-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/App-oo_modulino_zsh_completion_helper-0.04-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/DBIx-Migration-Directories-0.12-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/DBIx-Migration-Directories-0.12-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Net-Async-DigitalOcean-0.04-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Net-Async-DigitalOcean-0.04-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/ProjectBuilder-0.14.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/ProjectBuilder-0.14.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Captive-Portal-4.10-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Captive-Portal-4.10-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/App-rmcd-0.280-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/App-rmcd-0.280-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/AllKnowingDNS-1.7-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/AllKnowingDNS-1.7-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Debian-Packages-0.03-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Debian-Packages-0.03-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Lemonldap-NG-Cli-0.2-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Lemonldap-NG-Cli-0.2-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Devel-Required-0.16-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Devel-Required-0.16-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/mmds-1.902-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/mmds-1.902-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Lingua-YaTeA-0.626-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Lingua-YaTeA-0.626-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Net-ISP-Balance-1.31-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Net-ISP-Balance-1.31-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Linux-InitFS-0.2-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Linux-InitFS-0.2-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/Dpkg-1.21.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/Dpkg-1.21.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/perl-Hardware-UPS-Perl-0.43-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/perl-Hardware-UPS-Perl-0.43-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/shishi-0.0.1-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/shishi-0.0.1-0/blib/lib
    /tmp/loop_over_bdir-23447-q4XzrB/triceps-2.1.0-0/blib/arch
    /tmp/loop_over_bdir-23447-q4XzrB/triceps-2.1.0-0/blib/lib
    /home/sand/src/perl/repoperls/installed-perls/host/k93bionic/v5.35.9/ebf1/lib/site_perl/5.35.9/x86_64-linux-thread-multi-ld
    /home/sand/src/perl/repoperls/installed-perls/host/k93bionic/v5.35.9/ebf1/lib/site_perl/5.35.9
    /home/sand/src/perl/repoperls/installed-perls/host/k93bionic/v5.35.9/ebf1/lib/5.35.9/x86_64-linux-thread-multi-ld
    /home/sand/src/perl/repoperls/installed-perls/host/k93bionic/v5.35.9/ebf1/lib/5.35.9
    .
haarg commented 2 years ago

This module accepts a 'depth' parameter to its import method. This is undocumented so it's not entirely clear what the intention is. In a test, it has a module that uses Test::Attribute::AutoLevel, passing in a depth of 1. It then expects this to indicate the package that loaded the test module. This seems like another case of something only working accidentally, and not working as intended as soon as the module is used more than once, even before the change in 5.35.9. One possible fix for the module would be to have the depth option install an import method, but that seems wrong as well. I feel like mostly the depth option in the module was a poorly thought out feature that should be removed.

I've filed nekokak/p5-test-attribute-autolevel#7 to hopefully get some answers to find a path to fixing the module.

The module does not have any users on CPAN currently, so it is at least hopefully low impact.