* Package: dev-python/amodem-1.15.1 * Repository: gentoo * Maintainer: luke-jr+gentoobugs@utopios.org proxy-maint@gentoo.org * USE: abi_x86_64 amd64 elibc_glibc kernel_linux python_targets_python3_7 test userland_GNU * FEATURES: network-sandbox preserve-libs sandbox test userpriv usersandbox @@@@@ PLEASE PAY ATTENTION HERE!!! @@@@@ This information may help you to understand if this is a duplicate or if this bug exists after you pushed a fix; This ebuild was merged at the following commit: https://github.com/gentoo-mirror/gentoo/commit/c7622131327ea5148949d61a16f701b1a52c8d5c (Mon Aug 17 23:35:49 UTC 2020) @@@@@ END @@@@@ emerge --info: Portage 3.0.3 (python 3.7.8-final-0, default/linux/amd64/17.1, gcc-10.2.0, glibc-2.32, 5.4.0-1021-aws x86_64) ================================================================= System uname: Linux-5.4.0-1021-aws-x86_64-Intel-R-_Xeon-R-_Platinum_8175M_CPU_@_2.50GHz-with-gentoo-2.7 KiB Mem: 64359960 total, 47657288 free KiB Swap: 0 total, 0 free Timestamp of repository gentoo: Mon, 17 Aug 2020 23:35:49 +0000 sh bash 5.0_p18 ld GNU ld (Gentoo 2.34 p6) 2.34.0 app-shells/bash: 5.0_p18::gentoo dev-lang/perl: 5.30.3-r1::gentoo dev-lang/python: 2.7.18-r1::gentoo, 3.7.8-r2::gentoo, 3.8.5::gentoo, 3.9.0_rc1::gentoo dev-util/cmake: 3.18.1::gentoo sys-apps/baselayout: 2.7::gentoo sys-apps/openrc: 0.42.1::gentoo sys-apps/sandbox: 2.20::gentoo sys-devel/autoconf: 2.69-r5::gentoo sys-devel/automake: 1.16.2::gentoo sys-devel/binutils: 2.34-r2::gentoo sys-devel/gcc: 10.2.0::gentoo sys-devel/gcc-config: 2.3.1::gentoo sys-devel/libtool: 2.4.6-r6::gentoo sys-devel/make: 4.3::gentoo sys-kernel/linux-headers: 5.8::gentoo (virtual/os-headers) sys-libs/glibc: 2.32::gentoo Repositories: gentoo location: /usr/portage sync-type: rsync sync-uri: rsync://rsync.gentoo.org/gentoo-portage priority: -1000 sync-rsync-verify-max-age: 24 sync-rsync-verify-metamanifest: yes sync-rsync-extra-opts: sync-rsync-verify-jobs: 1 ACCEPT_KEYWORDS="amd64 ~amd64" ACCEPT_LICENSE="* MIT" CBUILD="x86_64-pc-linux-gnu" CC="x86_64-pc-linux-gnu-clang" CFLAGS="-O2 -pipe -march=native -frecord-gcc-switches -fno-diagnostics-color" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/share/gnupg/qualified.txt" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/env.d /etc/gconf /etc/gentoo-release /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo" CXX="x86_64-pc-linux-gnu-clang++" CXXFLAGS="-O2 -pipe -march=native -frecord-gcc-switches -fno-diagnostics-color" DISTDIR="/var/tmp/portage/dev-python/amodem-1.15.1/distdir" EMERGE_DEFAULT_OPTS="--with-bdeps=y -1 -b -k" ENV_UNSET="DBUS_SESSION_BUS_ADDRESS DISPLAY GOBIN GOPATH PERL5LIB PERL5OPT PERLPREFIX PERL_CORE PERL_MB_OPT PERL_MM_OPT XAUTHORITY XDG_CACHE_HOME XDG_CONFIG_HOME XDG_DATA_HOME XDG_RUNTIME_DIR" FCFLAGS="-O2 -pipe -march=native -frecord-gcc-switches -fno-diagnostics-color" FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-logs buildpkg collision-protect config-protect-if-modified distlocks ebuild-locks fixlafiles ipc-sandbox merge-sync multilib-strict network-sandbox news parallel-fetch pid-sandbox preserve-libs protect-owned qa-unresolved-soname-deps sandbox sfperms sign split-log strict test unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr" FFLAGS="-O2 -pipe -march=native -frecord-gcc-switches -fno-diagnostics-color" GENTOO_MIRRORS="http://distfiles.gentoo.org" LANG="C.UTF-8" LDFLAGS="-Wl,-O1 -Wl,--as-needed -Wl,--defsym=__gentoo_check_ldflags__=0 -fuse-ld=lld" MAKEOPTS="-j16 V=1" PKGDIR="/root/.packages" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages --exclude=/.git" PORTAGE_TMPDIR="/var/tmp" USE="acl amd64 berkdb bzip2 cli crypt dri fortran gdbm iconv ipv6 libglvnd libtirpc multilib native-symlinks ncurses nls nptl openmp pam pcre readline seccomp split-usr ssl tcpd test unicode xattr zlib" ABI_X86="64" ELIBC="glibc" KERNEL="linux" PYTHON_TARGETS="python3_7" USERLAND="GNU" Unset: CPPFLAGS, CTARGET, INSTALL_MASK, LC_ALL, LINGUAS, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS >>> Unpacking source... >>> Unpacking amodem-1.15.1.tar.gz to /var/tmp/portage/dev-python/amodem-1.15.1/work >>> Source unpacked in /var/tmp/portage/dev-python/amodem-1.15.1/work >>> Preparing source in /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1 ... >>> Source prepared. >>> Configuring source in /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1 ... >>> Source configured. >>> Compiling source in /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1 ... * python3_7: running distutils-r1_run_phase distutils-r1_python_compile python3.7 setup.py build -j 16 running build running build_py creating /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/__main__.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/__init__.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/send.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/common.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/recv.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/stream.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/levinson.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/alsa.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/config.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/equalizer.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/calib.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/detect.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/dsp.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/audio.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/async_reader.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/framing.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/main.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem copying amodem/sampling.py -> /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1-python3_7/lib/amodem warning: build_py: byte-compiling is disabled, skipping. >>> Source compiled. >>> Test phase: dev-python/amodem-1.15.1 * python3_7: running distutils-r1_run_phase python_test ============================= test session starts ============================== platform linux -- Python 3.7.8, pytest-6.0.1, py-1.9.0, pluggy-0.13.1 -- /usr/bin/python3.7 cachedir: .pytest_cache rootdir: /var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1 collecting ... collected 1 item / 11 errors ==================================== ERRORS ==================================== __________________ ERROR collecting amodem/tests/test_alsa.py __________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_alsa.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_alsa.py:1: in from amodem import alsa, config ../amodem-1.15.1-python3_7/lib/amodem/config.py:3: in import numpy as np E ModuleNotFoundError: No module named 'numpy' _________________ ERROR collecting amodem/tests/test_audio.py __________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_audio.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_audio.py:1: in from amodem import audio, config ../amodem-1.15.1-python3_7/lib/amodem/config.py:3: in import numpy as np E ModuleNotFoundError: No module named 'numpy' _________________ ERROR collecting amodem/tests/test_calib.py __________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_calib.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_calib.py:1: in from amodem import calib ../amodem-1.15.1-python3_7/lib/amodem/calib.py:7: in import numpy as np E ModuleNotFoundError: No module named 'numpy' _________________ ERROR collecting amodem/tests/test_common.py _________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_common.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_common.py:1: in from amodem import common ../amodem-1.15.1-python3_7/lib/amodem/common.py:9: in import numpy as np E ModuleNotFoundError: No module named 'numpy' ________________ ERROR collecting amodem/tests/test_configs.py _________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_configs.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_configs.py:1: in from amodem import config ../amodem-1.15.1-python3_7/lib/amodem/config.py:3: in import numpy as np E ModuleNotFoundError: No module named 'numpy' _________________ ERROR collecting amodem/tests/test_detect.py _________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_detect.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_detect.py:1: in import numpy as np E ModuleNotFoundError: No module named 'numpy' __________________ ERROR collecting amodem/tests/test_dsp.py ___________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_dsp.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_dsp.py:1: in from amodem import dsp ../amodem-1.15.1-python3_7/lib/amodem/dsp.py:3: in import numpy as np E ModuleNotFoundError: No module named 'numpy' _______________ ERROR collecting amodem/tests/test_equalizer.py ________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_equalizer.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_equalizer.py:1: in from numpy.random import RandomState E ModuleNotFoundError: No module named 'numpy' ________________ ERROR collecting amodem/tests/test_framing.py _________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_framing.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_framing.py:1: in from amodem import framing ../amodem-1.15.1-python3_7/lib/amodem/framing.py:7: in from . import common ../amodem-1.15.1-python3_7/lib/amodem/common.py:9: in import numpy as np E ModuleNotFoundError: No module named 'numpy' ________________ ERROR collecting amodem/tests/test_sampling.py ________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_sampling.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_sampling.py:1: in from amodem import sampling ../amodem-1.15.1-python3_7/lib/amodem/sampling.py:3: in import numpy as np E ModuleNotFoundError: No module named 'numpy' ________________ ERROR collecting amodem/tests/test_transfer.py ________________ ImportError while importing test module '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1/amodem/tests/test_transfer.py'. Hint: make sure your test modules/packages have valid Python names. Traceback: /usr/lib/python3.7/site-packages/_pytest/python.py:552: in _importtestmodule mod = import_path(self.fspath, mode=importmode) /usr/lib/python3.7/site-packages/_pytest/pathlib.py:520: in import_path importlib.import_module(module_name) /usr/lib/python3.7/importlib/__init__.py:127: in import_module return _bootstrap._gcd_import(name[level:], package, level) :1006: in _gcd_import ??? :983: in _find_and_load ??? :967: in _find_and_load_unlocked ??? :677: in _load_unlocked ??? /usr/lib/python3.7/site-packages/_pytest/assertion/rewrite.py:170: in exec_module exec(co, module.__dict__) amodem/tests/test_transfer.py:1: in from amodem import main ../amodem-1.15.1-python3_7/lib/amodem/main.py:4: in import numpy as np E ModuleNotFoundError: No module named 'numpy' =========================== short test summary info ============================ ERROR amodem/tests/test_alsa.py ERROR amodem/tests/test_audio.py ERROR amodem/tests/test_calib.py ERROR amodem/tests/test_common.py ERROR amodem/tests/test_configs.py ERROR amodem/tests/test_detect.py ERROR amodem/tests/test_dsp.py ERROR amodem/tests/test_equalizer.py ERROR amodem/tests/test_framing.py ERROR amodem/tests/test_sampling.py ERROR amodem/tests/test_transfer.py !!!!!!!!!!!!!!!!!!! Interrupted: 11 errors during collection !!!!!!!!!!!!!!!!!!! ============================== 11 errors in 0.84s ============================== * ERROR: dev-python/amodem-1.15.1::gentoo failed (test phase): * Tests fail with python3.7 * * Call stack: * ebuild.sh, line 125: Called src_test * environment, line 3010: Called distutils-r1_src_test * environment, line 1301: Called _distutils-r1_run_foreach_impl 'python_test' * environment, line 481: Called python_foreach_impl 'distutils-r1_run_phase' 'python_test' * environment, line 2620: Called multibuild_foreach_variant '_python_multibuild_wrapper' 'distutils-r1_run_phase' 'python_test' * environment, line 2084: Called _multibuild_run '_python_multibuild_wrapper' 'distutils-r1_run_phase' 'python_test' * environment, line 2082: Called _python_multibuild_wrapper 'distutils-r1_run_phase' 'python_test' * environment, line 874: Called distutils-r1_run_phase 'python_test' * environment, line 1238: Called python_test * environment, line 2970: Called die * The specific snippet of code: * pytest -vv || die "Tests fail with ${EPYTHON}" * * If you need support, post the output of `emerge --info '=dev-python/amodem-1.15.1::gentoo'`, * the complete build log and the output of `emerge -pqv '=dev-python/amodem-1.15.1::gentoo'`. * The complete build log is located at '/var/log/emerge-log/build/dev-python/amodem-1.15.1:20200818-004034.log'. * For convenience, a symlink to the build log is located at '/var/tmp/portage/dev-python/amodem-1.15.1/temp/build.log'. * The ebuild environment file is located at '/var/tmp/portage/dev-python/amodem-1.15.1/temp/environment'. * Working directory: '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1' * S: '/var/tmp/portage/dev-python/amodem-1.15.1/work/amodem-1.15.1'