this derivation will be built: /nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv building '/nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv' on 'ssh-ng://customer@mac02' building '/nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-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 TestFileTokenMissing niks3-go-unit-tests> === CONT TestFileTokenReadsAndCaches niks3-go-unit-tests> === CONT TestConvertHashToNix32 niks3-go-unit-tests> === RUN TestConvertHashToNix32/SRI_format_to_Nix32 niks3-go-unit-tests> === PAUSE TestConvertHashToNix32/SRI_format_to_Nix32 niks3-go-unit-tests> === RUN TestConvertHashToNix32/already_Nix32_format niks3-go-unit-tests> === PAUSE TestConvertHashToNix32/already_Nix32_format 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 TestRateLimiterFeedback_400DoesNotCountAsSuccess niks3-go-unit-tests> === CONT TestSetClientTLSDoesNotMutateDefaultTransport niks3-go-unit-tests> --- PASS: TestFileTokenMissing (0.00s) niks3-go-unit-tests> === CONT TestScriptTokenEmptyCommand niks3-go-unit-tests> --- PASS: TestScriptTokenEmptyCommand (0.00s) niks3-go-unit-tests> === CONT TestScriptTokenScriptFails niks3-go-unit-tests> === CONT TestStaticToken niks3-go-unit-tests> --- PASS: TestStaticToken (0.00s) niks3-go-unit-tests> === CONT TestScriptTokenCachesUntilRefresh niks3-go-unit-tests> === CONT TestDumpPathSingleFile niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> === CONT TestPartSizeForNAR niks3-go-unit-tests> === RUN TestPartSizeForNAR/zero_stays_at_minimum niks3-go-unit-tests> === CONT TestRateLimiterFeedback niks3-go-unit-tests> === RUN TestRateLimiterFeedback/429_enables_limiter 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 TestRateLimiterFeedback/200_does_not_enable_limiter 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> === CONT TestCaseHackSuffix niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/zero_stays_at_minimum 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 TestPartSizeForNAR/80_GiB_fits_at_minimum niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/80_GiB_fits_at_minimum niks3-go-unit-tests> === RUN TestPartSizeForNAR/115_GiB_needs_larger_parts niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/115_GiB_needs_larger_parts niks3-go-unit-tests> === RUN TestPartSizeForNAR/1_TiB niks3-go-unit-tests> === PAUSE TestPartSizeForNAR/1_TiB niks3-go-unit-tests> === RUN TestPartSizeForNAR/5_TiB_S3_max_object 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> === PAUSE TestPartSizeForNAR/capped_at_5_GiB niks3-go-unit-tests> === CONT TestPathInfoCACompatibility niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === PAUSE TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === RUN TestPathInfoCACompatibility/old_string_format_-_text 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 TestParsePathInfoJSONMultiplePaths niks3-go-unit-tests> === RUN TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths 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 TestParsePathInfoJSON niks3-go-unit-tests> === RUN TestParsePathInfoJSON/Nix_format niks3-go-unit-tests> === PAUSE TestParsePathInfoJSON/Nix_format 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> --- PASS: TestFileTokenReadsAndCaches (0.00s) 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 TestGetStorePathHash niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === RUN TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> === RUN TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI niks3-go-unit-tests> === PAUSE TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI 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 TestConvertHashToNix32/invalid_format niks3-go-unit-tests> === PAUSE TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === RUN TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> === PAUSE TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> === RUN TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> === PAUSE TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> === RUN TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === PAUSE TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === CONT TestConvertHashToNix32/already_Nix32_format niks3-go-unit-tests> === CONT TestShellSplitErrors niks3-go-unit-tests> === CONT TestSetClientTLS niks3-go-unit-tests> --- PASS: TestShellSplitErrors (0.00s) niks3-go-unit-tests> === CONT TestShellSplit niks3-go-unit-tests> --- PASS: TestShellSplit (0.00s) niks3-go-unit-tests> === CONT TestFileTokenEmpty niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> --- PASS: TestConvertHashToNix32 (0.00s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/SRI_format_to_Nix32 (0.00s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/invalid_format (0.00s) niks3-go-unit-tests> --- PASS: TestConvertHashToNix32/already_Nix32_format (0.00s) niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Request returned retryable status, retrying attempt=1 max_attempts=6 backoff=0s status=503 url=http://127.0.0.1:52357 niks3-go-unit-tests> --- PASS: TestDoServerRequestAttachesToken (0.00s) niks3-go-unit-tests> === CONT TestScriptTokenNoExpiryRerunsEveryCall niks3-go-unit-tests> --- PASS: TestFileTokenEmpty (0.00s) niks3-go-unit-tests> === CONT TestEncodeNixBase32 niks3-go-unit-tests> === RUN TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === PAUSE TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === RUN TestEncodeNixBase32/empty_input niks3-go-unit-tests> === PAUSE TestEncodeNixBase32/empty_input niks3-go-unit-tests> === CONT TestEncodeNixBase32WithRealHash niks3-go-unit-tests> --- PASS: TestEncodeNixBase32WithRealHash (0.00s) niks3-go-unit-tests> === CONT TestDumpPathWriterError niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Request returned retryable status, retrying attempt=2 max_attempts=6 backoff=0s status=503 url=http://127.0.0.1:52357 niks3-go-unit-tests> --- PASS: TestDoWithRetry_BodyReplayedViaGetBody (0.00s) niks3-go-unit-tests> === CONT TestScriptTokenBadJSON niks3-go-unit-tests> --- PASS: TestScriptTokenScriptFails (0.01s) niks3-go-unit-tests> === CONT TestSetClientTLSErrors niks3-go-unit-tests> --- PASS: TestSetClientTLSDoesNotMutateDefaultTransport (0.01s) niks3-go-unit-tests> === CONT TestDumpPathMatchesNix niks3-go-unit-tests> === RUN TestSetClientTLS/rejects_connection_without_client_cert niks3-go-unit-tests> === PAUSE TestSetClientTLS/rejects_connection_without_client_cert 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> === RUN TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> === PAUSE TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> === CONT TestScriptTokenEmptyToken niks3-go-unit-tests> === RUN TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> === RUN TestSetClientTLSErrors/missing_key_file 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> === RUN TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> === PAUSE TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> === CONT TestRateLimiterFeedback/429_enables_limiter niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Request returned retryable status, retrying attempt=1 max_attempts=2 backoff=0s status=429 url=http://127.0.0.1:52362 niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> === CONT TestRateLimiterFeedback/200_does_not_enable_limiter niks3-go-unit-tests> === CONT TestRateLimiterFeedback/400_does_not_enable_limiter niks3-go-unit-tests> === CONT TestRateLimiterFeedback/503_enables_limiter niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter enabled after throttle name=server-test rate=5 niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Request returned retryable status, retrying attempt=1 max_attempts=2 backoff=0s status=503 url=http://127.0.0.1:52368 niks3-go-unit-tests> 2026/06/08 09:35:32 WARN Rate limiter backed off name=server-test rate=5 niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/429_enables_limiter (0.00s) niks3-go-unit-tests> --- PASS: TestRateLimiterFeedback/200_does_not_enable_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> === CONT TestPartSizeForNAR/zero_stays_at_minimum niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/null_ca_field niks3-go-unit-tests> === CONT TestPartSizeForNAR/capped_at_5_GiB niks3-go-unit-tests> === CONT TestPartSizeForNAR/5_TiB_S3_max_object niks3-go-unit-tests> === CONT TestPartSizeForNAR/1_TiB 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> --- PASS: TestPartSizeForNAR (0.00s) 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/5_TiB_S3_max_object (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/1_TiB (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/115_GiB_needs_larger_parts (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/80_GiB_fits_at_minimum (0.00s) niks3-go-unit-tests> --- PASS: TestPartSizeForNAR/small_stays_at_minimum (0.00s) niks3-go-unit-tests> === CONT TestParsePathInfoJSONMultiplePaths/Nix_multiple_paths niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/new_structured_format_-_nar_method niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/new_structured_format_-_text niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/old_string_format_-_fixed_recursive niks3-go-unit-tests> === CONT TestPathInfoCACompatibility/old_string_format_-_text 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/new_structured_format_-_nar_method (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/new_structured_format_-_text (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/old_string_format_-_fixed_recursive (0.00s) niks3-go-unit-tests> --- PASS: TestPathInfoCACompatibility/old_string_format_-_text (0.00s) niks3-go-unit-tests> === CONT TestParsePathInfoJSONMultiplePaths/Lix_multiple_paths 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> === 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> --- PASS: TestParsePathInfoJSON (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/Nix_format (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/empty_input (0.00s) niks3-go-unit-tests> --- PASS: TestParsePathInfoJSON/Lix_format (0.00s) niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/old_string_format_with_dash_(SRI) niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/new_structured_format_with_sha512 niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/new_structured_format_-_converts_to_SRI niks3-go-unit-tests> === CONT TestPathInfoHashCompatibility/old_string_format_with_colon niks3-go-unit-tests> --- PASS: TestPathInfoHashCompatibility (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: TestPathInfoHashCompatibility/old_string_format_with_colon (0.00s) niks3-go-unit-tests> === CONT TestGetStorePathHash/valid_store_path niks3-go-unit-tests> === CONT TestGetStorePathHash/hash_with_invalid_characters_should_error niks3-go-unit-tests> === CONT TestGetStorePathHash/hash_with_wrong_length_should_error niks3-go-unit-tests> === CONT TestGetStorePathHash/basename_without_hyphen_should_error niks3-go-unit-tests> --- PASS: TestGetStorePathHash (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: TestGetStorePathHash/basename_without_hyphen_should_error (0.00s) niks3-go-unit-tests> === CONT TestEncodeNixBase32/test_string_hash niks3-go-unit-tests> === CONT TestEncodeNixBase32/empty_input 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> === CONT TestSetClientTLS/rejects_connection_without_client_cert niks3-go-unit-tests> --- PASS: TestScriptTokenBadJSON (0.01s) niks3-go-unit-tests> === CONT TestSetClientTLS/preserves_debug_logging_transport niks3-go-unit-tests> --- PASS: TestScriptTokenEmptyToken (0.01s) niks3-go-unit-tests> === CONT TestSetClientTLS/succeeds_with_client_cert_and_CA niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_cert_file niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_ca_file niks3-go-unit-tests> === CONT TestSetClientTLSErrors/invalid_ca_file niks3-go-unit-tests> 2026/06/08 09:35:32 http: TLS handshake error from 127.0.0.1:52370: read tcp 127.0.0.1:52361->127.0.0.1:52370: use of closed network connection niks3-go-unit-tests> === CONT TestSetClientTLSErrors/missing_key_file niks3-go-unit-tests> --- PASS: TestSetClientTLS (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/succeeds_with_client_cert_and_CA (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/rejects_connection_without_client_cert (0.01s) niks3-go-unit-tests> --- PASS: TestSetClientTLS/preserves_debug_logging_transport (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_cert_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_ca_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/missing_key_file (0.00s) niks3-go-unit-tests> --- PASS: TestSetClientTLSErrors/invalid_ca_file (0.00s) niks3-go-unit-tests> --- PASS: TestScriptTokenCachesUntilRefresh (0.03s) niks3-go-unit-tests> --- PASS: TestScriptTokenNoExpiryRerunsEveryCall (0.03s) niks3-go-unit-tests> --- PASS: TestDumpPathWriterError (0.05s) niks3-go-unit-tests> --- PASS: TestCaseHackSuffix (0.06s) niks3-go-unit-tests> --- PASS: TestDumpPathSingleFile (0.06s) niks3-go-unit-tests> --- PASS: TestDumpPathMatchesNix (0.08s) 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 "_nixbld1". 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 /nix/var/nix/builds/nix-44543-2510916886/postgres4102524406/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 /nix/var/nix/builds/nix-44543-2510916886/postgres4102524406/data -l logfile start niks3-go-unit-tests> niks3-go-unit-tests> /nix/var/nix/builds/nix-44543-2510916886/postgres4102524406:5432 - no response niks3-go-unit-tests> 2026-06-08 09:35:34.251 UTC [44579] LOG: starting PostgreSQL 17.10 on aarch64-apple-darwin25.4.0, compiled by clang version 21.1.8, 64-bit niks3-go-unit-tests> 2026-06-08 09:35:34.251 UTC [44579] LOG: listening on Unix socket "/nix/var/nix/builds/nix-44543-2510916886/postgres4102524406/.s.PGSQL.5432" niks3-go-unit-tests> 2026-06-08 09:35:34.253 UTC [44583] LOG: database system was shut down at 2026-06-08 09:35:34 UTC niks3-go-unit-tests> 2026-06-08 09:35:34.254 UTC [44579] LOG: database system is ready to accept connections niks3-go-unit-tests> /nix/var/nix/builds/nix-44543-2510916886/postgres4102524406:5432 - accepting connections niks3-go-unit-tests> RustFS API: http://49.12.162.61:52373 http://127.0.0.1:52373 niks3-go-unit-tests> RustFS Start Time: 2026-06-08 09:35:34 niks3-go-unit-tests> Console WebUI Start Time: 2026-06-08 09:35:34 niks3-go-unit-tests> Console WebUI available at: http://49.12.162.61: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 TestOrphanedObjectsGC niks3-go-unit-tests> === CONT TestGCTaskStore_DeduplicateSameParams niks3-go-unit-tests> --- PASS: TestGCTaskStore_DeduplicateSameParams (0.00s) niks3-go-unit-tests> === CONT TestGCTaskStore_Fail niks3-go-unit-tests> --- PASS: TestGCTaskStore_Fail (0.00s) niks3-go-unit-tests> === CONT TestGCTaskStore_PhaseUpdates niks3-go-unit-tests> === CONT TestService_healthCheckHandler niks3-go-unit-tests> --- PASS: TestGCTaskStore_PhaseUpdates (0.00s) niks3-go-unit-tests> === CONT TestGCTaskStore_CompletedAllowsNewTask niks3-go-unit-tests> --- PASS: TestGCTaskStore_CompletedAllowsNewTask (0.00s) niks3-go-unit-tests> === CONT TestService_createPendingClosureHandler niks3-go-unit-tests> === CONT TestGCTaskStore_GetReturnsLatest niks3-go-unit-tests> --- PASS: TestGCTaskStore_GetReturnsLatest (0.00s) niks3-go-unit-tests> === CONT TestService_cleanupPendingClosuresHandler niks3-go-unit-tests> === CONT TestGCTaskStore_GetEmpty niks3-go-unit-tests> --- PASS: TestGCTaskStore_GetEmpty (0.00s) niks3-go-unit-tests> === CONT TestGCTaskStore_ConflictDifferentParams niks3-go-unit-tests> === CONT TestReadProxyDisabled niks3-go-unit-tests> --- PASS: TestGCTaskStore_ConflictDifferentParams (0.00s) niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys niks3-go-unit-tests> === CONT TestCompleteMultipartUnregistered niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info niks3-go-unit-tests> === CONT TestService_verifyS3Integrity niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info 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> === RUN TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> === RUN TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> === PAUSE TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> === CONT TestIsValidUploadKey niks3-go-unit-tests> === RUN TestIsValidUploadKey/narinfo niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/narinfo niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_zst 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> === RUN TestIsValidUploadKey/build_log_home-manager_file niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_home-manager_file 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> === RUN TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === RUN TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === RUN TestIsValidUploadKey/realisation niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/realisation niks3-go-unit-tests> === RUN TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === RUN TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === RUN TestIsValidUploadKey/index.html niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/index.html niks3-go-unit-tests> === RUN TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === RUN TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === RUN TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> === RUN TestIsValidUploadKey/traversal niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/traversal niks3-go-unit-tests> === RUN TestIsValidUploadKey/traversal_nar niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/traversal_nar 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> === PAUSE TestIsValidUploadKey/empty_key niks3-go-unit-tests> === RUN TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === PAUSE TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === CONT TestProxyWriteTimeout niks3-go-unit-tests> === RUN TestProxyWriteTimeout/narinfo niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/narinfo niks3-go-unit-tests> === RUN TestProxyWriteTimeout/1_GiB_nar niks3-go-unit-tests> === PAUSE TestProxyWriteTimeout/1_GiB_nar 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 TestCompleteMultipartUploadHandler_RateLimitTriggersThrottle 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 TestService_Rustfstest niks3-go-unit-tests> 2026-06-08 09:35:34.755 UTC [44659] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.755 UTC [44659] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.755 UTC [44658] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.755 UTC [44658] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.757 UTC [44661] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.757 UTC [44661] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44663] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44663] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44660] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44660] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44664] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44664] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44665] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.758 UTC [44665] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.759 UTC [44662] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.759 UTC [44662] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.759 UTC [44666] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.759 UTC [44666] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.761 UTC [44667] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.761 UTC [44667] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (11.37ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (11.09ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (11.79ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (12.15ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (7.98ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (10.13ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (10.29ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (10.62ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (11.16ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (9.96ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (737.29µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (889.67µs) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (952.29µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (879.08µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (1.01ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (1.02ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (1.03ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (1.02ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (921.13µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (779.75µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.02ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.16ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.28ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.28ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.02ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.62ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.59ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.55ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.57ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.25ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> --- PASS: TestService_healthCheckHandler (0.31s) niks3-go-unit-tests> === CONT TestReadProxyRangeRequest niks3-go-unit-tests> 2026/06/08 09:35:34 WARN Authentication failed token_preview=wrongtoken token_length=10 reason="static API token mismatch" niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware (0.31s) niks3-go-unit-tests> === CONT TestReadProxyNarStreaming niks3-go-unit-tests> 2026/06/08 09:35:34 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.31s) niks3-go-unit-tests> === CONT TestReadProxyRootRedirectsToIndexHTML niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> --- PASS: TestService_Rustfstest (0.27s) niks3-go-unit-tests> === CONT TestReadProxyConditionalGet niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> --- PASS: TestReadProxyDisabled (0.31s) niks3-go-unit-tests> === CONT TestReadProxyHead 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.30s) niks3-go-unit-tests> === CONT TestReadProxyInvalidPath niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Aborted multipart uploads count=1 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026-06-08 09:35:34.794 UTC [44659] ERROR: Closure does not exist: id=1 niks3-go-unit-tests> 2026-06-08 09:35:34.794 UTC [44659] CONTEXT: PL/pgSQL function commit_pending_closure(bigint) line 16 at RAISE niks3-go-unit-tests> 2026-06-08 09:35:34.794 UTC [44659] 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.32s) niks3-go-unit-tests> === CONT TestReadProxy404 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete multipart upload request method=POST path=/api/multipart/complete niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Completed multipart upload object_key=nar/0000000000000000000000000000000000000000000000000000.nar.zst upload_id=NzllYzdjM2ItYzBmZi00OGE5LTg2OWUtN2M0YjM3ZTRhMWQ1LmY2MjJhOTU2LWE4Y2EtNDY2My1iYTNkLWEwMTI5ODFhNDBkYngxNzgwOTExMzM0Nzg2OTc5MDAw parts=10 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Completed multipart upload object_key=nar/dadb44fdadb44fdadb44fdadb44f000000000000000000000000.nar.zst upload_id=NzllYzdjM2ItYzBmZi00OGE5LTg2OWUtN2M0YjM3ZTRhMWQ1LjkzY2EzNjE2LWU1ODUtNDUwNS1hY2VmLTlkMTE1ZjMxOGFkNXgxNzgwOTExMzM0Nzg2MjIxMDAw parts=10 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received get closure request method=GET path=/api/closures/00000000000000000000000000000000 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Starting cleanup of old closures method=DELETE path=/api/closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Object in database but missing from S3 key=dadb44fdadb44fdadb44fdadb44f0000.narinfo niks3-go-unit-tests> 2026/06/08 09:35:34 WARN Found objects in DB but missing from S3, will re-upload count=1 niks3-go-unit-tests> --- PASS: TestService_verifyS3Integrity (0.44s) niks3-go-unit-tests> === CONT TestClientErrorHandling niks3-go-unit-tests> === RUN TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> === PAUSE TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> === RUN TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> === PAUSE TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> === RUN TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> === PAUSE TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> === CONT TestGCTaskStore_StartNew niks3-go-unit-tests> --- PASS: TestGCTaskStore_StartNew (0.00s) niks3-go-unit-tests> === CONT TestGCBugBareHashReferences niks3-go-unit-tests> 2026/06/08 09:35:34 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:34 INFO Vacuumed table table=pending_closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Vacuumed table table=pending_objects niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Vacuumed table table=multipart_uploads niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Vacuumed table table=closures niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Vacuumed table table=objects niks3-go-unit-tests> 2026-06-08 09:35:34.930 UTC [44687] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.930 UTC [44687] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.932 UTC [44688] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.932 UTC [44688] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (6.77ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (6.54ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (425.13µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (351.83µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.33ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.21ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxyNarStreaming (0.18s) niks3-go-unit-tests> === CONT TestClientWithDependencies niks3-go-unit-tests> 2026/06/08 09:35:34 INFO Received get closure request method=GET path=/api/closures/00000000000000000000000000000000 niks3-go-unit-tests> --- PASS: TestReadProxyRangeRequest (0.18s) niks3-go-unit-tests> === CONT TestClientMultipleUploads niks3-go-unit-tests> --- PASS: TestService_createPendingClosureHandler (0.49s) niks3-go-unit-tests> === CONT TestClientIntegration niks3-go-unit-tests> 2026-06-08 09:35:34.969 UTC [44693] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.969 UTC [44693] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.970 UTC [44695] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.970 UTC [44695] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:34.971 UTC [44697] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:34.971 UTC [44697] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (11.33ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (507µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 OK 1_commit_pending_closure.sql (1.46ms) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxyConditionalGet (0.21s) niks3-go-unit-tests> === CONT TestService_NativeMTLS niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (13.54ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20241026095416_initial_model.sql (13.88ms) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (497.54µs) niks3-go-unit-tests> 2026/06/08 09:35:34 OK 20251210153512_drop_unused_gin_index.sql (433.83µs) niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:34 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (849.29µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (934.33µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxyRootRedirectsToIndexHTML (0.22s) niks3-go-unit-tests> === CONT TestMultipartCleanup niks3-go-unit-tests> --- PASS: TestReadProxyHead (0.22s) niks3-go-unit-tests> === CONT TestServerTLSConfig niks3-go-unit-tests> === RUN TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === PAUSE TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === RUN TestServerTLSConfig/missing_CA_file niks3-go-unit-tests> === PAUSE TestServerTLSConfig/missing_CA_file niks3-go-unit-tests> === RUN TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === PAUSE TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === CONT TestService_AuthMiddleware_OIDC niks3-go-unit-tests> 2026/06/08 09:35:35 INFO OIDC provider initialized name=test 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.55s) niks3-go-unit-tests> === CONT TestClientCADerivations niks3-go-unit-tests> 2026-06-08 09:35:35.026 UTC [44705] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.026 UTC [44705] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.026 UTC [44706] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.026 UTC [44706] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (9.18ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (658.88µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (9.98ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (453.67µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.23ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (864.96µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxy404 (0.26s) niks3-go-unit-tests> === CONT TestCacheConfigHandler niks3-go-unit-tests> === RUN TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> === RUN TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> === RUN TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === RUN TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === PAUSE TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === CONT TestService_AuthMiddleware_MTLSBoundSubjects niks3-go-unit-tests> --- PASS: TestReadProxyInvalidPath (0.27s) niks3-go-unit-tests> === CONT TestService_ReadAuthMiddleware niks3-go-unit-tests> 2026-06-08 09:35:35.465 UTC [44712] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.465 UTC [44712] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.465 UTC [44713] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.465 UTC [44713] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.486 UTC [44714] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.486 UTC [44714] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.501 UTC [44715] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.501 UTC [44715] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.501 UTC [44716] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.501 UTC [44716] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.503 UTC [44717] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.503 UTC [44717] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (26.9ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (920.67µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (36.13ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (769.46µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.39ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (38.03ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.42ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (585.46µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.15ms) niks3-go-unit-tests> 2026/06/08 09:35:35 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:35 INFO Created nix-cache-info in bucket bucket=bucket18 niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: subject not in bound subjects subject="CN=reader" niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: subject not in bound subjects subject="CN=writer" niks3-go-unit-tests> --- PASS: TestService_NativeMTLS (0.54s) niks3-go-unit-tests> === CONT TestGenerateLandingPage niks3-go-unit-tests> --- PASS: TestGenerateLandingPage (0.00s) niks3-go-unit-tests> === CONT TestIsValidCachePath niks3-go-unit-tests> === RUN TestIsValidCachePath/narinfo niks3-go-unit-tests> === PAUSE TestIsValidCachePath/narinfo niks3-go-unit-tests> === RUN TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === PAUSE TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_zst niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_zst niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_xz niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_xz niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === RUN TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === RUN TestIsValidCachePath/ls niks3-go-unit-tests> === PAUSE TestIsValidCachePath/ls niks3-go-unit-tests> === RUN TestIsValidCachePath/log niks3-go-unit-tests> === PAUSE TestIsValidCachePath/log niks3-go-unit-tests> === RUN TestIsValidCachePath/realisation niks3-go-unit-tests> === PAUSE TestIsValidCachePath/realisation niks3-go-unit-tests> === RUN TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === PAUSE TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === RUN TestIsValidCachePath/index.html niks3-go-unit-tests> === PAUSE TestIsValidCachePath/index.html niks3-go-unit-tests> === RUN TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === PAUSE TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === RUN TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> === PAUSE TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> === RUN TestIsValidCachePath/invalid_char_e niks3-go-unit-tests> === PAUSE TestIsValidCachePath/invalid_char_e 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> === RUN TestIsValidCachePath/wrong_extension niks3-go-unit-tests> === PAUSE TestIsValidCachePath/wrong_extension niks3-go-unit-tests> === RUN TestIsValidCachePath/short_hash niks3-go-unit-tests> === PAUSE TestIsValidCachePath/short_hash niks3-go-unit-tests> === CONT TestReadProxyNarinfoAlreadyDecompressed niks3-go-unit-tests> 2026/06/08 09:35:35 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:35 WARN Authentication failed token_preview=eyJhbGciOi...9o5RqAHQ6g 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:35 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.53s) 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> === CONT TestReadProxyNarinfo niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (11.05ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (1.78ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (14.4ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (13.87ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (6.97ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (7.32ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (8.05ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (5.95ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (6.95ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026-06-08 09:35:35.566 UTC [44721] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.566 UTC [44721] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Created nix-cache-info in bucket bucket=bucket23 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Created nix-cache-info in bucket bucket=bucket22 niks3-go-unit-tests> 2026-06-08 09:35:35.575 UTC [44724] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.575 UTC [44724] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.589 UTC [44728] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.589 UTC [44728] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.591 UTC [44729] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.591 UTC [44729] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 0: /nix/var/nix/builds/nix-44543-2510916886/TestClientMultipleUploads3785516711/001/store/zbcja1idy3mqcjx8k18mp6zk9vvvxd48-test-file-0.txt niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:276: Created store path: /nix/var/nix/builds/nix-44543-2510916886/TestClientIntegration436073302/002/store/b1zzfbncc9ydvlqala1xrczc1fqax8aq-test-file.txt niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (49.51ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (51.09ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (1.15ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (1.26ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.78ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.96ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (16.9ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (11.72ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (1.12ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (1.88ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (2.77ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (1.71ms) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Created nix-cache-info in bucket bucket=bucket25 niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: subject not in bound subjects subject="CN=untrusted,O=Other" niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: bound subjects configured but subject DN unavailable niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: subject not in bound subjects subject="CN=untrusted" niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_MTLSBoundSubjects (0.65s) niks3-go-unit-tests> === CONT TestResurrectedObjectNotDeleted niks3-go-unit-tests> 2026/06/08 09:35:35 WARN mTLS auth: subject not in bound subjects subject="CN=writer" niks3-go-unit-tests> --- PASS: TestService_ReadAuthMiddleware (0.65s) niks3-go-unit-tests> === CONT TestParseSingleRange niks3-go-unit-tests> === RUN TestParseSingleRange/none niks3-go-unit-tests> === PAUSE TestParseSingleRange/none niks3-go-unit-tests> === RUN TestParseSingleRange/unknown_unit niks3-go-unit-tests> === PAUSE TestParseSingleRange/unknown_unit niks3-go-unit-tests> === RUN TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === PAUSE TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === RUN TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === PAUSE TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === RUN TestParseSingleRange/malformed_both_empty niks3-go-unit-tests> === PAUSE TestParseSingleRange/malformed_both_empty 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 TestParseSingleRange/closed niks3-go-unit-tests> === PAUSE TestParseSingleRange/closed 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> === PAUSE TestParseSingleRange/end_clamped_to_size niks3-go-unit-tests> === RUN TestParseSingleRange/suffix niks3-go-unit-tests> === PAUSE TestParseSingleRange/suffix niks3-go-unit-tests> === RUN TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === PAUSE TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === RUN TestParseSingleRange/single_byte niks3-go-unit-tests> === PAUSE TestParseSingleRange/single_byte niks3-go-unit-tests> === RUN TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === PAUSE TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === RUN TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> === PAUSE TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> === CONT TestService_AuthMiddleware_MTLSProxyHeader niks3-go-unit-tests> === NAME TestClientWithDependencies niks3-go-unit-tests> client_integration_test.go:593: Built derivation: /nix/var/nix/builds/nix-44543-2510916886/TestClientWithDependencies3900829637/001/store/p5jr3ljycbk0i7jvwpgxyim8ra5jcn6h-test-script niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 1: /nix/var/nix/builds/nix-44543-2510916886/TestClientMultipleUploads3785516711/001/store/xsibchqffph7inpxfsddcj3gnp8rgz4l-test-file-1.txt 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 TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:338: Created store path 2: /nix/var/nix/builds/nix-44543-2510916886/TestClientMultipleUploads3785516711/001/store/5ln1b0n5iydwxl4kj73xa32xsmvaygma-test-file-2.txt niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received cleanup request method=DELETE path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Aborted multipart uploads count=1 niks3-go-unit-tests> --- PASS: TestMultipartCleanup (0.82s) niks3-go-unit-tests> === CONT TestOrphanedObjectsGCStressTest niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:136: Built CA derivation: /nix/var/nix/builds/nix-44543-2510916886/TestClientCADerivations1130413851/001/store/372f1fn6v38ag6rq0rsqsd5fqhigzdcx-ca-test niks3-go-unit-tests> --- PASS: TestGCBugBareHashReferences (0.93s) niks3-go-unit-tests> === CONT TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading b1zzfbncc9ydvlqala1xrczc1fqax8aq-test-file.txt (152B) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Upload complete. (114ms) niks3-go-unit-tests> === NAME TestClientIntegration niks3-go-unit-tests> client_integration_test.go:292: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /nix/var/nix/builds/nix-44543-2510916886/TestClientIntegration436073302/002/store/b1zzfbncc9ydvlqala1xrczc1fqax8aq-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> 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:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading p5jr3ljycbk0i7jvwpgxyim8ra5jcn6h-test-script (136B) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:139: Found 1 dependencies (including self) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Upload complete. (79ms) niks3-go-unit-tests> === NAME TestClientWithDependencies niks3-go-unit-tests> client_integration_test.go:597: Skipping nix copy test - isolated store (/nix/var/nix/builds/nix-44543-2510916886/TestClientWithDependencies3900829637/001/store) requires matching store prefix niks3-go-unit-tests> --- PASS: TestClientWithDependencies (0.95s) niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/request_more_parts_rejects_non-NAR_key niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received request for more parts method=POST path=/ niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_nix-cache-info niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/ niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/complete_multipart_rejects_non-NAR_key niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete multipart upload request method=POST path=/ niks3-go-unit-tests> === CONT TestUploadHandlersRejectInvalidKeys/create_pending_closure_rejects_path_traversal niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/ 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/create_pending_closure_rejects_nix-cache-info (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> === CONT TestIsValidUploadKey/narinfo niks3-go-unit-tests> === CONT TestIsValidUploadKey/realisation_plus_in_output niks3-go-unit-tests> === CONT TestIsValidUploadKey/unknown_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/empty_key niks3-go-unit-tests> === CONT TestIsValidUploadKey/absolute niks3-go-unit-tests> === CONT TestIsValidUploadKey/traversal_nar niks3-go-unit-tests> === CONT TestIsValidUploadKey/traversal niks3-go-unit-tests> === CONT TestIsValidUploadKey/listing_key,_narinfo_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_key,_narinfo_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/narinfo_key,_nar_type niks3-go-unit-tests> === CONT TestIsValidUploadKey/index.html niks3-go-unit-tests> === CONT TestIsValidUploadKey/nix-cache-info niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_home-manager_file niks3-go-unit-tests> === CONT TestIsValidUploadKey/realisation niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_equals niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_question_mark niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log_plus_in_name niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_plain niks3-go-unit-tests> === CONT TestIsValidUploadKey/build_log niks3-go-unit-tests> === CONT TestIsValidUploadKey/listing niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_xz niks3-go-unit-tests> === CONT TestIsValidUploadKey/nar_zst niks3-go-unit-tests> --- PASS: TestIsValidUploadKey (0.02s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/narinfo (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/realisation_plus_in_output (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/unknown_type (0.00s) 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_nar (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/nar_key,_narinfo_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/narinfo_key,_nar_type (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/index.html (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nix-cache-info (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_home-manager_file (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/realisation (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_equals (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_question_mark (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log_plus_in_name (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_plain (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/build_log (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/listing (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_xz (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidUploadKey/nar_zst (0.00s) niks3-go-unit-tests> === CONT TestProxyWriteTimeout/narinfo 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: 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> === CONT TestUploadHandlersRejectOversizedBody/create_pending_closure niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/ niks3-go-unit-tests> 2026-06-08 09:35:35.908 UTC [44774] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.908 UTC [44774] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.909 UTC [44775] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.909 UTC [44775] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Starting cleanup of old closures method=DELETE path=/api/closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Garbage collection started niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Aborted multipart uploads count=0 niks3-go-unit-tests> 2026/06/08 09:35:35 WARN Force mode enabled - objects will be deleted immediately without grace period niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (8.7ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20241026095416_initial_model.sql (8.72ms) niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (806.96µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 20251210153512_drop_unused_gin_index.sql (593.67µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (947.04µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:35 OK 1_commit_pending_closure.sql (911.63µs) niks3-go-unit-tests> 2026/06/08 09:35:35 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestReadProxyNarinfoAlreadyDecompressed (0.40s) niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody/request_more_parts niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received request for more parts method=POST path=/ niks3-go-unit-tests> --- PASS: TestReadProxyNarinfo (0.40s) niks3-go-unit-tests> === CONT TestUploadHandlersRejectOversizedBody/complete_multipart niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete multipart upload request method=POST path=/ niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 3 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 5ln1b0n5iydwxl4kj73xa32xsmvaygma-test-file-2.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading zbcja1idy3mqcjx8k18mp6zk9vvvxd48-test-file-0.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading xsibchqffph7inpxfsddcj3gnp8rgz4l-test-file-1.txt (160B) niks3-go-unit-tests> === CONT TestClientErrorHandling/InvalidStorePath niks3-go-unit-tests> === CONT TestClientErrorHandling/ServerNotAvailable niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received sign narinfos request method=POST path=/api/pending_closures/2/sign niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Signed narinfos id=2 count=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received sign narinfos request method=POST path=/api/pending_closures/3/sign niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Signed narinfos id=3 count=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Uploading 3 narinfos niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete upload request method=POST path=/api/pending_closures/2/complete niks3-go-unit-tests> 2026-06-08 09:35:35.979 UTC [44781] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.979 UTC [44781] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:35.984 UTC [44783] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:35.984 UTC [44783] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Completed upload id=2 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete upload request method=POST path=/api/pending_closures/3/complete niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Completed upload id=3 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:35 INFO Upload complete. (156ms) niks3-go-unit-tests> === NAME TestClientMultipleUploads niks3-go-unit-tests> client_integration_test.go:349: Uploaded 3 paths in 196.035916ms niks3-go-unit-tests> --- PASS: TestClientMultipleUploads (1.05s) niks3-go-unit-tests> === CONT TestClientErrorHandling/InvalidAuthToken niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (15.11ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (12.03ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (750.25µs) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (927.67µs) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (1.11ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (1.47ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> --- PASS: TestService_AuthMiddleware_MTLSProxyHeader (0.30s) niks3-go-unit-tests> === CONT TestServerTLSConfig/no_client_CA niks3-go-unit-tests> === CONT TestServerTLSConfig/not_a_PEM_file niks3-go-unit-tests> === CONT TestServerTLSConfig/missing_CA_file 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/not_a_PEM_file (0.00s) niks3-go-unit-tests> --- PASS: TestServerTLSConfig/missing_CA_file (0.00s) niks3-go-unit-tests> === CONT TestCacheConfigHandler/full_config,_no_issuer niks3-go-unit-tests> === CONT TestCacheConfigHandler/no_signing_keys niks3-go-unit-tests> === CONT TestCacheConfigHandler/issuer_requested_but_no_OIDC_validator niks3-go-unit-tests> === CONT TestCacheConfigHandler/no_cache_url_configured niks3-go-unit-tests> --- PASS: TestCacheConfigHandler (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/issuer_requested_but_no_OIDC_validator (0.00s) niks3-go-unit-tests> --- PASS: TestCacheConfigHandler/no_cache_url_configured (0.00s) niks3-go-unit-tests> === CONT TestIsValidCachePath/narinfo niks3-go-unit-tests> === CONT TestIsValidCachePath/index.html niks3-go-unit-tests> === CONT TestIsValidCachePath/short_hash niks3-go-unit-tests> === CONT TestIsValidCachePath/wrong_extension niks3-go-unit-tests> === CONT TestIsValidCachePath/leading_slash niks3-go-unit-tests> === CONT TestIsValidCachePath/empty niks3-go-unit-tests> === CONT TestIsValidCachePath/random_path niks3-go-unit-tests> === CONT TestIsValidCachePath/invalid_char_u niks3-go-unit-tests> === CONT TestIsValidCachePath/invalid_char_e niks3-go-unit-tests> === CONT TestIsValidCachePath/traversal_in_middle niks3-go-unit-tests> === CONT TestIsValidCachePath/traversal_parent niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_uncompressed niks3-go-unit-tests> === CONT TestIsValidCachePath/nix-cache-info niks3-go-unit-tests> === CONT TestIsValidCachePath/realisation niks3-go-unit-tests> === CONT TestIsValidCachePath/log niks3-go-unit-tests> === CONT TestIsValidCachePath/ls niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_xz niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_bz2 niks3-go-unit-tests> === CONT TestIsValidCachePath/narinfo_all_nix_base32_chars niks3-go-unit-tests> === CONT TestIsValidCachePath/nar_zst niks3-go-unit-tests> --- PASS: TestIsValidCachePath (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/narinfo (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/index.html (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/short_hash (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/wrong_extension (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/leading_slash (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/empty (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/random_path (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/invalid_char_u (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/nar_uncompressed (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nix-cache-info (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/ls (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_xz (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_bz2 (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/narinfo_all_nix_base32_chars (0.00s) niks3-go-unit-tests> --- PASS: TestIsValidCachePath/nar_zst (0.00s) niks3-go-unit-tests> === CONT TestParseSingleRange/none niks3-go-unit-tests> === CONT TestParseSingleRange/open-ended niks3-go-unit-tests> === CONT TestParseSingleRange/start_far_past_EOF niks3-go-unit-tests> === CONT TestParseSingleRange/start_past_EOF niks3-go-unit-tests> === CONT TestParseSingleRange/single_byte niks3-go-unit-tests> === CONT TestParseSingleRange/suffix_exceeds_size niks3-go-unit-tests> === CONT TestParseSingleRange/suffix niks3-go-unit-tests> === CONT TestParseSingleRange/end_clamped_to_size niks3-go-unit-tests> === CONT TestParseSingleRange/multi-range_ignored niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_no_dash niks3-go-unit-tests> === CONT TestParseSingleRange/unknown_unit niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_both_empty niks3-go-unit-tests> === CONT TestParseSingleRange/closed niks3-go-unit-tests> === CONT TestParseSingleRange/malformed_end_before_start niks3-go-unit-tests> --- PASS: TestParseSingleRange (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/none (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/open-ended (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/start_far_past_EOF (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/start_past_EOF (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/single_byte (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/suffix_exceeds_size (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/suffix (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/end_clamped_to_size (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/unknown_unit (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/malformed_both_empty (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/closed (0.00s) niks3-go-unit-tests> --- PASS: TestParseSingleRange/malformed_end_before_start (0.00s) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 372f1fn6v38ag6rq0rsqsd5fqhigzdcx-ca-test (144B) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026-06-08 09:35:36.088 UTC [44793] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:36.088 UTC [44793] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> --- PASS: TestResurrectedObjectNotDeleted (0.38s) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Upload complete. (148ms) niks3-go-unit-tests> === NAME TestClientCADerivations niks3-go-unit-tests> client_ca_test.go:180: Narinfo contains CA field: StorePath: /nix/var/nix/builds/nix-44543-2510916886/TestClientCADerivations1130413851/001/store/372f1fn6v38ag6rq0rsqsd5fqhigzdcx-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: /nix/var/nix/builds/nix-44543-2510916886/TestClientCADerivations1130413851/001/store/9ly438frjzzdhvk6rkwfv4ns15wq8krz-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> 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:36.115 UTC [44796] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:36.115 UTC [44796] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (20.75ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (1.15ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (2.13ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (7.76ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (433µs) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (2.02ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Created nix-cache-info in bucket bucket=bucket33 niks3-go-unit-tests> client_ca_test.go:258: nix copy output: error: binary cache 's3://bucket25?endpoint=http://localhost:52373®ion=eu-west-1' is for Nix stores with prefix '/nix/store', not '/nix/var/nix/builds/nix-44543-2510916886/TestClientCADerivations1130413851/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.12s) niks3-go-unit-tests> 2026/06/08 09:35:36 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> 2026-06-08 09:35:36.172 UTC [44801] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:36.172 UTC [44801] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> 2026-06-08 09:35:36.180 UTC [44803] ERROR: relation "goose_db_version" does not exist at character 36 niks3-go-unit-tests> 2026-06-08 09:35:36.180 UTC [44803] STATEMENT: SELECT version_id, is_applied from goose_db_version ORDER BY id DESC niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:48: First store path: /nix/var/nix/builds/nix-44543-2510916886/TestNARDeduplicationMetadataUploadBug704252657/001/store/mhnbyn4cqvb1an7sp4a9sg1q66w7k6hl-file1.txt niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (4.73ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20241026095416_initial_model.sql (4.58ms) niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (624.38µs) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 20251210153512_drop_unused_gin_index.sql (461.96µs) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: successfully migrated database to version: 20251210153512 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (1.54ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:36 OK 1_commit_pending_closure.sql (1.43ms) niks3-go-unit-tests> 2026/06/08 09:35:36 goose: up to current file version: 1 niks3-go-unit-tests> 2026/06/08 09:35:36 WARN Request failed, retrying attempt=2 max_attempts=6 backoff=184.17128ms 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: TestUploadHandlersRejectOversizedBody (0.03s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/request_more_parts (0.03s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/complete_multipart (0.03s) niks3-go-unit-tests> --- PASS: TestUploadHandlersRejectOversizedBody/create_pending_closure (0.36s) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 1 paths to 127.0.0.1 (0 already cached) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading mhnbyn4cqvb1an7sp4a9sg1q66w7k6hl-file1.txt (160B) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received sign narinfos request method=POST path=/api/pending_closures/1/sign niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Signed narinfos id=1 count=1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received complete upload request method=POST path=/api/pending_closures/1/complete niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Completed upload id=1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Upload complete. (79ms) niks3-go-unit-tests> === NAME TestNARDeduplicationMetadataUploadBug niks3-go-unit-tests> metadata_upload_test.go:54: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /nix/var/nix/builds/nix-44543-2510916886/TestNARDeduplicationMetadataUploadBug704252657/001/store/mhnbyn4cqvb1an7sp4a9sg1q66w7k6hl-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> 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> metadata_upload_test.go:64: Second store path (same content): /nix/var/nix/builds/nix-44543-2510916886/TestNARDeduplicationMetadataUploadBug704252657/001/store/sb1xjqy2069dsdha2pqnshg73ipbl4y3-file2.txt niks3-go-unit-tests> 2026/06/08 09:35:36 WARN Authentication failed token_preview=invalid-token token_length=13 reason="static API token mismatch" niks3-go-unit-tests> 2026/06/08 09:35:36 WARN Request failed, retrying attempt=3 max_attempts=6 backoff=411.229231ms 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:36 INFO Received uploads request method=POST path=/api/pending_closures niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 0 paths to 127.0.0.1 (1 already cached) niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received sign narinfos request method=POST path=/api/pending_closures/2/sign niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Signed narinfos id=2 count=1 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Uploading 1 narinfos niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Received complete upload request method=POST path=/api/pending_closures/2/complete niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Completed upload id=2 niks3-go-unit-tests> 2026/06/08 09:35:36 INFO Upload complete. (72ms) niks3-go-unit-tests> metadata_upload_test.go:76: Retrieved narinfo from S3: niks3-go-unit-tests> StorePath: /nix/var/nix/builds/nix-44543-2510916886/TestNARDeduplicationMetadataUploadBug704252657/001/store/sb1xjqy2069dsdha2pqnshg73ipbl4y3-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.64s) 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 (0.71s) niks3-go-unit-tests> 2026/06/08 09:35:36 WARN Request failed, retrying attempt=4 max_attempts=6 backoff=733.314188ms 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:37 WARN Request failed, retrying attempt=5 max_attempts=6 backoff=1.611025159s 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:37 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=195 objects_failed=0 niks3-go-unit-tests> --- PASS: TestClientErrorHandling (0.00s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/InvalidStorePath (0.30s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/InvalidAuthToken (0.38s) niks3-go-unit-tests> --- PASS: TestClientErrorHandling/ServerNotAvailable (3.25s) niks3-go-unit-tests> 2026/06/08 09:35:39 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=402 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:35:41 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=612 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:35:43 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=822 objects_failed=0 niks3-go-unit-tests> 2026/06/08 09:35:45 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:35:45 INFO Vacuumed table table=pending_closures niks3-go-unit-tests> 2026/06/08 09:35:45 INFO Vacuumed table table=pending_objects niks3-go-unit-tests> 2026/06/08 09:35:45 INFO Vacuumed table table=multipart_uploads niks3-go-unit-tests> 2026/06/08 09:35:45 INFO Vacuumed table table=closures niks3-go-unit-tests> 2026/06/08 09:35:45 INFO Vacuumed table table=objects niks3-go-unit-tests> 2026/06/08 09:35:45 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 (10.97s) niks3-go-unit-tests> FAIL niks3-go-unit-tests> {"timestamp":"2026-06-08T09:35:45.930468Z","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(10)"} niks3-go-unit-tests> Server stopped successfully. niks3-go-unit-tests> 2026-06-08 09:35:47.469 UTC [44579] LOG: received smart shutdown request niks3-go-unit-tests> 2026-06-08 09:35:47.470 UTC [44579] LOG: background worker "logical replication launcher" (PID 44586) exited with exit code 1 niks3-go-unit-tests> 2026-06-08 09:35:47.473 UTC [44581] LOG: shutting down niks3-go-unit-tests> 2026-06-08 09:35:47.473 UTC [44581] LOG: checkpoint starting: shutdown immediate niks3-go-unit-tests> 2026-06-08 09:35:48.255 UTC [44581] LOG: checkpoint complete: wrote 11696 buffers (71.4%); 0 WAL file(s) added, 0 removed, 9 recycled; write=0.583 s, sync=0.199 s, total=0.783 s; sync files=11259, longest=0.001 s, average=0.001 s; distance=155691 kB, estimate=155691 kB; lsn=0/AD1D8A8, redo lsn=0/AD1D8A8 niks3-go-unit-tests> 2026-06-08 09:35:48.258 UTC [44579] LOG: database system is shut down error: build of '/nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv' on 'ssh-ng://customer@mac02' failed: Cannot build '/nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/9g353kmarrqg2j0h9ry511f78x16x96d-niks3-go-unit-tests Last 25 log lines: > --- PASS: TestClientErrorHandling/InvalidAuthToken (0.38s) > --- PASS: TestClientErrorHandling/ServerNotAvailable (3.25s) > 2026/06/08 09:35:39 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=402 objects_failed=0 > 2026/06/08 09:35:41 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=612 objects_failed=0 > 2026/06/08 09:35:43 INFO Garbage collection progress phase=cleanup_orphan_objects failed_uploads_deleted=0 old_closures_deleted=1 objects_marked=3 objects_deleted=822 objects_failed=0 > 2026/06/08 09:35:45 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:35:45 INFO Vacuumed table table=pending_closures > 2026/06/08 09:35:45 INFO Vacuumed table table=pending_objects > 2026/06/08 09:35:45 INFO Vacuumed table table=multipart_uploads > 2026/06/08 09:35:45 INFO Vacuumed table table=closures > 2026/06/08 09:35:45 INFO Vacuumed table table=objects > 2026/06/08 09:35:45 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 (10.97s) > FAIL > {"timestamp":"2026-06-08T09:35:45.930468Z","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(10)"} > Server stopped successfully. > 2026-06-08 09:35:47.469 UTC [44579] LOG: received smart shutdown request > 2026-06-08 09:35:47.470 UTC [44579] LOG: background worker "logical replication launcher" (PID 44586) exited with exit code 1 > 2026-06-08 09:35:47.473 UTC [44581] LOG: shutting down > 2026-06-08 09:35:47.473 UTC [44581] LOG: checkpoint starting: shutdown immediate > 2026-06-08 09:35:48.255 UTC [44581] LOG: checkpoint complete: wrote 11696 buffers (71.4%); 0 WAL file(s) added, 0 removed, 9 recycled; write=0.583 s, sync=0.199 s, total=0.783 s; sync files=11259, longest=0.001 s, average=0.001 s; distance=155691 kB, estimate=155691 kB; lsn=0/AD1D8A8, redo lsn=0/AD1D8A8 > 2026-06-08 09:35:48.258 UTC [44579] LOG: database system is shut down For full logs, run: nix log /nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv error: Cannot build '/nix/store/7kaw68wany146fniq8lw6s0czj6zhgvh-niks3-go-unit-tests.drv'. Reason: builder failed with exit code 1. Output paths: /nix/store/9g353kmarrqg2j0h9ry511f78x16x96d-niks3-go-unit-tests