this derivation will be built: /nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv building '/nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv' on 'ssh-ng://nix@jamie' building '/nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv' niks3-go-unit-tests> Running client tests... niks3-go-unit-tests> === RUN TestDoServerRequestAttachesToken niks3-go-unit-tests> === PAUSE TestDoServerRequestAttachesToken niks3-go-unit-tests> === RUN TestCaseHackSuffix niks3-go-unit-tests> === PAUSE TestCaseHackSuffix niks3-go-unit-tests> === RUN TestPartSizeForNAR niks3-go-unit-tests> === PAUSE TestPartSizeForNAR niks3-go-unit-tests> === RUN TestDumpPathMatchesNix niks3-go-unit-tests> === PAUSE TestDumpPathMatchesNix niks3-go-unit-tests> === RUN TestDumpPathSingleFile niks3-go-unit-tests> === PAUSE TestDumpPathSingleFile niks3-go-unit-tests> === RUN TestDumpPathWriterError niks3-go-unit-tests> === PAUSE TestDumpPathWriterError niks3-go-unit-tests> === RUN TestEncodeNixBase32 niks3-go-unit-tests> === PAUSE TestEncodeNixBase32 niks3-go-unit-tests> === RUN TestEncodeNixBase32WithRealHash niks3-go-unit-tests> === PAUSE TestEncodeNixBase32WithRealHash niks3-go-unit-tests> === RUN TestConvertHashToNix32 niks3-go-unit-tests> === PAUSE TestConvertHashToNix32 niks3-go-unit-tests> === RUN TestGetStorePathHash niks3-go-unit-tests> === PAUSE TestGetStorePathHash niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility niks3-go-unit-tests> === RUN TestParsePathInfoJSON niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON niks3-go-unit-tests> === RUN TestParsePathInfoJSONMultiplePaths niks3-go-unit-tests> === PAUSE TestParsePathInfoJSONMultiplePaths niks3-go-unit-tests> === RUN TestPathInfoCACompatibility niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility niks3-go-unit-tests> === RUN TestRateLimiterFeedback niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback niks3-go-unit-tests> === RUN TestRateLimiterFeedback_400DoesNotCountAsSuccess niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback_400DoesNotCountAsSuccess niks3-go-unit-tests> === RUN TestDoWithRetry_BodyReplayedViaGetBody niks3-go-unit-tests> === PAUSE TestDoWithRetry_BodyReplayedViaGetBody niks3-go-unit-tests> === RUN TestShellSplit niks3-go-unit-tests> === PAUSE TestShellSplit niks3-go-unit-tests> === RUN TestShellSplitErrors niks3-go-unit-tests> === PAUSE TestShellSplitErrors niks3-go-unit-tests> === RUN TestSetClientTLS niks3-go-unit-tests> === PAUSE TestSetClientTLS niks3-go-unit-tests> === RUN TestSetClientTLSDoesNotMutateDefaultTransport niks3-go-unit-tests> === PAUSE TestSetClientTLSDoesNotMutateDefaultTransport niks3-go-unit-tests> === RUN TestSetClientTLSErrors niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors niks3-go-unit-tests> === RUN TestStaticToken niks3-go-unit-tests> === PAUSE TestStaticToken niks3-go-unit-tests> === RUN TestFileTokenReadsAndCaches niks3-go-unit-tests> === PAUSE TestFileTokenReadsAndCaches niks3-go-unit-tests> === RUN TestFileTokenMissing niks3-go-unit-tests> === PAUSE TestFileTokenMissing niks3-go-unit-tests> === RUN TestFileTokenEmpty niks3-go-unit-tests> === PAUSE TestFileTokenEmpty niks3-go-unit-tests> === RUN TestScriptTokenNoExpiryRerunsEveryCall niks3-go-unit-tests> === PAUSE TestScriptTokenNoExpiryRerunsEveryCall niks3-go-unit-tests> === RUN TestScriptTokenCachesUntilRefresh niks3-go-unit-tests> === PAUSE TestScriptTokenCachesUntilRefresh niks3-go-unit-tests> === RUN TestScriptTokenEmptyToken niks3-go-unit-tests> === PAUSE TestScriptTokenEmptyToken niks3-go-unit-tests> === RUN TestScriptTokenBadJSON niks3-go-unit-tests> === PAUSE TestScriptTokenBadJSON niks3-go-unit-tests> === RUN TestScriptTokenScriptFails niks3-go-unit-tests> === PAUSE TestScriptTokenScriptFails niks3-go-unit-tests> === RUN TestScriptTokenEmptyCommand niks3-go-unit-tests> === PAUSE TestScriptTokenEmptyCommand niks3-go-unit-tests> === CONT TestDoServerRequestAttachesToken niks3-go-unit-tests> === CONT TestDoWithRetry_BodyReplayedViaGetBody niks3-go-unit-tests> === CONT TestEncodeNixBase32WithRealHash niks3-go-unit-tests> === CONT TestSetClientTLSDoesNotMutateDefaultTransport niks3-go-unit-tests> === CONT TestConvertHashToNix32 niks3-go-unit-tests> === CONT TestEncodeNixBase32 niks3-go-unit-tests> === CONT TestShellSplit niks3-go-unit-tests> === CONT TestShellSplitErrors niks3-go-unit-tests> --- PASS: TestEncodeNixBase32WithRealHash (0.00s) niks3-go-unit-tests> === CONT TestCaseHackSuffix niks3-go-unit-tests> === CONT TestScriptTokenEmptyToken niks3-go-unit-tests> === CONT TestSetClientTLS niks3-go-unit-tests> === RUN TestConvertHashToNix32/SRI_format_to_Nix32 niks3-go-unit-tests> === CONT TestRateLimiterFeedback niks3-go-unit-tests> === CONT TestPathInfoCACompatibility niks3-go-unit-tests> === CONT TestParsePathInfoJSONMultiplePaths niks3-go-unit-tests> === RUN TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === CONT TestParsePathInfoJSON niks3-go-unit-tests> === PAUSE TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility niks3-go-unit-tests> === RUN TestRateLimiterFeedback/429_enables_limiter niks3-go-unit-tests> === CONT TestDumpPathMatchesNix niks3-go-unit-tests> === CONT TestFileTokenMissing niks3-go-unit-tests> === PAUSE TestConvertHashToNix32/SRI_format_to_Nix32 niks3-go-unit-tests> === RUN TestEncodeNixBase32/empty_input niks3-go-unit-tests> === PAUSE TestEncodeNixBase32/empty_input niks3-go-unit-tests> === CONT TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === CONT TestEncodeNixBase32/empty_input niks3-go-unit-tests> === CONT TestPartSizeForNAR niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback/429_enables_limiter niks3-go-unit-tests> === RUN TestRateLimiterFeedback/503_enables_limiter niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback/503_enables_limiter niks3-go-unit-tests> === RUN TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths niks3-go-unit-tests> === CONT TestScriptTokenEmptyCommand niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === CONT TestFileTokenEmpty niks3-go-unit-tests> === PAUSE TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths niks3-go-unit-tests> === RUN TestParsePathInfoJSONMultiplePaths/Lix_multiple_paths niks3-go-unit-tests> === PAUSE TestParsePathInfoJSONMultiplePaths/Lix_multiple_paths niks3-go-unit-tests> === CONT TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/old_string_format_-_text niks3-go-unit-tests> === CONT TestParsePathInfoJSONMultiplePaths/Lix_multiple_paths niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/old_string_format_-_text niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/old_string_format_-_fixed_recursive niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/old_string_format_-_fixed_recursive niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/new_structured_format_-_text niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/new_structured_format_-_text niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/new_structured_format_-_nar_method niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/new_structured_format_-_nar_method niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === CONT TestScriptTokenBadJSON niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/new_structured_format_-_nar_method niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/old_string_format_-_fixed_recursive niks3-go-unit-tests> === RUN TestParsePathInfoJSON/Nix_format niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/old_string_format_-_text niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/Nix_format niks3-go-unit-tests> === CONT TestSetClientTLSErrors niks3-go-unit-tests> === RUN TestParsePathInfoJSON/Lix_format niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/Lix_format niks3-go-unit-tests> === RUN TestParsePathInfoJSON/empty_input niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/empty_input niks3-go-unit-tests> === RUN TestParsePathInfoJSON/whitespace_only niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/whitespace_only niks3-go-unit-tests> === RUN TestParsePathInfoJSON/invalid_JSON niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/invalid_JSON niks3-go-unit-tests> === CONT TestParsePathInfoJSON/Nix_format niks3-go-unit-tests> === CONT TestParsePathInfoJSON/whitespace_only niks3-go-unit-tests> === CONT TestParsePathInfoJSON/invalid_JSON niks3-go-unit-tests> === CONT TestParsePathInfoJSON/empty_input niks3-go-unit-tests> === CONT TestParsePathInfoJSON/Lix_format niks3-go-unit-tests> === CONT TestScriptTokenCachesUntilRefresh niks3-go-unit-tests> === CONT TestRateLimiterFeedback_400DoesNotCountAsSuccess niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> === CONT TestFileTokenReadsAndCaches niks3-go-unit-tests> --- PASS: TestShellSplitErrors (0.00s) niks3-go-unit-tests> === CONT TestGetStorePathHash niks3-go-unit-tests> === RUN TestConvertHashToNix32/already_Nix32_format niks3-go-unit-tests> === CONT TestScriptTokenScriptFails niks3-go-unit-tests> === RUN TestPartSizeForNAR/zero_stays_at_minimum niks3-go-unit-tests> === CONT TestScriptTokenNoExpiryRerunsEveryCall niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === RUN TestRateLimiterFeedback/200_does_not_enable_limiter niks3-go-unit-tests> === CONT TestDumpPathWriterError niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback/200_does_not_enable_limiter niks3-go-unit-tests> === RUN TestRateLimiterFeedback/400_does_not_enable_limiter niks3-go-unit-tests> === PAUSE TestRateLimiterFeedback/400_does_not_enable_limiter niks3-go-unit-tests> === RUN TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> === CONT TestRateLimiterFeedback/429_enables_limiter niks3-go-unit-tests> === RUN TestSetClientTLSErrors/missing_key_file niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/new_structured_format_-_text niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Request returned retryable status, retrying attempt=1 max_attempts=6 backoff=0s status=503 url=http://127.0.0.1:42891 niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/missing_key_file niks3-go-unit-tests> === RUN TestSetClientTLSErrors/missing_ca_file niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/missing_ca_file niks3-go-unit-tests> === CONT TestStaticToken niks3-go-unit-tests> --- PASS: TestShellSplit (0.00s) niks3-go-unit-tests> === RUN TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === PAUSE TestConvertHashToNix32/already_Nix32_format niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/zero_stays_at_minimum niks3-go-unit-tests> --- PASS: TestEncodeNixBase32 (0.00s) niks3-go-unit-tests> --- PASS: TestEncodeNixBase32/test_string_hash (0.00s) niks3-go-unit-tests> --- PASS: TestEncodeNixBase32/empty_input (0.00s) niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === CONT TestRateLimiterFeedback/400_does_not_enable_limiter niks3-go-unit-tests> === RUN TestPartSizeForNAR/small_stays_at_minimum niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/small_stays_at_minimum niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> === RUN TestPartSizeForNAR/80_GiB_fits_at_minimum niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/80_GiB_fits_at_minimum niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI niks3-go-unit-tests> === RUN TestPartSizeForNAR/115_GiB_needs_larger_parts niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/115_GiB_needs_larger_parts niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Request returned retryable status, retrying attempt=2 max_attempts=6 backoff=0s status=503 url=http://127.0.0.1:42891 niks3-go-unit-tests> === CONT TestRateLimiterFeedback/503_enables_limiter niks3-go-unit-tests> === RUN TestPartSizeForNAR/1_TiB niks3-go-unit-tests> === RUN TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/1_TiB niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> === RUN TestPartSizeForNAR/5_TiB_S3_max_object niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_key_file niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/5_TiB_S3_max_object niks3-go-unit-tests> === RUN TestPartSizeForNAR/capped_at_5_GiB niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Request returned retryable status, retrying attempt=1 max_attempts=2 backoff=0s status=429 url=http://127.0.0.1:40383 niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/capped_at_5_GiB niks3-go-unit-tests> === CONT TestPartSizeForNAR/zero_stays_at_minimum niks3-go-unit-tests> === CONT TestPartSizeForNAR/capped_at_5_GiB niks3-go-unit-tests> === CONT TestPartSizeForNAR/115_GiB_needs_larger_parts niks3-go-unit-tests> === CONT TestPartSizeForNAR/80_GiB_fits_at_minimum niks3-go-unit-tests> === CONT TestPartSizeForNAR/small_stays_at_minimum niks3-go-unit-tests> === PAUSE TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === RUN TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> === CONT TestPartSizeForNAR/1_TiB niks3-go-unit-tests> === RUN TestConvertHashToNix32/invalid_format niks3-go-unit-tests> === PAUSE TestConvertHashToNix32/invalid_format niks3-go-unit-tests> === CONT TestConvertHashToNix32/SRI_format_to_Nix32 niks3-go-unit-tests> === CONT TestConvertHashToNix32/invalid_format niks3-go-unit-tests> === CONT TestConvertHashToNix32/already_Nix32_format niks3-go-unit-tests> --- PASS: TestScriptTokenEmptyCommand (0.00s) niks3-go-unit-tests> --- PASS: TestFileTokenMissing (0.00s) niks3-go-unit-tests> === CONT TestDumpPathSingleFile niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/new_structured_format_with_sha512 niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/new_structured_format_with_sha512 niks3-go-unit-tests> === CONT TestRateLimiterFeedback/200_does_not_enable_limiter niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> === CONT TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_ca_file niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Request returned retryable status, retrying attempt=1 max_attempts=2 backoff=0s status=503 url=http://127.0.0.1:45611 niks3-go-unit-tests> === CONT TestPartSizeForNAR/5_TiB_S3_max_object niks3-go-unit-tests> === PAUSE TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> --- PASS: TestFileTokenEmpty (0.00s) niks3-go-unit-tests> === RUN TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> --- PASS: TestFileTokenReadsAndCaches (0.01s) niks3-go-unit-tests> === PAUSE TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === RUN TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/new_structured_format_with_sha512 niks3-go-unit-tests> === PAUSE TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI niks3-go-unit-tests> === CONT TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> 2026/06/08 09:35:52 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> === RUN TestSetClientTLS/rejects_connection_without_client_cert niks3-go-unit-tests> --- PASS: TestScriptTokenBadJSON (0.01s) niks3-go-unit-tests> === PAUSE TestSetClientTLS/rejects_connection_without_client_cert niks3-go-unit-tests> === CONT TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === RUN TestSetClientTLS/succeeds_with_client_cert_and_CA niks3-go-unit-tests> === PAUSE TestSetClientTLS/succeeds_with_client_cert_and_CA niks3-go-unit-tests> === CONT TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> === RUN TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> === PAUSE TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> === CONT TestSetClientTLS/rejects_connection_without_client_cert niks3-go-unit-tests> === CONT TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> === CONT TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === CONT TestSetClientTLS/succeeds_with_client_cert_and_CA niks3-go-unit-tests> --- PASS: TestSetClientTLSDoesNotMutateDefaultTransport (0.01s) niks3-go-unit-tests> --- PASS: TestScriptTokenCachesUntilRefresh (0.01s) niks3-go-unit-tests> --- PASS: TestDoServerRequestAttachesToken (0.01s) niks3-go-unit-tests> --- PASS: TestStaticToken (0.00s) niks3-go-unit-tests> --- PASS: TestDoWithRetry_BodyReplayedViaGetBody (0.01s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32 (0.01s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/invalid_format (0.00s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/SRI_format_to_Nix32 (0.00s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/already_Nix32_format (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR (0.01s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/zero_stays_at_minimum (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/capped_at_5_GiB (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/115_GiB_needs_larger_parts (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/small_stays_at_minimum (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/80_GiB_fits_at_minimum (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/1_TiB (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/5_TiB_S3_max_object (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/whitespace_only (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/invalid_JSON (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/Nix_format (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/empty_input (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/Lix_format (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSONMultiplePaths (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSONMultiplePaths/Lix_multiple_paths (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility (0.01s) niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility/old_string_format_with_colon (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility/new_structured_format_with_sha512 (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI (0.00s) niks3-go-unit-tests> --- PASS: TestScriptTokenEmptyToken (0.01s) niks3-go-unit-tests> --- PASS: TestScriptTokenScriptFails (0.00s) niks3-go-unit-tests> --- PASS: TestGetStorePathHash (0.00s) niks3-go-unit-tests> --- PASS: TestGetStorePathHash/basename_without_hyphen_should_error (0.00s) niks3-go-unit-tests> --- PASS: TestGetStorePathHash/valid_store_path (0.00s) niks3-go-unit-tests> --- PASS: TestGetStorePathHash/hash_with_invalid_characters_should_error (0.00s) niks3-go-unit-tests> --- PASS: TestGetStorePathHash/hash_with_wrong_length_should_error (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/null_ca_field (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/old_string_format_-_text (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/old_string_format_-_fixed_recursive (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/new_structured_format_-_nar_method (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/new_structured_format_-_text (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback (0.01s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/429_enables_limiter (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/400_does_not_enable_limiter (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/503_enables_limiter (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/200_does_not_enable_limiter (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_key_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_cert_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/invalid_ca_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_ca_file (0.00s) niks3-go-unit-tests> 2026/06/08 09:35:52 http: TLS handshake error from 127.0.0.1:55380: remote error: tls: bad certificate niks3-go-unit-tests> --- PASS: TestSetClientTLS (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/rejects_connection_without_client_cert (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/succeeds_with_client_cert_and_CA (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/preserves_debug_logging_transport (0.01s) niks3-go-unit-tests> --- PASS: TestScriptTokenNoExpiryRerunsEveryCall (0.01s) niks3-go-unit-tests> --- PASS: TestDumpPathSingleFile (0.03s) niks3-go-unit-tests> --- PASS: TestCaseHackSuffix (0.05s) niks3-go-unit-tests> --- PASS: TestDumpPathWriterError (0.05s) niks3-go-unit-tests> --- PASS: TestDumpPathMatchesNix (0.11s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback_400DoesNotCountAsSuccess (1.00s) niks3-go-unit-tests> PASS niks3-go-unit-tests> Running server tests... niks3-go-unit-tests> The files belonging to this database system will be owned by user "nixbld". niks3-go-unit-tests> This user must also own the server process. niks3-go-unit-tests> niks3-go-unit-tests> The database cluster will be initialized with locale "C". niks3-go-unit-tests> The default database encoding has accordingly been set to "SQL_ASCII". niks3-go-unit-tests> The default text search configuration will be set to "english". niks3-go-unit-tests> niks3-go-unit-tests> Data page checksums are disabled. niks3-go-unit-tests> niks3-go-unit-tests> creating directory /build/postgres1009562588/data ... ok niks3-go-unit-tests> creating subdirectories ... ok niks3-go-unit-tests> selecting dynamic shared memory implementation ... posix niks3-go-unit-tests> selecting default "max_connections" ... 100 niks3-go-unit-tests> selecting default "shared_buffers" ... 128MB niks3-go-unit-tests> selecting default time zone ... UTC niks3-go-unit-tests> creating configuration files ... ok niks3-go-unit-tests> running bootstrap script ... ok niks3-go-unit-tests> performing post-bootstrap initialization ... ok niks3-go-unit-tests> syncing data to disk ... ok niks3-go-unit-tests> niks3-go-unit-tests> initdb: warning: enabling "trust" authentication for local connections niks3-go-unit-tests> initdb: hint: You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb. niks3-go-unit-tests> niks3-go-unit-tests> Success. You can now start the database server using: niks3-go-unit-tests> niks3-go-unit-tests> pg_ctl -D /build/postgres1009562588/data -l logfile start niks3-go-unit-tests> niks3-go-unit-tests> /build/postgres1009562588:5432 - no response niks3-go-unit-tests> 2026-06-08 09:35:54.594 UTC [302] LOG: starting PostgreSQL 17.10 on x86_64-pc-linux-gnu, compiled by clang version 21.1.8, 64-bit niks3-go-unit-tests> 2026-06-08 09:35:54.594 UTC [302] LOG: listening on Unix socket "/build/postgres1009562588/.s.PGSQL.5432" niks3-go-unit-tests> 2026-06-08 09:35:54.598 UTC [306] LOG: database system was shut down at 2026-06-08 09:35:54 UTC niks3-go-unit-tests> 2026-06-08 09:35:54.603 UTC [302] LOG: database system is ready to accept connections niks3-go-unit-tests> /build/postgres1009562588:5432 - accepting connections niks3-go-unit-tests> RustFS API: http://127.0.0.1:46663 http://127.0.0.1:46663 niks3-go-unit-tests> RustFS Start Time: 2026-06-08 09:35:54 niks3-go-unit-tests> Console WebUI Start Time: 2026-06-08 09:35:54 niks3-go-unit-tests> Console WebUI available at: http://:::9001/rustfs/console/index.html niks3-go-unit-tests> Console WebUI (localhost): http://127.0.0.1:9001/rustfs/console/index.html niks3-go-unit-tests> === RUN TestService_AuthMiddleware niks3-go-unit-tests> === PAUSE TestService_AuthMiddleware niks3-go-unit-tests> === RUN TestService_AuthMiddleware_MTLSProxyHeader niks3-go-unit-tests> === PAUSE TestService_AuthMiddleware_MTLSProxyHeader niks3-go-unit-tests> === RUN TestService_AuthMiddleware_MTLSBoundSubjects niks3-go-unit-tests> === PAUSE TestService_AuthMiddleware_MTLSBoundSubjects niks3-go-unit-tests> === RUN TestService_ReadAuthMiddleware niks3-go-unit-tests> === PAUSE TestService_ReadAuthMiddleware niks3-go-unit-tests> === RUN TestService_AuthMiddleware_OIDC niks3-go-unit-tests> === PAUSE TestService_AuthMiddleware_OIDC niks3-go-unit-tests> === RUN TestCacheConfigHandler niks3-go-unit-tests> === PAUSE TestCacheConfigHandler niks3-go-unit-tests> === RUN TestClientCADerivations niks3-go-unit-tests> === PAUSE TestClientCADerivations niks3-go-unit-tests> === RUN TestClientErrorHandling niks3-go-unit-tests> === PAUSE TestClientErrorHandling niks3-go-unit-tests> === RUN TestClientIntegration niks3-go-unit-tests> === PAUSE TestClientIntegration niks3-go-unit-tests> === RUN TestClientMultipleUploads niks3-go-unit-tests> === PAUSE TestClientMultipleUploads niks3-go-unit-tests> === RUN TestClientWithDependencies niks3-go-unit-tests> === PAUSE TestClientWithDependencies niks3-go-unit-tests> === RUN TestGCBugBareHashReferences niks3-go-unit-tests> === PAUSE TestGCBugBareHashReferences niks3-go-unit-tests> === RUN TestGCTaskStore_StartNew niks3-go-unit-tests> === PAUSE TestGCTaskStore_StartNew niks3-go-unit-tests> === RUN TestGCTaskStore_DeduplicateSameParams niks3-go-unit-tests> === PAUSE TestGCTaskStore_DeduplicateSameParams niks3-go-unit-tests> === RUN TestGCTaskStore_ConflictDifferentParams niks3-go-unit-tests> === PAUSE TestGCTaskStore_ConflictDifferentParams niks3-go-unit-tests> === RUN TestGCTaskStore_GetEmpty niks3-go-unit-tests> === PAUSE TestGCTaskStore_GetEmpty niks3-go-unit-tests> === RUN TestGCTaskStore_GetReturnsLatest niks3-go-unit-tests> === PAUSE TestGCTaskStore_GetReturnsLatest niks3-go-unit-tests> === RUN TestGCTaskStore_CompletedAllowsNewTask niks3-go-unit-tests> === PAUSE TestGCTaskStore_CompletedAllowsNewTask niks3-go-unit-tests> === RUN TestGCTaskStore_PhaseUpdates niks3-go-unit-tests> === PAUSE TestGCTaskStore_PhaseUpdates niks3-go-unit-tests> === RUN TestGCTaskStore_Fail niks3-go-unit-tests> === PAUSE TestGCTaskStore_Fail niks3-go-unit-tests> === RUN TestService_healthCheckHandler niks3-go-unit-tests> === PAUSE TestService_healthCheckHandler niks3-go-unit-tests> === RUN TestGenerateLandingPage niks3-go-unit-tests> === PAUSE TestGenerateLandingPage niks3-go-unit-tests> === RUN TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> === PAUSE TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> === RUN TestService_NativeMTLS niks3-go-unit-tests> === PAUSE TestService_NativeMTLS niks3-go-unit-tests> === RUN TestServerTLSConfig niks3-go-unit-tests> === PAUSE TestServerTLSConfig niks3-go-unit-tests> === RUN TestMultipartCleanup niks3-go-unit-tests> === PAUSE TestMultipartCleanup niks3-go-unit-tests> === RUN TestOrphanedObjectsGC niks3-go-unit-tests> === PAUSE TestOrphanedObjectsGC niks3-go-unit-tests> === RUN TestOrphanedObjectsGCStressTest niks3-go-unit-tests> === PAUSE TestOrphanedObjectsGCStressTest niks3-go-unit-tests> === RUN TestResurrectedObjectNotDeleted niks3-go-unit-tests> === PAUSE TestResurrectedObjectNotDeleted niks3-go-unit-tests> === RUN TestParseSingleRange niks3-go-unit-tests> === PAUSE TestParseSingleRange niks3-go-unit-tests> === RUN TestIsValidCachePath niks3-go-unit-tests> === PAUSE TestIsValidCachePath niks3-go-unit-tests> === RUN TestReadProxyNarinfo niks3-go-unit-tests> === PAUSE TestReadProxyNarinfo niks3-go-unit-tests> === RUN TestReadProxyNarinfoAlreadyDecompressed niks3-go-unit-tests> === PAUSE TestReadProxyNarinfoAlreadyDecompressed niks3-go-unit-tests> === RUN TestReadProxyNarStreaming niks3-go-unit-tests> === PAUSE TestReadProxyNarStreaming niks3-go-unit-tests> === RUN TestReadProxy404 niks3-go-unit-tests> === PAUSE TestReadProxy404 niks3-go-unit-tests> === RUN TestReadProxyInvalidPath niks3-go-unit-tests> === PAUSE TestReadProxyInvalidPath niks3-go-unit-tests> === RUN TestReadProxyHead niks3-go-unit-tests> === PAUSE TestReadProxyHead niks3-go-unit-tests> === RUN TestReadProxyConditionalGet niks3-go-unit-tests> === PAUSE TestReadProxyConditionalGet niks3-go-unit-tests> === RUN TestReadProxyRootRedirectsToIndexHTML niks3-go-unit-tests> === PAUSE TestReadProxyRootRedirectsToIndexHTML niks3-go-unit-tests> === RUN TestReadProxyDisabled niks3-go-unit-tests> === PAUSE TestReadProxyDisabled niks3-go-unit-tests> === RUN TestReadProxyRangeRequest niks3-go-unit-tests> === PAUSE TestReadProxyRangeRequest niks3-go-unit-tests> === RUN TestService_Rustfstest niks3-go-unit-tests> === PAUSE TestService_Rustfstest niks3-go-unit-tests> === RUN TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle niks3-go-unit-tests> === PAUSE TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle niks3-go-unit-tests> === RUN TestProxyWriteTimeout niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout niks3-go-unit-tests> === RUN TestIsValidUploadKey niks3-go-unit-tests> === PAUSE TestIsValidUploadKey niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys niks3-go-unit-tests> === RUN TestUploadHandlersRejectOversizedBody niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectOversizedBody niks3-go-unit-tests> === RUN TestService_cleanupPendingClosuresHandler niks3-go-unit-tests> === PAUSE TestService_cleanupPendingClosuresHandler niks3-go-unit-tests> === RUN TestService_createPendingClosureHandler niks3-go-unit-tests> === PAUSE TestService_createPendingClosureHandler niks3-go-unit-tests> === RUN TestService_verifyS3Integrity niks3-go-unit-tests> === PAUSE TestService_verifyS3Integrity niks3-go-unit-tests> === RUN TestCompleteMultipartUnregistered niks3-go-unit-tests> === PAUSE TestCompleteMultipartUnregistered niks3-go-unit-tests> === CONT TestService_AuthMiddleware niks3-go-unit-tests> === CONT TestProxyWriteTimeout niks3-go-unit-tests> === CONT TestReadProxyNarinfoAlreadyDecompressed niks3-go-unit-tests> === RUN TestProxyWriteTimeout/narinfo niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/narinfo niks3-go-unit-tests> === CONT TestMultipartCleanup niks3-go-unit-tests> === CONT TestService_AuthMiddleware_OIDC niks3-go-unit-tests> === CONT TestService_ReadAuthMiddleware niks3-go-unit-tests> === CONT TestReadProxy404 niks3-go-unit-tests> === RUN TestProxyWriteTimeout/1_GiB_nar niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/1_GiB_nar niks3-go-unit-tests> === CONT TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle niks3-go-unit-tests> === CONT TestService_Rustfstest niks3-go-unit-tests> === CONT TestReadProxyRangeRequest niks3-go-unit-tests> === CONT TestReadProxyDisabled niks3-go-unit-tests> === CONT TestReadProxyRootRedirectsToIndexHTML niks3-go-unit-tests> === CONT TestReadProxyConditionalGet niks3-go-unit-tests> === CONT TestReadProxyHead niks3-go-unit-tests> === CONT TestReadProxyInvalidPath niks3-go-unit-tests> === CONT TestGCTaskStore_CompletedAllowsNewTask niks3-go-unit-tests> --- PASS: TestGCTaskStore_CompletedAllowsNewTask (0.00s) niks3-go-unit-tests> === CONT TestReadProxyNarStreaming niks3-go-unit-tests> === CONT TestCompleteMultipartUnregistered niks3-go-unit-tests> === CONT TestService_verifyS3Integrity niks3-go-unit-tests> === CONT TestService_createPendingClosureHandler niks3-go-unit-tests> === CONT TestService_cleanupPendingClosuresHandler niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys niks3-go-unit-tests> === CONT TestIsValidUploadKey niks3-go-unit-tests> === CONT TestGenerateLandingPage niks3-go-unit-tests> === CONT TestServerTLSConfig niks3-go-unit-tests> === CONT TestService_NativeMTLS niks3-go-unit-tests> === CONT TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> === CONT TestParseSingleRange niks3-go-unit-tests> === CONT TestReadProxyNarinfo niks3-go-unit-tests> === CONT TestIsValidCachePath niks3-go-unit-tests> === CONT TestGCTaskStore_Fail niks3-go-unit-tests> === CONT TestService_healthCheckHandler niks3-go-unit-tests> === CONT TestOrphanedObjectsGCStressTest niks3-go-unit-tests> === CONT TestResurrectedObjectNotDeleted niks3-go-unit-tests> === CONT TestOrphanedObjectsGC niks3-go-unit-tests> === CONT TestGCTaskStore_PhaseUpdates niks3-go-unit-tests> === CONT TestClientMultipleUploads niks3-go-unit-tests> === CONT TestGCTaskStore_GetReturnsLatest niks3-go-unit-tests> === CONT TestGCTaskStore_GetEmpty niks3-go-unit-tests> === CONT TestGCTaskStore_ConflictDifferentParams niks3-go-unit-tests> === CONT TestGCTaskStore_DeduplicateSameParams niks3-go-unit-tests> === CONT TestGCTaskStore_StartNew niks3-go-unit-tests> === CONT TestGCBugBareHashReferences niks3-go-unit-tests> === CONT TestClientWithDependencies niks3-go-unit-tests> === CONT TestCacheConfigHandler niks3-go-unit-tests> === CONT TestClientIntegration niks3-go-unit-tests> === CONT TestClientErrorHandling niks3-go-unit-tests> === CONT TestClientCADerivations niks3-go-unit-tests> === CONT TestService_AuthMiddleware_MTLSBoundSubjects niks3-go-unit-tests> === CONT TestService_AuthMiddleware_MTLSProxyHeader niks3-go-unit-tests> === RUN TestProxyWriteTimeout/10_GiB_nar niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/10_GiB_nar niks3-go-unit-tests> === RUN TestProxyWriteTimeout/unknown_size niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/unknown_size niks3-go-unit-tests> === CONT TestProxyWriteTimeout/narinfo niks3-go-unit-tests> === RUN TestIsValidCachePath/narinfo niks3-go-unit-tests> --- PASS: TestGCTaskStore_PhaseUpdates (0.00s) niks3-go-unit-tests> === CONT TestProxyWriteTimeout/unknown_size niks3-go-unit-tests> === CONT TestProxyWriteTimeout/10_GiB_nar niks3-go-unit-tests> === CONT TestProxyWriteTimeout/1_GiB_nar niks3-go-unit-tests> --- PASS: TestGCTaskStore_Fail (0.00s) niks3-go-unit-tests> --- PASS: TestGCTaskStore_ConflictDifferentParams (0.00s) niks3-go-unit-tests> --- PASS: TestGCTaskStore_StartNew (0.00s) niks3-go-unit-tests> --- PASS: TestProxyWriteTimeout (0.00s) niks3-go-unit-tests> --- PASS: TestProxyWriteTimeout/narinfo (0.00s) niks3-go-unit-tests> --- PASS: TestProxyWriteTimeout/unknown_size (0.00s) niks3-go-unit-tests> --- PASS: TestProxyWriteTimeout/10_GiB_nar (0.00s) niks3-go-unit-tests> --- PASS: TestProxyWriteTimeout/1_GiB_nar (0.00s) niks3-go-unit-tests> === RUN TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === PAUSE TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === RUN TestIsValidUploadKey/narinfo niks3-go-unit-tests> === RUN TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> --- PASS: TestGCTaskStore_GetEmpty (0.00s) niks3-go-unit-tests> --- PASS: TestGCTaskStore_GetReturnsLatest (0.00s) niks3-go-unit-tests> === RUN TestServerTLSConfig/missing_CA_file niks3-go-unit-tests> === RUN TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> --- PASS: TestGCTaskStore_DeduplicateSameParams (0.00s) niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/narinfo niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> === RUN TestParseSingleRange/none niks3-go-unit-tests> === PAUSE TestServerTLSConfig/missing_CA_file niks3-go-unit-tests> === PAUSE TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_zst niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info niks3-go-unit-tests> === RUN TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> === PAUSE TestIsValidCachePath/narinfo niks3-go-unit-tests> === RUN TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nar_zst niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_xz niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nar_xz niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_plain niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nar_plain niks3-go-unit-tests> === RUN TestIsValidUploadKey/listing niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/listing niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log niks3-go-unit-tests> === PAUSE TestParseSingleRange/none niks3-go-unit-tests> === RUN TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === RUN TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> === PAUSE TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_path_traversal niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_path_traversal niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> === PAUSE TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> === PAUSE TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log_home-manager_file niks3-go-unit-tests> === CONT TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_home-manager_file niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> === CONT TestServerTLSConfig/missing_CA_file niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> === RUN TestParseSingleRange/unknown_unit niks3-go-unit-tests> === PAUSE TestParseSingleRange/unknown_unit niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log_plus_in_name niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_plus_in_name niks3-go-unit-tests> === CONT TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === RUN TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === RUN TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_zst niks3-go-unit-tests> === PAUSE TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> === RUN TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> === PAUSE TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_zst niks3-go-unit-tests> === CONT TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_xz niks3-go-unit-tests> === RUN TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === CONT TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> === PAUSE TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === CONT TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> === RUN TestParseSingleRange/malformed_both_empty niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_path_traversal niks3-go-unit-tests> === RUN TestIsValidUploadKey/realisation niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_xz niks3-go-unit-tests> === PAUSE TestParseSingleRange/malformed_both_empty niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === RUN TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/realisation niks3-go-unit-tests> === RUN TestParseSingleRange/malformed_end_before_start niks3-go-unit-tests> === PAUSE TestParseSingleRange/malformed_end_before_start niks3-go-unit-tests> === RUN TestIsValidCachePath/ls niks3-go-unit-tests> === RUN TestParseSingleRange/closed niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === RUN TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === CONT TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> === PAUSE TestParseSingleRange/closed niks3-go-unit-tests> === CONT TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> === RUN TestParseSingleRange/open-ended niks3-go-unit-tests> === PAUSE TestParseSingleRange/open-ended niks3-go-unit-tests> === RUN TestParseSingleRange/end_clamped_to_size niks3-go-unit-tests> === CONT TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === PAUSE TestParseSingleRange/end_clamped_to_size niks3-go-unit-tests> --- PASS: TestServerTLSConfig (0.00s) niks3-go-unit-tests> --- PASS: TestServerTLSConfig/no_client_CA (0.00s) niks3-go-unit-tests> --- PASS: TestServerTLSConfig/missing_CA_file (0.00s) niks3-go-unit-tests> --- PASS: TestServerTLSConfig/not_a_PEM_file (0.00s) niks3-go-unit-tests> === RUN TestParseSingleRange/suffix niks3-go-unit-tests> === PAUSE TestParseSingleRange/suffix niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === RUN TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === RUN TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === PAUSE TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === PAUSE TestIsValidCachePath/ls niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete multipart upload request method=POST path=/ niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/ niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === CONT TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === RUN TestIsValidUploadKey/index.html niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received request for more parts method=POST path=/ niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/index.html niks3-go-unit-tests> --- PASS: TestGenerateLandingPage (0.01s) niks3-go-unit-tests> === RUN TestParseSingleRange/single_byte niks3-go-unit-tests> === RUN TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === PAUSE TestParseSingleRange/single_byte niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === RUN TestIsValidCachePath/log niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === RUN TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === PAUSE TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === PAUSE TestIsValidCachePath/log niks3-go-unit-tests> === RUN TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> --- PASS: TestCacheConfigHandler (0.01s) niks3-go-unit-tests> --- PASS: TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator (0.00s) niks3-go-unit-tests> --- PASS: TestCacheConfigHandler/full_config,_no_issuer (0.00s) niks3-go-unit-tests> --- PASS: TestCacheConfigHandler/no_signing_keys (0.00s) niks3-go-unit-tests> --- PASS: TestCacheConfigHandler/no_cache_url_configured (0.00s) niks3-go-unit-tests> === RUN TestIsValidCachePath/realisation niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/ niks3-go-unit-tests> === PAUSE TestIsValidCachePath/realisation niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> === RUN TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectInvalidKeys (0.00s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key (0.00s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key (0.00s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_path_traversal (0.00s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info (0.00s) niks3-go-unit-tests> === RUN TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === PAUSE TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> === RUN TestIsValidUploadKey/traversal niks3-go-unit-tests> === RUN TestIsValidCachePath/index.html niks3-go-unit-tests> === CONT TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> === PAUSE TestIsValidCachePath/index.html niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_end_before_start niks3-go-unit-tests> === RUN TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === CONT TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === PAUSE TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/traversal niks3-go-unit-tests> === CONT TestParseSingleRange/closed niks3-go-unit-tests> === RUN TestIsValidUploadKey/traversal_nar niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/traversal_nar niks3-go-unit-tests> === CONT TestParseSingleRange/suffix niks3-go-unit-tests> === RUN TestIsValidUploadKey/absolute niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/absolute niks3-go-unit-tests> === RUN TestIsValidUploadKey/empty_key niks3-go-unit-tests> === CONT TestParseSingleRange/open-ended niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/empty_key niks3-go-unit-tests> === CONT TestParseSingleRange/none niks3-go-unit-tests> === RUN TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === CONT TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === CONT TestIsValidUploadKey/narinfo niks3-go-unit-tests> === CONT TestIsValidUploadKey/empty_key niks3-go-unit-tests> === CONT TestIsValidUploadKey/realisation niks3-go-unit-tests> === CONT TestParseSingleRange/end_clamped_to_size niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_plain niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_plus_in_name niks3-go-unit-tests> === CONT TestIsValidUploadKey/absolute niks3-go-unit-tests> === CONT TestIsValidUploadKey/traversal niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_home-manager_file niks3-go-unit-tests> === CONT TestIsValidUploadKey/index.html niks3-go-unit-tests> === CONT TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_xz niks3-go-unit-tests> === CONT TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_zst niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_both_empty niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log niks3-go-unit-tests> === CONT TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === RUN TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> === PAUSE TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> === CONT TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === RUN TestIsValidCachePath/invalid_char_e niks3-go-unit-tests> === PAUSE TestIsValidCachePath/invalid_char_e niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === RUN TestIsValidCachePath/invalid_char_u niks3-go-unit-tests> === PAUSE TestIsValidCachePath/invalid_char_u niks3-go-unit-tests> === RUN TestIsValidCachePath/random_path niks3-go-unit-tests> === PAUSE TestIsValidCachePath/random_path niks3-go-unit-tests> === RUN TestIsValidCachePath/empty niks3-go-unit-tests> === PAUSE TestIsValidCachePath/empty niks3-go-unit-tests> === RUN TestIsValidCachePath/leading_slash niks3-go-unit-tests> === PAUSE TestIsValidCachePath/leading_slash niks3-go-unit-tests> === CONT TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === CONT TestIsValidUploadKey/traversal_nar niks3-go-unit-tests> === CONT TestParseSingleRange/single_byte niks3-go-unit-tests> === CONT TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/listing niks3-go-unit-tests> === CONT TestParseSingleRange/unknown_unit niks3-go-unit-tests> === RUN TestIsValidCachePath/wrong_extension niks3-go-unit-tests> --- PASS: TestIsValidUploadKey (0.01s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/empty_key (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/absolute (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/traversal (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/listing_key,_narinfo_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/index.html (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_plain (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_equals (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/realisation (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nix-cache-info (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_home-manager_file (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_zst (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/narinfo (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_plus_in_name (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_xz (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_key,_narinfo_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/unknown_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/realisation_plus_in_output (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_question_mark (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/traversal_nar (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/narinfo_key,_nar_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/listing (0.00s) niks3-go-unit-tests> === PAUSE TestIsValidCachePath/wrong_extension niks3-go-unit-tests> --- PASS: TestParseSingleRange (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/start_far_past_EOF (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/multi-range_ignored (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/malformed_no_dash (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/malformed_end_before_start (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/closed (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/suffix (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/open-ended (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/none (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/start_past_EOF (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/end_clamped_to_size (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/malformed_both_empty (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/suffix_exceeds_size (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/single_byte (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/unknown_unit (0.00s) niks3-go-unit-tests> === RUN TestIsValidCachePath/short_hash niks3-go-unit-tests> === PAUSE TestIsValidCachePath/short_hash niks3-go-unit-tests> === CONT TestIsValidCachePath/narinfo niks3-go-unit-tests> === CONT TestIsValidCachePath/short_hash niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === CONT TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === CONT TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === CONT TestIsValidCachePath/random_path niks3-go-unit-tests> === CONT TestIsValidCachePath/realisation niks3-go-unit-tests> === CONT TestIsValidCachePath/wrong_extension niks3-go-unit-tests> === CONT TestIsValidCachePath/log niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_xz niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_zst niks3-go-unit-tests> === CONT TestIsValidCachePath/leading_slash niks3-go-unit-tests> === CONT TestIsValidCachePath/ls niks3-go-unit-tests> === CONT TestIsValidCachePath/empty niks3-go-unit-tests> === CONT TestIsValidCachePath/invalid_char_e niks3-go-unit-tests> === CONT TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> 2026/06/08 09:35:55 INFO OIDC provider initialized name=test niks3-go-unit-tests> === CONT TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === CONT TestIsValidCachePath/index.html niks3-go-unit-tests> === CONT TestIsValidCachePath/invalid_char_u niks3-go-unit-tests> --- PASS: TestIsValidCachePath (0.01s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/narinfo (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_uncompressed (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_bz2 (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/short_hash (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/narinfo_all_nix_base32_chars (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nix-cache-info (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/random_path (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/wrong_extension (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/realisation (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/log (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_xz (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_zst (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/leading_slash (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/ls (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/empty (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/invalid_char_e (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/traversal_in_middle (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/traversal_parent (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/index.html (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/invalid_char_u (0.00s) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Request failed, retrying attempt=1 max_attempts=6 backoff=100ms error="Post \"http://localhost:19999/api/pending_closures\": dial tcp [::1]:19999: connect: connection refused" url=http://localhost:19999/api/pending_closures niks3-go-unit-tests> === RUN TestUploadHandlersRejectOversizedBody/create_pending_closure niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectOversizedBody/create_pending_closure niks3-go-unit-tests> === RUN TestUploadHandlersRejectOversizedBody/complete_multipart niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectOversizedBody/complete_multipart niks3-go-unit-tests> === RUN TestUploadHandlersRejectOversizedBody/request_more_parts niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectOversizedBody/request_more_parts niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody/create_pending_closure niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody/request_more_parts niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/ niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody/complete_multipart niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received request for more parts method=POST path=/ niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete multipart upload request method=POST path=/ niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Request failed, retrying attempt=2 max_attempts=6 backoff=189.053585ms error="Post \"http://localhost:19999/api/pending_closures\": dial tcp [::1]:19999: connect: connection refused" url=http://localhost:19999/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Request failed, retrying attempt=3 max_attempts=6 backoff=432.60498ms error="Post \"http://localhost:19999/api/pending_closures\": dial tcp [::1]:19999: connect: connection refused" url=http://localhost:19999/api/pending_closures niks3-go-unit-tests> 2026-06-08 09:35:55.480 UTC [1274] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.480 UTC [1274] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.480 UTC [1275] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.480 UTC [1275] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.483 UTC [1277] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.483 UTC [1277] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.483 UTC [1276] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.483 UTC [1276] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.484 UTC [1279] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.484 UTC [1279] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.484 UTC [1278] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.484 UTC [1278] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.486 UTC [1280] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.486 UTC [1280] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.486 UTC [1281] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.486 UTC [1281] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.487 UTC [1282] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.487 UTC [1282] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.506 UTC [1283] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.506 UTC [1283] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.540 UTC [1284] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.540 UTC [1284] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.552 UTC [1285] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.552 UTC [1285] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.557 UTC [1286] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.557 UTC [1286] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.583 UTC [1287] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.583 UTC [1287] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (65.8ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (71.08ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.15ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.3ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (5.36ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026-06-08 09:35:55.601 UTC [1288] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.601 UTC [1288] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.603 UTC [1289] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.603 UTC [1289] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (6.96ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (77.56ms) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026-06-08 09:35:55.609 UTC [1290] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.609 UTC [1290] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestReadProxyInvalidPath (0.61s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (89.63ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (74.83ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (35.69ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (46.41ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (92.53ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (92.18ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (93.38ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (15.96ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (97.6ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (30.42ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (93.8ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (6.77ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> === NAME TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle niks3-go-unit-tests> throttle_test.go:161: expected multipart upload for NAR file niks3-go-unit-tests> --- FAIL: TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle (0.62s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.83ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.06ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.02ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.97ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.71ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (5.04ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.91ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (5.19ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.95ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (6.21ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (23.42ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.95ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.41ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (3.97ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.04ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.18ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.06ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (5.38ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.2ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (5.19ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.88ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (5.55ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.7ms) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Authentication failed token_preview=wrongtoken token_length=10 reason="static API token mismatch" niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware (0.63s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026-06-08 09:35:55.632 UTC [1294] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.632 UTC [1294] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestReadProxyDisabled (0.63s) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: subject not in bound subjects subject="CN=writer" niks3-go-unit-tests> --- PASS: TestService_ReadAuthMiddleware (0.63s) niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1292] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1292] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1293] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1293] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1291] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.633 UTC [1291] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestService_Rustfstest (0.63s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.79ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.7ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Created nix-cache-info in bucket bucket=bucket12 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (13.65ms) niks3-go-unit-tests> 2026-06-08 09:35:55.640 UTC [1304] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.640 UTC [1304] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.640 UTC [1303] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.640 UTC [1303] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.641 UTC [1306] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.641 UTC [1306] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (15.44ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (6.74ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1305] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1305] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1308] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1308] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1307] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1307] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1309] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.644 UTC [1309] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestReadProxyRootRedirectsToIndexHTML (0.65s) niks3-go-unit-tests> --- PASS: TestReadProxyNarinfoAlreadyDecompressed (0.65s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.51ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026-06-08 09:35:55.646 UTC [1310] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.646 UTC [1310] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestReadProxyNarStreaming (0.65s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.67ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026-06-08 09:35:55.648 UTC [1311] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.648 UTC [1311] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:55.649 UTC [1312] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.649 UTC [1312] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.21ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (3.79ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026-06-08 09:35:55.651 UTC [1314] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.651 UTC [1314] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (9.71ms) niks3-go-unit-tests> 2026-06-08 09:35:55.656 UTC [1315] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.656 UTC [1315] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (11.07ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (12.11ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.96ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (13.7ms) niks3-go-unit-tests> 2026-06-08 09:35:55.660 UTC [1316] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.660 UTC [1316] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestReadProxyRangeRequest (0.66s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.58ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.75ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.85ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (6.53ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.92ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026-06-08 09:35:55.664 UTC [1318] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:55.664 UTC [1318] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (9.54ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.43ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (3.64ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.43ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.41ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (3.7ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.51ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (5.38ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.6ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (13.05ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (12.98ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.61ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (14.32ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.13ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.49ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> --- PASS: TestService_healthCheckHandler (0.67s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (3.95ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (16.35ms) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: subject not in bound subjects subject="CN=untrusted,O=Other" niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: bound subjects configured but subject DN unavailable niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: subject not in bound subjects subject="CN=untrusted" niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_MTLSBoundSubjects (0.67s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (10.66ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (13.48ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (4.53ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxy404 (0.68s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (4.69ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.12ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.51ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.29ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.48ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> --- PASS: TestReadProxyNarinfo (0.67s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.44ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.44ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (2.88ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.83ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (7.73ms) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.52ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (1.76ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (1.94ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.08ms) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.49ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> === RUN TestService_AuthMiddleware_OIDC/valid_OIDC_token niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.27ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: subject not in bound subjects subject="CN=reader" niks3-go-unit-tests> 2026/06/08 09:35:55 WARN mTLS auth: subject not in bound subjects subject="CN=writer" niks3-go-unit-tests> --- PASS: TestService_NativeMTLS (0.68s) niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 0: /build/TestClientMultipleUploads1690727780/001/store/h175vii5hb8v4q7h29qjw3d6w06c61m8-test-file-0.txt niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO OIDC auth successful provider=test niks3-go-unit-tests> === RUN TestService_AuthMiddleware_OIDC/OIDC_token_with_wrong_org_rejected niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (7.46ms) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Created nix-cache-info in bucket bucket=bucket27 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Created nix-cache-info in bucket bucket=bucket28 niks3-go-unit-tests> 2026/06/08 09:35:55 ERROR Multipart upload not found error="no rows in result set" upload_id=does-not-exist object_key=nar/0000000000000000000000000000000000000000000000000000.nar.zst niks3-go-unit-tests> --- PASS: TestCompleteMultipartUnregistered (0.68s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Created nix-cache-info in bucket bucket=bucket32 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20241026095416_initial_model.sql (7.86ms) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Authentication failed token_preview=eyJhbGciOi...DZGxd-MfuQ token_length=702 oidc_error="bound claims validation failed: claim \"repository_owner\" value [otherorg] not in allowed patterns [myorg]" oidc_provider=test tried_providers=[test] niks3-go-unit-tests> === RUN TestService_AuthMiddleware_OIDC/malformed_token_rejected niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Authentication failed token_preview=not-a-valid-jwt token_length=15 oidc_error="no provider could verify the token (signature or issuer mismatch)" oidc_provider="" tried_providers=[test] niks3-go-unit-tests> === RUN TestService_AuthMiddleware_OIDC/static_token_still_works_with_OIDC_configured niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_OIDC (0.68s) niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_OIDC/valid_OIDC_token (0.00s) niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_OIDC/OIDC_token_with_wrong_org_rejected (0.00s) niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_OIDC/malformed_token_rejected (0.00s) niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_OIDC/static_token_still_works_with_OIDC_configured (0.00s) niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (1.74ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (1.16ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (1.9ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 20251210153512_drop_unused_gin_index.sql (1.43ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (2.2ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 OK 1_commit_pending_closure.sql (1.47ms) niks3-go-unit-tests> 2026/06/08 09:35:55 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_MTLSProxyHeader (0.69s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Created nix-cache-info in bucket bucket=bucket34 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Aborted multipart uploads count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> --- PASS: TestResurrectedObjectNotDeleted (0.69s) niks3-go-unit-tests> 2026-06-08 09:35:55.699 UTC [1315] ERROR: Closure does not exist: id=1 niks3-go-unit-tests> 2026-06-08 09:35:55.699 UTC [1315] CONTEXT: PL/pgSQL function commit_pending_closure(bigint) line 16 at RAISE niks3-go-unit-tests> 2026-06-08 09:35:55.699 UTC [1315] STATEMENT: -- name: CommitPendingClosure :exec niks3-go-unit-tests> SELECT commit_pending_closure($1::bigint) niks3-go-unit-tests> niks3-go-unit-tests> --- PASS: TestService_cleanupPendingClosuresHandler (0.69s) niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 1: /build/TestClientMultipleUploads1690727780/001/store/ak3llir3s0bq96am1q2y06k3ld5qgd4d-test-file-1.txt niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:276: Created store path: /build/TestClientIntegration660266646/002/store/vpksn2wvkblxlhcjwnwdcvmp8lyr8g74-test-file.txt niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:48: First store path: /build/TestNARDeduplicationMetadataUploadBug4144562305/001/store/97wwzl2hb31z46z347p2jpwdb408kqiz-file1.txt niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 2: /build/TestClientMultipleUploads1690727780/001/store/2wp7flwffqlqv919x961zychsclqajs2-test-file-2.txt niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Aborted multipart uploads count=1 niks3-go-unit-tests> --- PASS: TestMultipartCleanup (0.76s) niks3-go-unit-tests> === NAME TestClientWithDependencies niks3-go-unit-tests> client_integration_test.go:593: Built derivation: /build/TestClientWithDependencies3503576994/001/store/526m0zqhb29cfm555657xlk9l78cg5yf-test-script niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:136: Built CA derivation: /build/TestClientCADerivations1271508168/001/store/al5ngr0xwy1kqlq01ac1y3ikxxca7c4z-ca-test niks3-go-unit-tests> === NAME TestClientWithDependencies niks3-go-unit-tests> client_integration_test.go:595: Found 1 dependencies (including self) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:139: Found 1 dependencies (including self) niks3-go-unit-tests> --- PASS: TestReadProxyConditionalGet (0.81s) niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Authentication failed token_preview=invalid-token token_length=13 reason="static API token mismatch" niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> --- PASS: TestReadProxyHead (0.82s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 97wwzl2hb31z46z347p2jpwdb408kqiz-file1.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading vpksn2wvkblxlhcjwnwdcvmp8lyr8g74-test-file.txt (152B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (82ms) niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:54: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /build/TestNARDeduplicationMetadataUploadBug4144562305/001/store/97wwzl2hb31z46z347p2jpwdb408kqiz-file1.txt niks3-go-unit-tests> URL: nar/1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf.nar.zst niks3-go-unit-tests> Compression: zstd niks3-go-unit-tests> NarHash: sha256:1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf niks3-go-unit-tests> NarSize: 160 niks3-go-unit-tests> References: niks3-go-unit-tests> CA: fixed:r:sha256:1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> metadata_upload_test.go:55: Retrieved .ls file from S3 (compressed size: 77 bytes) niks3-go-unit-tests> metadata_upload_test.go:55: Decompressed .ls content (64 bytes): niks3-go-unit-tests> {"version":1,"root":{"type":"regular","size":44,"narOffset":96}} niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 3 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 2wp7flwffqlqv919x961zychsclqajs2-test-file-2.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading h175vii5hb8v4q7h29qjw3d6w06c61m8-test-file-0.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading ak3llir3s0bq96am1q2y06k3ld5qgd4d-test-file-1.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (80ms) niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:292: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /build/TestClientIntegration660266646/002/store/vpksn2wvkblxlhcjwnwdcvmp8lyr8g74-test-file.txt niks3-go-unit-tests> URL: nar/11l1b7hsy9g9pz8i2rcn4n128l6pyr2yf58d49r12hr5caw9dzk1.nar.zst niks3-go-unit-tests> Compression: zstd niks3-go-unit-tests> NarHash: sha256:11l1b7hsy9g9pz8i2rcn4n128l6pyr2yf58d49r12hr5caw9dzk1 niks3-go-unit-tests> NarSize: 152 niks3-go-unit-tests> References: niks3-go-unit-tests> CA: fixed:r:sha256:11l1b7hsy9g9pz8i2rcn4n128l6pyr2yf58d49r12hr5caw9dzk1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 526m0zqhb29cfm555657xlk9l78cg5yf-test-script (136B) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody (0.18s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/complete_multipart (0.03s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/request_more_parts (0.05s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/create_pending_closure (0.67s) niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:293: Retrieved .ls file from S3 (compressed size: 77 bytes) niks3-go-unit-tests> client_integration_test.go:293: Decompressed .ls content (64 bytes): niks3-go-unit-tests> {"version":1,"root":{"type":"regular","size":39,"narOffset":96}} niks3-go-unit-tests> client_integration_test.go:296: Testing garbage collection... niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/2/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=2 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/3/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=3 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 3 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (44ms) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/2/complete niks3-go-unit-tests> === NAME TestClientWithDependencies niks3-go-unit-tests> client_integration_test.go:597: Skipping nix copy test - isolated store (/build/TestClientWithDependencies3503576994/001/store) requires matching store prefix niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=2 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/3/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=3 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (92ms) niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:349: Uploaded 3 paths in 123.766764ms niks3-go-unit-tests> --- PASS: TestClientWithDependencies (0.87s) niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:64: Second store path (same content): /build/TestNARDeduplicationMetadataUploadBug4144562305/001/store/3mi3x1ai2jg6zyccd5fmhsrdv0p3qb6b-file2.txt niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Request failed, retrying attempt=4 max_attempts=6 backoff=854.277364ms error="Post \"http://localhost:19999/api/pending_closures\": dial tcp [::1]:19999: connect: connection refused" url=http://localhost:19999/api/pending_closures niks3-go-unit-tests> --- PASS: TestClientMultipleUploads (0.87s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Starting cleanup of old closures method=DELETE path=/api/closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Garbage collection started niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Force mode enabled - objects will be deleted immediately without grace period niks3-go-unit-tests> --- PASS: TestGCBugBareHashReferences (0.89s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading al5ngr0xwy1kqlq01ac1y3ikxxca7c4z-ca-test (144B) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (80ms) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:180: Narinfo contains CA field: StorePath: /build/TestClientCADerivations1271508168/001/store/al5ngr0xwy1kqlq01ac1y3ikxxca7c4z-ca-test niks3-go-unit-tests> URL: nar/04jj7iiy79vhzp5kk3r2751n9x3xa44j98y5bk1ds4jp31kky74n.nar.zst niks3-go-unit-tests> Compression: zstd niks3-go-unit-tests> NarHash: sha256:04jj7iiy79vhzp5kk3r2751n9x3xa44j98y5bk1ds4jp31kky74n niks3-go-unit-tests> NarSize: 144 niks3-go-unit-tests> References: niks3-go-unit-tests> Deriver: /build/TestClientCADerivations1271508168/001/store/vl9fyp0mvi7mcl4l7algn3y9jagh9wqm-ca-test.drv niks3-go-unit-tests> CA: fixed:r:sha256:04jj7iiy79vhzp5kk3r2751n9x3xa44j98y5bk1ds4jp31kky74n niks3-go-unit-tests> client_ca_test.go:185: Checking for realisation files in S3... niks3-go-unit-tests> === NAME TestOrphanedObjectsGC niks3-go-unit-tests> orphaned_objects_gc_test.go:290: GC Test Summary: niks3-go-unit-tests> orphaned_objects_gc_test.go:291: - Kept: 2 objects from closure A niks3-go-unit-tests> orphaned_objects_gc_test.go:292: - Deleted: 2 objects from closure B niks3-go-unit-tests> orphaned_objects_gc_test.go:293: - Deleted: 6 orphaned chain objects (X1->X2->X3) niks3-go-unit-tests> orphaned_objects_gc_test.go:294: - Deleted: 2 orphaned single objects (Y) niks3-go-unit-tests> orphaned_objects_gc_test.go:295: - Total deleted: 10 objects niks3-go-unit-tests> --- PASS: TestOrphanedObjectsGC (0.92s) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:207: No realisation files uploaded - this is expected for locally built CA derivations niks3-go-unit-tests> client_ca_test.go:208: Locally built CA derivations don't have DrvOutput IDs until they're substituted from a cache niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed multipart upload object_key=nar/dadb44fdadb44fdadb44fdadb44f000000000000000000000000.nar.zst upload_id=OTdiOTE0OTMtNzVkOS00OTc0LWFlNDAtZTQxZmI4ZGQyYTcwLjA1OTZkZjY5LWYxMmMtNDIxMy04OTMzLTU5ZmZiZmQ2MWM3OHgxNzgwOTExMzU1NjgzOTU3OTg4 parts=10 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Object in database but missing from S3 key=dadb44fdadb44fdadb44fdadb44f0000.narinfo niks3-go-unit-tests> 2026/06/08 09:35:55 WARN Found objects in DB but missing from S3, will re-upload count=1 niks3-go-unit-tests> --- PASS: TestService_verifyS3Integrity (0.94s) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed multipart upload object_key=nar/0000000000000000000000000000000000000000000000000000.nar.zst upload_id=OTdiOTE0OTMtNzVkOS00OTc0LWFlNDAtZTQxZmI4ZGQyYTcwLmU2YzNhYmNiLTYxZTQtNDc5OC05ZWJiLTA2M2UwMTRiODZkM3gxNzgwOTExMzU1NjgxNzk5MDQw parts=10 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received get closure request method=GET path=/api/closures/00000000000000000000000000000000 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Starting cleanup of old closures method=DELETE path=/api/closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Garbage collection completed failed-uploads-deleted=0 old-closures-deleted=1 objects-marked-for-deletion=2 objects-deleted-after-grace-period=0 objects-failed-to-delete=0 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Vacuumed table table=pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Vacuumed table table=pending_objects niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 0 paths to 127.0.0.1 (1 already cached) niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Vacuumed table table=multipart_uploads niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Vacuumed table table=closures niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received sign narinfos request method=POST path=/api/pending_closures/2/sign niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Signed narinfos id=2 count=1 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Vacuumed table table=objects niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Received complete upload request method=POST path=/api/pending_closures/2/complete niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Completed upload id=2 niks3-go-unit-tests> 2026/06/08 09:35:55 INFO Upload complete. (70ms) niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:76: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /build/TestNARDeduplicationMetadataUploadBug4144562305/001/store/3mi3x1ai2jg6zyccd5fmhsrdv0p3qb6b-file2.txt niks3-go-unit-tests> URL: nar/1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf.nar.zst niks3-go-unit-tests> Compression: zstd niks3-go-unit-tests> NarHash: sha256:1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf niks3-go-unit-tests> NarSize: 160 niks3-go-unit-tests> References: niks3-go-unit-tests> CA: fixed:r:sha256:1byf36hhc5sn8lvwqfkjh3ybgn76slmx8naakslrypxs6mna71rf niks3-go-unit-tests> metadata_upload_test.go:77: Retrieved .ls file from S3 (compressed size: 62 bytes) niks3-go-unit-tests> metadata_upload_test.go:77: Decompressed .ls content (49 bytes): niks3-go-unit-tests> {"version":1,"root":{"type":"regular","size":44}} niks3-go-unit-tests> --- PASS: TestNARDeduplicationMetadataUploadBug (0.97s) niks3-go-unit-tests> 2026/06/08 09:35:56 INFO Received get closure request method=GET path=/api/closures/00000000000000000000000000000000 niks3-go-unit-tests> --- PASS: TestService_createPendingClosureHandler (1.00s) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:258: nix copy output: warning: you don't have Internet access; disabling some network-dependent features niks3-go-unit-tests> warning: failed to create TLS context for AWS credential providers; SSO, STS WebIdentity, and ECS container authentication will be unavailable niks3-go-unit-tests> error: binary cache 's3://bucket34?endpoint=http://localhost:46663®ion=eu-west-1' is for Nix stores with prefix '/nix/store', not '/build/TestClientCADerivations1271508168/001/store' niks3-go-unit-tests> client_ca_test.go:259: nix copy failed (might be expected with isolated stores): exit status 1 niks3-go-unit-tests> --- PASS: TestClientCADerivations (1.09s) niks3-go-unit-tests> === NAME TestOrphanedObjectsGCStressTest niks3-go-unit-tests> orphaned_objects_gc_test.go:425: Created 10 active closures, 5 to-delete closures, 20 orphaned chains niks3-go-unit-tests> orphaned_objects_gc_test.go:446: Marked 210 objects for deletion niks3-go-unit-tests> orphaned_objects_gc_test.go:509: Stress test completed successfully: niks3-go-unit-tests> orphaned_objects_gc_test.go:510: - Active objects preserved: 20 niks3-go-unit-tests> orphaned_objects_gc_test.go:511: - Objects deleted: 210 niks3-go-unit-tests> orphaned_objects_gc_test.go:512: - Total GC'd: 210 niks3-go-unit-tests> --- PASS: TestOrphanedObjectsGCStressTest (1.46s) niks3-go-unit-tests> 2026/06/08 09:35:56 WARN Request failed, retrying attempt=5 max_attempts=6 backoff=1.499624182s error="Post \"http://localhost:19999/api/pending_closures\": dial tcp [::1]:19999: connect: connection refused" url=http://localhost:19999/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:57 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=108 objects_failed=0 niks3-go-unit-tests> --- PASS: TestClientErrorHandling (0.00s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/InvalidStorePath (0.68s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/InvalidAuthToken (0.81s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/ServerNotAvailable (3.23s) niks3-go-unit-tests> 2026/06/08 09:35:59 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=225 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:01 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=330 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:03 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=444 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:05 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=558 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:07 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=669 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:09 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=777 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:11 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=888 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=1002 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Garbage collection completed failed-uploads-deleted=0 old-closures-deleted=1 objects-marked-for-deletion=3 objects-deleted-after-grace-period=1006 objects-failed-to-delete=0 niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Vacuumed table table=pending_closures niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Vacuumed table table=pending_objects niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Vacuumed table table=multipart_uploads niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Vacuumed table table=closures niks3-go-unit-tests> 2026/06/08 09:36:13 INFO Vacuumed table table=objects niks3-go-unit-tests> 2026/06/08 09:36:15 INFO Garbage collection progress phase="" failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=1006 objects_failed=0 niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:303: Objects in database after GC: niks3-go-unit-tests> client_integration_test.go:303: Successfully deleted all objects with GC --force niks3-go-unit-tests> --- PASS: TestClientIntegration (20.91s) niks3-go-unit-tests> FAIL niks3-go-unit-tests> {"timestamp":"2026-06-08T09:36:15.915110602Z","level":"ERROR","fields":{"message":"Cannot perform graceful shutdown, other references exist err: GracefulShutdown"},"target":"rustfs::server::http","filename":"rustfs/src/server/http.rs","line_number":408,"threadName":"rustfs-worker","threadId":"ThreadId(670)"} niks3-go-unit-tests> Server stopped successfully. niks3-go-unit-tests> 2026-06-08 09:36:17.522 UTC [302] LOG: received smart shutdown request niks3-go-unit-tests> 2026-06-08 09:36:17.527 UTC [302] LOG: background worker "logical replication launcher" (PID 309) exited with exit code 1 niks3-go-unit-tests> 2026-06-08 09:36:17.533 UTC [304] LOG: shutting down niks3-go-unit-tests> 2026-06-08 09:36:17.533 UTC [304] LOG: checkpoint starting: shutdown immediate niks3-go-unit-tests> 2026-06-08 09:36:18.253 UTC [304] LOG: checkpoint complete: wrote 8181 buffers (49.9%); 0 WAL file(s) added, 0 removed, 9 recycled; write=0.131 s, sync=0.583 s, total=0.721 s; sync files=11259, longest=0.006 s, average=0.001 s; distance=152947 kB, estimate=152947 kB; lsn=0/AA49568, redo lsn=0/AA49568 niks3-go-unit-tests> 2026-06-08 09:36:18.319 UTC [302] LOG: database system is shut down error: build of '/nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv' on 'ssh-ng://nix@jamie' failed: Cannot build '/nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/wisr73kffzzxjw5f64mqxwal8maiv3x8-niks3-go-unit-tests Last 25 log lines: > 2026/06/08 09:36:05 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=558 objects_failed=0 > 2026/06/08 09:36:07 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=669 objects_failed=0 > 2026/06/08 09:36:09 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=777 objects_failed=0 > 2026/06/08 09:36:11 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=888 objects_failed=0 > 2026/06/08 09:36:13 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=1002 objects_failed=0 > 2026/06/08 09:36:13 INFO Garbage collection completed failed-uploads-deleted=0 old-closures-deleted=1 objects-marked-for-deletion=3 objects-deleted-after-grace-period=1006 objects-failed-to-delete=0 > 2026/06/08 09:36:13 INFO Vacuumed table table=pending_closures > 2026/06/08 09:36:13 INFO Vacuumed table table=pending_objects > 2026/06/08 09:36:13 INFO Vacuumed table table=multipart_uploads > 2026/06/08 09:36:13 INFO Vacuumed table table=closures > 2026/06/08 09:36:13 INFO Vacuumed table table=objects > 2026/06/08 09:36:15 INFO Garbage collection progress phase="" failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=1006 objects_failed=0 > === NAME TestClientIntegration > client_integration_test.go:303: Objects in database after GC: > client_integration_test.go:303: Successfully deleted all objects with GC --force > --- PASS: TestClientIntegration (20.91s) > FAIL > {"timestamp":"2026-06-08T09:36:15.915110602Z","level":"ERROR","fields":{"message":"Cannot perform graceful shutdown, other references exist err: GracefulShutdown"},"target":"rustfs::server::http","filename":"rustfs/src/server/http.rs","line_number":408,"threadName":"rustfs-worker","threadId":"ThreadId(670)"} > Server stopped successfully. > 2026-06-08 09:36:17.522 UTC [302] LOG: received smart shutdown request > 2026-06-08 09:36:17.527 UTC [302] LOG: background worker "logical replication launcher" (PID 309) exited with exit code 1 > 2026-06-08 09:36:17.533 UTC [304] LOG: shutting down > 2026-06-08 09:36:17.533 UTC [304] LOG: checkpoint starting: shutdown immediate > 2026-06-08 09:36:18.253 UTC [304] LOG: checkpoint complete: wrote 8181 buffers (49.9%); 0 WAL file(s) added, 0 removed, 9 recycled; write=0.131 s, sync=0.583 s, total=0.721 s; sync files=11259, longest=0.006 s, average=0.001 s; distance=152947 kB, estimate=152947 kB; lsn=0/AA49568, redo lsn=0/AA49568 > 2026-06-08 09:36:18.319 UTC [302] LOG: database system is shut down For full logs, run: nix log /nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv error: Cannot build '/nix/store/kh8fn2d9avfc3vajv1kz8pss8pjx2kyy-niks3-go-unit-tests.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/wisr73kffzzxjw5f64mqxwal8maiv3x8-niks3-go-unit-tests