$ docker run --rm --name validator-libsodium-usage-php83-r13-aead-xchacha20poly1305-roundtrip-48096 -t --mount type=bind,src=/tmp/validator-status-libsodium-usage-php83-r13-aead-xchacha20poly1305-roundtrip,dst=/validator/status --mount type=bind,src=/home/runner/work/validator/validator/.work/pages-artifacts/debs/port/libsodium,dst=/override-debs,readonly validator-libsodium-shared bash -lc 'set -euo pipefail /validator/tests/_shared/install_override_debs.sh exec /validator/tests/_shared/run_library_tests.sh "$@"' validator-testcase libsodium usage-php83-r13-aead-xchacha20poly1305-roundtrip -- bash -c 'PS4=$1; shift; set -x; source "$@"' validator-xtrace '__VALIDATOR_XTRACE__ ' /validator/tests/libsodium/tests/cases/usage/usage-php83-r13-aead-xchacha20poly1305-roundtrip.sh installing override packages from /override-debs (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 ... 22270 files and directories currently installed.) Preparing to unpack .../libsodium-dev_1.0.18-1ubuntu0.24.04.1+safelibs1778011697_amd64.deb ... Unpacking libsodium-dev:amd64 (1.0.18-1ubuntu0.24.04.1+safelibs1778011697) over (1.0.18-1ubuntu0.24.04.1) ... Preparing to unpack .../libsodium23_1.0.18-1ubuntu0.24.04.1+safelibs1778011697_amd64.deb ... Unpacking libsodium23:amd64 (1.0.18-1ubuntu0.24.04.1+safelibs1778011697) over (1.0.18-1ubuntu0.24.04.1) ... Setting up libsodium23:amd64 (1.0.18-1ubuntu0.24.04.1+safelibs1778011697) ... Setting up libsodium-dev:amd64 (1.0.18-1ubuntu0.24.04.1+safelibs1778011697) ... Processing triggers for libc-bin (2.39-0ubuntu8.7) ... $key = str_repeat("\x44", SODIUM_CRYPTO_AEAD_XCHACHA20POLY1305_IETF_KEYBYTES); $nonce = str_repeat("\x55", SODIUM_CRYPTO_AEAD_XCHACHA20POLY1305_IETF_NPUBBYTES); $plain = "php r13 xchacha20poly1305 payload"; $ad = "r13-aad"; $ct = sodium_crypto_aead_xchacha20poly1305_ietf_encrypt($plain, $ad, $nonce, $key); if ($ct === $plain) { fwrite(STDERR, "ct == plain\n"); exit(1); } $pt = sodium_crypto_aead_xchacha20poly1305_ietf_decrypt($ct, $ad, $nonce, $key); if ($pt !== $plain) { fwrite(STDERR, "round-trip mismatch\n"); exit(1); } // Wrong AAD must fail (returns false). $bad = sodium_crypto_aead_xchacha20poly1305_ietf_decrypt($ct, "wrong-ad", $nonce, $key); if ($bad !== false) { fwrite(STDERR, "wrong AAD accepted\n"); exit(1); } echo "ok\n"; ' ok