>>> anubis: Building community/anubis 1.24.0-r0 (using abuild 3.16.0-r0) started Mon, 29 Dec 2025 14:01:11 +0000 >>> anubis: Validating /home/buildozer/aports/community/anubis/APKBUILD... >>> anubis: Analyzing dependencies... >>> anubis: Installing for build: build-base go (1/2) Installing go (1.25.5-r0) (2/2) Installing .makedepends-anubis (20251229.140112) Executing busybox-1.37.0-r30.trigger OK: 594.2 MiB in 109 packages >>> anubis: Cleaning up srcdir >>> anubis: Cleaning up pkgdir >>> anubis: Cleaning up tmpdir >>> anubis: Fetching https://distfiles.alpinelinux.org/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz Connecting to distfiles.alpinelinux.org (172.105.82.32:443) wget: server returned error: HTTP/1.1 404 Not Found >>> anubis: Fetching https://github.com/TecharoHQ/anubis/releases/download/v1.24.0/anubis-src-vendor-npm-1.24.0.tar.gz Connecting to github.com (140.82.121.4:443) Connecting to release-assets.githubusercontent.com (185.199.110.133:443) saving to '/var/cache/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz.part' anubis-src-vendor-np 100% |********************************| 15.7M 0:00:00 ETA '/var/cache/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz.part' saved /var/cache/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz: OK /home/buildozer/aports/community/anubis/anubis.initd: OK /home/buildozer/aports/community/anubis/anubis.confd: OK >>> anubis: Fetching https://distfiles.alpinelinux.org/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz /var/cache/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz: OK /home/buildozer/aports/community/anubis/anubis.initd: OK /home/buildozer/aports/community/anubis/anubis.confd: OK >>> anubis: Unpacking /var/cache/distfiles/edge/anubis-src-vendor-npm-1.24.0.tar.gz... ? github.com/TecharoHQ/anubis [no test files] ? github.com/TecharoHQ/anubis/cmd/anubis [no test files] ? github.com/TecharoHQ/anubis/cmd/containerbuild [no test files] === RUN TestDataFileConversion === RUN TestDataFileConversion/simple_default === RUN TestDataFileConversion/simple_json === RUN TestDataFileConversion/simple_deny_action === RUN TestDataFileConversion/simple_custom_name === RUN TestDataFileConversion/blacklist_with_crawl_delay === RUN TestDataFileConversion/wildcards === RUN TestDataFileConversion/empty_file === RUN TestDataFileConversion/complex_scenario === RUN TestDataFileConversion/consecutive_user_agents --- PASS: TestDataFileConversion (0.00s) --- PASS: TestDataFileConversion/simple_default (0.00s) --- PASS: TestDataFileConversion/simple_json (0.00s) --- PASS: TestDataFileConversion/simple_deny_action (0.00s) --- PASS: TestDataFileConversion/simple_custom_name (0.00s) --- PASS: TestDataFileConversion/blacklist_with_crawl_delay (0.00s) --- PASS: TestDataFileConversion/wildcards (0.00s) --- PASS: TestDataFileConversion/empty_file (0.00s) --- PASS: TestDataFileConversion/complex_scenario (0.00s) --- PASS: TestDataFileConversion/consecutive_user_agents (0.00s) === RUN TestCaseInsensitiveParsing --- PASS: TestCaseInsensitiveParsing (0.00s) === RUN TestVariousOutputFormats --- PASS: TestVariousOutputFormats (0.00s) === RUN TestDifferentActions === RUN TestDifferentActions/action_ALLOW === RUN TestDifferentActions/action_DENY === RUN TestDifferentActions/action_CHALLENGE === RUN TestDifferentActions/action_WEIGH --- PASS: TestDifferentActions (0.00s) --- PASS: TestDifferentActions/action_ALLOW (0.00s) --- PASS: TestDifferentActions/action_DENY (0.00s) --- PASS: TestDifferentActions/action_CHALLENGE (0.00s) --- PASS: TestDifferentActions/action_WEIGH (0.00s) === RUN TestPolicyNaming === RUN TestPolicyNaming/name_custom-policy === RUN TestPolicyNaming/name_my-rules === RUN TestPolicyNaming/name_site-protection --- PASS: TestPolicyNaming (0.00s) --- PASS: TestPolicyNaming/name_custom-policy (0.00s) --- PASS: TestPolicyNaming/name_my-rules (0.00s) --- PASS: TestPolicyNaming/name_site-protection (0.00s) === RUN TestCrawlDelayWeights === RUN TestCrawlDelayWeights/weight_1 === RUN TestCrawlDelayWeights/weight_5 === RUN TestCrawlDelayWeights/weight_10 === RUN TestCrawlDelayWeights/weight_25 --- PASS: TestCrawlDelayWeights (0.00s) --- PASS: TestCrawlDelayWeights/weight_1 (0.00s) --- PASS: TestCrawlDelayWeights/weight_5 (0.00s) --- PASS: TestCrawlDelayWeights/weight_10 (0.00s) --- PASS: TestCrawlDelayWeights/weight_25 (0.00s) === RUN TestBlacklistActions === RUN TestBlacklistActions/blacklist_DENY === RUN TestBlacklistActions/blacklist_CHALLENGE --- PASS: TestBlacklistActions (0.00s) --- PASS: TestBlacklistActions/blacklist_DENY (0.00s) --- PASS: TestBlacklistActions/blacklist_CHALLENGE (0.00s) PASS ok github.com/TecharoHQ/anubis/cmd/robots2policy 0.016s ? github.com/TecharoHQ/anubis/cmd/robots2policy/batch [no test files] === RUN TestBotPoliciesEmbed embed_test.go:21: Found 50 YAML files to verify === RUN TestBotPoliciesEmbed/apps/allow-api-routes.yaml === RUN TestBotPoliciesEmbed/apps/bookstack-saml.yaml === RUN TestBotPoliciesEmbed/apps/gitea-rss-feeds.yaml === RUN TestBotPoliciesEmbed/bots/_deny-pathological.yaml === RUN TestBotPoliciesEmbed/bots/aggressive-brazilian-scrapers.yaml === RUN TestBotPoliciesEmbed/bots/ai-catchall.yaml === RUN TestBotPoliciesEmbed/bots/ai-robots-txt.yaml === RUN TestBotPoliciesEmbed/bots/cloudflare-workers.yaml === RUN TestBotPoliciesEmbed/bots/custom-async-http-client.yaml === RUN TestBotPoliciesEmbed/bots/headless-browsers.yaml === RUN TestBotPoliciesEmbed/bots/us-ai-scraper.yaml === RUN TestBotPoliciesEmbed/clients/ai.yaml === RUN TestBotPoliciesEmbed/clients/docker-client.yaml === RUN TestBotPoliciesEmbed/clients/git.yaml === RUN TestBotPoliciesEmbed/clients/go-get.yaml === RUN TestBotPoliciesEmbed/clients/mistral-mistralai-user.yaml === RUN TestBotPoliciesEmbed/clients/openai-chatgpt-user.yaml === RUN TestBotPoliciesEmbed/clients/telegram-preview.yaml === RUN TestBotPoliciesEmbed/clients/vk-preview.yaml === RUN TestBotPoliciesEmbed/clients/x-firefox-ai.yaml === RUN TestBotPoliciesEmbed/common/allow-api-like.yaml === RUN TestBotPoliciesEmbed/common/allow-private-addresses.yaml === RUN TestBotPoliciesEmbed/common/json-api.yaml === RUN TestBotPoliciesEmbed/common/keep-internet-working.yaml === RUN TestBotPoliciesEmbed/common/rfc-violations.yaml === RUN TestBotPoliciesEmbed/crawlers/_allow-good.yaml === RUN TestBotPoliciesEmbed/crawlers/ai-search.yaml === RUN TestBotPoliciesEmbed/crawlers/ai-training.yaml === RUN TestBotPoliciesEmbed/crawlers/alibaba-cloud.yaml === RUN TestBotPoliciesEmbed/crawlers/applebot.yaml === RUN TestBotPoliciesEmbed/crawlers/bingbot.yaml === RUN TestBotPoliciesEmbed/crawlers/commoncrawl.yaml === RUN TestBotPoliciesEmbed/crawlers/duckduckbot.yaml === RUN TestBotPoliciesEmbed/crawlers/googlebot.yaml === RUN TestBotPoliciesEmbed/crawlers/huawei-cloud.yaml === RUN TestBotPoliciesEmbed/crawlers/internet-archive.yaml === RUN TestBotPoliciesEmbed/crawlers/kagibot.yaml === RUN TestBotPoliciesEmbed/crawlers/marginalia.yaml === RUN TestBotPoliciesEmbed/crawlers/mojeekbot.yaml === RUN TestBotPoliciesEmbed/crawlers/openai-gptbot.yaml === RUN TestBotPoliciesEmbed/crawlers/openai-searchbot.yaml === RUN TestBotPoliciesEmbed/crawlers/qwantbot.yaml === RUN TestBotPoliciesEmbed/crawlers/tencent-cloud.yaml === RUN TestBotPoliciesEmbed/crawlers/yandexbot.yaml === RUN TestBotPoliciesEmbed/meta/ai-block-aggressive.yaml === RUN TestBotPoliciesEmbed/meta/ai-block-moderate.yaml === RUN TestBotPoliciesEmbed/meta/ai-block-permissive.yaml === RUN TestBotPoliciesEmbed/meta/default-config.yaml === RUN TestBotPoliciesEmbed/meta/messengers-preview.yaml === RUN TestBotPoliciesEmbed/services/uptime-robot.yaml --- PASS: TestBotPoliciesEmbed (0.00s) --- PASS: TestBotPoliciesEmbed/apps/allow-api-routes.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/apps/bookstack-saml.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/apps/gitea-rss-feeds.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/_deny-pathological.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/aggressive-brazilian-scrapers.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/ai-catchall.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/ai-robots-txt.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/cloudflare-workers.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/custom-async-http-client.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/headless-browsers.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/bots/us-ai-scraper.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/ai.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/docker-client.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/git.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/go-get.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/mistral-mistralai-user.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/openai-chatgpt-user.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/telegram-preview.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/vk-preview.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/clients/x-firefox-ai.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/common/allow-api-like.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/common/allow-private-addresses.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/common/json-api.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/common/keep-internet-working.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/common/rfc-violations.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/_allow-good.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/ai-search.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/ai-training.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/alibaba-cloud.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/applebot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/bingbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/commoncrawl.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/duckduckbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/googlebot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/huawei-cloud.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/internet-archive.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/kagibot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/marginalia.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/mojeekbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/openai-gptbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/openai-searchbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/qwantbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/tencent-cloud.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/crawlers/yandexbot.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/meta/ai-block-aggressive.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/meta/ai-block-moderate.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/meta/ai-block-permissive.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/meta/default-config.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/meta/messengers-preview.yaml (0.00s) --- PASS: TestBotPoliciesEmbed/services/uptime-robot.yaml (0.00s) PASS ok github.com/TecharoHQ/anubis/data 0.006s === RUN TestImpl --- PASS: TestImpl (0.02s) === RUN TestCleanup --- PASS: TestCleanup (0.00s) PASS ok github.com/TecharoHQ/anubis/decaymap 0.020s === RUN TestClampIP === RUN TestClampIP/IPv4_normal_address === RUN TestClampIP/IPv4_boundary_-_network_address === RUN TestClampIP/IPv4_boundary_-_broadcast_address === RUN TestClampIP/IPv4_class_A_address === RUN TestClampIP/IPv4_loopback === RUN TestClampIP/IPv4_link-local === RUN TestClampIP/IPv4_public_address === RUN TestClampIP/IPv6_normal_address === RUN TestClampIP/IPv6_with_full_expansion === RUN TestClampIP/IPv6_loopback === RUN TestClampIP/IPv6_unspecified_address === RUN TestClampIP/IPv6_link-local === RUN TestClampIP/IPv6_unique_local === RUN TestClampIP/IPv6_documentation_prefix === RUN TestClampIP/IPv6_global_unicast === RUN TestClampIP/IPv6_multicast === RUN TestClampIP/IPv4-mapped_IPv6_address === RUN TestClampIP/IPv4-mapped_IPv6_with_different_format === RUN TestClampIP/IPv4-mapped_IPv6_loopback --- PASS: TestClampIP (0.00s) --- PASS: TestClampIP/IPv4_normal_address (0.00s) --- PASS: TestClampIP/IPv4_boundary_-_network_address (0.00s) --- PASS: TestClampIP/IPv4_boundary_-_broadcast_address (0.00s) --- PASS: TestClampIP/IPv4_class_A_address (0.00s) --- PASS: TestClampIP/IPv4_loopback (0.00s) --- PASS: TestClampIP/IPv4_link-local (0.00s) --- PASS: TestClampIP/IPv4_public_address (0.00s) --- PASS: TestClampIP/IPv6_normal_address (0.00s) --- PASS: TestClampIP/IPv6_with_full_expansion (0.00s) --- PASS: TestClampIP/IPv6_loopback (0.00s) --- PASS: TestClampIP/IPv6_unspecified_address (0.00s) --- PASS: TestClampIP/IPv6_link-local (0.00s) --- PASS: TestClampIP/IPv6_unique_local (0.00s) --- PASS: TestClampIP/IPv6_documentation_prefix (0.00s) --- PASS: TestClampIP/IPv6_global_unicast (0.00s) --- PASS: TestClampIP/IPv6_multicast (0.00s) --- PASS: TestClampIP/IPv4-mapped_IPv6_address (0.00s) --- PASS: TestClampIP/IPv4-mapped_IPv6_with_different_format (0.00s) --- PASS: TestClampIP/IPv4-mapped_IPv6_loopback (0.00s) === RUN TestClampIPSuccess === RUN TestClampIPSuccess/IPv4_address === RUN TestClampIPSuccess/IPv6_address === RUN TestClampIPSuccess/IPv4-mapped_IPv6 --- PASS: TestClampIPSuccess (0.00s) --- PASS: TestClampIPSuccess/IPv4_address (0.00s) --- PASS: TestClampIPSuccess/IPv6_address (0.00s) --- PASS: TestClampIPSuccess/IPv4-mapped_IPv6 (0.00s) === RUN TestClampIPZeroValue --- PASS: TestClampIPZeroValue (0.00s) === RUN TestClampIPSpecialCases === RUN TestClampIPSpecialCases/Minimum_IPv4 === RUN TestClampIPSpecialCases/Maximum_IPv4 === RUN TestClampIPSpecialCases/Minimum_IPv6 === RUN TestClampIPSpecialCases/Maximum_IPv6_prefix_part --- PASS: TestClampIPSpecialCases (0.00s) --- PASS: TestClampIPSpecialCases/Minimum_IPv4 (0.00s) --- PASS: TestClampIPSpecialCases/Maximum_IPv4 (0.00s) --- PASS: TestClampIPSpecialCases/Minimum_IPv6 (0.00s) --- PASS: TestClampIPSpecialCases/Maximum_IPv6_prefix_part (0.00s) === RUN TestHashCollisions hash_bench_test.go:176: Basic test: 22 realistic inputs, no collisions hash_bench_test.go:199: Stress test 1: 22400 similar string variations, no collisions hash_bench_test.go:224: Stress test 2: 70000 sequential patterns, no collisions hash_bench_test.go:227: TOTAL: Tested 92422 inputs across realistic scenarios - NO COLLISIONS --- PASS: TestHashCollisions (0.07s) === RUN TestXXHashFormat hash_bench_test.go:259: Input: "short" -> Hash: a4dbb3294161a9a4 hash_bench_test.go:259: Input: "" -> Hash: ef46db3751d8e999 hash_bench_test.go:259: Input: "very long string with lots of content that might be used in policy checking and other internal hashing scenarios" -> Hash: 66442c9447f2401b hash_bench_test.go:259: Input: "User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36" -> Hash: 853008ee50e116bf --- PASS: TestXXHashFormat (0.00s) === RUN TestListOr_UnmarshalJSON === RUN TestListOr_UnmarshalJSON/single_value_should_be_unmarshaled_as_single_item === RUN TestListOr_UnmarshalJSON/array_should_be_unmarshaled_as_multiple_items === RUN TestListOr_UnmarshalJSON/single_number_should_be_unmarshaled_as_single_item === RUN TestListOr_UnmarshalJSON/array_of_numbers_should_be_unmarshaled_as_multiple_items --- PASS: TestListOr_UnmarshalJSON (0.00s) --- PASS: TestListOr_UnmarshalJSON/single_value_should_be_unmarshaled_as_single_item (0.00s) --- PASS: TestListOr_UnmarshalJSON/array_should_be_unmarshaled_as_multiple_items (0.00s) --- PASS: TestListOr_UnmarshalJSON/single_number_should_be_unmarshaled_as_single_item (0.00s) --- PASS: TestListOr_UnmarshalJSON/array_of_numbers_should_be_unmarshaled_as_multiple_items (0.00s) === RUN TestErrorLogFilter --- PASS: TestErrorLogFilter (0.00s) === RUN TestGetRequestLogger --- PASS: TestGetRequestLogger (0.00s) === RUN TestXForwardedForUpdateIgnoreUnix --- PASS: TestXForwardedForUpdateIgnoreUnix (0.00s) === RUN TestXForwardedForUpdateAddToChain --- PASS: TestXForwardedForUpdateAddToChain (0.00s) === RUN TestComputeXFFHeader === RUN TestComputeXFFHeader/StripPrivate === RUN TestComputeXFFHeader/StripPrivate#01 === RUN TestComputeXFFHeader/StripLoopback === RUN TestComputeXFFHeader/StripCGNAT === RUN TestComputeXFFHeader/StripLinkLocalUnicastIPv4 === RUN TestComputeXFFHeader/StripLinkLocalUnicastIPv6 === RUN TestComputeXFFHeader/Flatten === RUN TestComputeXFFHeader/TrimSpaces === RUN TestComputeXFFHeader/invalid-ip-port === RUN TestComputeXFFHeader/invalid-remote-ip === RUN TestComputeXFFHeader/no-xff-dont-panic --- PASS: TestComputeXFFHeader (0.00s) --- PASS: TestComputeXFFHeader/StripPrivate (0.00s) --- PASS: TestComputeXFFHeader/StripPrivate#01 (0.00s) --- PASS: TestComputeXFFHeader/StripLoopback (0.00s) --- PASS: TestComputeXFFHeader/StripCGNAT (0.00s) --- PASS: TestComputeXFFHeader/StripLinkLocalUnicastIPv4 (0.00s) --- PASS: TestComputeXFFHeader/StripLinkLocalUnicastIPv6 (0.00s) --- PASS: TestComputeXFFHeader/Flatten (0.00s) --- PASS: TestComputeXFFHeader/TrimSpaces (0.00s) --- PASS: TestComputeXFFHeader/invalid-ip-port (0.00s) --- PASS: TestComputeXFFHeader/invalid-remote-ip (0.00s) --- PASS: TestComputeXFFHeader/no-xff-dont-panic (0.00s) PASS ok github.com/TecharoHQ/anubis/internal 0.085s ? github.com/TecharoHQ/anubis/internal/actorify [no test files] === RUN TestDns_ArpaReverseIP === RUN TestDns_ArpaReverseIP/ipv4 === RUN TestDns_ArpaReverseIP/ipv6 === RUN TestDns_ArpaReverseIP/invalid_ip === RUN TestDns_ArpaReverseIP/ipv4-mapped_ipv6 --- PASS: TestDns_ArpaReverseIP (0.00s) --- PASS: TestDns_ArpaReverseIP/ipv4 (0.00s) --- PASS: TestDns_ArpaReverseIP/ipv6 (0.00s) --- PASS: TestDns_ArpaReverseIP/invalid_ip (0.00s) --- PASS: TestDns_ArpaReverseIP/ipv4-mapped_ipv6 (0.00s) === RUN TestDns_ReverseDNS === RUN TestDns_ReverseDNS/cache_miss === RUN TestDns_ReverseDNS/cache_hit === RUN TestDns_ReverseDNS/cache_expiration === RUN TestDns_ReverseDNS/not_found --- PASS: TestDns_ReverseDNS (2.00s) --- PASS: TestDns_ReverseDNS/cache_miss (0.00s) --- PASS: TestDns_ReverseDNS/cache_hit (0.00s) --- PASS: TestDns_ReverseDNS/cache_expiration (2.00s) --- PASS: TestDns_ReverseDNS/not_found (0.00s) === RUN TestDns_LookupHost === RUN TestDns_LookupHost/cache_miss === RUN TestDns_LookupHost/cache_hit === RUN TestDns_LookupHost/cache_expiration === RUN TestDns_LookupHost/not_found --- PASS: TestDns_LookupHost (2.00s) --- PASS: TestDns_LookupHost/cache_miss (0.00s) --- PASS: TestDns_LookupHost/cache_hit (0.00s) --- PASS: TestDns_LookupHost/cache_expiration (2.00s) --- PASS: TestDns_LookupHost/not_found (0.00s) === RUN TestDns_VerifyFCrDNS === RUN TestDns_VerifyFCrDNS/valid_no_pattern 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 === RUN TestDns_VerifyFCrDNS/valid_partial_no_pattern 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=one.one.one.one addr=1.1.1.1 === RUN TestDns_VerifyFCrDNS/not_found_no_pattern === RUN TestDns_VerifyFCrDNS/unknown_error_no_pattern 2025/12/29 14:01:46 ERROR DNS: reverse lookup failed addr=1.2.3.4 err="unknown error" === RUN TestDns_VerifyFCrDNS/valid_match 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 === RUN TestDns_VerifyFCrDNS/valid_no_match === RUN TestDns_VerifyFCrDNS/not_found_with_pattern === RUN TestDns_VerifyFCrDNS/unknown_error_with_pattern 2025/12/29 14:01:46 ERROR DNS: reverse lookup failed addr=1.2.3.4 err="unknown error" === RUN TestDns_VerifyFCrDNS/invalid_pattern 2025/12/29 14:01:46 ERROR DNS: verifyFCrDNS invalid regex pattern err="error parsing regexp: missing closing ]: `[`" === RUN TestDns_VerifyFCrDNS/reverse_cache_hit 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 === RUN TestDns_VerifyFCrDNS/forward_cache_hit 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 2025/12/29 14:01:46 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 --- PASS: TestDns_VerifyFCrDNS (0.00s) --- PASS: TestDns_VerifyFCrDNS/valid_no_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/valid_partial_no_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/not_found_no_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/unknown_error_no_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/valid_match (0.00s) --- PASS: TestDns_VerifyFCrDNS/valid_no_match (0.00s) --- PASS: TestDns_VerifyFCrDNS/not_found_with_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/unknown_error_with_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/invalid_pattern (0.00s) --- PASS: TestDns_VerifyFCrDNS/reverse_cache_hit (0.00s) --- PASS: TestDns_VerifyFCrDNS/forward_cache_hit (0.00s) PASS ok github.com/TecharoHQ/anubis/internal/dns 4.016s === RUN TestReverse4 === RUN TestReverse4/1.2.3.4->4.3.2.1 --- PASS: TestReverse4 (0.00s) --- PASS: TestReverse4/1.2.3.4->4.3.2.1 (0.00s) === RUN TestReverse6 === RUN TestReverse6/1234:5678:9ABC:DEF0:1234:5678:9ABC:DEF0->0.f.e.d.c.b.a.9.8.7.6.5.4.3.2.1.0.f.e.d.c.b.a.9.8.7.6.5.4.3.2.1 --- PASS: TestReverse6 (0.00s) --- PASS: TestReverse6/1234:5678:9ABC:DEF0:1234:5678:9ABC:DEF0->0.f.e.d.c.b.a.9.8.7.6.5.4.3.2.1.0.f.e.d.c.b.a.9.8.7.6.5.4.3.2.1 (0.00s) === RUN TestLookup dnsbl_test.go:60: response: 0 --- PASS: TestLookup (0.11s) PASS ok github.com/TecharoHQ/anubis/internal/dnsbl 0.112s === RUN TestGlob_EqualityAndEmpty === RUN TestGlob_EqualityAndEmpty/exact_match === RUN TestGlob_EqualityAndEmpty/exact_mismatch === RUN TestGlob_EqualityAndEmpty/empty_pattern_and_subject === RUN TestGlob_EqualityAndEmpty/empty_pattern_with_non-empty_subject === RUN TestGlob_EqualityAndEmpty/pattern_star_matches_empty === RUN TestGlob_EqualityAndEmpty/pattern_star_matches_anything --- PASS: TestGlob_EqualityAndEmpty (0.00s) --- PASS: TestGlob_EqualityAndEmpty/exact_match (0.00s) --- PASS: TestGlob_EqualityAndEmpty/exact_mismatch (0.00s) --- PASS: TestGlob_EqualityAndEmpty/empty_pattern_and_subject (0.00s) --- PASS: TestGlob_EqualityAndEmpty/empty_pattern_with_non-empty_subject (0.00s) --- PASS: TestGlob_EqualityAndEmpty/pattern_star_matches_empty (0.00s) --- PASS: TestGlob_EqualityAndEmpty/pattern_star_matches_anything (0.00s) === RUN TestGlob_LeadingAndTrailing === RUN TestGlob_LeadingAndTrailing/prefix_match_-_minimal === RUN TestGlob_LeadingAndTrailing/prefix_match_-_extended === RUN TestGlob_LeadingAndTrailing/prefix_mismatch_-_not_at_start === RUN TestGlob_LeadingAndTrailing/suffix_match_-_minimal === RUN TestGlob_LeadingAndTrailing/suffix_match_-_extended === RUN TestGlob_LeadingAndTrailing/suffix_mismatch_-_not_at_end === RUN TestGlob_LeadingAndTrailing/contains_match === RUN TestGlob_LeadingAndTrailing/contains_mismatch_-_missing_needle --- PASS: TestGlob_LeadingAndTrailing (0.00s) --- PASS: TestGlob_LeadingAndTrailing/prefix_match_-_minimal (0.00s) --- PASS: TestGlob_LeadingAndTrailing/prefix_match_-_extended (0.00s) --- PASS: TestGlob_LeadingAndTrailing/prefix_mismatch_-_not_at_start (0.00s) --- PASS: TestGlob_LeadingAndTrailing/suffix_match_-_minimal (0.00s) --- PASS: TestGlob_LeadingAndTrailing/suffix_match_-_extended (0.00s) --- PASS: TestGlob_LeadingAndTrailing/suffix_mismatch_-_not_at_end (0.00s) --- PASS: TestGlob_LeadingAndTrailing/contains_match (0.00s) --- PASS: TestGlob_LeadingAndTrailing/contains_mismatch_-_missing_needle (0.00s) === RUN TestGlob_MiddleAndOrder === RUN TestGlob_MiddleAndOrder/middle_wildcard_basic === RUN TestGlob_MiddleAndOrder/middle_wildcard_gap === RUN TestGlob_MiddleAndOrder/middle_wildcard_requires_start_f === RUN TestGlob_MiddleAndOrder/order_enforced_across_parts === RUN TestGlob_MiddleAndOrder/order_mismatch_fails === RUN TestGlob_MiddleAndOrder/must_end_with_last_part_when_no_trailing_* === RUN TestGlob_MiddleAndOrder/failing_when_trailing_chars_remain === RUN TestGlob_MiddleAndOrder/first_part_must_start_when_no_leading_* === RUN TestGlob_MiddleAndOrder/works_with_overlapping_content === RUN TestGlob_MiddleAndOrder/needle_not_found_fails --- PASS: TestGlob_MiddleAndOrder (0.00s) --- PASS: TestGlob_MiddleAndOrder/middle_wildcard_basic (0.00s) --- PASS: TestGlob_MiddleAndOrder/middle_wildcard_gap (0.00s) --- PASS: TestGlob_MiddleAndOrder/middle_wildcard_requires_start_f (0.00s) --- PASS: TestGlob_MiddleAndOrder/order_enforced_across_parts (0.00s) --- PASS: TestGlob_MiddleAndOrder/order_mismatch_fails (0.00s) --- PASS: TestGlob_MiddleAndOrder/must_end_with_last_part_when_no_trailing_* (0.00s) --- PASS: TestGlob_MiddleAndOrder/failing_when_trailing_chars_remain (0.00s) --- PASS: TestGlob_MiddleAndOrder/first_part_must_start_when_no_leading_* (0.00s) --- PASS: TestGlob_MiddleAndOrder/works_with_overlapping_content (0.00s) --- PASS: TestGlob_MiddleAndOrder/needle_not_found_fails (0.00s) === RUN TestGlob_ConsecutiveStarsAndEmptyParts === RUN TestGlob_ConsecutiveStarsAndEmptyParts/double_star_matches_anything === RUN TestGlob_ConsecutiveStarsAndEmptyParts/double_star_matches_anything_non-empty === RUN TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_behave_like_single === RUN TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_with_gaps === RUN TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_+_trailing_star === RUN TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_still_enforce_anchors --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/double_star_matches_anything (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/double_star_matches_anything_non-empty (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_behave_like_single (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_with_gaps (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_+_trailing_star (0.00s) --- PASS: TestGlob_ConsecutiveStarsAndEmptyParts/consecutive_stars_still_enforce_anchors (0.00s) === RUN TestGlob_MaxPartsLimit --- PASS: TestGlob_MaxPartsLimit (0.00s) === RUN TestGlob_CaseSensitivity --- PASS: TestGlob_CaseSensitivity (0.00s) === RUN TestGlob_EmptySubjectInteractions --- PASS: TestGlob_EmptySubjectInteractions (0.00s) PASS ok github.com/TecharoHQ/anubis/internal/glob 0.005s ? github.com/TecharoHQ/anubis/internal/honeypot [no test files] ? github.com/TecharoHQ/anubis/internal/honeypot/naive [no test files] === RUN TestCacheReturnsDefault === RUN TestCacheReturnsDefault/og:title === RUN TestCacheReturnsDefault/og:description --- PASS: TestCacheReturnsDefault (0.00s) --- PASS: TestCacheReturnsDefault/og:title (0.00s) --- PASS: TestCacheReturnsDefault/og:description (0.00s) === RUN TestCheckCache --- PASS: TestCheckCache (0.00s) === RUN TestGetOGTags === RUN TestGetOGTags/ensure_image_is_cached_as_allow --- PASS: TestGetOGTags (0.00s) --- PASS: TestGetOGTags/ensure_image_is_cached_as_allow (0.00s) === RUN TestGetOGTagsWithHostConsideration === RUN TestGetOGTagsWithHostConsideration/Host_Not_Considered_-_Same_Host === RUN TestGetOGTagsWithHostConsideration/Host_Not_Considered_-_Different_Host === RUN TestGetOGTagsWithHostConsideration/Host_Considered_-_Same_Host === RUN TestGetOGTagsWithHostConsideration/Host_Considered_-_Different_Host --- PASS: TestGetOGTagsWithHostConsideration (0.00s) --- PASS: TestGetOGTagsWithHostConsideration/Host_Not_Considered_-_Same_Host (0.00s) --- PASS: TestGetOGTagsWithHostConsideration/Host_Not_Considered_-_Different_Host (0.00s) --- PASS: TestGetOGTagsWithHostConsideration/Host_Considered_-_Same_Host (0.00s) --- PASS: TestGetOGTagsWithHostConsideration/Host_Considered_-_Different_Host (0.00s) === RUN TestFetchHTMLDocument === RUN TestFetchHTMLDocument/Valid_HTML === RUN TestFetchHTMLDocument/Empty_HTML === RUN TestFetchHTMLDocument/Not_found_error === RUN TestFetchHTMLDocument/Unsupported_Content-Type === RUN TestFetchHTMLDocument/Too_large_content --- PASS: TestFetchHTMLDocument (0.00s) --- PASS: TestFetchHTMLDocument/Valid_HTML (0.00s) --- PASS: TestFetchHTMLDocument/Empty_HTML (0.00s) --- PASS: TestFetchHTMLDocument/Not_found_error (0.00s) --- PASS: TestFetchHTMLDocument/Unsupported_Content-Type (0.00s) --- PASS: TestFetchHTMLDocument/Too_large_content (0.00s) === RUN TestFetchHTMLDocumentInvalidURL --- PASS: TestFetchHTMLDocumentInvalidURL (0.01s) === RUN TestIntegrationGetOGTags === RUN TestIntegrationGetOGTags/Simple_page === RUN TestIntegrationGetOGTags/Complete_page === RUN TestIntegrationGetOGTags/Page_with_no_OG_tags === RUN TestIntegrationGetOGTags/Nonexistent_page --- PASS: TestIntegrationGetOGTags (0.00s) --- PASS: TestIntegrationGetOGTags/Simple_page (0.00s) --- PASS: TestIntegrationGetOGTags/Complete_page (0.00s) --- PASS: TestIntegrationGetOGTags/Page_with_no_OG_tags (0.00s) --- PASS: TestIntegrationGetOGTags/Nonexistent_page (0.00s) === RUN TestMemoryUsage mem_test.go:112: Memory allocated for 10k getTarget calls: mem_test.go:113: Total: 630.52 KB (0.62 MB) mem_test.go:114: Per operation: 64.56 bytes mem_test.go:143: Memory allocated for 1k extractOGTags calls: mem_test.go:144: Total: 333.59 KB (0.33 MB) mem_test.go:145: Per operation: 341.60 bytes --- PASS: TestMemoryUsage (0.01s) === RUN TestNewOGTagCache === RUN TestNewOGTagCache/Basic_initialization === RUN TestNewOGTagCache/Empty_target --- PASS: TestNewOGTagCache (0.00s) --- PASS: TestNewOGTagCache/Basic_initialization (0.00s) --- PASS: TestNewOGTagCache/Empty_target (0.00s) === RUN TestNewOGTagCache_UnixSocket --- PASS: TestNewOGTagCache_UnixSocket (0.00s) === RUN TestGetTarget === RUN TestGetTarget/No_path_or_query === RUN TestGetTarget/With_complex_path === RUN TestGetTarget/With_query_and_path === RUN TestGetTarget/Unix_socket_target === RUN TestGetTarget/Unix_socket_target_with_/// --- PASS: TestGetTarget (0.00s) --- PASS: TestGetTarget/No_path_or_query (0.00s) --- PASS: TestGetTarget/With_complex_path (0.00s) --- PASS: TestGetTarget/With_query_and_path (0.00s) --- PASS: TestGetTarget/Unix_socket_target (0.00s) --- PASS: TestGetTarget/Unix_socket_target_with_/// (0.00s) === RUN TestIntegrationGetOGTags_UnixSocket --- PASS: TestIntegrationGetOGTags_UnixSocket (0.10s) === RUN TestGetOGTagsWithTargetHostOverride === RUN TestGetOGTagsWithTargetHostOverride/default_host_uses_original === RUN TestGetOGTagsWithTargetHostOverride/override_host_respected --- PASS: TestGetOGTagsWithTargetHostOverride (0.00s) --- PASS: TestGetOGTagsWithTargetHostOverride/default_host_uses_original (0.00s) --- PASS: TestGetOGTagsWithTargetHostOverride/override_host_respected (0.00s) === RUN TestGetOGTagsWithInsecureSkipVerify 2025/12/29 14:01:42 http: TLS handshake error from 127.0.0.1:43274: remote error: tls: bad certificate --- PASS: TestGetOGTagsWithInsecureSkipVerify (0.05s) === RUN TestGetOGTagsWithTargetSNI === RUN TestGetOGTagsWithTargetSNI/explicit_SNI_override === RUN TestGetOGTagsWithTargetSNI/auto_SNI_uses_original_host === RUN TestGetOGTagsWithTargetSNI/default_SNI_uses_backend_host --- PASS: TestGetOGTagsWithTargetSNI (0.35s) --- PASS: TestGetOGTagsWithTargetSNI/explicit_SNI_override (0.12s) --- PASS: TestGetOGTagsWithTargetSNI/auto_SNI_uses_original_host (0.07s) --- PASS: TestGetOGTagsWithTargetSNI/default_SNI_uses_backend_host (0.16s) === RUN TestExtractOGTags === RUN TestExtractOGTags/Basic_OG_tags === RUN TestExtractOGTags/OG_tags_with_name_attribute === RUN TestExtractOGTags/No_approved_OG_tags === RUN TestExtractOGTags/Empty_content === RUN TestExtractOGTags/Explicitly_approved_tag --- PASS: TestExtractOGTags (0.00s) --- PASS: TestExtractOGTags/Basic_OG_tags (0.00s) --- PASS: TestExtractOGTags/OG_tags_with_name_attribute (0.00s) --- PASS: TestExtractOGTags/No_approved_OG_tags (0.00s) --- PASS: TestExtractOGTags/Empty_content (0.00s) --- PASS: TestExtractOGTags/Explicitly_approved_tag (0.00s) === RUN TestIsOGMetaTag === RUN TestIsOGMetaTag/Meta_OG_tag === RUN TestIsOGMetaTag/Regular_meta_tag === RUN TestIsOGMetaTag/Not_a_meta_tag --- PASS: TestIsOGMetaTag (0.00s) --- PASS: TestIsOGMetaTag/Meta_OG_tag (0.00s) --- PASS: TestIsOGMetaTag/Regular_meta_tag (0.00s) --- PASS: TestIsOGMetaTag/Not_a_meta_tag (0.00s) === RUN TestExtractMetaTagInfo === RUN TestExtractMetaTagInfo/OG_title_with_property_(approved_by_prefix) === RUN TestExtractMetaTagInfo/OG_description_with_name_(approved_by_prefix) === RUN TestExtractMetaTagInfo/Regular_meta_tag_(name=description,_approved_by_exact_match) === RUN TestExtractMetaTagInfo/Regular_meta_tag_(name=keywords,_not_approved) === RUN TestExtractMetaTagInfo/Twitter_tag_(not_approved_by_default) === RUN TestExtractMetaTagInfo/No_content_(but_approved_property) === RUN TestExtractMetaTagInfo/No_property/name_attribute === RUN TestExtractMetaTagInfo/Explicitly_approved_tag_with_property_attribute --- PASS: TestExtractMetaTagInfo (0.00s) --- PASS: TestExtractMetaTagInfo/OG_title_with_property_(approved_by_prefix) (0.00s) --- PASS: TestExtractMetaTagInfo/OG_description_with_name_(approved_by_prefix) (0.00s) --- PASS: TestExtractMetaTagInfo/Regular_meta_tag_(name=description,_approved_by_exact_match) (0.00s) --- PASS: TestExtractMetaTagInfo/Regular_meta_tag_(name=keywords,_not_approved) (0.00s) --- PASS: TestExtractMetaTagInfo/Twitter_tag_(not_approved_by_default) (0.00s) --- PASS: TestExtractMetaTagInfo/No_content_(but_approved_property) (0.00s) --- PASS: TestExtractMetaTagInfo/No_property/name_attribute (0.00s) --- PASS: TestExtractMetaTagInfo/Explicitly_approved_tag_with_property_attribute (0.00s) === RUN FuzzGetTarget === RUN FuzzGetTarget/seed#0 === RUN FuzzGetTarget/seed#1 === RUN FuzzGetTarget/seed#2 === RUN FuzzGetTarget/seed#3 === RUN FuzzGetTarget/seed#4 === RUN FuzzGetTarget/seed#5 === RUN FuzzGetTarget/seed#6 === RUN FuzzGetTarget/seed#7 === RUN FuzzGetTarget/seed#8 === RUN FuzzGetTarget/seed#9 === RUN FuzzGetTarget/seed#10 === RUN FuzzGetTarget/seed#11 === RUN FuzzGetTarget/seed#12 === RUN FuzzGetTarget/seed#13 === RUN FuzzGetTarget/seed#14 --- PASS: FuzzGetTarget (0.00s) --- PASS: FuzzGetTarget/seed#0 (0.00s) --- PASS: FuzzGetTarget/seed#1 (0.00s) --- PASS: FuzzGetTarget/seed#2 (0.00s) --- PASS: FuzzGetTarget/seed#3 (0.00s) --- PASS: FuzzGetTarget/seed#4 (0.00s) --- PASS: FuzzGetTarget/seed#5 (0.00s) --- PASS: FuzzGetTarget/seed#6 (0.00s) --- PASS: FuzzGetTarget/seed#7 (0.00s) --- PASS: FuzzGetTarget/seed#8 (0.00s) --- PASS: FuzzGetTarget/seed#9 (0.00s) --- PASS: FuzzGetTarget/seed#10 (0.00s) --- PASS: FuzzGetTarget/seed#11 (0.00s) --- PASS: FuzzGetTarget/seed#12 (0.00s) --- PASS: FuzzGetTarget/seed#13 (0.00s) --- PASS: FuzzGetTarget/seed#14 (0.00s) === RUN FuzzExtractOGTags === RUN FuzzExtractOGTags/seed#0 === RUN FuzzExtractOGTags/seed#1 === RUN FuzzExtractOGTags/seed#2 === RUN FuzzExtractOGTags/seed#3 === RUN FuzzExtractOGTags/seed#4 === RUN FuzzExtractOGTags/seed#5 === RUN FuzzExtractOGTags/seed#6 === RUN FuzzExtractOGTags/seed#7 === RUN FuzzExtractOGTags/seed#8 === RUN FuzzExtractOGTags/seed#9 === RUN FuzzExtractOGTags/seed#10 === RUN FuzzExtractOGTags/seed#11 === RUN FuzzExtractOGTags/seed#12 === RUN FuzzExtractOGTags/seed#13 === RUN FuzzExtractOGTags/seed#14 === RUN FuzzExtractOGTags/seed#15 === RUN FuzzExtractOGTags/seed#16 === RUN FuzzExtractOGTags/seed#17 === RUN FuzzExtractOGTags/seed#18 === RUN FuzzExtractOGTags/seed#19 === RUN FuzzExtractOGTags/seed#20 === RUN FuzzExtractOGTags/seed#21 --- PASS: FuzzExtractOGTags (0.01s) --- PASS: FuzzExtractOGTags/seed#0 (0.00s) --- PASS: FuzzExtractOGTags/seed#1 (0.00s) --- PASS: FuzzExtractOGTags/seed#2 (0.00s) --- PASS: FuzzExtractOGTags/seed#3 (0.00s) --- PASS: FuzzExtractOGTags/seed#4 (0.00s) --- PASS: FuzzExtractOGTags/seed#5 (0.00s) --- PASS: FuzzExtractOGTags/seed#6 (0.00s) --- PASS: FuzzExtractOGTags/seed#7 (0.00s) --- PASS: FuzzExtractOGTags/seed#8 (0.00s) --- PASS: FuzzExtractOGTags/seed#9 (0.00s) --- PASS: FuzzExtractOGTags/seed#10 (0.00s) --- PASS: FuzzExtractOGTags/seed#11 (0.00s) --- PASS: FuzzExtractOGTags/seed#12 (0.01s) --- PASS: FuzzExtractOGTags/seed#13 (0.00s) --- PASS: FuzzExtractOGTags/seed#14 (0.00s) --- PASS: FuzzExtractOGTags/seed#15 (0.00s) --- PASS: FuzzExtractOGTags/seed#16 (0.00s) --- PASS: FuzzExtractOGTags/seed#17 (0.00s) --- PASS: FuzzExtractOGTags/seed#18 (0.00s) --- PASS: FuzzExtractOGTags/seed#19 (0.00s) --- PASS: FuzzExtractOGTags/seed#20 (0.00s) --- PASS: FuzzExtractOGTags/seed#21 (0.00s) === RUN FuzzGetTargetRoundTrip === RUN FuzzGetTargetRoundTrip/seed#0 === RUN FuzzGetTargetRoundTrip/seed#1 --- PASS: FuzzGetTargetRoundTrip (0.00s) --- PASS: FuzzGetTargetRoundTrip/seed#0 (0.00s) --- PASS: FuzzGetTargetRoundTrip/seed#1 (0.00s) === RUN FuzzExtractMetaTagInfo === RUN FuzzExtractMetaTagInfo/seed#0 === RUN FuzzExtractMetaTagInfo/seed#1 === RUN FuzzExtractMetaTagInfo/seed#2 === RUN FuzzExtractMetaTagInfo/seed#3 === RUN FuzzExtractMetaTagInfo/seed#4 === RUN FuzzExtractMetaTagInfo/seed#5 === RUN FuzzExtractMetaTagInfo/seed#6 --- PASS: FuzzExtractMetaTagInfo (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#0 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#1 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#2 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#3 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#4 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#5 (0.00s) --- PASS: FuzzExtractMetaTagInfo/seed#6 (0.00s) PASS ok github.com/TecharoHQ/anubis/internal/ogtags 0.556s === RUN TestPlaywrightBrowser playwright_test.go:222: npx not found in PATH, skipping integration smoke testing: exec: "npx": executable file not found in $PATH --- SKIP: TestPlaywrightBrowser (0.00s) === RUN TestPlaywrightWithBasePrefix playwright_test.go:302: NOTE(Xe)\ these tests require HTTPS support in #364 --- SKIP: TestPlaywrightWithBasePrefix (0.00s) PASS ok github.com/TecharoHQ/anubis/internal/test 0.017s === RUN TestLoadPolicies === RUN TestLoadPolicies/botPolicies.yaml {"time":"2025-12-29T14:01:42.877912535Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":180},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"geoip","settings":{"countries":["BR","CN"]}} {"time":"2025-12-29T14:01:42.877997894Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":171},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"asn","settings":{"match":[13335,136907,45102]}} --- PASS: TestLoadPolicies (0.03s) --- PASS: TestLoadPolicies/botPolicies.yaml (0.03s) === RUN TestCVE2025_24369 anubis_test.go:262: loading policy file: ./testdata/test_config.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:42.91124195Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:44259","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.911379608Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:44259","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-30ff-74fa-97c4-b80da228e6de"} anubis_test.go:44: {"time":"2025-12-29T14:01:42.911441307Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:44259","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:42.911328305Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-30ff-74fa-97c4-b80da228e6de","method":"fast","randomData":"c1aafd4235d00a3022a373d543bf49eb2718e85018e59a482bbe101f96b6d4fa22cc6a78ab5c71ca2280500112a04fdc76a11c8b10b73ae79b7cba4ad86fd334","policyRuleHash":"ac980f49c4d35fab","difficulty":1,"spent":false},"rules":{"algorithm":"fast","difficulty":1},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:44259/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-30ff-74fa-97c4-b80da228e6de; Path=/; Expires=Mon, 29 Dec 2025 14:01:42 GMT anubis_test.go:195: requested cookies for http://127.0.0.1:44259/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=0&id=019b6a6a-30ff-74fa-97c4-b80da228e6de&nonce=0&redir=%2F&response=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-30ff-74fa-97c4-b80da228e6de; Path=/; Expires=Mon, 29 Dec 2025 14:01:42 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:42.912336314Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:44259","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.912602677Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":525},"msg":"challenge validate call failed","host":"127.0.0.1:44259","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-30ff-74fa-97c4-b80da228e6de","err":"challenge: error when processing challenge: validate: challenge: user failed challenge: wanted response e40f160d504fd5904450dfe45f8f3e6a4636571478b5da5678d9fa223a4c36a9 but got ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"} anubis_test.go:44: {"time":"2025-12-29T14:01:42.912716118Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":531},"msg":"challenge failed","host":"127.0.0.1:44259","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-30ff-74fa-97c4-b80da228e6de","err":"challenge: error when processing challenge: validate: challenge: user failed challenge: wanted response e40f160d504fd5904450dfe45f8f3e6a4636571478b5da5678d9fa223a4c36a9 but got ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"} anubis_test.go:209: set cookie: http://127.0.0.1:44259/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=0&id=019b6a6a-30ff-74fa-97c4-b80da228e6de&nonce=0&redir=%2F&response=ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff -> techaro.lol-anubis=; Path=/; Expires=Mon, 29 Dec 2025 14:00:42 GMT; Max-Age=0 --- PASS: TestCVE2025_24369 (0.03s) === RUN TestCookieCustomExpiration anubis_test.go:283: loading policy file: testdata/zero_difficulty.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:42.950633448Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:42595","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.950771966Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:42595","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3126-7b47-9f19-f31d65e24feb"} anubis_test.go:44: {"time":"2025-12-29T14:01:42.95083551Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:42595","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:42.950742575Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-3126-7b47-9f19-f31d65e24feb","method":"fast","randomData":"dc96be5bcd5f3ec6c02100a19ad7f7a9a302880a295124d04c0bfe62d7f189e7406437ec6f09a76fc33c9164841fea1ab37b2a9f77ec73e714823a286f2e48f8","policyRuleHash":"ac980f49c4d35fab","spent":false},"rules":{"algorithm":"fast"},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:42595/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-3126-7b47-9f19-f31d65e24feb; Path=/; Expires=Mon, 29 Dec 2025 14:11:42 GMT anubis_test.go:299: lib.challengeResp{ID:"019b6a6a-3126-7b47-9f19-f31d65e24feb", Challenge:"dc96be5bcd5f3ec6c02100a19ad7f7a9a302880a295124d04c0bfe62d7f189e7406437ec6f09a76fc33c9164841fea1ab37b2a9f77ec73e714823a286f2e48f8"} anubis_test.go:299: elapsedTime=420&id=019b6a6a-3126-7b47-9f19-f31d65e24feb&nonce=0&redir=%2F&response=fc630497f1f834681e5531bfee633398adab35f7539e9f8bc13ad81ae79cb65f anubis_test.go:195: requested cookies for http://127.0.0.1:42595/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3126-7b47-9f19-f31d65e24feb&nonce=0&redir=%2F&response=fc630497f1f834681e5531bfee633398adab35f7539e9f8bc13ad81ae79cb65f anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-3126-7b47-9f19-f31d65e24feb; Path=/; Expires=Mon, 29 Dec 2025 14:11:42 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:42.951799694Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:42595","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.951985406Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:42595","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3126-7b47-9f19-f31d65e24feb","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:42.952257119Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:42595","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3126-7b47-9f19-f31d65e24feb"} anubis_test.go:209: set cookie: http://127.0.0.1:42595/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3126-7b47-9f19-f31d65e24feb&nonce=0&redir=%2F&response=fc630497f1f834681e5531bfee633398adab35f7539e9f8bc13ad81ae79cb65f -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTI2LTdiNDctOWYxOS1mMzFkNjVlMjRmZWIiLCJleHAiOjE3NjcwMTc1MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.ctIfUuUAqgk2P7hRj6XPxyRI2esb6ycZV9VJoWjeGIQfMbqXePVzSVCmaVFWiYqcAkO0CpVrb14C-_UJ2nEACw; Path=/; Expires=Mon, 29 Dec 2025 14:11:42 GMT anubis_test.go:308: &http.Cookie{Name:"techaro.lol-anubis", Value:"eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTI2LTdiNDctOWYxOS1mMzFkNjVlMjRmZWIiLCJleHAiOjE3NjcwMTc1MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.ctIfUuUAqgk2P7hRj6XPxyRI2esb6ycZV9VJoWjeGIQfMbqXePVzSVCmaVFWiYqcAkO0CpVrb14C-_UJ2nEACw", Quoted:false, Path:"/", Domain:"", Expires:time.Date(2025, time.December, 29, 14, 11, 42, 0, time.UTC), RawExpires:"Mon, 29 Dec 2025 14:11:42 GMT", MaxAge:0, Secure:false, HttpOnly:false, SameSite:0, Partitioned:false, Raw:"techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTI2LTdiNDctOWYxOS1mMzFkNjVlMjRmZWIiLCJleHAiOjE3NjcwMTc1MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.ctIfUuUAqgk2P7hRj6XPxyRI2esb6ycZV9VJoWjeGIQfMbqXePVzSVCmaVFWiYqcAkO0CpVrb14C-_UJ2nEACw; Path=/; Expires=Mon, 29 Dec 2025 14:11:42 GMT", Unparsed:[]string(nil)} --- PASS: TestCookieCustomExpiration (0.04s) === RUN TestCookieSettings anubis_test.go:321: loading policy file: testdata/zero_difficulty.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:42.981357859Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:42149","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.981461707Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:42149","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3145-766e-9be3-71f97e09aac0"} anubis_test.go:44: {"time":"2025-12-29T14:01:42.981511014Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:42149","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:42.981424436Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-3145-766e-9be3-71f97e09aac0","method":"fast","randomData":"c96046b34d5de0daac5ce45cd9a8630e3e854bd0a68ebae49e12a276a631c0a8dcc04e7238e71086c98980ec3b7dd42e149e7f708a3d0e1a2dd7a662bd34ecb0","policyRuleHash":"ac980f49c4d35fab","spent":false},"rules":{"algorithm":"fast"},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:42149/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-3145-766e-9be3-71f97e09aac0; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:42 GMT; Secure; SameSite=None; Partitioned anubis_test.go:340: lib.challengeResp{ID:"019b6a6a-3145-766e-9be3-71f97e09aac0", Challenge:"c96046b34d5de0daac5ce45cd9a8630e3e854bd0a68ebae49e12a276a631c0a8dcc04e7238e71086c98980ec3b7dd42e149e7f708a3d0e1a2dd7a662bd34ecb0"} anubis_test.go:340: elapsedTime=420&id=019b6a6a-3145-766e-9be3-71f97e09aac0&nonce=0&redir=%2F&response=125f14bc1611d4af7b582403a458514edfb85d6b27654df0f6cf94a375e13679 anubis_test.go:195: requested cookies for http://127.0.0.1:42149/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3145-766e-9be3-71f97e09aac0&nonce=0&redir=%2F&response=125f14bc1611d4af7b582403a458514edfb85d6b27654df0f6cf94a375e13679 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-3145-766e-9be3-71f97e09aac0; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:42 GMT; Secure; SameSite=None; Partitioned anubis_test.go:44: {"time":"2025-12-29T14:01:42.982311796Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:42149","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:42.982468193Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:42149","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3145-766e-9be3-71f97e09aac0","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:42.982604114Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:42149","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3145-766e-9be3-71f97e09aac0"} anubis_test.go:209: set cookie: http://127.0.0.1:42149/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3145-766e-9be3-71f97e09aac0&nonce=0&redir=%2F&response=125f14bc1611d4af7b582403a458514edfb85d6b27654df0f6cf94a375e13679 -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTQ1LTc2NmUtOWJlMy03MWY5N2UwOWFhYzAiLCJleHAiOjE3Njc2MjE3MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.u4MPDHGpRa4GeE4ir09Gdv1vfrB8uHZKBYc8R-CFPofXFfJ9BU5dhCdwPCYk3-Ityy1U22ehBDEBbRDaTxfLAg; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:42 GMT; Secure; SameSite=None; Partitioned anubis_test.go:349: &http.Cookie{Name:"techaro.lol-anubis", Value:"eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTQ1LTc2NmUtOWJlMy03MWY5N2UwOWFhYzAiLCJleHAiOjE3Njc2MjE3MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.u4MPDHGpRa4GeE4ir09Gdv1vfrB8uHZKBYc8R-CFPofXFfJ9BU5dhCdwPCYk3-Ityy1U22ehBDEBbRDaTxfLAg", Quoted:false, Path:"/", Domain:"127.0.0.1", Expires:time.Date(2026, time.January, 5, 14, 1, 42, 0, time.UTC), RawExpires:"Mon, 05 Jan 2026 14:01:42 GMT", MaxAge:0, Secure:true, HttpOnly:false, SameSite:4, Partitioned:true, Raw:"techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTQ1LTc2NmUtOWJlMy03MWY5N2UwOWFhYzAiLCJleHAiOjE3Njc2MjE3MDIsImlhdCI6MTc2NzAxNjkwMiwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MiwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.u4MPDHGpRa4GeE4ir09Gdv1vfrB8uHZKBYc8R-CFPofXFfJ9BU5dhCdwPCYk3-Ityy1U22ehBDEBbRDaTxfLAg; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:42 GMT; Secure; SameSite=None; Partitioned", Unparsed:[]string(nil)} --- PASS: TestCookieSettings (0.03s) === RUN TestCookieSettingsSameSiteNoneModeDowngradedToLaxWhenUnsecure anubis_test.go:377: loading policy file: testdata/zero_difficulty.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:43.016941021Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:38915","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:43.017025561Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:38915","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3169-7019-8248-fcb7a318ddee"} anubis_test.go:44: {"time":"2025-12-29T14:01:43.017063122Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:38915","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:43.01700839Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-3169-7019-8248-fcb7a318ddee","method":"fast","randomData":"3d1e42fc647c7bd2f53a178de92fc8b89a3bd1928d078b6a27383a1e43bc16838d099849ceb7ad0e33f9e5a8d44f18716653ba0a64582eab137cc157f1dbff49","policyRuleHash":"ac980f49c4d35fab","spent":false},"rules":{"algorithm":"fast"},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:38915/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-3169-7019-8248-fcb7a318ddee; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:43 GMT; SameSite=Lax; Partitioned anubis_test.go:396: lib.challengeResp{ID:"019b6a6a-3169-7019-8248-fcb7a318ddee", Challenge:"3d1e42fc647c7bd2f53a178de92fc8b89a3bd1928d078b6a27383a1e43bc16838d099849ceb7ad0e33f9e5a8d44f18716653ba0a64582eab137cc157f1dbff49"} anubis_test.go:396: elapsedTime=420&id=019b6a6a-3169-7019-8248-fcb7a318ddee&nonce=0&redir=%2F&response=bfe3a0677b3c0711583c231b71ab1bd4e46b5b7afb1b94b5faa75dab7b69cb8b anubis_test.go:195: requested cookies for http://127.0.0.1:38915/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3169-7019-8248-fcb7a318ddee&nonce=0&redir=%2F&response=bfe3a0677b3c0711583c231b71ab1bd4e46b5b7afb1b94b5faa75dab7b69cb8b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-3169-7019-8248-fcb7a318ddee; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:43 GMT; SameSite=Lax; Partitioned anubis_test.go:44: {"time":"2025-12-29T14:01:43.01909925Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:38915","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:43.019279199Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:38915","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3169-7019-8248-fcb7a318ddee","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:43.019524724Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:38915","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-3169-7019-8248-fcb7a318ddee"} anubis_test.go:209: set cookie: http://127.0.0.1:38915/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3169-7019-8248-fcb7a318ddee&nonce=0&redir=%2F&response=bfe3a0677b3c0711583c231b71ab1bd4e46b5b7afb1b94b5faa75dab7b69cb8b -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTY5LTcwMTktODI0OC1mY2I3YTMxOGRkZWUiLCJleHAiOjE3Njc2MjE3MDMsImlhdCI6MTc2NzAxNjkwMywibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MywicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ._s6r2QkaCvXQ-_STmmwyAMEm1Nb0WlErB2eibAkchpHv_m5TMIFSnubd6-EeyMy5rc6vFsyq8sGo98cHvbUYDA; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:43 GMT; SameSite=Lax; Partitioned anubis_test.go:405: &http.Cookie{Name:"techaro.lol-anubis", Value:"eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTY5LTcwMTktODI0OC1mY2I3YTMxOGRkZWUiLCJleHAiOjE3Njc2MjE3MDMsImlhdCI6MTc2NzAxNjkwMywibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MywicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ._s6r2QkaCvXQ-_STmmwyAMEm1Nb0WlErB2eibAkchpHv_m5TMIFSnubd6-EeyMy5rc6vFsyq8sGo98cHvbUYDA", Quoted:false, Path:"/", Domain:"127.0.0.1", Expires:time.Date(2026, time.January, 5, 14, 1, 43, 0, time.UTC), RawExpires:"Mon, 05 Jan 2026 14:01:43 GMT", MaxAge:0, Secure:false, HttpOnly:false, SameSite:2, Partitioned:true, Raw:"techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMTY5LTcwMTktODI0OC1mY2I3YTMxOGRkZWUiLCJleHAiOjE3Njc2MjE3MDMsImlhdCI6MTc2NzAxNjkwMywibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MywicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ._s6r2QkaCvXQ-_STmmwyAMEm1Nb0WlErB2eibAkchpHv_m5TMIFSnubd6-EeyMy5rc6vFsyq8sGo98cHvbUYDA; Path=/; Domain=127.0.0.1; Expires=Mon, 05 Jan 2026 14:01:43 GMT; SameSite=Lax; Partitioned", Unparsed:[]string(nil)} --- PASS: TestCookieSettingsSameSiteNoneModeDowngradedToLaxWhenUnsecure (0.04s) === RUN TestCheckDefaultDifficultyMatchesPolicy === RUN TestCheckDefaultDifficultyMatchesPolicy/1 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/2 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/3 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/4 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/5 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/6 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/7 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/8 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow === RUN TestCheckDefaultDifficultyMatchesPolicy/9 anubis_test.go:439: loading policy file: testdata/test_config_no_thresholds.yaml anubis_test.go:462: default/allow --- PASS: TestCheckDefaultDifficultyMatchesPolicy (0.36s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/1 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/2 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/3 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/4 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/5 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/6 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/7 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/8 (0.04s) --- PASS: TestCheckDefaultDifficultyMatchesPolicy/9 (0.04s) === RUN TestBasePrefix === RUN TestBasePrefix/no_prefix anubis_test.go:507: loading policy file: ./testdata/test_config.yaml anubis_test.go:533: http://127.0.0.1:40245/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F anubis_test.go:44: {"time":"2025-12-29T14:01:43.417757055Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:40245","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:43.417908581Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:40245","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-32f9-7d1d-8393-4b9f969f10a4"} anubis_test.go:44: {"time":"2025-12-29T14:01:43.41797618Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:40245","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:43.417865187Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-32f9-7d1d-8393-4b9f969f10a4","method":"fast","randomData":"758af6468763e11fc4d0c1a2803f872406542f287552b9e73230d2acbef1517c4a3ee2a3e8bb03b8a01890cd43f1457af1593bb1e9ee4e58201444d5174e9e21","policyRuleHash":"ac980f49c4d35fab","difficulty":1,"spent":false},"rules":{"algorithm":"fast","difficulty":1},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:40245/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-32f9-7d1d-8393-4b9f969f10a4; Path=/; Expires=Mon, 29 Dec 2025 14:01:43 GMT anubis_test.go:551: {"rules":{"algorithm":"fast","difficulty":1},"challenge":"758af6468763e11fc4d0c1a2803f872406542f287552b9e73230d2acbef1517c4a3ee2a3e8bb03b8a01890cd43f1457af1593bb1e9ee4e58201444d5174e9e21","id":"019b6a6a-32f9-7d1d-8393-4b9f969f10a4"} anubis_test.go:602: http://127.0.0.1:40245/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-32f9-7d1d-8393-4b9f969f10a4&nonce=135717&redir=%2F&response=00000cf6c13da56858d640565989363e1af80e0e6fb373ec2584e0a513190062 anubis_test.go:195: requested cookies for http://127.0.0.1:40245/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-32f9-7d1d-8393-4b9f969f10a4&nonce=135717&redir=%2F&response=00000cf6c13da56858d640565989363e1af80e0e6fb373ec2584e0a513190062 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-32f9-7d1d-8393-4b9f969f10a4; Path=/; Expires=Mon, 29 Dec 2025 14:01:43 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:43.823970744Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:40245","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:43.824155912Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:40245","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-32f9-7d1d-8393-4b9f969f10a4","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:43.824396198Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:40245","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-32f9-7d1d-8393-4b9f969f10a4"} anubis_test.go:209: set cookie: http://127.0.0.1:40245/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-32f9-7d1d-8393-4b9f969f10a4&nonce=135717&redir=%2F&response=00000cf6c13da56858d640565989363e1af80e0e6fb373ec2584e0a513190062 -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zMmY5LTdkMWQtODM5My00YjlmOTY5ZjEwYTQiLCJleHAiOjE3NjcwMTY5MDMsImlhdCI6MTc2NzAxNjkwMywibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0MywicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.vQcQFayt-9ydUzyPOwmy3C7tEkp-nriTL1A99_ceBQGS_gh-F637L90KNUyq-MXCjcii7URq8UWbumDq0vaCAA; Path=/; Expires=Mon, 29 Dec 2025 14:01:43 GMT === RUN TestBasePrefix/with_prefix anubis_test.go:507: loading policy file: ./testdata/test_config.yaml anubis_test.go:533: http://127.0.0.1:45397/myapp/.within.website/x/cmd/anubis/api/make-challenge?redir=%2Fmyapp anubis_test.go:44: {"time":"2025-12-29T14:01:43.867703585Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:45397","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:43.867858224Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:45397","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-34bb-7c63-8da2-ffd62604984a"} anubis_test.go:44: {"time":"2025-12-29T14:01:43.867924394Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:45397","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:43.867816519Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-34bb-7c63-8da2-ffd62604984a","method":"fast","randomData":"c49d8a3811ba721d637d921e77742ae2efe6272df2e2d8dfb3d1c3636b479c94ae56a7a2f0d3c9db3210f372f55c350a48fbcd906334e1871a2b7528b337f18d","policyRuleHash":"ac980f49c4d35fab","difficulty":1,"spent":false},"rules":{"algorithm":"fast","difficulty":1},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:45397/myapp/.within.website/x/cmd/anubis/api/make-challenge?redir=%2Fmyapp -> techaro.lol-anubis-cookie-verification=019b6a6a-34bb-7c63-8da2-ffd62604984a; Path=/; Expires=Mon, 29 Dec 2025 14:01:43 GMT anubis_test.go:551: {"rules":{"algorithm":"fast","difficulty":1},"challenge":"c49d8a3811ba721d637d921e77742ae2efe6272df2e2d8dfb3d1c3636b479c94ae56a7a2f0d3c9db3210f372f55c350a48fbcd906334e1871a2b7528b337f18d","id":"019b6a6a-34bb-7c63-8da2-ffd62604984a"} anubis_test.go:602: http://127.0.0.1:45397/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-34bb-7c63-8da2-ffd62604984a&nonce=87836&redir=%2F&response=0000b50b1455b9a4fd6ea6dbbf7b96d46510dad613010d23987ccb6c508d339d anubis_test.go:195: requested cookies for http://127.0.0.1:45397/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-34bb-7c63-8da2-ffd62604984a&nonce=87836&redir=%2F&response=0000b50b1455b9a4fd6ea6dbbf7b96d46510dad613010d23987ccb6c508d339d anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-34bb-7c63-8da2-ffd62604984a; Path=/; Expires=Mon, 29 Dec 2025 14:01:43 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.130231831Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:45397","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:44.130390728Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:45397","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-34bb-7c63-8da2-ffd62604984a","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:44.130624283Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:45397","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-34bb-7c63-8da2-ffd62604984a"} anubis_test.go:209: set cookie: http://127.0.0.1:45397/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-34bb-7c63-8da2-ffd62604984a&nonce=87836&redir=%2F&response=0000b50b1455b9a4fd6ea6dbbf7b96d46510dad613010d23987ccb6c508d339d -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zNGJiLTdjNjMtOGRhMi1mZmQ2MjYwNDk4NGEiLCJleHAiOjE3NjcwMTY5MDQsImlhdCI6MTc2NzAxNjkwNCwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0NCwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.oXJh0slzkYH5dZo7qJzbCeZX5_FMoVSShS1GXIj-TlIvpVKKc3R_P_2kQzshek2Tc98akjnXhj2dkOYanj7CBw; Path=/myapp/; Expires=Mon, 29 Dec 2025 14:01:44 GMT === RUN TestBasePrefix/with_prefix_and_trailing_slash anubis_test.go:507: loading policy file: ./testdata/test_config.yaml anubis_test.go:533: http://127.0.0.1:46405/myapp/.within.website/x/cmd/anubis/api/make-challenge?redir=%2Fmyapp%2F anubis_test.go:44: {"time":"2025-12-29T14:01:44.172563797Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:46405","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:44.172710634Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:46405","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-35ec-7a16-94c5-befee1a89a80"} anubis_test.go:44: {"time":"2025-12-29T14:01:44.172775176Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:46405","method":"POST","path":"/myapp/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:44.172666192Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-35ec-7a16-94c5-befee1a89a80","method":"fast","randomData":"a21c43a3f4acbedbc0b7374ec7b9e531b8181b15e077289e40ee1a2290cf7b25b00b0ae41b86ed67a4a50f3a2d44b1f336fd1f6b8d2310deb1641aebd4143308","policyRuleHash":"ac980f49c4d35fab","difficulty":1,"spent":false},"rules":{"algorithm":"fast","difficulty":1},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:46405/myapp/.within.website/x/cmd/anubis/api/make-challenge?redir=%2Fmyapp%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-35ec-7a16-94c5-befee1a89a80; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:551: {"rules":{"algorithm":"fast","difficulty":1},"challenge":"a21c43a3f4acbedbc0b7374ec7b9e531b8181b15e077289e40ee1a2290cf7b25b00b0ae41b86ed67a4a50f3a2d44b1f336fd1f6b8d2310deb1641aebd4143308","id":"019b6a6a-35ec-7a16-94c5-befee1a89a80"} anubis_test.go:602: http://127.0.0.1:46405/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-35ec-7a16-94c5-befee1a89a80&nonce=50255&redir=%2F&response=0000ffe98bb4e83f123ad33554835f040ac39e6dc17de51399592dd7bcb12932 anubis_test.go:195: requested cookies for http://127.0.0.1:46405/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-35ec-7a16-94c5-befee1a89a80&nonce=50255&redir=%2F&response=0000ffe98bb4e83f123ad33554835f040ac39e6dc17de51399592dd7bcb12932 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-35ec-7a16-94c5-befee1a89a80; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.325333229Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:46405","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:44.325487649Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:46405","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-35ec-7a16-94c5-befee1a89a80","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:44.325718537Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:46405","method":"GET","path":"/myapp/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-35ec-7a16-94c5-befee1a89a80"} anubis_test.go:209: set cookie: http://127.0.0.1:46405/myapp/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-35ec-7a16-94c5-befee1a89a80&nonce=50255&redir=%2F&response=0000ffe98bb4e83f123ad33554835f040ac39e6dc17de51399592dd7bcb12932 -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJDSEFMTEVOR0UiLCJjaGFsbGVuZ2UiOiIwMTliNmE2YS0zNWVjLTdhMTYtOTRjNS1iZWZlZTFhODlhODAiLCJleHAiOjE3NjcwMTY5MDQsImlhdCI6MTc2NzAxNjkwNCwibWV0aG9kIjoiZmFzdCIsIm5iZiI6MTc2NzAxNjg0NCwicG9saWN5UnVsZSI6ImFjOTgwZjQ5YzRkMzVmYWIifQ.y6uc5do_1-9yCXDoum81wtThfvpOiEu4f4V0lDNp-sIVk3btSdwbzhaYLzT8RhY8iE1piysmTV4asB_HySKdAQ; Path=/myapp/; Expires=Mon, 29 Dec 2025 14:01:44 GMT --- PASS: TestBasePrefix (0.95s) --- PASS: TestBasePrefix/no_prefix (0.45s) --- PASS: TestBasePrefix/with_prefix (0.31s) --- PASS: TestBasePrefix/with_prefix_and_trailing_slash (0.20s) === RUN TestCustomStatusCodes anubis_test.go:651: loading policy file: ./testdata/aggressive_403.yaml === RUN TestCustomStatusCodes/DENY === NAME TestCustomStatusCodes anubis_test.go:44: {"time":"2025-12-29T14:01:44.32897455Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":307},"msg":"explicit deny","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"DENY","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/deny","rule":"DENY","weight":0}} anubis_test.go:44: {"time":"2025-12-29T14:01:44.32908627Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":315},"msg":"rule hash","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"DENY","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/deny","rule":"DENY","weight":0},"hash":"484487c000d57854"} === RUN TestCustomStatusCodes/ALLOW === NAME TestCustomStatusCodes anubis_test.go:44: {"time":"2025-12-29T14:01:44.329896992Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":302},"msg":"allowing traffic to origin (explicit)","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"ALLOW","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"default/allow","rule":"ALLOW","weight":0}} anubis_test.go:640: ALLOW === RUN TestCustomStatusCodes/CHALLENGE === NAME TestCustomStatusCodes anubis_test.go:44: {"time":"2025-12-29T14:01:44.330551569Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":319},"msg":"challenge requested","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/challenge","rule":"CHALLENGE","weight":0}} anubis_test.go:44: {"time":"2025-12-29T14:01:44.330615637Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).maybeReverseProxy","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":228},"msg":"cookie not found","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/challenge","rule":"CHALLENGE","weight":0},"path":"/"} anubis_test.go:44: {"time":"2025-12-29T14:01:44.33072416Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:41149","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","challenge":"019b6a6a-368a-7a79-9946-7cc7b8ab1753"} --- PASS: TestCustomStatusCodes (0.01s) --- PASS: TestCustomStatusCodes/DENY (0.00s) --- PASS: TestCustomStatusCodes/ALLOW (0.00s) --- PASS: TestCustomStatusCodes/CHALLENGE (0.00s) === RUN TestCloudflareWorkersRule === RUN TestCloudflareWorkersRule/cel anubis_test.go:685: loading policy file: ./testdata/cloudflare-workers-cel.yaml === RUN TestCloudflareWorkersRule/cel/with-cf-worker-header === RUN TestCloudflareWorkersRule/cel/no-cf-worker-header === RUN TestCloudflareWorkersRule/header anubis_test.go:685: loading policy file: ./testdata/cloudflare-workers-header.yaml === RUN TestCloudflareWorkersRule/header/with-cf-worker-header === RUN TestCloudflareWorkersRule/header/no-cf-worker-header --- PASS: TestCloudflareWorkersRule (0.00s) --- PASS: TestCloudflareWorkersRule/cel (0.00s) --- PASS: TestCloudflareWorkersRule/cel/with-cf-worker-header (0.00s) --- PASS: TestCloudflareWorkersRule/cel/no-cf-worker-header (0.00s) --- PASS: TestCloudflareWorkersRule/header (0.00s) --- PASS: TestCloudflareWorkersRule/header/with-cf-worker-header (0.00s) --- PASS: TestCloudflareWorkersRule/header/no-cf-worker-header (0.00s) === RUN TestRuleChange anubis_test.go:741: loading policy file: testdata/rule_change.yaml 2025/12/29 14:01:44 ERROR this should be impossible, asked to issue a challenge but the rule is not a challenge rule cr.name=default/allow cr.rule=ALLOW cr.weight=0 rule="&{Rules:0xc000952048 Challenge:0xc0000ff800 Weight: Name: Action:}" anubis_test.go:44: {"time":"2025-12-29T14:01:44.341203056Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:42255","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"default/allow","rule":"ALLOW","weight":0},"challenge":"019b6a6a-3695-7285-a319-94a2fe08afc0"} anubis_test.go:44: {"time":"2025-12-29T14:01:44.341283897Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:42255","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"default/allow","rule":"ALLOW","weight":0},"challenge":{"issuedAt":"2025-12-29T14:01:44.341170866Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-3695-7285-a319-94a2fe08afc0","method":"fast","randomData":"51f3989d36c6c20eab0e50164f6c0c543ae340520e597cd34bc99cea533ff1d85b3f5b7a1cc51894cfa870a00b6fd2c0d55c1d68dfe828a21910cd4a8f601d18","policyRuleHash":"ac980f49c4d35fab","spent":false},"rules":{"algorithm":"fast"},"cr":{"name":"default/allow","rule":"ALLOW","weight":0}} anubis_test.go:209: set cookie: http://127.0.0.1:42255/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-3695-7285-a319-94a2fe08afc0; Path=/; Domain=127.0.0.1; Expires=Mon, 29 Dec 2025 14:11:44 GMT anubis_test.go:758: lib.challengeResp{ID:"019b6a6a-3695-7285-a319-94a2fe08afc0", Challenge:"51f3989d36c6c20eab0e50164f6c0c543ae340520e597cd34bc99cea533ff1d85b3f5b7a1cc51894cfa870a00b6fd2c0d55c1d68dfe828a21910cd4a8f601d18"} anubis_test.go:758: elapsedTime=420&id=019b6a6a-3695-7285-a319-94a2fe08afc0&nonce=0&redir=%2F&response=f5f58f06cc19c960d7b8fe18960951f4d6fcf0ca356e766c3a572162a8544c9e anubis_test.go:195: requested cookies for http://127.0.0.1:42255/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3695-7285-a319-94a2fe08afc0&nonce=0&redir=%2F&response=f5f58f06cc19c960d7b8fe18960951f4d6fcf0ca356e766c3a572162a8544c9e anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-3695-7285-a319-94a2fe08afc0; Path=/; Domain=127.0.0.1; Expires=Mon, 29 Dec 2025 14:11:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.342108545Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork.(*Impl).Validate","file":"github.com/TecharoHQ/anubis/lib/challenge/proofofwork/proofofwork.go","line":77},"msg":"challenge took","host":"127.0.0.1:42255","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"default/allow","rule":"ALLOW","weight":0},"challenge":"019b6a6a-3695-7285-a319-94a2fe08afc0","elapsedTime":420} anubis_test.go:44: {"time":"2025-12-29T14:01:44.342366345Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"127.0.0.1:42255","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"default/allow","rule":"ALLOW","weight":0},"challenge":"019b6a6a-3695-7285-a319-94a2fe08afc0"} anubis_test.go:209: set cookie: http://127.0.0.1:42255/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&id=019b6a6a-3695-7285-a319-94a2fe08afc0&nonce=0&redir=%2F&response=f5f58f06cc19c960d7b8fe18960951f4d6fcf0ca356e766c3a572162a8544c9e -> techaro.lol-anubis=eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJhY3Rpb24iOiJBTExPVyIsImNoYWxsZW5nZSI6IjAxOWI2YTZhLTM2OTUtNzI4NS1hMzE5LTk0YTJmZTA4YWZjMCIsImV4cCI6MTc2NzAxNzUwNCwiaWF0IjoxNzY3MDE2OTA0LCJtZXRob2QiOiJmYXN0IiwibmJmIjoxNzY3MDE2ODQ0LCJwb2xpY3lSdWxlIjoiYWM5ODBmNDljNGQzNWZhYiJ9.Tjbq5OvTCB7ArIvZYubwmL5szV_TDF-IX3hBIu7yhVgCw_RMX0ZYoDTkrHith9-g_5aLvgTCHWWh7xXl7a9FCQ; Path=/; Domain=127.0.0.1; Expires=Mon, 29 Dec 2025 14:11:44 GMT --- PASS: TestRuleChange (0.01s) === RUN TestStripBasePrefixFromRequest === RUN TestStripBasePrefixFromRequest/strip_disabled_-_no_change === RUN TestStripBasePrefixFromRequest/strip_enabled_-_removes_prefix === RUN TestStripBasePrefixFromRequest/strip_enabled_-_root_becomes_slash === RUN TestStripBasePrefixFromRequest/strip_enabled_-_trailing_slash_on_base_prefix === RUN TestStripBasePrefixFromRequest/strip_enabled_-_no_prefix_match === RUN TestStripBasePrefixFromRequest/strip_enabled_-_empty_base_prefix === RUN TestStripBasePrefixFromRequest/strip_enabled_-_nested_path === RUN TestStripBasePrefixFromRequest/strip_enabled_-_exact_match_becomes_root --- PASS: TestStripBasePrefixFromRequest (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_disabled_-_no_change (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_removes_prefix (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_root_becomes_slash (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_trailing_slash_on_base_prefix (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_no_prefix_match (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_empty_base_prefix (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_nested_path (0.00s) --- PASS: TestStripBasePrefixFromRequest/strip_enabled_-_exact_match_becomes_root (0.00s) === RUN TestChallengeFor_ErrNotFound anubis_test.go:868: loading policy file: testdata/aggressive_403.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:44.345262964Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":319},"msg":"challenge requested","host":"example.com","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/challenge","rule":"CHALLENGE","weight":0}} anubis_test.go:44: {"time":"2025-12-29T14:01:44.345326748Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).maybeReverseProxy","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":228},"msg":"cookie not found","host":"example.com","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"bot/challenge","rule":"CHALLENGE","weight":0},"path":"/"} anubis_test.go:44: {"time":"2025-12-29T14:01:44.345426871Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"example.com","method":"GET","path":"/","user_agent":"CHALLENGE","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","challenge":"019b6a6a-3699-7614-9297-20bc0d8dff58"} === RUN TestChallengeFor_ErrNotFound/make_sure_challenge_page_is_issued === RUN TestChallengeFor_ErrNotFound/make_sure_that_the_body_is_not_an_error_page === RUN TestChallengeFor_ErrNotFound/make_sure_new_test_cookie_is_issued --- PASS: TestChallengeFor_ErrNotFound (0.00s) --- PASS: TestChallengeFor_ErrNotFound/make_sure_challenge_page_is_issued (0.00s) --- PASS: TestChallengeFor_ErrNotFound/make_sure_that_the_body_is_not_an_error_page (0.00s) --- PASS: TestChallengeFor_ErrNotFound/make_sure_new_test_cookie_is_issued (0.00s) === RUN TestPassChallengeXSS anubis_test.go:930: loading policy file: ./testdata/test_config.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:44.385543146Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).check","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":620},"msg":"adjusting weight","host":"127.0.0.1:43847","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","name":"generic-browser","delta":10} anubis_test.go:44: {"time":"2025-12-29T14:01:44.385701718Z","level":"INFO","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).issueChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":137},"msg":"new challenge issued","host":"127.0.0.1:43847","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":"019b6a6a-36c1-79ee-8c09-380c78178226"} anubis_test.go:44: {"time":"2025-12-29T14:01:44.385768128Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).MakeChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":430},"msg":"made challenge","host":"127.0.0.1:43847","method":"POST","path":"/.within.website/x/cmd/anubis/api/make-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","check_result":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10},"challenge":{"issuedAt":"2025-12-29T14:01:44.385655754Z","metadata":{"User-Agent":"Mozilla/5.0","X-Real-Ip":"127.0.0.1"},"id":"019b6a6a-36c1-79ee-8c09-380c78178226","method":"fast","randomData":"2039d43c30b2827dbf38fcf71872768709da2145b828df4e2bac57860bed1d22ce9e13ef8094948d0818747011d632ee39b7200f26f78fa53baf993f496934e7","policyRuleHash":"ac980f49c4d35fab","difficulty":1,"spent":false},"rules":{"algorithm":"fast","difficulty":1},"cr":{"name":"threshold/minimal-suspicion","rule":"CHALLENGE","weight":10}} anubis_test.go:209: set cookie: http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/make-challenge?redir=%2F -> techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT === RUN TestPassChallengeXSS/with_test_cookie === RUN TestPassChallengeXSS/with_test_cookie/javascript_alert === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=javascript%3Aalert%28%27xss%27%29&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.386600452Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"javascript"} === RUN TestPassChallengeXSS/with_test_cookie/vbscript === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=vbscript%3Amsgbox%28%22XSS%22%29&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.387332836Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"vbscript"} === RUN TestPassChallengeXSS/with_test_cookie/data_url === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847 anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=data%3Atext%2Fhtml%3Bbase64%2CPHNjcmlwdD5hbGVydCgneHNzJyk8L3NjcmlwdD4%3D&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.387978573Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"data"} === RUN TestPassChallengeXSS/no_test_cookie === RUN TestPassChallengeXSS/no_test_cookie/javascript_alert === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=javascript%3Aalert%28%27xss%27%29&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.388526206Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"javascript"} === RUN TestPassChallengeXSS/no_test_cookie/vbscript === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=vbscript%3Amsgbox%28%22XSS%22%29&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.389104885Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"vbscript"} === RUN TestPassChallengeXSS/no_test_cookie/data_url === NAME TestPassChallengeXSS anubis_test.go:195: requested cookies for http://127.0.0.1:43847/.within.website/x/cmd/anubis/api/pass-challenge?elapsedTime=420&nonce=0&redir=data%3Atext%2Fhtml%3Bbase64%2CPHNjcmlwdD5hbGVydCgneHNzJyk8L3NjcmlwdD4%3D&response=7664fcb34227d84dd81a8ae566ef678a0197e686ff10dcc145383945bd79fe3b anubis_test.go:198: get cookie: <- techaro.lol-anubis-cookie-verification=019b6a6a-36c1-79ee-8c09-380c78178226; Path=/; Expires=Mon, 29 Dec 2025 14:01:44 GMT anubis_test.go:44: {"time":"2025-12-29T14:01:44.389723531Z","level":"ERROR","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":450},"msg":"XSS attempt blocked, invalid redirect scheme","host":"127.0.0.1:43847","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"Mozilla/5.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"127.0.0.1","scheme":"data"} --- PASS: TestPassChallengeXSS (0.04s) --- PASS: TestPassChallengeXSS/with_test_cookie (0.00s) --- PASS: TestPassChallengeXSS/with_test_cookie/javascript_alert (0.00s) --- PASS: TestPassChallengeXSS/with_test_cookie/vbscript (0.00s) --- PASS: TestPassChallengeXSS/with_test_cookie/data_url (0.00s) --- PASS: TestPassChallengeXSS/no_test_cookie (0.00s) --- PASS: TestPassChallengeXSS/no_test_cookie/javascript_alert (0.00s) --- PASS: TestPassChallengeXSS/no_test_cookie/vbscript (0.00s) --- PASS: TestPassChallengeXSS/no_test_cookie/data_url (0.00s) === RUN TestPassChallengeNilRuleChallengeFallback anubis_test.go:1054: loading policy file: testdata/zero_difficulty.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:44.431686512Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).hydrateChallengeRule","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":163},"msg":"rule missing challenge configuration; using stored challenge metadata","host":"example.com","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"NilChallengeTester/1.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"203.0.113.4","check_result":{"name":"threshold/allow-all","rule":"ALLOW","weight":0},"rule":""} anubis_test.go:44: {"time":"2025-12-29T14:01:44.432067104Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).PassChallenge","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":583},"msg":"challenge passed, redirecting to app","host":"example.com","method":"GET","path":"/.within.website/x/cmd/anubis/api/pass-challenge","user_agent":"NilChallengeTester/1.0","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"203.0.113.4","check_result":{"name":"threshold/allow-all","rule":"ALLOW","weight":0},"challenge":"test-challenge"} --- PASS: TestPassChallengeNilRuleChallengeFallback (0.04s) === RUN TestXForwardedForNoDoubleComma anubis_test.go:1115: loading policy file: testdata/permissive.yaml anubis_test.go:44: {"time":"2025-12-29T14:01:44.435663376Z","level":"DEBUG","source":{"function":"github.com/TecharoHQ/anubis/lib.(*Server).checkRules","file":"github.com/TecharoHQ/anubis/lib/anubis.go","line":302},"msg":"allowing traffic to origin (explicit)","host":"127.0.0.1:44511","method":"GET","path":"/","user_agent":"Go-http-client/1.1","accept_language":"","priority":"","x-forwarded-for":"","x-real-ip":"10.0.0.1","check_result":{"name":"bot/ipv4-rfc-1918","rule":"ALLOW","weight":0}} --- PASS: TestXForwardedForNoDoubleComma (0.00s) === RUN TestInvalidChallengeMethod --- PASS: TestInvalidChallengeMethod (0.00s) === RUN TestBadConfigs === RUN TestBadConfigs/badregexes.json config_test.go:32: can't parse policy file config/testdata/bad/badregexes.json: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` bot 2: config: bot entry for "headers-bad" is not valid: config.Bot: must set either user_agent_regex, path_regex, headers_regex, or remote_addresses === RUN TestBadConfigs/badregexes.yaml config_test.go:32: can't parse policy file config/testdata/bad/badregexes.yaml: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` === RUN TestBadConfigs/dns-ttl-custom.yaml config_test.go:32: can't parse policy file config/testdata/bad/dns-ttl-custom.yaml: can't parse policy config YAML config/testdata/bad/dns-ttl-custom.yaml: error unmarshaling JSON: while decoding JSON: json: cannot unmarshal string into Go struct field DnsTTL.dns_ttl.reverse of type int === RUN TestBadConfigs/import_and_bot.json config_test.go:32: can't parse policy file config/testdata/bad/import_and_bot.json: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestBadConfigs/import_and_bot.yaml config_test.go:32: can't parse policy file config/testdata/bad/import_and_bot.yaml: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestBadConfigs/import_invalid_file.json config_test.go:32: can't parse policy file config/testdata/bad/import_invalid_file.json: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestBadConfigs/import_invalid_file.yaml config_test.go:32: can't parse policy file config/testdata/bad/import_invalid_file.yaml: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestBadConfigs/impressum-no-footer.yaml config_test.go:32: can't parse policy file config/testdata/bad/impressum-no-footer.yaml: errors validating policy config config/testdata/bad/impressum-no-footer.yaml: config: missing value: impressum footer must be defined === RUN TestBadConfigs/impressum-no-page-contents.yaml config_test.go:32: can't parse policy file config/testdata/bad/impressum-no-page-contents.yaml: errors validating policy config config/testdata/bad/impressum-no-page-contents.yaml: config: missing value: impressum page title must be defined config: missing value: impressum body title must be defined === RUN TestBadConfigs/invalid.json config_test.go:32: can't parse policy file config/testdata/bad/invalid.json: config is not valid: bot 0: config.BotOrImport: rule definition is invalid, you must set either bot rules or an import statement, not both === RUN TestBadConfigs/invalid.yaml config_test.go:32: can't parse policy file config/testdata/bad/invalid.yaml: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/logging-invalid-sink.yaml config_test.go:32: can't parse policy file config/testdata/bad/logging-invalid-sink.yaml: config is not valid: config: must define at least one (1) bot rule config.Logging: invalid sink: sink nope is unknown to me === RUN TestBadConfigs/logging-no-parameters.yaml config_test.go:32: can't parse policy file config/testdata/bad/logging-no-parameters.yaml: config is not valid: config: must define at least one (1) bot rule config.Logging: missing value parameters in logging block logging file config is nil, why are you calling this? === RUN TestBadConfigs/multiple_expression_types.json config_test.go:32: can't parse policy file config/testdata/bad/multiple_expression_types.json: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestBadConfigs/multiple_expression_types.yaml config_test.go:32: can't parse policy file config/testdata/bad/multiple_expression_types.yaml: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestBadConfigs/nobots.json config_test.go:32: can't parse policy file config/testdata/bad/nobots.json: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/nobots.yaml config_test.go:32: can't parse policy file config/testdata/bad/nobots.yaml: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/opengraph_bad_ttl.yaml config_test.go:32: can't parse policy file config/testdata/bad/opengraph_bad_ttl.yaml: config is not valid: config.OpenGraph: invalid OpenGraph configuration config.OpenGraph: ttl does not parse as a Duration, see https://pkg.go.dev/time#ParseDuration (formatted like 5m -> 5 minutes, 2h -> 2 hours, etc): ParseDuration("taco") returned: time: invalid duration "taco" === RUN TestBadConfigs/regex_ends_newline.json config_test.go:32: can't parse policy file config/testdata/bad/regex_ends_newline.json: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestBadConfigs/regex_ends_newline.yaml config_test.go:32: can't parse policy file config/testdata/bad/regex_ends_newline.yaml: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestBadConfigs/status-codes-0.json config_test.go:32: can't parse policy file config/testdata/bad/status-codes-0.json: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestBadConfigs/status-codes-0.yaml config_test.go:32: can't parse policy file config/testdata/bad/status-codes-0.yaml: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestBadConfigs/threshold-challenge-without-challenge.yaml config_test.go:32: can't parse policy file config/testdata/bad/threshold-challenge-without-challenge.yaml: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestBadConfigs/thresholds.yaml config_test.go:32: can't parse policy file config/testdata/bad/thresholds.yaml: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestBadConfigs/unparseable.json config_test.go:32: can't parse policy file config/testdata/bad/unparseable.json: can't parse policy config YAML config/testdata/bad/unparseable.json: error converting YAML to JSON: yaml: did not find expected node content === RUN TestBadConfigs/unparseable.yaml config_test.go:32: can't parse policy file config/testdata/bad/unparseable.yaml: can't parse policy config YAML config/testdata/bad/unparseable.yaml: error converting YAML to JSON: yaml: did not find expected node content --- PASS: TestBadConfigs (0.01s) --- PASS: TestBadConfigs/badregexes.json (0.00s) --- PASS: TestBadConfigs/badregexes.yaml (0.00s) --- PASS: TestBadConfigs/dns-ttl-custom.yaml (0.00s) --- PASS: TestBadConfigs/import_and_bot.json (0.00s) --- PASS: TestBadConfigs/import_and_bot.yaml (0.00s) --- PASS: TestBadConfigs/import_invalid_file.json (0.00s) --- PASS: TestBadConfigs/import_invalid_file.yaml (0.00s) --- PASS: TestBadConfigs/impressum-no-footer.yaml (0.00s) --- PASS: TestBadConfigs/impressum-no-page-contents.yaml (0.00s) --- PASS: TestBadConfigs/invalid.json (0.00s) --- PASS: TestBadConfigs/invalid.yaml (0.00s) --- PASS: TestBadConfigs/logging-invalid-sink.yaml (0.00s) --- PASS: TestBadConfigs/logging-no-parameters.yaml (0.00s) --- PASS: TestBadConfigs/multiple_expression_types.json (0.00s) --- PASS: TestBadConfigs/multiple_expression_types.yaml (0.00s) --- PASS: TestBadConfigs/nobots.json (0.00s) --- PASS: TestBadConfigs/nobots.yaml (0.00s) --- PASS: TestBadConfigs/opengraph_bad_ttl.yaml (0.00s) --- PASS: TestBadConfigs/regex_ends_newline.json (0.00s) --- PASS: TestBadConfigs/regex_ends_newline.yaml (0.00s) --- PASS: TestBadConfigs/status-codes-0.json (0.00s) --- PASS: TestBadConfigs/status-codes-0.yaml (0.00s) --- PASS: TestBadConfigs/threshold-challenge-without-challenge.yaml (0.00s) --- PASS: TestBadConfigs/thresholds.yaml (0.00s) --- PASS: TestBadConfigs/unparseable.json (0.00s) --- PASS: TestBadConfigs/unparseable.yaml (0.00s) === RUN TestGoodConfigs === RUN TestGoodConfigs/allow_everyone.json === RUN TestGoodConfigs/allow_everyone.json/with-thoth === RUN TestGoodConfigs/allow_everyone.json/without-thoth === RUN TestGoodConfigs/allow_everyone.yaml === RUN TestGoodConfigs/allow_everyone.yaml/with-thoth === RUN TestGoodConfigs/allow_everyone.yaml/without-thoth === RUN TestGoodConfigs/block_cf_workers.json === RUN TestGoodConfigs/block_cf_workers.json/with-thoth === RUN TestGoodConfigs/block_cf_workers.json/without-thoth === RUN TestGoodConfigs/block_cf_workers.yaml === RUN TestGoodConfigs/block_cf_workers.yaml/with-thoth === RUN TestGoodConfigs/block_cf_workers.yaml/without-thoth === RUN TestGoodConfigs/challenge_cloudflare.yaml === RUN TestGoodConfigs/challenge_cloudflare.yaml/with-thoth === RUN TestGoodConfigs/challenge_cloudflare.yaml/without-thoth {"time":"2025-12-29T14:01:44.452452425Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":171},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"asn","settings":{"match":[13335]}} === RUN TestGoodConfigs/challengemozilla.json === RUN TestGoodConfigs/challengemozilla.json/with-thoth === RUN TestGoodConfigs/challengemozilla.json/without-thoth === RUN TestGoodConfigs/challengemozilla.yaml === RUN TestGoodConfigs/challengemozilla.yaml/with-thoth === RUN TestGoodConfigs/challengemozilla.yaml/without-thoth === RUN TestGoodConfigs/dns-ttl-custom.yaml === RUN TestGoodConfigs/dns-ttl-custom.yaml/with-thoth === RUN TestGoodConfigs/dns-ttl-custom.yaml/without-thoth === RUN TestGoodConfigs/entropy.yaml === RUN TestGoodConfigs/entropy.yaml/with-thoth === RUN TestGoodConfigs/entropy.yaml/without-thoth === RUN TestGoodConfigs/everything_blocked.json === RUN TestGoodConfigs/everything_blocked.json/with-thoth === RUN TestGoodConfigs/everything_blocked.json/without-thoth === RUN TestGoodConfigs/everything_blocked.yaml === RUN TestGoodConfigs/everything_blocked.yaml/with-thoth === RUN TestGoodConfigs/everything_blocked.yaml/without-thoth === RUN TestGoodConfigs/geoip_us.yaml === RUN TestGoodConfigs/geoip_us.yaml/with-thoth === RUN TestGoodConfigs/geoip_us.yaml/without-thoth {"time":"2025-12-29T14:01:44.466460873Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":180},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"geoip","settings":{"countries":["US"]}} === RUN TestGoodConfigs/git_client.json === RUN TestGoodConfigs/git_client.json/with-thoth === RUN TestGoodConfigs/git_client.json/without-thoth === RUN TestGoodConfigs/git_client.yaml === RUN TestGoodConfigs/git_client.yaml/with-thoth === RUN TestGoodConfigs/git_client.yaml/without-thoth === RUN TestGoodConfigs/import_filesystem.json === RUN TestGoodConfigs/import_filesystem.json/with-thoth === RUN TestGoodConfigs/import_filesystem.json/without-thoth === RUN TestGoodConfigs/import_filesystem.yaml === RUN TestGoodConfigs/import_filesystem.yaml/with-thoth === RUN TestGoodConfigs/import_filesystem.yaml/without-thoth === RUN TestGoodConfigs/import_keep_internet_working.json === RUN TestGoodConfigs/import_keep_internet_working.json/with-thoth === RUN TestGoodConfigs/import_keep_internet_working.json/without-thoth === RUN TestGoodConfigs/import_keep_internet_working.yaml === RUN TestGoodConfigs/import_keep_internet_working.yaml/with-thoth === RUN TestGoodConfigs/import_keep_internet_working.yaml/without-thoth === RUN TestGoodConfigs/impressum.yaml === RUN TestGoodConfigs/impressum.yaml/with-thoth === RUN TestGoodConfigs/impressum.yaml/without-thoth === RUN TestGoodConfigs/logging-file.yaml === RUN TestGoodConfigs/logging-file.yaml/with-thoth === RUN TestGoodConfigs/logging-file.yaml/without-thoth === RUN TestGoodConfigs/logging-stdio.yaml === RUN TestGoodConfigs/logging-stdio.yaml/with-thoth === RUN TestGoodConfigs/logging-stdio.yaml/without-thoth === RUN TestGoodConfigs/no-thresholds.yaml === RUN TestGoodConfigs/no-thresholds.yaml/with-thoth === RUN TestGoodConfigs/no-thresholds.yaml/without-thoth === RUN TestGoodConfigs/old_xesite.json === RUN TestGoodConfigs/old_xesite.json/with-thoth === RUN TestGoodConfigs/old_xesite.json/without-thoth === RUN TestGoodConfigs/opengraph_all_good.yaml === RUN TestGoodConfigs/opengraph_all_good.yaml/with-thoth === RUN TestGoodConfigs/opengraph_all_good.yaml/without-thoth === RUN TestGoodConfigs/simple-weight.yaml === RUN TestGoodConfigs/simple-weight.yaml/with-thoth === RUN TestGoodConfigs/simple-weight.yaml/without-thoth === RUN TestGoodConfigs/status-codes-paranoid.json === RUN TestGoodConfigs/status-codes-paranoid.json/with-thoth === RUN TestGoodConfigs/status-codes-paranoid.json/without-thoth === RUN TestGoodConfigs/status-codes-paranoid.yaml === RUN TestGoodConfigs/status-codes-paranoid.yaml/with-thoth === RUN TestGoodConfigs/status-codes-paranoid.yaml/without-thoth === RUN TestGoodConfigs/status-codes-rfc.json === RUN TestGoodConfigs/status-codes-rfc.json/with-thoth === RUN TestGoodConfigs/status-codes-rfc.json/without-thoth === RUN TestGoodConfigs/status-codes-rfc.yaml === RUN TestGoodConfigs/status-codes-rfc.yaml/with-thoth === RUN TestGoodConfigs/status-codes-rfc.yaml/without-thoth === RUN TestGoodConfigs/thresholds.yaml === RUN TestGoodConfigs/thresholds.yaml/with-thoth === RUN TestGoodConfigs/thresholds.yaml/without-thoth === RUN TestGoodConfigs/weight-no-weight.yaml === RUN TestGoodConfigs/weight-no-weight.yaml/with-thoth === RUN TestGoodConfigs/weight-no-weight.yaml/without-thoth --- PASS: TestGoodConfigs (0.07s) --- PASS: TestGoodConfigs/allow_everyone.json (0.00s) --- PASS: TestGoodConfigs/allow_everyone.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/entropy.yaml (0.00s) --- PASS: TestGoodConfigs/entropy.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/entropy.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.json (0.00s) --- PASS: TestGoodConfigs/git_client.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.yaml (0.00s) --- PASS: TestGoodConfigs/git_client.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/impressum.yaml (0.00s) --- PASS: TestGoodConfigs/impressum.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/impressum.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/old_xesite.json (0.00s) --- PASS: TestGoodConfigs/old_xesite.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/old_xesite.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/thresholds.yaml (0.01s) --- PASS: TestGoodConfigs/thresholds.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/thresholds.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml/without-thoth (0.00s) === RUN TestSetCookie === RUN TestSetCookie/basic http_test.go:40: loading policy file: ./testdata/test_config.yaml === RUN TestSetCookie/domain_techaro.lol http_test.go:40: loading policy file: ./testdata/test_config.yaml === RUN TestSetCookie/dynamic_cookie_domain http_test.go:40: loading policy file: ./testdata/test_config.yaml --- PASS: TestSetCookie (0.12s) --- PASS: TestSetCookie/basic (0.04s) --- PASS: TestSetCookie/domain_techaro.lol (0.04s) --- PASS: TestSetCookie/dynamic_cookie_domain (0.04s) === RUN TestClearCookie http_test.go:58: loading policy file: ./testdata/test_config.yaml --- PASS: TestClearCookie (0.04s) === RUN TestClearCookieWithDomain http_test.go:83: loading policy file: ./testdata/test_config.yaml --- PASS: TestClearCookieWithDomain (0.04s) === RUN TestClearCookieWithDynamicDomain http_test.go:108: loading policy file: ./testdata/test_config.yaml --- PASS: TestClearCookieWithDynamicDomain (0.04s) === RUN TestRenderIndexRedirect --- PASS: TestRenderIndexRedirect (0.00s) === RUN TestRenderIndexUnauthorized --- PASS: TestRenderIndexUnauthorized (0.00s) === RUN TestRedirectSecurity === RUN TestRedirectSecurity/constructRedirectURL:_javascript_protocol_should_be_rejected 2025/12/29 14:01:44 WARN invalid protocol in X-Forwarded-Proto host=example.com method=GET path=/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" proto=javascript redirect_security_test.go:216: expected error containing "invalid", got: Invalid redirect === RUN TestRedirectSecurity/constructRedirectURL:_data_protocol_should_be_rejected 2025/12/29 14:01:44 WARN invalid protocol in X-Forwarded-Proto host=example.com method=GET path=/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" proto=data redirect_security_test.go:216: expected error containing "invalid", got: Invalid redirect === RUN TestRedirectSecurity/constructRedirectURL:_file_protocol_should_be_rejected redirect_security_test.go:216: expected error containing "invalid", got: Missing required X-Forwarded-* headers === RUN TestRedirectSecurity/constructRedirectURL:_ftp_protocol_should_be_rejected 2025/12/29 14:01:44 WARN invalid protocol in X-Forwarded-Proto host=example.com method=GET path=/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" proto=ftp redirect_security_test.go:216: expected error containing "invalid", got: Invalid redirect === RUN TestRedirectSecurity/constructRedirectURL:_https_protocol_should_be_allowed === RUN TestRedirectSecurity/constructRedirectURL:_http_protocol_should_be_allowed === RUN TestRedirectSecurity/serveHTTPNext:_javascript:_URL_should_be_rejected 2025/12/29 14:01:44 WARN XSS attempt blocked, invalid redirect scheme host=example.com method=GET path=/.within.website/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" scheme=javascript redir=javascript:alert(1) === RUN TestRedirectSecurity/serveHTTPNext:_data:_URL_should_be_rejected 2025/12/29 14:01:44 WARN XSS attempt blocked, invalid redirect scheme host=example.com method=GET path=/.within.website/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" scheme=data redir=data:text/html, === RUN TestRedirectSecurity/serveHTTPNext:_file:_URL_should_be_rejected 2025/12/29 14:01:44 WARN XSS attempt blocked, invalid redirect scheme host=example.com method=GET path=/.within.website/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" scheme=file redir=file:///etc/passwd === RUN TestRedirectSecurity/serveHTTPNext:_vbscript:_URL_should_be_rejected 2025/12/29 14:01:44 WARN XSS attempt blocked, invalid redirect scheme host=example.com method=GET path=/.within.website/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" scheme=vbscript redir=vbscript:msgbox(1) === RUN TestRedirectSecurity/serveHTTPNext:_valid_https_URL_should_work === RUN TestRedirectSecurity/serveHTTPNext:_valid_relative_URL_should_work === RUN TestRedirectSecurity/serveHTTPNext:_external_domain_should_be_blocked === RUN TestRedirectSecurity/serveHTTPNext:_relative_path_should_work === RUN TestRedirectSecurity/serveHTTPNext:_empty_redir_should_show_success_page === RUN TestRedirectSecurity/renderIndex:_javascript_protocol_in_X-Forwarded-Proto 2025/12/29 14:01:44 WARN invalid protocol in X-Forwarded-Proto host=example.com method=GET path=/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" proto=javascript === RUN TestRedirectSecurity/renderIndex:_data_protocol_in_X-Forwarded-Proto 2025/12/29 14:01:44 WARN invalid protocol in X-Forwarded-Proto host=example.com method=GET path=/ user_agent="" accept_language="" priority="" x-forwarded-for="" x-real-ip="" proto=data === RUN TestRedirectSecurity/renderIndex:_valid_https_redirect --- PASS: TestRedirectSecurity (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_javascript_protocol_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_data_protocol_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_file_protocol_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_ftp_protocol_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_https_protocol_should_be_allowed (0.00s) --- PASS: TestRedirectSecurity/constructRedirectURL:_http_protocol_should_be_allowed (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_javascript:_URL_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_data:_URL_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_file:_URL_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_vbscript:_URL_should_be_rejected (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_valid_https_URL_should_work (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_valid_relative_URL_should_work (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_external_domain_should_be_blocked (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_relative_path_should_work (0.00s) --- PASS: TestRedirectSecurity/serveHTTPNext:_empty_redir_should_show_success_page (0.00s) --- PASS: TestRedirectSecurity/renderIndex:_javascript_protocol_in_X-Forwarded-Proto (0.00s) --- PASS: TestRedirectSecurity/renderIndex:_data_protocol_in_X-Forwarded-Proto (0.00s) --- PASS: TestRedirectSecurity/renderIndex:_valid_https_redirect (0.00s) PASS ok github.com/TecharoHQ/anubis/lib 1.924s ? github.com/TecharoHQ/anubis/lib/challenge [no test files] === RUN TestNew --- PASS: TestNew (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/challenge/challengetest 0.016s ? github.com/TecharoHQ/anubis/lib/challenge/metarefresh [no test files] ? github.com/TecharoHQ/anubis/lib/challenge/preact [no test files] === RUN TestBasic === RUN TestBasic/allgood === RUN TestBasic/no-params === RUN TestBasic/missing-nonce === RUN TestBasic/missing-elapsedTime === RUN TestBasic/missing-response === RUN TestBasic/wrong-nonce-format === RUN TestBasic/wrong-elapsedTime-format === RUN TestBasic/invalid-response --- PASS: TestBasic (0.01s) --- PASS: TestBasic/allgood (0.01s) --- PASS: TestBasic/no-params (0.00s) --- PASS: TestBasic/missing-nonce (0.00s) --- PASS: TestBasic/missing-elapsedTime (0.00s) --- PASS: TestBasic/missing-response (0.00s) --- PASS: TestBasic/wrong-nonce-format (0.00s) --- PASS: TestBasic/wrong-elapsedTime-format (0.00s) --- PASS: TestBasic/invalid-response (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/challenge/proofofwork 0.022s === RUN TestASNsValid === RUN TestASNsValid/basic_valid === RUN TestASNsValid/private_ASN --- PASS: TestASNsValid (0.00s) --- PASS: TestASNsValid/basic_valid (0.00s) --- PASS: TestASNsValid/private_ASN (0.00s) === RUN TestIsPrivateASN === RUN TestIsPrivateASN/13335->false === RUN TestIsPrivateASN/64513->true === RUN TestIsPrivateASN/4206942069->true --- PASS: TestIsPrivateASN (0.00s) --- PASS: TestIsPrivateASN/13335->false (0.00s) --- PASS: TestIsPrivateASN/64513->true (0.00s) --- PASS: TestIsPrivateASN/4206942069->true (0.00s) === RUN TestExpressionOrListMarshalJSON === RUN TestExpressionOrListMarshalJSON/single_expression === RUN TestExpressionOrListMarshalJSON/all === RUN TestExpressionOrListMarshalJSON/all_one === RUN TestExpressionOrListMarshalJSON/any === RUN TestExpressionOrListMarshalJSON/any_one --- PASS: TestExpressionOrListMarshalJSON (0.00s) --- PASS: TestExpressionOrListMarshalJSON/single_expression (0.00s) --- PASS: TestExpressionOrListMarshalJSON/all (0.00s) --- PASS: TestExpressionOrListMarshalJSON/all_one (0.00s) --- PASS: TestExpressionOrListMarshalJSON/any (0.00s) --- PASS: TestExpressionOrListMarshalJSON/any_one (0.00s) === RUN TestExpressionOrListMarshalYAML === RUN TestExpressionOrListMarshalYAML/single_expression === RUN TestExpressionOrListMarshalYAML/all === RUN TestExpressionOrListMarshalYAML/all_one === RUN TestExpressionOrListMarshalYAML/any === RUN TestExpressionOrListMarshalYAML/any_one --- PASS: TestExpressionOrListMarshalYAML (0.00s) --- PASS: TestExpressionOrListMarshalYAML/single_expression (0.00s) --- PASS: TestExpressionOrListMarshalYAML/all (0.00s) --- PASS: TestExpressionOrListMarshalYAML/all_one (0.00s) --- PASS: TestExpressionOrListMarshalYAML/any (0.00s) --- PASS: TestExpressionOrListMarshalYAML/any_one (0.00s) === RUN TestExpressionOrListUnmarshalJSON === RUN TestExpressionOrListUnmarshalJSON/simple === RUN TestExpressionOrListUnmarshalJSON/object-and === RUN TestExpressionOrListUnmarshalJSON/object-or === RUN TestExpressionOrListUnmarshalJSON/both-or-and === RUN TestExpressionOrListUnmarshalJSON/expression-empty --- PASS: TestExpressionOrListUnmarshalJSON (0.00s) --- PASS: TestExpressionOrListUnmarshalJSON/simple (0.00s) --- PASS: TestExpressionOrListUnmarshalJSON/object-and (0.00s) --- PASS: TestExpressionOrListUnmarshalJSON/object-or (0.00s) --- PASS: TestExpressionOrListUnmarshalJSON/both-or-and (0.00s) --- PASS: TestExpressionOrListUnmarshalJSON/expression-empty (0.00s) === RUN TestExpressionOrListString === RUN TestExpressionOrListString/single_expression === RUN TestExpressionOrListString/all === RUN TestExpressionOrListString/all_with_&& === RUN TestExpressionOrListString/any === RUN TestExpressionOrListString/any_with_|| --- PASS: TestExpressionOrListString (0.00s) --- PASS: TestExpressionOrListString/single_expression (0.00s) --- PASS: TestExpressionOrListString/all (0.00s) --- PASS: TestExpressionOrListString/all_with_&& (0.00s) --- PASS: TestExpressionOrListString/any (0.00s) --- PASS: TestExpressionOrListString/any_with_|| (0.00s) === RUN TestGeoIPValid === RUN TestGeoIPValid/basic_valid === RUN TestGeoIPValid/invalid_country --- PASS: TestGeoIPValid (0.00s) --- PASS: TestGeoIPValid/basic_valid (0.00s) --- PASS: TestGeoIPValid/invalid_country (0.00s) === RUN TestImpressumValid === RUN TestImpressumValid/basic_happy_path === RUN TestImpressumValid/no_footer === RUN TestImpressumValid/page_not_valid --- PASS: TestImpressumValid (0.00s) --- PASS: TestImpressumValid/basic_happy_path (0.00s) --- PASS: TestImpressumValid/no_footer (0.00s) --- PASS: TestImpressumValid/page_not_valid (0.00s) === RUN TestLoggingValid === RUN TestLoggingValid/simple_happy === RUN TestLoggingValid/default_file_config === RUN TestLoggingValid/invalid_sink === RUN TestLoggingValid/missing_parameters === RUN TestLoggingValid/invalid_parameters === RUN TestLoggingValid/file_sink_with_no_filename === RUN TestLoggingValid/file_sink_with_negative_max_backups === RUN TestLoggingValid/file_sink_with_negative_max_age --- PASS: TestLoggingValid (0.00s) --- PASS: TestLoggingValid/simple_happy (0.00s) --- PASS: TestLoggingValid/default_file_config (0.00s) --- PASS: TestLoggingValid/invalid_sink (0.00s) --- PASS: TestLoggingValid/missing_parameters (0.00s) --- PASS: TestLoggingValid/invalid_parameters (0.00s) --- PASS: TestLoggingValid/file_sink_with_no_filename (0.00s) --- PASS: TestLoggingValid/file_sink_with_negative_max_backups (0.00s) --- PASS: TestLoggingValid/file_sink_with_negative_max_age (0.00s) === RUN TestOpenGraphFileConfigValid === RUN TestOpenGraphFileConfigValid/basic_happy_path === RUN TestOpenGraphFileConfigValid/basic_happy_path_with_default === RUN TestOpenGraphFileConfigValid/invalid_time_duration === RUN TestOpenGraphFileConfigValid/missing_og:title_in_defaults --- PASS: TestOpenGraphFileConfigValid (0.00s) --- PASS: TestOpenGraphFileConfigValid/basic_happy_path (0.00s) --- PASS: TestOpenGraphFileConfigValid/basic_happy_path_with_default (0.00s) --- PASS: TestOpenGraphFileConfigValid/invalid_time_duration (0.00s) --- PASS: TestOpenGraphFileConfigValid/missing_og:title_in_defaults (0.00s) === RUN TestThresholdValid === RUN TestThresholdValid/basic_allow === RUN TestThresholdValid/basic_challenge === RUN TestThresholdValid/no_name === RUN TestThresholdValid/no_expression === RUN TestThresholdValid/invalid_expression === RUN TestThresholdValid/invalid_action === RUN TestThresholdValid/challenge_action_but_no_challenge === RUN TestThresholdValid/challenge_invalid --- PASS: TestThresholdValid (0.00s) --- PASS: TestThresholdValid/basic_allow (0.00s) --- PASS: TestThresholdValid/basic_challenge (0.00s) --- PASS: TestThresholdValid/no_name (0.00s) --- PASS: TestThresholdValid/no_expression (0.00s) --- PASS: TestThresholdValid/invalid_expression (0.00s) --- PASS: TestThresholdValid/invalid_action (0.00s) --- PASS: TestThresholdValid/challenge_action_but_no_challenge (0.00s) --- PASS: TestThresholdValid/challenge_invalid (0.00s) === RUN TestDefaultThresholdsValid === RUN TestDefaultThresholdsValid/0_legacy-anubis-behaviour --- PASS: TestDefaultThresholdsValid (0.00s) --- PASS: TestDefaultThresholdsValid/0_legacy-anubis-behaviour (0.00s) === RUN TestLoadActuallyLoadsThresholds --- PASS: TestLoadActuallyLoadsThresholds (0.00s) === RUN TestBotValid === RUN TestBotValid/simple_user_agent === RUN TestBotValid/simple_path === RUN TestBotValid/no_rule_name === RUN TestBotValid/no_rule_matcher === RUN TestBotValid/both_user-agent_and_path === RUN TestBotValid/unknown_action === RUN TestBotValid/invalid_user_agent_regex === RUN TestBotValid/invalid_path_regex === RUN TestBotValid/invalid_headers_regex === RUN TestBotValid/challenge_difficulty_too_low === RUN TestBotValid/challenge_difficulty_too_high === RUN TestBotValid/invalid_cidr_range === RUN TestBotValid/only_filter_by_IP_range === RUN TestBotValid/filter_by_user_agent_and_IP_range === RUN TestBotValid/filter_by_path_and_IP_range === RUN TestBotValid/weight_rule_without_weight === RUN TestBotValid/weight_rule_with_weight_adjust --- PASS: TestBotValid (0.00s) --- PASS: TestBotValid/simple_user_agent (0.00s) --- PASS: TestBotValid/simple_path (0.00s) --- PASS: TestBotValid/no_rule_name (0.00s) --- PASS: TestBotValid/no_rule_matcher (0.00s) --- PASS: TestBotValid/both_user-agent_and_path (0.00s) --- PASS: TestBotValid/unknown_action (0.00s) --- PASS: TestBotValid/invalid_user_agent_regex (0.00s) --- PASS: TestBotValid/invalid_path_regex (0.00s) --- PASS: TestBotValid/invalid_headers_regex (0.00s) --- PASS: TestBotValid/challenge_difficulty_too_low (0.00s) --- PASS: TestBotValid/challenge_difficulty_too_high (0.00s) --- PASS: TestBotValid/invalid_cidr_range (0.00s) --- PASS: TestBotValid/only_filter_by_IP_range (0.00s) --- PASS: TestBotValid/filter_by_user_agent_and_IP_range (0.00s) --- PASS: TestBotValid/filter_by_path_and_IP_range (0.00s) --- PASS: TestBotValid/weight_rule_without_weight (0.00s) --- PASS: TestBotValid/weight_rule_with_weight_adjust (0.00s) === RUN TestConfigValidKnownGood === RUN TestConfigValidKnownGood/allow_everyone.json === RUN TestConfigValidKnownGood/allow_everyone.yaml === RUN TestConfigValidKnownGood/block_cf_workers.json === RUN TestConfigValidKnownGood/block_cf_workers.yaml === RUN TestConfigValidKnownGood/challenge_cloudflare.yaml === RUN TestConfigValidKnownGood/challengemozilla.json === RUN TestConfigValidKnownGood/challengemozilla.yaml === RUN TestConfigValidKnownGood/dns-ttl-custom.yaml === RUN TestConfigValidKnownGood/entropy.yaml === RUN TestConfigValidKnownGood/everything_blocked.json === RUN TestConfigValidKnownGood/everything_blocked.yaml === RUN TestConfigValidKnownGood/geoip_us.yaml === RUN TestConfigValidKnownGood/git_client.json === RUN TestConfigValidKnownGood/git_client.yaml === RUN TestConfigValidKnownGood/import_filesystem.json === RUN TestConfigValidKnownGood/import_filesystem.yaml === RUN TestConfigValidKnownGood/import_keep_internet_working.json === RUN TestConfigValidKnownGood/import_keep_internet_working.yaml === RUN TestConfigValidKnownGood/impressum.yaml === RUN TestConfigValidKnownGood/logging-file.yaml === RUN TestConfigValidKnownGood/logging-stdio.yaml === RUN TestConfigValidKnownGood/no-thresholds.yaml === RUN TestConfigValidKnownGood/old_xesite.json === RUN TestConfigValidKnownGood/opengraph_all_good.yaml === RUN TestConfigValidKnownGood/simple-weight.yaml === RUN TestConfigValidKnownGood/status-codes-paranoid.json === RUN TestConfigValidKnownGood/status-codes-paranoid.yaml === RUN TestConfigValidKnownGood/status-codes-rfc.json === RUN TestConfigValidKnownGood/status-codes-rfc.yaml === RUN TestConfigValidKnownGood/thresholds.yaml === RUN TestConfigValidKnownGood/weight-no-weight.yaml --- PASS: TestConfigValidKnownGood (0.01s) --- PASS: TestConfigValidKnownGood/allow_everyone.json (0.00s) --- PASS: TestConfigValidKnownGood/allow_everyone.yaml (0.00s) --- PASS: TestConfigValidKnownGood/block_cf_workers.json (0.00s) --- PASS: TestConfigValidKnownGood/block_cf_workers.yaml (0.00s) --- PASS: TestConfigValidKnownGood/challenge_cloudflare.yaml (0.00s) --- PASS: TestConfigValidKnownGood/challengemozilla.json (0.00s) --- PASS: TestConfigValidKnownGood/challengemozilla.yaml (0.00s) --- PASS: TestConfigValidKnownGood/dns-ttl-custom.yaml (0.00s) --- PASS: TestConfigValidKnownGood/entropy.yaml (0.00s) --- PASS: TestConfigValidKnownGood/everything_blocked.json (0.00s) --- PASS: TestConfigValidKnownGood/everything_blocked.yaml (0.00s) --- PASS: TestConfigValidKnownGood/geoip_us.yaml (0.00s) --- PASS: TestConfigValidKnownGood/git_client.json (0.00s) --- PASS: TestConfigValidKnownGood/git_client.yaml (0.00s) --- PASS: TestConfigValidKnownGood/import_filesystem.json (0.00s) --- PASS: TestConfigValidKnownGood/import_filesystem.yaml (0.00s) --- PASS: TestConfigValidKnownGood/import_keep_internet_working.json (0.00s) --- PASS: TestConfigValidKnownGood/import_keep_internet_working.yaml (0.00s) --- PASS: TestConfigValidKnownGood/impressum.yaml (0.00s) --- PASS: TestConfigValidKnownGood/logging-file.yaml (0.00s) --- PASS: TestConfigValidKnownGood/logging-stdio.yaml (0.00s) --- PASS: TestConfigValidKnownGood/no-thresholds.yaml (0.00s) --- PASS: TestConfigValidKnownGood/old_xesite.json (0.00s) --- PASS: TestConfigValidKnownGood/opengraph_all_good.yaml (0.00s) --- PASS: TestConfigValidKnownGood/simple-weight.yaml (0.00s) --- PASS: TestConfigValidKnownGood/status-codes-paranoid.json (0.00s) --- PASS: TestConfigValidKnownGood/status-codes-paranoid.yaml (0.00s) --- PASS: TestConfigValidKnownGood/status-codes-rfc.json (0.00s) --- PASS: TestConfigValidKnownGood/status-codes-rfc.yaml (0.00s) --- PASS: TestConfigValidKnownGood/thresholds.yaml (0.00s) --- PASS: TestConfigValidKnownGood/weight-no-weight.yaml (0.00s) === RUN TestImportStatement === RUN TestImportStatement/(data)/apps/allow-api-routes.yaml === RUN TestImportStatement/(data)/apps/bookstack-saml.yaml === RUN TestImportStatement/(data)/apps/gitea-rss-feeds.yaml === RUN TestImportStatement/(data)/apps/qualys-ssl-labs.yml === RUN TestImportStatement/(data)/apps/searx-checker.yml === RUN TestImportStatement/(data)/bots/_deny-pathological.yaml === RUN TestImportStatement/(data)/bots/aggressive-brazilian-scrapers.yaml === RUN TestImportStatement/(data)/bots/ai-catchall.yaml === RUN TestImportStatement/(data)/bots/ai-robots-txt.yaml === RUN TestImportStatement/(data)/bots/cloudflare-workers.yaml === RUN TestImportStatement/(data)/bots/custom-async-http-client.yaml === RUN TestImportStatement/(data)/bots/headless-browsers.yaml === RUN TestImportStatement/(data)/bots/irc-bots/archlinux-phrik.yaml === RUN TestImportStatement/(data)/bots/irc-bots/gentoo-chat.yaml === RUN TestImportStatement/(data)/bots/us-ai-scraper.yaml === RUN TestImportStatement/(data)/common/allow-api-like.yaml === RUN TestImportStatement/(data)/common/allow-private-addresses.yaml === RUN TestImportStatement/(data)/common/json-api.yaml === RUN TestImportStatement/(data)/common/keep-internet-working.yaml === RUN TestImportStatement/(data)/common/rfc-violations.yaml === RUN TestImportStatement/(data)/crawlers/_allow-good.yaml === RUN TestImportStatement/(data)/crawlers/ai-search.yaml === RUN TestImportStatement/(data)/crawlers/ai-training.yaml === RUN TestImportStatement/(data)/crawlers/alibaba-cloud.yaml === RUN TestImportStatement/(data)/crawlers/applebot.yaml === RUN TestImportStatement/(data)/crawlers/bingbot.yaml === RUN TestImportStatement/(data)/crawlers/commoncrawl.yaml === RUN TestImportStatement/(data)/crawlers/duckduckbot.yaml === RUN TestImportStatement/(data)/crawlers/googlebot.yaml === RUN TestImportStatement/(data)/crawlers/huawei-cloud.yaml === RUN TestImportStatement/(data)/crawlers/internet-archive.yaml === RUN TestImportStatement/(data)/crawlers/kagibot.yaml === RUN TestImportStatement/(data)/crawlers/marginalia.yaml === RUN TestImportStatement/(data)/crawlers/mojeekbot.yaml === RUN TestImportStatement/(data)/crawlers/openai-gptbot.yaml === RUN TestImportStatement/(data)/crawlers/openai-searchbot.yaml === RUN TestImportStatement/(data)/crawlers/qwantbot.yaml === RUN TestImportStatement/(data)/crawlers/tencent-cloud.yaml === RUN TestImportStatement/(data)/crawlers/yandexbot.yaml === RUN TestImportStatement/(data)/meta/ai-block-aggressive.yaml === RUN TestImportStatement/(data)/meta/ai-block-moderate.yaml === RUN TestImportStatement/(data)/meta/ai-block-permissive.yaml === RUN TestImportStatement/(data)/meta/default-config.yaml === RUN TestImportStatement/(data)/meta/messengers-preview.yaml --- PASS: TestImportStatement (0.03s) --- PASS: TestImportStatement/(data)/apps/allow-api-routes.yaml (0.00s) --- PASS: TestImportStatement/(data)/apps/bookstack-saml.yaml (0.00s) --- PASS: TestImportStatement/(data)/apps/gitea-rss-feeds.yaml (0.00s) --- PASS: TestImportStatement/(data)/apps/qualys-ssl-labs.yml (0.00s) --- PASS: TestImportStatement/(data)/apps/searx-checker.yml (0.00s) --- PASS: TestImportStatement/(data)/bots/_deny-pathological.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/aggressive-brazilian-scrapers.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/ai-catchall.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/ai-robots-txt.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/cloudflare-workers.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/custom-async-http-client.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/headless-browsers.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/irc-bots/archlinux-phrik.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/irc-bots/gentoo-chat.yaml (0.00s) --- PASS: TestImportStatement/(data)/bots/us-ai-scraper.yaml (0.00s) --- PASS: TestImportStatement/(data)/common/allow-api-like.yaml (0.00s) --- PASS: TestImportStatement/(data)/common/allow-private-addresses.yaml (0.00s) --- PASS: TestImportStatement/(data)/common/json-api.yaml (0.00s) --- PASS: TestImportStatement/(data)/common/keep-internet-working.yaml (0.00s) --- PASS: TestImportStatement/(data)/common/rfc-violations.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/_allow-good.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/ai-search.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/ai-training.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/alibaba-cloud.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/applebot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/bingbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/commoncrawl.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/duckduckbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/googlebot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/huawei-cloud.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/internet-archive.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/kagibot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/marginalia.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/mojeekbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/openai-gptbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/openai-searchbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/qwantbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/tencent-cloud.yaml (0.00s) --- PASS: TestImportStatement/(data)/crawlers/yandexbot.yaml (0.00s) --- PASS: TestImportStatement/(data)/meta/ai-block-aggressive.yaml (0.00s) --- PASS: TestImportStatement/(data)/meta/ai-block-moderate.yaml (0.00s) --- PASS: TestImportStatement/(data)/meta/ai-block-permissive.yaml (0.00s) --- PASS: TestImportStatement/(data)/meta/default-config.yaml (0.01s) --- PASS: TestImportStatement/(data)/meta/messengers-preview.yaml (0.00s) === RUN TestConfigValidBad === RUN TestConfigValidBad/badregexes.json config_test.go:318: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` bot 2: config: bot entry for "headers-bad" is not valid: config.Bot: must set either user_agent_regex, path_regex, headers_regex, or remote_addresses === RUN TestConfigValidBad/badregexes.yaml config_test.go:318: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` === RUN TestConfigValidBad/dns-ttl-custom.yaml config_test.go:318: can't parse policy config YAML testdata/bad/dns-ttl-custom.yaml: error unmarshaling JSON: while decoding JSON: json: cannot unmarshal string into Go struct field DnsTTL.dns_ttl.reverse of type int === RUN TestConfigValidBad/import_and_bot.json config_test.go:318: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestConfigValidBad/import_and_bot.yaml config_test.go:318: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestConfigValidBad/import_invalid_file.json config_test.go:318: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestConfigValidBad/import_invalid_file.yaml config_test.go:318: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestConfigValidBad/impressum-no-footer.yaml config_test.go:318: errors validating policy config testdata/bad/impressum-no-footer.yaml: config: missing value: impressum footer must be defined === RUN TestConfigValidBad/impressum-no-page-contents.yaml config_test.go:318: errors validating policy config testdata/bad/impressum-no-page-contents.yaml: config: missing value: impressum page title must be defined config: missing value: impressum body title must be defined === RUN TestConfigValidBad/invalid.json config_test.go:318: config is not valid: bot 0: config.BotOrImport: rule definition is invalid, you must set either bot rules or an import statement, not both === RUN TestConfigValidBad/invalid.yaml config_test.go:318: config is not valid: config: must define at least one (1) bot rule === RUN TestConfigValidBad/logging-invalid-sink.yaml config_test.go:318: config is not valid: config: must define at least one (1) bot rule config.Logging: invalid sink: sink nope is unknown to me === RUN TestConfigValidBad/logging-no-parameters.yaml config_test.go:318: config is not valid: config: must define at least one (1) bot rule config.Logging: missing value parameters in logging block logging file config is nil, why are you calling this? === RUN TestConfigValidBad/multiple_expression_types.json config_test.go:318: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestConfigValidBad/multiple_expression_types.yaml config_test.go:318: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestConfigValidBad/nobots.json config_test.go:318: config is not valid: config: must define at least one (1) bot rule === RUN TestConfigValidBad/nobots.yaml config_test.go:318: config is not valid: config: must define at least one (1) bot rule === RUN TestConfigValidBad/opengraph_bad_ttl.yaml config_test.go:318: config is not valid: config.OpenGraph: invalid OpenGraph configuration config.OpenGraph: ttl does not parse as a Duration, see https://pkg.go.dev/time#ParseDuration (formatted like 5m -> 5 minutes, 2h -> 2 hours, etc): ParseDuration("taco") returned: time: invalid duration "taco" === RUN TestConfigValidBad/regex_ends_newline.json config_test.go:318: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestConfigValidBad/regex_ends_newline.yaml config_test.go:318: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestConfigValidBad/status-codes-0.json config_test.go:318: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestConfigValidBad/status-codes-0.yaml config_test.go:318: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestConfigValidBad/threshold-challenge-without-challenge.yaml config_test.go:318: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestConfigValidBad/thresholds.yaml config_test.go:318: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestConfigValidBad/unparseable.json config_test.go:318: can't parse policy config YAML testdata/bad/unparseable.json: error converting YAML to JSON: yaml: did not find expected node content === RUN TestConfigValidBad/unparseable.yaml config_test.go:318: can't parse policy config YAML testdata/bad/unparseable.yaml: error converting YAML to JSON: yaml: did not find expected node content --- PASS: TestConfigValidBad (0.00s) --- PASS: TestConfigValidBad/badregexes.json (0.00s) --- PASS: TestConfigValidBad/badregexes.yaml (0.00s) --- PASS: TestConfigValidBad/dns-ttl-custom.yaml (0.00s) --- PASS: TestConfigValidBad/import_and_bot.json (0.00s) --- PASS: TestConfigValidBad/import_and_bot.yaml (0.00s) --- PASS: TestConfigValidBad/import_invalid_file.json (0.00s) --- PASS: TestConfigValidBad/import_invalid_file.yaml (0.00s) --- PASS: TestConfigValidBad/impressum-no-footer.yaml (0.00s) --- PASS: TestConfigValidBad/impressum-no-page-contents.yaml (0.00s) --- PASS: TestConfigValidBad/invalid.json (0.00s) --- PASS: TestConfigValidBad/invalid.yaml (0.00s) --- PASS: TestConfigValidBad/logging-invalid-sink.yaml (0.00s) --- PASS: TestConfigValidBad/logging-no-parameters.yaml (0.00s) --- PASS: TestConfigValidBad/multiple_expression_types.json (0.00s) --- PASS: TestConfigValidBad/multiple_expression_types.yaml (0.00s) --- PASS: TestConfigValidBad/nobots.json (0.00s) --- PASS: TestConfigValidBad/nobots.yaml (0.00s) --- PASS: TestConfigValidBad/opengraph_bad_ttl.yaml (0.00s) --- PASS: TestConfigValidBad/regex_ends_newline.json (0.00s) --- PASS: TestConfigValidBad/regex_ends_newline.yaml (0.00s) --- PASS: TestConfigValidBad/status-codes-0.json (0.00s) --- PASS: TestConfigValidBad/status-codes-0.yaml (0.00s) --- PASS: TestConfigValidBad/threshold-challenge-without-challenge.yaml (0.00s) --- PASS: TestConfigValidBad/thresholds.yaml (0.00s) --- PASS: TestConfigValidBad/unparseable.json (0.00s) --- PASS: TestConfigValidBad/unparseable.yaml (0.00s) === RUN TestBotConfigZero --- PASS: TestBotConfigZero (0.00s) === RUN TestStoreValid === RUN TestStoreValid/no_backend === RUN TestStoreValid/in-memory_backend === RUN TestStoreValid/bbolt_backend === RUN TestStoreValid/valkey_backend === RUN TestStoreValid/valkey_backend_no_URL === RUN TestStoreValid/valkey_backend_bad_URL === RUN TestStoreValid/bbolt_backend_no_path === RUN TestStoreValid/unknown_backend --- PASS: TestStoreValid (0.00s) --- PASS: TestStoreValid/no_backend (0.00s) --- PASS: TestStoreValid/in-memory_backend (0.00s) --- PASS: TestStoreValid/bbolt_backend (0.00s) --- PASS: TestStoreValid/valkey_backend (0.00s) --- PASS: TestStoreValid/valkey_backend_no_URL (0.00s) --- PASS: TestStoreValid/valkey_backend_bad_URL (0.00s) --- PASS: TestStoreValid/bbolt_backend_no_path (0.00s) --- PASS: TestStoreValid/unknown_backend (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/config 0.049s === RUN TestLocalizationService === RUN TestLocalizationService/de_localization === RUN TestLocalizationService/en_localization === RUN TestLocalizationService/es_localization === RUN TestLocalizationService/et_localization === RUN TestLocalizationService/fil_localization === RUN TestLocalizationService/fr_localization === RUN TestLocalizationService/is_localization === RUN TestLocalizationService/ja_localization === RUN TestLocalizationService/nb_localization === RUN TestLocalizationService/nl_localization === RUN TestLocalizationService/nn_localization === RUN TestLocalizationService/pt-BR_localization === RUN TestLocalizationService/ru_localization === RUN TestLocalizationService/sv_localization === RUN TestLocalizationService/tr_localization === RUN TestLocalizationService/uk_localization === RUN TestLocalizationService/vi_localization === RUN TestLocalizationService/zh-CN_localization === RUN TestLocalizationService/zh-TW_localization === RUN TestLocalizationService/All_required_keys_exist_in_de === RUN TestLocalizationService/All_required_keys_exist_in_en === RUN TestLocalizationService/All_required_keys_exist_in_es === RUN TestLocalizationService/All_required_keys_exist_in_et === RUN TestLocalizationService/All_required_keys_exist_in_fil === RUN TestLocalizationService/All_required_keys_exist_in_fr === RUN TestLocalizationService/All_required_keys_exist_in_is === RUN TestLocalizationService/All_required_keys_exist_in_ja === RUN TestLocalizationService/All_required_keys_exist_in_nb === RUN TestLocalizationService/All_required_keys_exist_in_nl === RUN TestLocalizationService/All_required_keys_exist_in_nn === RUN TestLocalizationService/All_required_keys_exist_in_pt-BR === RUN TestLocalizationService/All_required_keys_exist_in_ru === RUN TestLocalizationService/All_required_keys_exist_in_sv === RUN TestLocalizationService/All_required_keys_exist_in_tr === RUN TestLocalizationService/All_required_keys_exist_in_uk === RUN TestLocalizationService/All_required_keys_exist_in_vi === RUN TestLocalizationService/All_required_keys_exist_in_zh-CN === RUN TestLocalizationService/All_required_keys_exist_in_zh-TW --- PASS: TestLocalizationService (0.01s) --- PASS: TestLocalizationService/de_localization (0.00s) --- PASS: TestLocalizationService/en_localization (0.00s) --- PASS: TestLocalizationService/es_localization (0.00s) --- PASS: TestLocalizationService/et_localization (0.00s) --- PASS: TestLocalizationService/fil_localization (0.00s) --- PASS: TestLocalizationService/fr_localization (0.00s) --- PASS: TestLocalizationService/is_localization (0.00s) --- PASS: TestLocalizationService/ja_localization (0.00s) --- PASS: TestLocalizationService/nb_localization (0.00s) --- PASS: TestLocalizationService/nl_localization (0.00s) --- PASS: TestLocalizationService/nn_localization (0.00s) --- PASS: TestLocalizationService/pt-BR_localization (0.00s) --- PASS: TestLocalizationService/ru_localization (0.00s) --- PASS: TestLocalizationService/sv_localization (0.00s) --- PASS: TestLocalizationService/tr_localization (0.00s) --- PASS: TestLocalizationService/uk_localization (0.00s) --- PASS: TestLocalizationService/vi_localization (0.00s) --- PASS: TestLocalizationService/zh-CN_localization (0.00s) --- PASS: TestLocalizationService/zh-TW_localization (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_de (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_en (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_es (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_et (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_fil (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_fr (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_is (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_ja (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_nb (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_nl (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_nn (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_pt-BR (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_ru (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_sv (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_tr (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_uk (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_vi (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_zh-CN (0.00s) --- PASS: TestLocalizationService/All_required_keys_exist_in_zh-TW (0.00s) === RUN TestComprehensiveTranslations === RUN TestComprehensiveTranslations/cs === RUN TestComprehensiveTranslations/cs/access_denied === RUN TestComprehensiveTranslations/cs/ai_companies_explanation === RUN TestComprehensiveTranslations/cs/algorithm === RUN TestComprehensiveTranslations/cs/anubis_compromise === RUN TestComprehensiveTranslations/cs/authorization_required === RUN TestComprehensiveTranslations/cs/benchmark_requires_js === RUN TestComprehensiveTranslations/cs/benchmarking_anubis === RUN TestComprehensiveTranslations/cs/celphase === RUN TestComprehensiveTranslations/cs/client_error_browser === RUN TestComprehensiveTranslations/cs/compare === RUN TestComprehensiveTranslations/cs/connection_security === RUN TestComprehensiveTranslations/cs/contact_webmaster === RUN TestComprehensiveTranslations/cs/cookies_disabled === RUN TestComprehensiveTranslations/cs/difficulty === RUN TestComprehensiveTranslations/cs/dronebl_entry === RUN TestComprehensiveTranslations/cs/failed_to_sign_jwt === RUN TestComprehensiveTranslations/cs/go_home === RUN TestComprehensiveTranslations/cs/hack_purpose === RUN TestComprehensiveTranslations/cs/internal_server_error === RUN TestComprehensiveTranslations/cs/invalid_invocation === RUN TestComprehensiveTranslations/cs/invalid_redirect === RUN TestComprehensiveTranslations/cs/iters === RUN TestComprehensiveTranslations/cs/iters_a === RUN TestComprehensiveTranslations/cs/iters_b === RUN TestComprehensiveTranslations/cs/javascript_required === RUN TestComprehensiveTranslations/cs/js_calculating === RUN TestComprehensiveTranslations/cs/js_calculating_difficulty === RUN TestComprehensiveTranslations/cs/js_calculation_error === RUN TestComprehensiveTranslations/cs/js_calculation_error_msg === RUN TestComprehensiveTranslations/cs/js_challenge_error === RUN TestComprehensiveTranslations/cs/js_challenge_error_msg === RUN TestComprehensiveTranslations/cs/js_context_not_secure === RUN TestComprehensiveTranslations/cs/js_context_not_secure_msg === RUN TestComprehensiveTranslations/cs/js_cookies_error === RUN TestComprehensiveTranslations/cs/js_done_took === RUN TestComprehensiveTranslations/cs/js_finished_reading === RUN TestComprehensiveTranslations/cs/js_iterations === RUN TestComprehensiveTranslations/cs/js_missing_feature === RUN TestComprehensiveTranslations/cs/js_speed === RUN TestComprehensiveTranslations/cs/js_success === RUN TestComprehensiveTranslations/cs/js_verification_longer === RUN TestComprehensiveTranslations/cs/js_web_crypto_error === RUN TestComprehensiveTranslations/cs/js_web_workers_error === RUN TestComprehensiveTranslations/cs/jshelter_note === RUN TestComprehensiveTranslations/cs/loading === RUN TestComprehensiveTranslations/cs/made_with === RUN TestComprehensiveTranslations/cs/making_sure_not_bot === RUN TestComprehensiveTranslations/cs/mascot_design === RUN TestComprehensiveTranslations/cs/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/cs/oh_noes === RUN TestComprehensiveTranslations/cs/protected_by === RUN TestComprehensiveTranslations/cs/protected_from === RUN TestComprehensiveTranslations/cs/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/cs/redirect_not_parseable === RUN TestComprehensiveTranslations/cs/see_dronebl_lookup === RUN TestComprehensiveTranslations/cs/simplified_explanation === RUN TestComprehensiveTranslations/cs/static_check_endpoint === RUN TestComprehensiveTranslations/cs/time === RUN TestComprehensiveTranslations/cs/time_a === RUN TestComprehensiveTranslations/cs/time_b === RUN TestComprehensiveTranslations/cs/try_again === RUN TestComprehensiveTranslations/cs/version_info === RUN TestComprehensiveTranslations/cs/why_am_i_seeing === RUN TestComprehensiveTranslations/cs/you_are_not_a_bot === RUN TestComprehensiveTranslations/de === RUN TestComprehensiveTranslations/de/access_denied === RUN TestComprehensiveTranslations/de/ai_companies_explanation === RUN TestComprehensiveTranslations/de/algorithm === RUN TestComprehensiveTranslations/de/anubis_compromise === RUN TestComprehensiveTranslations/de/authorization_required === RUN TestComprehensiveTranslations/de/benchmark_requires_js === RUN TestComprehensiveTranslations/de/benchmarking_anubis === RUN TestComprehensiveTranslations/de/celphase === RUN TestComprehensiveTranslations/de/client_error_browser === RUN TestComprehensiveTranslations/de/compare === RUN TestComprehensiveTranslations/de/connection_security === RUN TestComprehensiveTranslations/de/contact_webmaster === RUN TestComprehensiveTranslations/de/cookies_disabled === RUN TestComprehensiveTranslations/de/difficulty === RUN TestComprehensiveTranslations/de/dronebl_entry === RUN TestComprehensiveTranslations/de/failed_to_sign_jwt === RUN TestComprehensiveTranslations/de/go_home === RUN TestComprehensiveTranslations/de/hack_purpose === RUN TestComprehensiveTranslations/de/internal_server_error === RUN TestComprehensiveTranslations/de/invalid_invocation === RUN TestComprehensiveTranslations/de/invalid_redirect === RUN TestComprehensiveTranslations/de/iters === RUN TestComprehensiveTranslations/de/iters_a === RUN TestComprehensiveTranslations/de/iters_b === RUN TestComprehensiveTranslations/de/javascript_required === RUN TestComprehensiveTranslations/de/js_calculating === RUN TestComprehensiveTranslations/de/js_calculating_difficulty === RUN TestComprehensiveTranslations/de/js_calculation_error === RUN TestComprehensiveTranslations/de/js_calculation_error_msg === RUN TestComprehensiveTranslations/de/js_challenge_error === RUN TestComprehensiveTranslations/de/js_challenge_error_msg === RUN TestComprehensiveTranslations/de/js_context_not_secure === RUN TestComprehensiveTranslations/de/js_context_not_secure_msg === RUN TestComprehensiveTranslations/de/js_cookies_error === RUN TestComprehensiveTranslations/de/js_done_took === RUN TestComprehensiveTranslations/de/js_finished_reading === RUN TestComprehensiveTranslations/de/js_iterations === RUN TestComprehensiveTranslations/de/js_missing_feature === RUN TestComprehensiveTranslations/de/js_speed === RUN TestComprehensiveTranslations/de/js_success === RUN TestComprehensiveTranslations/de/js_verification_longer === RUN TestComprehensiveTranslations/de/js_web_crypto_error === RUN TestComprehensiveTranslations/de/js_web_workers_error === RUN TestComprehensiveTranslations/de/jshelter_note === RUN TestComprehensiveTranslations/de/loading === RUN TestComprehensiveTranslations/de/made_with === RUN TestComprehensiveTranslations/de/making_sure_not_bot === RUN TestComprehensiveTranslations/de/mascot_design === RUN TestComprehensiveTranslations/de/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/de/oh_noes === RUN TestComprehensiveTranslations/de/protected_by === RUN TestComprehensiveTranslations/de/protected_from === RUN TestComprehensiveTranslations/de/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/de/redirect_not_parseable === RUN TestComprehensiveTranslations/de/see_dronebl_lookup === RUN TestComprehensiveTranslations/de/simplified_explanation === RUN TestComprehensiveTranslations/de/static_check_endpoint === RUN TestComprehensiveTranslations/de/time === RUN TestComprehensiveTranslations/de/time_a === RUN TestComprehensiveTranslations/de/time_b === RUN TestComprehensiveTranslations/de/try_again === RUN TestComprehensiveTranslations/de/version_info === RUN TestComprehensiveTranslations/de/why_am_i_seeing === RUN TestComprehensiveTranslations/de/you_are_not_a_bot === RUN TestComprehensiveTranslations/en === RUN TestComprehensiveTranslations/en/access_denied === RUN TestComprehensiveTranslations/en/ai_companies_explanation === RUN TestComprehensiveTranslations/en/algorithm === RUN TestComprehensiveTranslations/en/anubis_compromise === RUN TestComprehensiveTranslations/en/authorization_required === RUN TestComprehensiveTranslations/en/benchmark_requires_js === RUN TestComprehensiveTranslations/en/benchmarking_anubis === RUN TestComprehensiveTranslations/en/celphase === RUN TestComprehensiveTranslations/en/client_error_browser === RUN TestComprehensiveTranslations/en/compare === RUN TestComprehensiveTranslations/en/connection_security === RUN TestComprehensiveTranslations/en/contact_webmaster === RUN TestComprehensiveTranslations/en/cookies_disabled === RUN TestComprehensiveTranslations/en/difficulty === RUN TestComprehensiveTranslations/en/dronebl_entry === RUN TestComprehensiveTranslations/en/failed_to_sign_jwt === RUN TestComprehensiveTranslations/en/go_home === RUN TestComprehensiveTranslations/en/hack_purpose === RUN TestComprehensiveTranslations/en/internal_server_error === RUN TestComprehensiveTranslations/en/invalid_invocation === RUN TestComprehensiveTranslations/en/invalid_redirect === RUN TestComprehensiveTranslations/en/iters === RUN TestComprehensiveTranslations/en/iters_a === RUN TestComprehensiveTranslations/en/iters_b === RUN TestComprehensiveTranslations/en/javascript_required === RUN TestComprehensiveTranslations/en/js_calculating === RUN TestComprehensiveTranslations/en/js_calculating_difficulty === RUN TestComprehensiveTranslations/en/js_calculation_error === RUN TestComprehensiveTranslations/en/js_calculation_error_msg === RUN TestComprehensiveTranslations/en/js_challenge_error === RUN TestComprehensiveTranslations/en/js_challenge_error_msg === RUN TestComprehensiveTranslations/en/js_context_not_secure === RUN TestComprehensiveTranslations/en/js_context_not_secure_msg === RUN TestComprehensiveTranslations/en/js_cookies_error === RUN TestComprehensiveTranslations/en/js_done_took === RUN TestComprehensiveTranslations/en/js_finished_reading === RUN TestComprehensiveTranslations/en/js_iterations === RUN TestComprehensiveTranslations/en/js_missing_feature === RUN TestComprehensiveTranslations/en/js_speed === RUN TestComprehensiveTranslations/en/js_success === RUN TestComprehensiveTranslations/en/js_verification_longer === RUN TestComprehensiveTranslations/en/js_web_crypto_error === RUN TestComprehensiveTranslations/en/js_web_workers_error === RUN TestComprehensiveTranslations/en/jshelter_note === RUN TestComprehensiveTranslations/en/loading === RUN TestComprehensiveTranslations/en/made_with === RUN TestComprehensiveTranslations/en/making_sure_not_bot === RUN TestComprehensiveTranslations/en/mascot_design === RUN TestComprehensiveTranslations/en/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/en/oh_noes === RUN TestComprehensiveTranslations/en/protected_by === RUN TestComprehensiveTranslations/en/protected_from === RUN TestComprehensiveTranslations/en/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/en/redirect_not_parseable === RUN TestComprehensiveTranslations/en/see_dronebl_lookup === RUN TestComprehensiveTranslations/en/simplified_explanation === RUN TestComprehensiveTranslations/en/static_check_endpoint === RUN TestComprehensiveTranslations/en/time === RUN TestComprehensiveTranslations/en/time_a === RUN TestComprehensiveTranslations/en/time_b === RUN TestComprehensiveTranslations/en/try_again === RUN TestComprehensiveTranslations/en/version_info === RUN TestComprehensiveTranslations/en/why_am_i_seeing === RUN TestComprehensiveTranslations/en/you_are_not_a_bot === RUN TestComprehensiveTranslations/es === RUN TestComprehensiveTranslations/es/access_denied === RUN TestComprehensiveTranslations/es/ai_companies_explanation === RUN TestComprehensiveTranslations/es/algorithm === RUN TestComprehensiveTranslations/es/anubis_compromise === RUN TestComprehensiveTranslations/es/authorization_required === RUN TestComprehensiveTranslations/es/benchmark_requires_js === RUN TestComprehensiveTranslations/es/benchmarking_anubis === RUN TestComprehensiveTranslations/es/celphase === RUN TestComprehensiveTranslations/es/client_error_browser === RUN TestComprehensiveTranslations/es/compare === RUN TestComprehensiveTranslations/es/connection_security === RUN TestComprehensiveTranslations/es/contact_webmaster === RUN TestComprehensiveTranslations/es/cookies_disabled === RUN TestComprehensiveTranslations/es/difficulty === RUN TestComprehensiveTranslations/es/dronebl_entry === RUN TestComprehensiveTranslations/es/failed_to_sign_jwt === RUN TestComprehensiveTranslations/es/go_home === RUN TestComprehensiveTranslations/es/hack_purpose === RUN TestComprehensiveTranslations/es/internal_server_error === RUN TestComprehensiveTranslations/es/invalid_invocation === RUN TestComprehensiveTranslations/es/invalid_redirect === RUN TestComprehensiveTranslations/es/iters === RUN TestComprehensiveTranslations/es/iters_a === RUN TestComprehensiveTranslations/es/iters_b === RUN TestComprehensiveTranslations/es/javascript_required === RUN TestComprehensiveTranslations/es/js_calculating === RUN TestComprehensiveTranslations/es/js_calculating_difficulty === RUN TestComprehensiveTranslations/es/js_calculation_error === RUN TestComprehensiveTranslations/es/js_calculation_error_msg === RUN TestComprehensiveTranslations/es/js_challenge_error === RUN TestComprehensiveTranslations/es/js_challenge_error_msg === RUN TestComprehensiveTranslations/es/js_context_not_secure === RUN TestComprehensiveTranslations/es/js_context_not_secure_msg === RUN TestComprehensiveTranslations/es/js_cookies_error === RUN TestComprehensiveTranslations/es/js_done_took === RUN TestComprehensiveTranslations/es/js_finished_reading === RUN TestComprehensiveTranslations/es/js_iterations === RUN TestComprehensiveTranslations/es/js_missing_feature === RUN TestComprehensiveTranslations/es/js_speed === RUN TestComprehensiveTranslations/es/js_success === RUN TestComprehensiveTranslations/es/js_verification_longer === RUN TestComprehensiveTranslations/es/js_web_crypto_error === RUN TestComprehensiveTranslations/es/js_web_workers_error === RUN TestComprehensiveTranslations/es/jshelter_note === RUN TestComprehensiveTranslations/es/loading === RUN TestComprehensiveTranslations/es/made_with === RUN TestComprehensiveTranslations/es/making_sure_not_bot === RUN TestComprehensiveTranslations/es/mascot_design === RUN TestComprehensiveTranslations/es/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/es/oh_noes === RUN TestComprehensiveTranslations/es/protected_by === RUN TestComprehensiveTranslations/es/protected_from === RUN TestComprehensiveTranslations/es/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/es/redirect_not_parseable === RUN TestComprehensiveTranslations/es/see_dronebl_lookup === RUN TestComprehensiveTranslations/es/simplified_explanation === RUN TestComprehensiveTranslations/es/static_check_endpoint === RUN TestComprehensiveTranslations/es/time === RUN TestComprehensiveTranslations/es/time_a === RUN TestComprehensiveTranslations/es/time_b === RUN TestComprehensiveTranslations/es/try_again === RUN TestComprehensiveTranslations/es/version_info === RUN TestComprehensiveTranslations/es/why_am_i_seeing === RUN TestComprehensiveTranslations/es/you_are_not_a_bot === RUN TestComprehensiveTranslations/et === RUN TestComprehensiveTranslations/et/access_denied === RUN TestComprehensiveTranslations/et/ai_companies_explanation === RUN TestComprehensiveTranslations/et/algorithm === RUN TestComprehensiveTranslations/et/anubis_compromise === RUN TestComprehensiveTranslations/et/authorization_required === RUN TestComprehensiveTranslations/et/benchmark_requires_js === RUN TestComprehensiveTranslations/et/benchmarking_anubis === RUN TestComprehensiveTranslations/et/celphase === RUN TestComprehensiveTranslations/et/client_error_browser === RUN TestComprehensiveTranslations/et/compare === RUN TestComprehensiveTranslations/et/connection_security === RUN TestComprehensiveTranslations/et/contact_webmaster === RUN TestComprehensiveTranslations/et/cookies_disabled === RUN TestComprehensiveTranslations/et/difficulty === RUN TestComprehensiveTranslations/et/dronebl_entry === RUN TestComprehensiveTranslations/et/failed_to_sign_jwt === RUN TestComprehensiveTranslations/et/go_home === RUN TestComprehensiveTranslations/et/hack_purpose === RUN TestComprehensiveTranslations/et/internal_server_error === RUN TestComprehensiveTranslations/et/invalid_invocation === RUN TestComprehensiveTranslations/et/invalid_redirect === RUN TestComprehensiveTranslations/et/iters === RUN TestComprehensiveTranslations/et/iters_a === RUN TestComprehensiveTranslations/et/iters_b === RUN TestComprehensiveTranslations/et/javascript_required === RUN TestComprehensiveTranslations/et/js_calculating === RUN TestComprehensiveTranslations/et/js_calculating_difficulty === RUN TestComprehensiveTranslations/et/js_calculation_error === RUN TestComprehensiveTranslations/et/js_calculation_error_msg === RUN TestComprehensiveTranslations/et/js_challenge_error === RUN TestComprehensiveTranslations/et/js_challenge_error_msg === RUN TestComprehensiveTranslations/et/js_context_not_secure === RUN TestComprehensiveTranslations/et/js_context_not_secure_msg === RUN TestComprehensiveTranslations/et/js_cookies_error === RUN TestComprehensiveTranslations/et/js_done_took === RUN TestComprehensiveTranslations/et/js_finished_reading === RUN TestComprehensiveTranslations/et/js_iterations === RUN TestComprehensiveTranslations/et/js_missing_feature === RUN TestComprehensiveTranslations/et/js_speed === RUN TestComprehensiveTranslations/et/js_success === RUN TestComprehensiveTranslations/et/js_verification_longer === RUN TestComprehensiveTranslations/et/js_web_crypto_error === RUN TestComprehensiveTranslations/et/js_web_workers_error === RUN TestComprehensiveTranslations/et/jshelter_note === RUN TestComprehensiveTranslations/et/loading === RUN TestComprehensiveTranslations/et/made_with === RUN TestComprehensiveTranslations/et/making_sure_not_bot === RUN TestComprehensiveTranslations/et/mascot_design === RUN TestComprehensiveTranslations/et/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/et/oh_noes === RUN TestComprehensiveTranslations/et/protected_by === RUN TestComprehensiveTranslations/et/protected_from === RUN TestComprehensiveTranslations/et/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/et/redirect_not_parseable === RUN TestComprehensiveTranslations/et/see_dronebl_lookup === RUN TestComprehensiveTranslations/et/simplified_explanation === RUN TestComprehensiveTranslations/et/static_check_endpoint === RUN TestComprehensiveTranslations/et/time === RUN TestComprehensiveTranslations/et/time_a === RUN TestComprehensiveTranslations/et/time_b === RUN TestComprehensiveTranslations/et/try_again === RUN TestComprehensiveTranslations/et/version_info === RUN TestComprehensiveTranslations/et/why_am_i_seeing === RUN TestComprehensiveTranslations/et/you_are_not_a_bot === RUN TestComprehensiveTranslations/fi === RUN TestComprehensiveTranslations/fi/access_denied === RUN TestComprehensiveTranslations/fi/ai_companies_explanation === RUN TestComprehensiveTranslations/fi/algorithm === RUN TestComprehensiveTranslations/fi/anubis_compromise === RUN TestComprehensiveTranslations/fi/authorization_required === RUN TestComprehensiveTranslations/fi/benchmark_requires_js === RUN TestComprehensiveTranslations/fi/benchmarking_anubis === RUN TestComprehensiveTranslations/fi/celphase === RUN TestComprehensiveTranslations/fi/client_error_browser === RUN TestComprehensiveTranslations/fi/compare === RUN TestComprehensiveTranslations/fi/connection_security === RUN TestComprehensiveTranslations/fi/contact_webmaster === RUN TestComprehensiveTranslations/fi/cookies_disabled === RUN TestComprehensiveTranslations/fi/difficulty === RUN TestComprehensiveTranslations/fi/dronebl_entry === RUN TestComprehensiveTranslations/fi/failed_to_sign_jwt === RUN TestComprehensiveTranslations/fi/go_home === RUN TestComprehensiveTranslations/fi/hack_purpose === RUN TestComprehensiveTranslations/fi/internal_server_error === RUN TestComprehensiveTranslations/fi/invalid_invocation === RUN TestComprehensiveTranslations/fi/invalid_redirect === RUN TestComprehensiveTranslations/fi/iters === RUN TestComprehensiveTranslations/fi/iters_a === RUN TestComprehensiveTranslations/fi/iters_b === RUN TestComprehensiveTranslations/fi/javascript_required === RUN TestComprehensiveTranslations/fi/js_calculating === RUN TestComprehensiveTranslations/fi/js_calculating_difficulty === RUN TestComprehensiveTranslations/fi/js_calculation_error === RUN TestComprehensiveTranslations/fi/js_calculation_error_msg === RUN TestComprehensiveTranslations/fi/js_challenge_error === RUN TestComprehensiveTranslations/fi/js_challenge_error_msg === RUN TestComprehensiveTranslations/fi/js_context_not_secure === RUN TestComprehensiveTranslations/fi/js_context_not_secure_msg === RUN TestComprehensiveTranslations/fi/js_cookies_error === RUN TestComprehensiveTranslations/fi/js_done_took === RUN TestComprehensiveTranslations/fi/js_finished_reading === RUN TestComprehensiveTranslations/fi/js_iterations === RUN TestComprehensiveTranslations/fi/js_missing_feature === RUN TestComprehensiveTranslations/fi/js_speed === RUN TestComprehensiveTranslations/fi/js_success === RUN TestComprehensiveTranslations/fi/js_verification_longer === RUN TestComprehensiveTranslations/fi/js_web_crypto_error === RUN TestComprehensiveTranslations/fi/js_web_workers_error === RUN TestComprehensiveTranslations/fi/jshelter_note === RUN TestComprehensiveTranslations/fi/loading === RUN TestComprehensiveTranslations/fi/made_with === RUN TestComprehensiveTranslations/fi/making_sure_not_bot === RUN TestComprehensiveTranslations/fi/mascot_design === RUN TestComprehensiveTranslations/fi/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/fi/oh_noes === RUN TestComprehensiveTranslations/fi/protected_by === RUN TestComprehensiveTranslations/fi/protected_from === RUN TestComprehensiveTranslations/fi/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/fi/redirect_not_parseable === RUN TestComprehensiveTranslations/fi/see_dronebl_lookup === RUN TestComprehensiveTranslations/fi/simplified_explanation === RUN TestComprehensiveTranslations/fi/static_check_endpoint === RUN TestComprehensiveTranslations/fi/time === RUN TestComprehensiveTranslations/fi/time_a === RUN TestComprehensiveTranslations/fi/time_b === RUN TestComprehensiveTranslations/fi/try_again === RUN TestComprehensiveTranslations/fi/version_info === RUN TestComprehensiveTranslations/fi/why_am_i_seeing === RUN TestComprehensiveTranslations/fi/you_are_not_a_bot === RUN TestComprehensiveTranslations/fil === RUN TestComprehensiveTranslations/fil/access_denied === RUN TestComprehensiveTranslations/fil/ai_companies_explanation === RUN TestComprehensiveTranslations/fil/algorithm === RUN TestComprehensiveTranslations/fil/anubis_compromise === RUN TestComprehensiveTranslations/fil/authorization_required === RUN TestComprehensiveTranslations/fil/benchmark_requires_js === RUN TestComprehensiveTranslations/fil/benchmarking_anubis === RUN TestComprehensiveTranslations/fil/celphase === RUN TestComprehensiveTranslations/fil/client_error_browser === RUN TestComprehensiveTranslations/fil/compare === RUN TestComprehensiveTranslations/fil/connection_security === RUN TestComprehensiveTranslations/fil/contact_webmaster === RUN TestComprehensiveTranslations/fil/cookies_disabled === RUN TestComprehensiveTranslations/fil/difficulty === RUN TestComprehensiveTranslations/fil/dronebl_entry === RUN TestComprehensiveTranslations/fil/failed_to_sign_jwt === RUN TestComprehensiveTranslations/fil/go_home === RUN TestComprehensiveTranslations/fil/hack_purpose === RUN TestComprehensiveTranslations/fil/internal_server_error === RUN TestComprehensiveTranslations/fil/invalid_invocation === RUN TestComprehensiveTranslations/fil/invalid_redirect === RUN TestComprehensiveTranslations/fil/iters === RUN TestComprehensiveTranslations/fil/iters_a === RUN TestComprehensiveTranslations/fil/iters_b === RUN TestComprehensiveTranslations/fil/javascript_required === RUN TestComprehensiveTranslations/fil/js_calculating === RUN TestComprehensiveTranslations/fil/js_calculating_difficulty === RUN TestComprehensiveTranslations/fil/js_calculation_error === RUN TestComprehensiveTranslations/fil/js_calculation_error_msg === RUN TestComprehensiveTranslations/fil/js_challenge_error === RUN TestComprehensiveTranslations/fil/js_challenge_error_msg === RUN TestComprehensiveTranslations/fil/js_context_not_secure === RUN TestComprehensiveTranslations/fil/js_context_not_secure_msg === RUN TestComprehensiveTranslations/fil/js_cookies_error === RUN TestComprehensiveTranslations/fil/js_done_took === RUN TestComprehensiveTranslations/fil/js_finished_reading === RUN TestComprehensiveTranslations/fil/js_iterations === RUN TestComprehensiveTranslations/fil/js_missing_feature === RUN TestComprehensiveTranslations/fil/js_speed === RUN TestComprehensiveTranslations/fil/js_success === RUN TestComprehensiveTranslations/fil/js_verification_longer === RUN TestComprehensiveTranslations/fil/js_web_crypto_error === RUN TestComprehensiveTranslations/fil/js_web_workers_error === RUN TestComprehensiveTranslations/fil/jshelter_note === RUN TestComprehensiveTranslations/fil/loading === RUN TestComprehensiveTranslations/fil/made_with === RUN TestComprehensiveTranslations/fil/making_sure_not_bot === RUN TestComprehensiveTranslations/fil/mascot_design === RUN TestComprehensiveTranslations/fil/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/fil/oh_noes === RUN TestComprehensiveTranslations/fil/protected_by === RUN TestComprehensiveTranslations/fil/protected_from === RUN TestComprehensiveTranslations/fil/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/fil/redirect_not_parseable === RUN TestComprehensiveTranslations/fil/see_dronebl_lookup === RUN TestComprehensiveTranslations/fil/simplified_explanation === RUN TestComprehensiveTranslations/fil/static_check_endpoint === RUN TestComprehensiveTranslations/fil/time === RUN TestComprehensiveTranslations/fil/time_a === RUN TestComprehensiveTranslations/fil/time_b === RUN TestComprehensiveTranslations/fil/try_again === RUN TestComprehensiveTranslations/fil/version_info === RUN TestComprehensiveTranslations/fil/why_am_i_seeing === RUN TestComprehensiveTranslations/fil/you_are_not_a_bot === RUN TestComprehensiveTranslations/fr === RUN TestComprehensiveTranslations/fr/access_denied === RUN TestComprehensiveTranslations/fr/ai_companies_explanation === RUN TestComprehensiveTranslations/fr/algorithm === RUN TestComprehensiveTranslations/fr/anubis_compromise === RUN TestComprehensiveTranslations/fr/authorization_required === RUN TestComprehensiveTranslations/fr/benchmark_requires_js === RUN TestComprehensiveTranslations/fr/benchmarking_anubis === RUN TestComprehensiveTranslations/fr/celphase === RUN TestComprehensiveTranslations/fr/client_error_browser === RUN TestComprehensiveTranslations/fr/compare === RUN TestComprehensiveTranslations/fr/connection_security === RUN TestComprehensiveTranslations/fr/contact_webmaster === RUN TestComprehensiveTranslations/fr/cookies_disabled === RUN TestComprehensiveTranslations/fr/difficulty === RUN TestComprehensiveTranslations/fr/dronebl_entry === RUN TestComprehensiveTranslations/fr/failed_to_sign_jwt === RUN TestComprehensiveTranslations/fr/go_home === RUN TestComprehensiveTranslations/fr/hack_purpose === RUN TestComprehensiveTranslations/fr/internal_server_error === RUN TestComprehensiveTranslations/fr/invalid_invocation === RUN TestComprehensiveTranslations/fr/invalid_redirect === RUN TestComprehensiveTranslations/fr/iters === RUN TestComprehensiveTranslations/fr/iters_a === RUN TestComprehensiveTranslations/fr/iters_b === RUN TestComprehensiveTranslations/fr/javascript_required === RUN TestComprehensiveTranslations/fr/js_calculating === RUN TestComprehensiveTranslations/fr/js_calculating_difficulty === RUN TestComprehensiveTranslations/fr/js_calculation_error === RUN TestComprehensiveTranslations/fr/js_calculation_error_msg === RUN TestComprehensiveTranslations/fr/js_challenge_error === RUN TestComprehensiveTranslations/fr/js_challenge_error_msg === RUN TestComprehensiveTranslations/fr/js_context_not_secure === RUN TestComprehensiveTranslations/fr/js_context_not_secure_msg === RUN TestComprehensiveTranslations/fr/js_cookies_error === RUN TestComprehensiveTranslations/fr/js_done_took === RUN TestComprehensiveTranslations/fr/js_finished_reading === RUN TestComprehensiveTranslations/fr/js_iterations === RUN TestComprehensiveTranslations/fr/js_missing_feature === RUN TestComprehensiveTranslations/fr/js_speed === RUN TestComprehensiveTranslations/fr/js_success === RUN TestComprehensiveTranslations/fr/js_verification_longer === RUN TestComprehensiveTranslations/fr/js_web_crypto_error === RUN TestComprehensiveTranslations/fr/js_web_workers_error === RUN TestComprehensiveTranslations/fr/jshelter_note === RUN TestComprehensiveTranslations/fr/loading === RUN TestComprehensiveTranslations/fr/made_with === RUN TestComprehensiveTranslations/fr/making_sure_not_bot === RUN TestComprehensiveTranslations/fr/mascot_design === RUN TestComprehensiveTranslations/fr/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/fr/oh_noes === RUN TestComprehensiveTranslations/fr/protected_by === RUN TestComprehensiveTranslations/fr/protected_from === RUN TestComprehensiveTranslations/fr/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/fr/redirect_not_parseable === RUN TestComprehensiveTranslations/fr/see_dronebl_lookup === RUN TestComprehensiveTranslations/fr/simplified_explanation === RUN TestComprehensiveTranslations/fr/static_check_endpoint === RUN TestComprehensiveTranslations/fr/time === RUN TestComprehensiveTranslations/fr/time_a === RUN TestComprehensiveTranslations/fr/time_b === RUN TestComprehensiveTranslations/fr/try_again === RUN TestComprehensiveTranslations/fr/version_info === RUN TestComprehensiveTranslations/fr/why_am_i_seeing === RUN TestComprehensiveTranslations/fr/you_are_not_a_bot === RUN TestComprehensiveTranslations/is === RUN TestComprehensiveTranslations/is/access_denied === RUN TestComprehensiveTranslations/is/ai_companies_explanation === RUN TestComprehensiveTranslations/is/algorithm === RUN TestComprehensiveTranslations/is/anubis_compromise === RUN TestComprehensiveTranslations/is/authorization_required === RUN TestComprehensiveTranslations/is/benchmark_requires_js === RUN TestComprehensiveTranslations/is/benchmarking_anubis === RUN TestComprehensiveTranslations/is/celphase === RUN TestComprehensiveTranslations/is/client_error_browser === RUN TestComprehensiveTranslations/is/compare === RUN TestComprehensiveTranslations/is/connection_security === RUN TestComprehensiveTranslations/is/contact_webmaster === RUN TestComprehensiveTranslations/is/cookies_disabled === RUN TestComprehensiveTranslations/is/difficulty === RUN TestComprehensiveTranslations/is/dronebl_entry === RUN TestComprehensiveTranslations/is/failed_to_sign_jwt === RUN TestComprehensiveTranslations/is/go_home === RUN TestComprehensiveTranslations/is/hack_purpose === RUN TestComprehensiveTranslations/is/internal_server_error === RUN TestComprehensiveTranslations/is/invalid_invocation === RUN TestComprehensiveTranslations/is/invalid_redirect === RUN TestComprehensiveTranslations/is/iters === RUN TestComprehensiveTranslations/is/iters_a === RUN TestComprehensiveTranslations/is/iters_b === RUN TestComprehensiveTranslations/is/javascript_required === RUN TestComprehensiveTranslations/is/js_calculating === RUN TestComprehensiveTranslations/is/js_calculating_difficulty === RUN TestComprehensiveTranslations/is/js_calculation_error === RUN TestComprehensiveTranslations/is/js_calculation_error_msg === RUN TestComprehensiveTranslations/is/js_challenge_error === RUN TestComprehensiveTranslations/is/js_challenge_error_msg === RUN TestComprehensiveTranslations/is/js_context_not_secure === RUN TestComprehensiveTranslations/is/js_context_not_secure_msg === RUN TestComprehensiveTranslations/is/js_cookies_error === RUN TestComprehensiveTranslations/is/js_done_took === RUN TestComprehensiveTranslations/is/js_finished_reading === RUN TestComprehensiveTranslations/is/js_iterations === RUN TestComprehensiveTranslations/is/js_missing_feature === RUN TestComprehensiveTranslations/is/js_speed === RUN TestComprehensiveTranslations/is/js_success === RUN TestComprehensiveTranslations/is/js_verification_longer === RUN TestComprehensiveTranslations/is/js_web_crypto_error === RUN TestComprehensiveTranslations/is/js_web_workers_error === RUN TestComprehensiveTranslations/is/jshelter_note === RUN TestComprehensiveTranslations/is/loading === RUN TestComprehensiveTranslations/is/made_with === RUN TestComprehensiveTranslations/is/making_sure_not_bot === RUN TestComprehensiveTranslations/is/mascot_design === RUN TestComprehensiveTranslations/is/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/is/oh_noes === RUN TestComprehensiveTranslations/is/protected_by === RUN TestComprehensiveTranslations/is/protected_from === RUN TestComprehensiveTranslations/is/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/is/redirect_not_parseable === RUN TestComprehensiveTranslations/is/see_dronebl_lookup === RUN TestComprehensiveTranslations/is/simplified_explanation === RUN TestComprehensiveTranslations/is/static_check_endpoint === RUN TestComprehensiveTranslations/is/time === RUN TestComprehensiveTranslations/is/time_a === RUN TestComprehensiveTranslations/is/time_b === RUN TestComprehensiveTranslations/is/try_again === RUN TestComprehensiveTranslations/is/version_info === RUN TestComprehensiveTranslations/is/why_am_i_seeing === RUN TestComprehensiveTranslations/is/you_are_not_a_bot === RUN TestComprehensiveTranslations/it === RUN TestComprehensiveTranslations/it/access_denied === RUN TestComprehensiveTranslations/it/ai_companies_explanation === RUN TestComprehensiveTranslations/it/algorithm === RUN TestComprehensiveTranslations/it/anubis_compromise === RUN TestComprehensiveTranslations/it/authorization_required === RUN TestComprehensiveTranslations/it/benchmark_requires_js === RUN TestComprehensiveTranslations/it/benchmarking_anubis === RUN TestComprehensiveTranslations/it/celphase === RUN TestComprehensiveTranslations/it/client_error_browser === RUN TestComprehensiveTranslations/it/compare === RUN TestComprehensiveTranslations/it/connection_security === RUN TestComprehensiveTranslations/it/contact_webmaster === RUN TestComprehensiveTranslations/it/cookies_disabled === RUN TestComprehensiveTranslations/it/difficulty === RUN TestComprehensiveTranslations/it/dronebl_entry === RUN TestComprehensiveTranslations/it/failed_to_sign_jwt === RUN TestComprehensiveTranslations/it/go_home === RUN TestComprehensiveTranslations/it/hack_purpose === RUN TestComprehensiveTranslations/it/internal_server_error === RUN TestComprehensiveTranslations/it/invalid_invocation === RUN TestComprehensiveTranslations/it/invalid_redirect === RUN TestComprehensiveTranslations/it/iters === RUN TestComprehensiveTranslations/it/iters_a === RUN TestComprehensiveTranslations/it/iters_b === RUN TestComprehensiveTranslations/it/javascript_required === RUN TestComprehensiveTranslations/it/js_calculating === RUN TestComprehensiveTranslations/it/js_calculating_difficulty === RUN TestComprehensiveTranslations/it/js_calculation_error === RUN TestComprehensiveTranslations/it/js_calculation_error_msg === RUN TestComprehensiveTranslations/it/js_challenge_error === RUN TestComprehensiveTranslations/it/js_challenge_error_msg === RUN TestComprehensiveTranslations/it/js_context_not_secure === RUN TestComprehensiveTranslations/it/js_context_not_secure_msg === RUN TestComprehensiveTranslations/it/js_cookies_error === RUN TestComprehensiveTranslations/it/js_done_took === RUN TestComprehensiveTranslations/it/js_finished_reading === RUN TestComprehensiveTranslations/it/js_iterations === RUN TestComprehensiveTranslations/it/js_missing_feature === RUN TestComprehensiveTranslations/it/js_speed === RUN TestComprehensiveTranslations/it/js_success === RUN TestComprehensiveTranslations/it/js_verification_longer === RUN TestComprehensiveTranslations/it/js_web_crypto_error === RUN TestComprehensiveTranslations/it/js_web_workers_error === RUN TestComprehensiveTranslations/it/jshelter_note === RUN TestComprehensiveTranslations/it/loading === RUN TestComprehensiveTranslations/it/made_with === RUN TestComprehensiveTranslations/it/making_sure_not_bot === RUN TestComprehensiveTranslations/it/mascot_design === RUN TestComprehensiveTranslations/it/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/it/oh_noes === RUN TestComprehensiveTranslations/it/protected_by === RUN TestComprehensiveTranslations/it/protected_from === RUN TestComprehensiveTranslations/it/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/it/redirect_not_parseable === RUN TestComprehensiveTranslations/it/see_dronebl_lookup === RUN TestComprehensiveTranslations/it/simplified_explanation === RUN TestComprehensiveTranslations/it/static_check_endpoint === RUN TestComprehensiveTranslations/it/time === RUN TestComprehensiveTranslations/it/time_a === RUN TestComprehensiveTranslations/it/time_b === RUN TestComprehensiveTranslations/it/try_again === RUN TestComprehensiveTranslations/it/version_info === RUN TestComprehensiveTranslations/it/why_am_i_seeing === RUN TestComprehensiveTranslations/it/you_are_not_a_bot === RUN TestComprehensiveTranslations/ja === RUN TestComprehensiveTranslations/ja/access_denied === RUN TestComprehensiveTranslations/ja/ai_companies_explanation === RUN TestComprehensiveTranslations/ja/algorithm === RUN TestComprehensiveTranslations/ja/anubis_compromise === RUN TestComprehensiveTranslations/ja/authorization_required === RUN TestComprehensiveTranslations/ja/benchmark_requires_js === RUN TestComprehensiveTranslations/ja/benchmarking_anubis === RUN TestComprehensiveTranslations/ja/celphase === RUN TestComprehensiveTranslations/ja/client_error_browser === RUN TestComprehensiveTranslations/ja/compare === RUN TestComprehensiveTranslations/ja/connection_security === RUN TestComprehensiveTranslations/ja/contact_webmaster === RUN TestComprehensiveTranslations/ja/cookies_disabled === RUN TestComprehensiveTranslations/ja/difficulty === RUN TestComprehensiveTranslations/ja/dronebl_entry === RUN TestComprehensiveTranslations/ja/failed_to_sign_jwt === RUN TestComprehensiveTranslations/ja/go_home === RUN TestComprehensiveTranslations/ja/hack_purpose === RUN TestComprehensiveTranslations/ja/internal_server_error === RUN TestComprehensiveTranslations/ja/invalid_invocation === RUN TestComprehensiveTranslations/ja/invalid_redirect === RUN TestComprehensiveTranslations/ja/iters === RUN TestComprehensiveTranslations/ja/iters_a === RUN TestComprehensiveTranslations/ja/iters_b === RUN TestComprehensiveTranslations/ja/javascript_required === RUN TestComprehensiveTranslations/ja/js_calculating === RUN TestComprehensiveTranslations/ja/js_calculating_difficulty === RUN TestComprehensiveTranslations/ja/js_calculation_error === RUN TestComprehensiveTranslations/ja/js_calculation_error_msg === RUN TestComprehensiveTranslations/ja/js_challenge_error === RUN TestComprehensiveTranslations/ja/js_challenge_error_msg === RUN TestComprehensiveTranslations/ja/js_context_not_secure === RUN TestComprehensiveTranslations/ja/js_context_not_secure_msg === RUN TestComprehensiveTranslations/ja/js_cookies_error === RUN TestComprehensiveTranslations/ja/js_done_took === RUN TestComprehensiveTranslations/ja/js_finished_reading === RUN TestComprehensiveTranslations/ja/js_iterations === RUN TestComprehensiveTranslations/ja/js_missing_feature === RUN TestComprehensiveTranslations/ja/js_speed === RUN TestComprehensiveTranslations/ja/js_success === RUN TestComprehensiveTranslations/ja/js_verification_longer === RUN TestComprehensiveTranslations/ja/js_web_crypto_error === RUN TestComprehensiveTranslations/ja/js_web_workers_error === RUN TestComprehensiveTranslations/ja/jshelter_note === RUN TestComprehensiveTranslations/ja/loading === RUN TestComprehensiveTranslations/ja/made_with === RUN TestComprehensiveTranslations/ja/making_sure_not_bot === RUN TestComprehensiveTranslations/ja/mascot_design === RUN TestComprehensiveTranslations/ja/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/ja/oh_noes === RUN TestComprehensiveTranslations/ja/protected_by === RUN TestComprehensiveTranslations/ja/protected_from === RUN TestComprehensiveTranslations/ja/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/ja/redirect_not_parseable === RUN TestComprehensiveTranslations/ja/see_dronebl_lookup === RUN TestComprehensiveTranslations/ja/simplified_explanation === RUN TestComprehensiveTranslations/ja/static_check_endpoint === RUN TestComprehensiveTranslations/ja/time === RUN TestComprehensiveTranslations/ja/time_a === RUN TestComprehensiveTranslations/ja/time_b === RUN TestComprehensiveTranslations/ja/try_again === RUN TestComprehensiveTranslations/ja/version_info === RUN TestComprehensiveTranslations/ja/why_am_i_seeing === RUN TestComprehensiveTranslations/ja/you_are_not_a_bot === RUN TestComprehensiveTranslations/lt === RUN TestComprehensiveTranslations/lt/access_denied === RUN TestComprehensiveTranslations/lt/ai_companies_explanation === RUN TestComprehensiveTranslations/lt/algorithm === RUN TestComprehensiveTranslations/lt/anubis_compromise === RUN TestComprehensiveTranslations/lt/authorization_required === RUN TestComprehensiveTranslations/lt/benchmark_requires_js === RUN TestComprehensiveTranslations/lt/benchmarking_anubis === RUN TestComprehensiveTranslations/lt/celphase === RUN TestComprehensiveTranslations/lt/client_error_browser === RUN TestComprehensiveTranslations/lt/compare === RUN TestComprehensiveTranslations/lt/connection_security === RUN TestComprehensiveTranslations/lt/contact_webmaster === RUN TestComprehensiveTranslations/lt/cookies_disabled === RUN TestComprehensiveTranslations/lt/difficulty === RUN TestComprehensiveTranslations/lt/dronebl_entry === RUN TestComprehensiveTranslations/lt/failed_to_sign_jwt === RUN TestComprehensiveTranslations/lt/go_home === RUN TestComprehensiveTranslations/lt/hack_purpose === RUN TestComprehensiveTranslations/lt/internal_server_error === RUN TestComprehensiveTranslations/lt/invalid_invocation === RUN TestComprehensiveTranslations/lt/invalid_redirect === RUN TestComprehensiveTranslations/lt/iters === RUN TestComprehensiveTranslations/lt/iters_a === RUN TestComprehensiveTranslations/lt/iters_b === RUN TestComprehensiveTranslations/lt/javascript_required === RUN TestComprehensiveTranslations/lt/js_calculating === RUN TestComprehensiveTranslations/lt/js_calculating_difficulty === RUN TestComprehensiveTranslations/lt/js_calculation_error === RUN TestComprehensiveTranslations/lt/js_calculation_error_msg === RUN TestComprehensiveTranslations/lt/js_challenge_error === RUN TestComprehensiveTranslations/lt/js_challenge_error_msg === RUN TestComprehensiveTranslations/lt/js_context_not_secure === RUN TestComprehensiveTranslations/lt/js_context_not_secure_msg === RUN TestComprehensiveTranslations/lt/js_cookies_error === RUN TestComprehensiveTranslations/lt/js_done_took === RUN TestComprehensiveTranslations/lt/js_finished_reading === RUN TestComprehensiveTranslations/lt/js_iterations === RUN TestComprehensiveTranslations/lt/js_missing_feature === RUN TestComprehensiveTranslations/lt/js_speed === RUN TestComprehensiveTranslations/lt/js_success === RUN TestComprehensiveTranslations/lt/js_verification_longer === RUN TestComprehensiveTranslations/lt/js_web_crypto_error === RUN TestComprehensiveTranslations/lt/js_web_workers_error === RUN TestComprehensiveTranslations/lt/jshelter_note === RUN TestComprehensiveTranslations/lt/loading === RUN TestComprehensiveTranslations/lt/made_with === RUN TestComprehensiveTranslations/lt/making_sure_not_bot === RUN TestComprehensiveTranslations/lt/mascot_design === RUN TestComprehensiveTranslations/lt/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/lt/oh_noes === RUN TestComprehensiveTranslations/lt/protected_by === RUN TestComprehensiveTranslations/lt/protected_from === RUN TestComprehensiveTranslations/lt/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/lt/redirect_not_parseable === RUN TestComprehensiveTranslations/lt/see_dronebl_lookup === RUN TestComprehensiveTranslations/lt/simplified_explanation === RUN TestComprehensiveTranslations/lt/static_check_endpoint === RUN TestComprehensiveTranslations/lt/time === RUN TestComprehensiveTranslations/lt/time_a === RUN TestComprehensiveTranslations/lt/time_b === RUN TestComprehensiveTranslations/lt/try_again === RUN TestComprehensiveTranslations/lt/version_info === RUN TestComprehensiveTranslations/lt/why_am_i_seeing === RUN TestComprehensiveTranslations/lt/you_are_not_a_bot === RUN TestComprehensiveTranslations/nb === RUN TestComprehensiveTranslations/nb/access_denied === RUN TestComprehensiveTranslations/nb/ai_companies_explanation === RUN TestComprehensiveTranslations/nb/algorithm === RUN TestComprehensiveTranslations/nb/anubis_compromise === RUN TestComprehensiveTranslations/nb/authorization_required === RUN TestComprehensiveTranslations/nb/benchmark_requires_js === RUN TestComprehensiveTranslations/nb/benchmarking_anubis === RUN TestComprehensiveTranslations/nb/celphase === RUN TestComprehensiveTranslations/nb/client_error_browser === RUN TestComprehensiveTranslations/nb/compare === RUN TestComprehensiveTranslations/nb/connection_security === RUN TestComprehensiveTranslations/nb/contact_webmaster === RUN TestComprehensiveTranslations/nb/cookies_disabled === RUN TestComprehensiveTranslations/nb/difficulty === RUN TestComprehensiveTranslations/nb/dronebl_entry === RUN TestComprehensiveTranslations/nb/failed_to_sign_jwt === RUN TestComprehensiveTranslations/nb/go_home === RUN TestComprehensiveTranslations/nb/hack_purpose === RUN TestComprehensiveTranslations/nb/internal_server_error === RUN TestComprehensiveTranslations/nb/invalid_invocation === RUN TestComprehensiveTranslations/nb/invalid_redirect === RUN TestComprehensiveTranslations/nb/iters === RUN TestComprehensiveTranslations/nb/iters_a === RUN TestComprehensiveTranslations/nb/iters_b === RUN TestComprehensiveTranslations/nb/javascript_required === RUN TestComprehensiveTranslations/nb/js_calculating === RUN TestComprehensiveTranslations/nb/js_calculating_difficulty === RUN TestComprehensiveTranslations/nb/js_calculation_error === RUN TestComprehensiveTranslations/nb/js_calculation_error_msg === RUN TestComprehensiveTranslations/nb/js_challenge_error === RUN TestComprehensiveTranslations/nb/js_challenge_error_msg === RUN TestComprehensiveTranslations/nb/js_context_not_secure === RUN TestComprehensiveTranslations/nb/js_context_not_secure_msg === RUN TestComprehensiveTranslations/nb/js_cookies_error === RUN TestComprehensiveTranslations/nb/js_done_took === RUN TestComprehensiveTranslations/nb/js_finished_reading === RUN TestComprehensiveTranslations/nb/js_iterations === RUN TestComprehensiveTranslations/nb/js_missing_feature === RUN TestComprehensiveTranslations/nb/js_speed === RUN TestComprehensiveTranslations/nb/js_success === RUN TestComprehensiveTranslations/nb/js_verification_longer === RUN TestComprehensiveTranslations/nb/js_web_crypto_error === RUN TestComprehensiveTranslations/nb/js_web_workers_error === RUN TestComprehensiveTranslations/nb/jshelter_note === RUN TestComprehensiveTranslations/nb/loading === RUN TestComprehensiveTranslations/nb/made_with === RUN TestComprehensiveTranslations/nb/making_sure_not_bot === RUN TestComprehensiveTranslations/nb/mascot_design === RUN TestComprehensiveTranslations/nb/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/nb/oh_noes === RUN TestComprehensiveTranslations/nb/protected_by === RUN TestComprehensiveTranslations/nb/protected_from === RUN TestComprehensiveTranslations/nb/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/nb/redirect_not_parseable === RUN TestComprehensiveTranslations/nb/see_dronebl_lookup === RUN TestComprehensiveTranslations/nb/simplified_explanation === RUN TestComprehensiveTranslations/nb/static_check_endpoint === RUN TestComprehensiveTranslations/nb/time === RUN TestComprehensiveTranslations/nb/time_a === RUN TestComprehensiveTranslations/nb/time_b === RUN TestComprehensiveTranslations/nb/try_again === RUN TestComprehensiveTranslations/nb/version_info === RUN TestComprehensiveTranslations/nb/why_am_i_seeing === RUN TestComprehensiveTranslations/nb/you_are_not_a_bot === RUN TestComprehensiveTranslations/nl === RUN TestComprehensiveTranslations/nl/access_denied === RUN TestComprehensiveTranslations/nl/ai_companies_explanation === RUN TestComprehensiveTranslations/nl/algorithm === RUN TestComprehensiveTranslations/nl/anubis_compromise === RUN TestComprehensiveTranslations/nl/authorization_required === RUN TestComprehensiveTranslations/nl/benchmark_requires_js === RUN TestComprehensiveTranslations/nl/benchmarking_anubis === RUN TestComprehensiveTranslations/nl/celphase === RUN TestComprehensiveTranslations/nl/client_error_browser === RUN TestComprehensiveTranslations/nl/compare === RUN TestComprehensiveTranslations/nl/connection_security === RUN TestComprehensiveTranslations/nl/contact_webmaster === RUN TestComprehensiveTranslations/nl/cookies_disabled === RUN TestComprehensiveTranslations/nl/difficulty === RUN TestComprehensiveTranslations/nl/dronebl_entry === RUN TestComprehensiveTranslations/nl/failed_to_sign_jwt === RUN TestComprehensiveTranslations/nl/go_home === RUN TestComprehensiveTranslations/nl/hack_purpose === RUN TestComprehensiveTranslations/nl/internal_server_error === RUN TestComprehensiveTranslations/nl/invalid_invocation === RUN TestComprehensiveTranslations/nl/invalid_redirect === RUN TestComprehensiveTranslations/nl/iters === RUN TestComprehensiveTranslations/nl/iters_a === RUN TestComprehensiveTranslations/nl/iters_b === RUN TestComprehensiveTranslations/nl/javascript_required === RUN TestComprehensiveTranslations/nl/js_calculating === RUN TestComprehensiveTranslations/nl/js_calculating_difficulty === RUN TestComprehensiveTranslations/nl/js_calculation_error === RUN TestComprehensiveTranslations/nl/js_calculation_error_msg === RUN TestComprehensiveTranslations/nl/js_challenge_error === RUN TestComprehensiveTranslations/nl/js_challenge_error_msg === RUN TestComprehensiveTranslations/nl/js_context_not_secure === RUN TestComprehensiveTranslations/nl/js_context_not_secure_msg === RUN TestComprehensiveTranslations/nl/js_cookies_error === RUN TestComprehensiveTranslations/nl/js_done_took === RUN TestComprehensiveTranslations/nl/js_finished_reading === RUN TestComprehensiveTranslations/nl/js_iterations === RUN TestComprehensiveTranslations/nl/js_missing_feature === RUN TestComprehensiveTranslations/nl/js_speed === RUN TestComprehensiveTranslations/nl/js_success === RUN TestComprehensiveTranslations/nl/js_verification_longer === RUN TestComprehensiveTranslations/nl/js_web_crypto_error === RUN TestComprehensiveTranslations/nl/js_web_workers_error === RUN TestComprehensiveTranslations/nl/jshelter_note === RUN TestComprehensiveTranslations/nl/loading === RUN TestComprehensiveTranslations/nl/made_with === RUN TestComprehensiveTranslations/nl/making_sure_not_bot === RUN TestComprehensiveTranslations/nl/mascot_design === RUN TestComprehensiveTranslations/nl/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/nl/oh_noes === RUN TestComprehensiveTranslations/nl/protected_by === RUN TestComprehensiveTranslations/nl/protected_from === RUN TestComprehensiveTranslations/nl/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/nl/redirect_not_parseable === RUN TestComprehensiveTranslations/nl/see_dronebl_lookup === RUN TestComprehensiveTranslations/nl/simplified_explanation === RUN TestComprehensiveTranslations/nl/static_check_endpoint === RUN TestComprehensiveTranslations/nl/time === RUN TestComprehensiveTranslations/nl/time_a === RUN TestComprehensiveTranslations/nl/time_b === RUN TestComprehensiveTranslations/nl/try_again === RUN TestComprehensiveTranslations/nl/version_info === RUN TestComprehensiveTranslations/nl/why_am_i_seeing === RUN TestComprehensiveTranslations/nl/you_are_not_a_bot === RUN TestComprehensiveTranslations/nn === RUN TestComprehensiveTranslations/nn/access_denied === RUN TestComprehensiveTranslations/nn/ai_companies_explanation === RUN TestComprehensiveTranslations/nn/algorithm === RUN TestComprehensiveTranslations/nn/anubis_compromise === RUN TestComprehensiveTranslations/nn/authorization_required === RUN TestComprehensiveTranslations/nn/benchmark_requires_js === RUN TestComprehensiveTranslations/nn/benchmarking_anubis === RUN TestComprehensiveTranslations/nn/celphase === RUN TestComprehensiveTranslations/nn/client_error_browser === RUN TestComprehensiveTranslations/nn/compare === RUN TestComprehensiveTranslations/nn/connection_security === RUN TestComprehensiveTranslations/nn/contact_webmaster === RUN TestComprehensiveTranslations/nn/cookies_disabled === RUN TestComprehensiveTranslations/nn/difficulty === RUN TestComprehensiveTranslations/nn/dronebl_entry === RUN TestComprehensiveTranslations/nn/failed_to_sign_jwt === RUN TestComprehensiveTranslations/nn/go_home === RUN TestComprehensiveTranslations/nn/hack_purpose === RUN TestComprehensiveTranslations/nn/internal_server_error === RUN TestComprehensiveTranslations/nn/invalid_invocation === RUN TestComprehensiveTranslations/nn/invalid_redirect === RUN TestComprehensiveTranslations/nn/iters === RUN TestComprehensiveTranslations/nn/iters_a === RUN TestComprehensiveTranslations/nn/iters_b === RUN TestComprehensiveTranslations/nn/javascript_required === RUN TestComprehensiveTranslations/nn/js_calculating === RUN TestComprehensiveTranslations/nn/js_calculating_difficulty === RUN TestComprehensiveTranslations/nn/js_calculation_error === RUN TestComprehensiveTranslations/nn/js_calculation_error_msg === RUN TestComprehensiveTranslations/nn/js_challenge_error === RUN TestComprehensiveTranslations/nn/js_challenge_error_msg === RUN TestComprehensiveTranslations/nn/js_context_not_secure === RUN TestComprehensiveTranslations/nn/js_context_not_secure_msg === RUN TestComprehensiveTranslations/nn/js_cookies_error === RUN TestComprehensiveTranslations/nn/js_done_took === RUN TestComprehensiveTranslations/nn/js_finished_reading === RUN TestComprehensiveTranslations/nn/js_iterations === RUN TestComprehensiveTranslations/nn/js_missing_feature === RUN TestComprehensiveTranslations/nn/js_speed === RUN TestComprehensiveTranslations/nn/js_success === RUN TestComprehensiveTranslations/nn/js_verification_longer === RUN TestComprehensiveTranslations/nn/js_web_crypto_error === RUN TestComprehensiveTranslations/nn/js_web_workers_error === RUN TestComprehensiveTranslations/nn/jshelter_note === RUN TestComprehensiveTranslations/nn/loading === RUN TestComprehensiveTranslations/nn/made_with === RUN TestComprehensiveTranslations/nn/making_sure_not_bot === RUN TestComprehensiveTranslations/nn/mascot_design === RUN TestComprehensiveTranslations/nn/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/nn/oh_noes === RUN TestComprehensiveTranslations/nn/protected_by === RUN TestComprehensiveTranslations/nn/protected_from === RUN TestComprehensiveTranslations/nn/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/nn/redirect_not_parseable === RUN TestComprehensiveTranslations/nn/see_dronebl_lookup === RUN TestComprehensiveTranslations/nn/simplified_explanation === RUN TestComprehensiveTranslations/nn/static_check_endpoint === RUN TestComprehensiveTranslations/nn/time === RUN TestComprehensiveTranslations/nn/time_a === RUN TestComprehensiveTranslations/nn/time_b === RUN TestComprehensiveTranslations/nn/try_again === RUN TestComprehensiveTranslations/nn/version_info === RUN TestComprehensiveTranslations/nn/why_am_i_seeing === RUN TestComprehensiveTranslations/nn/you_are_not_a_bot === RUN TestComprehensiveTranslations/pt-BR === RUN TestComprehensiveTranslations/pt-BR/access_denied === RUN TestComprehensiveTranslations/pt-BR/ai_companies_explanation === RUN TestComprehensiveTranslations/pt-BR/algorithm === RUN TestComprehensiveTranslations/pt-BR/anubis_compromise === RUN TestComprehensiveTranslations/pt-BR/authorization_required === RUN TestComprehensiveTranslations/pt-BR/benchmark_requires_js === RUN TestComprehensiveTranslations/pt-BR/benchmarking_anubis === RUN TestComprehensiveTranslations/pt-BR/celphase === RUN TestComprehensiveTranslations/pt-BR/client_error_browser === RUN TestComprehensiveTranslations/pt-BR/compare === RUN TestComprehensiveTranslations/pt-BR/connection_security === RUN TestComprehensiveTranslations/pt-BR/contact_webmaster === RUN TestComprehensiveTranslations/pt-BR/cookies_disabled === RUN TestComprehensiveTranslations/pt-BR/difficulty === RUN TestComprehensiveTranslations/pt-BR/dronebl_entry === RUN TestComprehensiveTranslations/pt-BR/failed_to_sign_jwt === RUN TestComprehensiveTranslations/pt-BR/go_home === RUN TestComprehensiveTranslations/pt-BR/hack_purpose === RUN TestComprehensiveTranslations/pt-BR/internal_server_error === RUN TestComprehensiveTranslations/pt-BR/invalid_invocation === RUN TestComprehensiveTranslations/pt-BR/invalid_redirect === RUN TestComprehensiveTranslations/pt-BR/iters === RUN TestComprehensiveTranslations/pt-BR/iters_a === RUN TestComprehensiveTranslations/pt-BR/iters_b === RUN TestComprehensiveTranslations/pt-BR/javascript_required === RUN TestComprehensiveTranslations/pt-BR/js_calculating === RUN TestComprehensiveTranslations/pt-BR/js_calculating_difficulty === RUN TestComprehensiveTranslations/pt-BR/js_calculation_error === RUN TestComprehensiveTranslations/pt-BR/js_calculation_error_msg === RUN TestComprehensiveTranslations/pt-BR/js_challenge_error === RUN TestComprehensiveTranslations/pt-BR/js_challenge_error_msg === RUN TestComprehensiveTranslations/pt-BR/js_context_not_secure === RUN TestComprehensiveTranslations/pt-BR/js_context_not_secure_msg === RUN TestComprehensiveTranslations/pt-BR/js_cookies_error === RUN TestComprehensiveTranslations/pt-BR/js_done_took === RUN TestComprehensiveTranslations/pt-BR/js_finished_reading === RUN TestComprehensiveTranslations/pt-BR/js_iterations === RUN TestComprehensiveTranslations/pt-BR/js_missing_feature === RUN TestComprehensiveTranslations/pt-BR/js_speed === RUN TestComprehensiveTranslations/pt-BR/js_success === RUN TestComprehensiveTranslations/pt-BR/js_verification_longer === RUN TestComprehensiveTranslations/pt-BR/js_web_crypto_error === RUN TestComprehensiveTranslations/pt-BR/js_web_workers_error === RUN TestComprehensiveTranslations/pt-BR/jshelter_note === RUN TestComprehensiveTranslations/pt-BR/loading === RUN TestComprehensiveTranslations/pt-BR/made_with === RUN TestComprehensiveTranslations/pt-BR/making_sure_not_bot === RUN TestComprehensiveTranslations/pt-BR/mascot_design === RUN TestComprehensiveTranslations/pt-BR/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/pt-BR/oh_noes === RUN TestComprehensiveTranslations/pt-BR/protected_by === RUN TestComprehensiveTranslations/pt-BR/protected_from === RUN TestComprehensiveTranslations/pt-BR/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/pt-BR/redirect_not_parseable === RUN TestComprehensiveTranslations/pt-BR/see_dronebl_lookup === RUN TestComprehensiveTranslations/pt-BR/simplified_explanation === RUN TestComprehensiveTranslations/pt-BR/static_check_endpoint === RUN TestComprehensiveTranslations/pt-BR/time === RUN TestComprehensiveTranslations/pt-BR/time_a === RUN TestComprehensiveTranslations/pt-BR/time_b === RUN TestComprehensiveTranslations/pt-BR/try_again === RUN TestComprehensiveTranslations/pt-BR/version_info === RUN TestComprehensiveTranslations/pt-BR/why_am_i_seeing === RUN TestComprehensiveTranslations/pt-BR/you_are_not_a_bot === RUN TestComprehensiveTranslations/ru === RUN TestComprehensiveTranslations/ru/access_denied === RUN TestComprehensiveTranslations/ru/ai_companies_explanation === RUN TestComprehensiveTranslations/ru/algorithm === RUN TestComprehensiveTranslations/ru/anubis_compromise === RUN TestComprehensiveTranslations/ru/authorization_required === RUN TestComprehensiveTranslations/ru/benchmark_requires_js === RUN TestComprehensiveTranslations/ru/benchmarking_anubis === RUN TestComprehensiveTranslations/ru/celphase === RUN TestComprehensiveTranslations/ru/client_error_browser === RUN TestComprehensiveTranslations/ru/compare === RUN TestComprehensiveTranslations/ru/connection_security === RUN TestComprehensiveTranslations/ru/contact_webmaster === RUN TestComprehensiveTranslations/ru/cookies_disabled === RUN TestComprehensiveTranslations/ru/difficulty === RUN TestComprehensiveTranslations/ru/dronebl_entry === RUN TestComprehensiveTranslations/ru/failed_to_sign_jwt === RUN TestComprehensiveTranslations/ru/go_home === RUN TestComprehensiveTranslations/ru/hack_purpose === RUN TestComprehensiveTranslations/ru/internal_server_error === RUN TestComprehensiveTranslations/ru/invalid_invocation === RUN TestComprehensiveTranslations/ru/invalid_redirect === RUN TestComprehensiveTranslations/ru/iters === RUN TestComprehensiveTranslations/ru/iters_a === RUN TestComprehensiveTranslations/ru/iters_b === RUN TestComprehensiveTranslations/ru/javascript_required === RUN TestComprehensiveTranslations/ru/js_calculating === RUN TestComprehensiveTranslations/ru/js_calculating_difficulty === RUN TestComprehensiveTranslations/ru/js_calculation_error === RUN TestComprehensiveTranslations/ru/js_calculation_error_msg === RUN TestComprehensiveTranslations/ru/js_challenge_error === RUN TestComprehensiveTranslations/ru/js_challenge_error_msg === RUN TestComprehensiveTranslations/ru/js_context_not_secure === RUN TestComprehensiveTranslations/ru/js_context_not_secure_msg === RUN TestComprehensiveTranslations/ru/js_cookies_error === RUN TestComprehensiveTranslations/ru/js_done_took === RUN TestComprehensiveTranslations/ru/js_finished_reading === RUN TestComprehensiveTranslations/ru/js_iterations === RUN TestComprehensiveTranslations/ru/js_missing_feature === RUN TestComprehensiveTranslations/ru/js_speed === RUN TestComprehensiveTranslations/ru/js_success === RUN TestComprehensiveTranslations/ru/js_verification_longer === RUN TestComprehensiveTranslations/ru/js_web_crypto_error === RUN TestComprehensiveTranslations/ru/js_web_workers_error === RUN TestComprehensiveTranslations/ru/jshelter_note === RUN TestComprehensiveTranslations/ru/loading === RUN TestComprehensiveTranslations/ru/made_with === RUN TestComprehensiveTranslations/ru/making_sure_not_bot === RUN TestComprehensiveTranslations/ru/mascot_design === RUN TestComprehensiveTranslations/ru/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/ru/oh_noes === RUN TestComprehensiveTranslations/ru/protected_by === RUN TestComprehensiveTranslations/ru/protected_from === RUN TestComprehensiveTranslations/ru/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/ru/redirect_not_parseable === RUN TestComprehensiveTranslations/ru/see_dronebl_lookup === RUN TestComprehensiveTranslations/ru/simplified_explanation === RUN TestComprehensiveTranslations/ru/static_check_endpoint === RUN TestComprehensiveTranslations/ru/time === RUN TestComprehensiveTranslations/ru/time_a === RUN TestComprehensiveTranslations/ru/time_b === RUN TestComprehensiveTranslations/ru/try_again === RUN TestComprehensiveTranslations/ru/version_info === RUN TestComprehensiveTranslations/ru/why_am_i_seeing === RUN TestComprehensiveTranslations/ru/you_are_not_a_bot === RUN TestComprehensiveTranslations/tr === RUN TestComprehensiveTranslations/tr/access_denied === RUN TestComprehensiveTranslations/tr/ai_companies_explanation === RUN TestComprehensiveTranslations/tr/algorithm === RUN TestComprehensiveTranslations/tr/anubis_compromise === RUN TestComprehensiveTranslations/tr/authorization_required === RUN TestComprehensiveTranslations/tr/benchmark_requires_js === RUN TestComprehensiveTranslations/tr/benchmarking_anubis === RUN TestComprehensiveTranslations/tr/celphase === RUN TestComprehensiveTranslations/tr/client_error_browser === RUN TestComprehensiveTranslations/tr/compare === RUN TestComprehensiveTranslations/tr/connection_security === RUN TestComprehensiveTranslations/tr/contact_webmaster === RUN TestComprehensiveTranslations/tr/cookies_disabled === RUN TestComprehensiveTranslations/tr/difficulty === RUN TestComprehensiveTranslations/tr/dronebl_entry === RUN TestComprehensiveTranslations/tr/failed_to_sign_jwt === RUN TestComprehensiveTranslations/tr/go_home === RUN TestComprehensiveTranslations/tr/hack_purpose === RUN TestComprehensiveTranslations/tr/internal_server_error === RUN TestComprehensiveTranslations/tr/invalid_invocation === RUN TestComprehensiveTranslations/tr/invalid_redirect === RUN TestComprehensiveTranslations/tr/iters === RUN TestComprehensiveTranslations/tr/iters_a === RUN TestComprehensiveTranslations/tr/iters_b === RUN TestComprehensiveTranslations/tr/javascript_required === RUN TestComprehensiveTranslations/tr/js_calculating === RUN TestComprehensiveTranslations/tr/js_calculating_difficulty === RUN TestComprehensiveTranslations/tr/js_calculation_error === RUN TestComprehensiveTranslations/tr/js_calculation_error_msg === RUN TestComprehensiveTranslations/tr/js_challenge_error === RUN TestComprehensiveTranslations/tr/js_challenge_error_msg === RUN TestComprehensiveTranslations/tr/js_context_not_secure === RUN TestComprehensiveTranslations/tr/js_context_not_secure_msg === RUN TestComprehensiveTranslations/tr/js_cookies_error === RUN TestComprehensiveTranslations/tr/js_done_took === RUN TestComprehensiveTranslations/tr/js_finished_reading === RUN TestComprehensiveTranslations/tr/js_iterations === RUN TestComprehensiveTranslations/tr/js_missing_feature === RUN TestComprehensiveTranslations/tr/js_speed === RUN TestComprehensiveTranslations/tr/js_success === RUN TestComprehensiveTranslations/tr/js_verification_longer === RUN TestComprehensiveTranslations/tr/js_web_crypto_error === RUN TestComprehensiveTranslations/tr/js_web_workers_error === RUN TestComprehensiveTranslations/tr/jshelter_note === RUN TestComprehensiveTranslations/tr/loading === RUN TestComprehensiveTranslations/tr/made_with === RUN TestComprehensiveTranslations/tr/making_sure_not_bot === RUN TestComprehensiveTranslations/tr/mascot_design === RUN TestComprehensiveTranslations/tr/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/tr/oh_noes === RUN TestComprehensiveTranslations/tr/protected_by === RUN TestComprehensiveTranslations/tr/protected_from === RUN TestComprehensiveTranslations/tr/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/tr/redirect_not_parseable === RUN TestComprehensiveTranslations/tr/see_dronebl_lookup === RUN TestComprehensiveTranslations/tr/simplified_explanation === RUN TestComprehensiveTranslations/tr/static_check_endpoint === RUN TestComprehensiveTranslations/tr/time === RUN TestComprehensiveTranslations/tr/time_a === RUN TestComprehensiveTranslations/tr/time_b === RUN TestComprehensiveTranslations/tr/try_again === RUN TestComprehensiveTranslations/tr/version_info === RUN TestComprehensiveTranslations/tr/why_am_i_seeing === RUN TestComprehensiveTranslations/tr/you_are_not_a_bot === RUN TestComprehensiveTranslations/uk === RUN TestComprehensiveTranslations/uk/access_denied === RUN TestComprehensiveTranslations/uk/ai_companies_explanation === RUN TestComprehensiveTranslations/uk/algorithm === RUN TestComprehensiveTranslations/uk/anubis_compromise === RUN TestComprehensiveTranslations/uk/authorization_required === RUN TestComprehensiveTranslations/uk/benchmark_requires_js === RUN TestComprehensiveTranslations/uk/benchmarking_anubis === RUN TestComprehensiveTranslations/uk/celphase === RUN TestComprehensiveTranslations/uk/client_error_browser === RUN TestComprehensiveTranslations/uk/compare === RUN TestComprehensiveTranslations/uk/connection_security === RUN TestComprehensiveTranslations/uk/contact_webmaster === RUN TestComprehensiveTranslations/uk/cookies_disabled === RUN TestComprehensiveTranslations/uk/difficulty === RUN TestComprehensiveTranslations/uk/dronebl_entry === RUN TestComprehensiveTranslations/uk/failed_to_sign_jwt === RUN TestComprehensiveTranslations/uk/go_home === RUN TestComprehensiveTranslations/uk/hack_purpose === RUN TestComprehensiveTranslations/uk/internal_server_error === RUN TestComprehensiveTranslations/uk/invalid_invocation === RUN TestComprehensiveTranslations/uk/invalid_redirect === RUN TestComprehensiveTranslations/uk/iters === RUN TestComprehensiveTranslations/uk/iters_a === RUN TestComprehensiveTranslations/uk/iters_b === RUN TestComprehensiveTranslations/uk/javascript_required === RUN TestComprehensiveTranslations/uk/js_calculating === RUN TestComprehensiveTranslations/uk/js_calculating_difficulty === RUN TestComprehensiveTranslations/uk/js_calculation_error === RUN TestComprehensiveTranslations/uk/js_calculation_error_msg === RUN TestComprehensiveTranslations/uk/js_challenge_error === RUN TestComprehensiveTranslations/uk/js_challenge_error_msg === RUN TestComprehensiveTranslations/uk/js_context_not_secure === RUN TestComprehensiveTranslations/uk/js_context_not_secure_msg === RUN TestComprehensiveTranslations/uk/js_cookies_error === RUN TestComprehensiveTranslations/uk/js_done_took === RUN TestComprehensiveTranslations/uk/js_finished_reading === RUN TestComprehensiveTranslations/uk/js_iterations === RUN TestComprehensiveTranslations/uk/js_missing_feature === RUN TestComprehensiveTranslations/uk/js_speed === RUN TestComprehensiveTranslations/uk/js_success === RUN TestComprehensiveTranslations/uk/js_verification_longer === RUN TestComprehensiveTranslations/uk/js_web_crypto_error === RUN TestComprehensiveTranslations/uk/js_web_workers_error === RUN TestComprehensiveTranslations/uk/jshelter_note === RUN TestComprehensiveTranslations/uk/loading === RUN TestComprehensiveTranslations/uk/made_with === RUN TestComprehensiveTranslations/uk/making_sure_not_bot === RUN TestComprehensiveTranslations/uk/mascot_design === RUN TestComprehensiveTranslations/uk/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/uk/oh_noes === RUN TestComprehensiveTranslations/uk/protected_by === RUN TestComprehensiveTranslations/uk/protected_from === RUN TestComprehensiveTranslations/uk/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/uk/redirect_not_parseable === RUN TestComprehensiveTranslations/uk/see_dronebl_lookup === RUN TestComprehensiveTranslations/uk/simplified_explanation === RUN TestComprehensiveTranslations/uk/static_check_endpoint === RUN TestComprehensiveTranslations/uk/time === RUN TestComprehensiveTranslations/uk/time_a === RUN TestComprehensiveTranslations/uk/time_b === RUN TestComprehensiveTranslations/uk/try_again === RUN TestComprehensiveTranslations/uk/version_info === RUN TestComprehensiveTranslations/uk/why_am_i_seeing === RUN TestComprehensiveTranslations/uk/you_are_not_a_bot === RUN TestComprehensiveTranslations/vi === RUN TestComprehensiveTranslations/vi/access_denied === RUN TestComprehensiveTranslations/vi/ai_companies_explanation === RUN TestComprehensiveTranslations/vi/algorithm === RUN TestComprehensiveTranslations/vi/anubis_compromise === RUN TestComprehensiveTranslations/vi/authorization_required === RUN TestComprehensiveTranslations/vi/benchmark_requires_js === RUN TestComprehensiveTranslations/vi/benchmarking_anubis === RUN TestComprehensiveTranslations/vi/celphase === RUN TestComprehensiveTranslations/vi/client_error_browser === RUN TestComprehensiveTranslations/vi/compare === RUN TestComprehensiveTranslations/vi/connection_security === RUN TestComprehensiveTranslations/vi/contact_webmaster === RUN TestComprehensiveTranslations/vi/cookies_disabled === RUN TestComprehensiveTranslations/vi/difficulty === RUN TestComprehensiveTranslations/vi/dronebl_entry === RUN TestComprehensiveTranslations/vi/failed_to_sign_jwt === RUN TestComprehensiveTranslations/vi/go_home === RUN TestComprehensiveTranslations/vi/hack_purpose === RUN TestComprehensiveTranslations/vi/internal_server_error === RUN TestComprehensiveTranslations/vi/invalid_invocation === RUN TestComprehensiveTranslations/vi/invalid_redirect === RUN TestComprehensiveTranslations/vi/iters === RUN TestComprehensiveTranslations/vi/iters_a === RUN TestComprehensiveTranslations/vi/iters_b === RUN TestComprehensiveTranslations/vi/javascript_required === RUN TestComprehensiveTranslations/vi/js_calculating === RUN TestComprehensiveTranslations/vi/js_calculating_difficulty === RUN TestComprehensiveTranslations/vi/js_calculation_error === RUN TestComprehensiveTranslations/vi/js_calculation_error_msg === RUN TestComprehensiveTranslations/vi/js_challenge_error === RUN TestComprehensiveTranslations/vi/js_challenge_error_msg === RUN TestComprehensiveTranslations/vi/js_context_not_secure === RUN TestComprehensiveTranslations/vi/js_context_not_secure_msg === RUN TestComprehensiveTranslations/vi/js_cookies_error === RUN TestComprehensiveTranslations/vi/js_done_took === RUN TestComprehensiveTranslations/vi/js_finished_reading === RUN TestComprehensiveTranslations/vi/js_iterations === RUN TestComprehensiveTranslations/vi/js_missing_feature === RUN TestComprehensiveTranslations/vi/js_speed === RUN TestComprehensiveTranslations/vi/js_success === RUN TestComprehensiveTranslations/vi/js_verification_longer === RUN TestComprehensiveTranslations/vi/js_web_crypto_error === RUN TestComprehensiveTranslations/vi/js_web_workers_error === RUN TestComprehensiveTranslations/vi/jshelter_note === RUN TestComprehensiveTranslations/vi/loading === RUN TestComprehensiveTranslations/vi/made_with === RUN TestComprehensiveTranslations/vi/making_sure_not_bot === RUN TestComprehensiveTranslations/vi/mascot_design === RUN TestComprehensiveTranslations/vi/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/vi/oh_noes === RUN TestComprehensiveTranslations/vi/protected_by === RUN TestComprehensiveTranslations/vi/protected_from === RUN TestComprehensiveTranslations/vi/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/vi/redirect_not_parseable === RUN TestComprehensiveTranslations/vi/see_dronebl_lookup === RUN TestComprehensiveTranslations/vi/simplified_explanation === RUN TestComprehensiveTranslations/vi/static_check_endpoint === RUN TestComprehensiveTranslations/vi/time === RUN TestComprehensiveTranslations/vi/time_a === RUN TestComprehensiveTranslations/vi/time_b === RUN TestComprehensiveTranslations/vi/try_again === RUN TestComprehensiveTranslations/vi/version_info === RUN TestComprehensiveTranslations/vi/why_am_i_seeing === RUN TestComprehensiveTranslations/vi/you_are_not_a_bot === RUN TestComprehensiveTranslations/zh-CN === RUN TestComprehensiveTranslations/zh-CN/access_denied === RUN TestComprehensiveTranslations/zh-CN/ai_companies_explanation === RUN TestComprehensiveTranslations/zh-CN/algorithm === RUN TestComprehensiveTranslations/zh-CN/anubis_compromise === RUN TestComprehensiveTranslations/zh-CN/authorization_required === RUN TestComprehensiveTranslations/zh-CN/benchmark_requires_js === RUN TestComprehensiveTranslations/zh-CN/benchmarking_anubis === RUN TestComprehensiveTranslations/zh-CN/celphase === RUN TestComprehensiveTranslations/zh-CN/client_error_browser === RUN TestComprehensiveTranslations/zh-CN/compare === RUN TestComprehensiveTranslations/zh-CN/connection_security === RUN TestComprehensiveTranslations/zh-CN/contact_webmaster === RUN TestComprehensiveTranslations/zh-CN/cookies_disabled === RUN TestComprehensiveTranslations/zh-CN/difficulty === RUN TestComprehensiveTranslations/zh-CN/dronebl_entry === RUN TestComprehensiveTranslations/zh-CN/failed_to_sign_jwt === RUN TestComprehensiveTranslations/zh-CN/go_home === RUN TestComprehensiveTranslations/zh-CN/hack_purpose === RUN TestComprehensiveTranslations/zh-CN/internal_server_error === RUN TestComprehensiveTranslations/zh-CN/invalid_invocation === RUN TestComprehensiveTranslations/zh-CN/invalid_redirect === RUN TestComprehensiveTranslations/zh-CN/iters === RUN TestComprehensiveTranslations/zh-CN/iters_a === RUN TestComprehensiveTranslations/zh-CN/iters_b === RUN TestComprehensiveTranslations/zh-CN/javascript_required === RUN TestComprehensiveTranslations/zh-CN/js_calculating === RUN TestComprehensiveTranslations/zh-CN/js_calculating_difficulty === RUN TestComprehensiveTranslations/zh-CN/js_calculation_error === RUN TestComprehensiveTranslations/zh-CN/js_calculation_error_msg === RUN TestComprehensiveTranslations/zh-CN/js_challenge_error === RUN TestComprehensiveTranslations/zh-CN/js_challenge_error_msg === RUN TestComprehensiveTranslations/zh-CN/js_context_not_secure === RUN TestComprehensiveTranslations/zh-CN/js_context_not_secure_msg === RUN TestComprehensiveTranslations/zh-CN/js_cookies_error === RUN TestComprehensiveTranslations/zh-CN/js_done_took === RUN TestComprehensiveTranslations/zh-CN/js_finished_reading === RUN TestComprehensiveTranslations/zh-CN/js_iterations === RUN TestComprehensiveTranslations/zh-CN/js_missing_feature === RUN TestComprehensiveTranslations/zh-CN/js_speed === RUN TestComprehensiveTranslations/zh-CN/js_success === RUN TestComprehensiveTranslations/zh-CN/js_verification_longer === RUN TestComprehensiveTranslations/zh-CN/js_web_crypto_error === RUN TestComprehensiveTranslations/zh-CN/js_web_workers_error === RUN TestComprehensiveTranslations/zh-CN/jshelter_note === RUN TestComprehensiveTranslations/zh-CN/loading === RUN TestComprehensiveTranslations/zh-CN/made_with === RUN TestComprehensiveTranslations/zh-CN/making_sure_not_bot === RUN TestComprehensiveTranslations/zh-CN/mascot_design === RUN TestComprehensiveTranslations/zh-CN/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/zh-CN/oh_noes === RUN TestComprehensiveTranslations/zh-CN/protected_by === RUN TestComprehensiveTranslations/zh-CN/protected_from === RUN TestComprehensiveTranslations/zh-CN/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/zh-CN/redirect_not_parseable === RUN TestComprehensiveTranslations/zh-CN/see_dronebl_lookup === RUN TestComprehensiveTranslations/zh-CN/simplified_explanation === RUN TestComprehensiveTranslations/zh-CN/static_check_endpoint === RUN TestComprehensiveTranslations/zh-CN/time === RUN TestComprehensiveTranslations/zh-CN/time_a === RUN TestComprehensiveTranslations/zh-CN/time_b === RUN TestComprehensiveTranslations/zh-CN/try_again === RUN TestComprehensiveTranslations/zh-CN/version_info === RUN TestComprehensiveTranslations/zh-CN/why_am_i_seeing === RUN TestComprehensiveTranslations/zh-CN/you_are_not_a_bot === RUN TestComprehensiveTranslations/zh-TW === RUN TestComprehensiveTranslations/zh-TW/access_denied === RUN TestComprehensiveTranslations/zh-TW/ai_companies_explanation === RUN TestComprehensiveTranslations/zh-TW/algorithm === RUN TestComprehensiveTranslations/zh-TW/anubis_compromise === RUN TestComprehensiveTranslations/zh-TW/authorization_required === RUN TestComprehensiveTranslations/zh-TW/benchmark_requires_js === RUN TestComprehensiveTranslations/zh-TW/benchmarking_anubis === RUN TestComprehensiveTranslations/zh-TW/celphase === RUN TestComprehensiveTranslations/zh-TW/client_error_browser === RUN TestComprehensiveTranslations/zh-TW/compare === RUN TestComprehensiveTranslations/zh-TW/connection_security === RUN TestComprehensiveTranslations/zh-TW/contact_webmaster === RUN TestComprehensiveTranslations/zh-TW/cookies_disabled === RUN TestComprehensiveTranslations/zh-TW/difficulty === RUN TestComprehensiveTranslations/zh-TW/dronebl_entry === RUN TestComprehensiveTranslations/zh-TW/failed_to_sign_jwt === RUN TestComprehensiveTranslations/zh-TW/go_home === RUN TestComprehensiveTranslations/zh-TW/hack_purpose === RUN TestComprehensiveTranslations/zh-TW/internal_server_error === RUN TestComprehensiveTranslations/zh-TW/invalid_invocation === RUN TestComprehensiveTranslations/zh-TW/invalid_redirect === RUN TestComprehensiveTranslations/zh-TW/iters === RUN TestComprehensiveTranslations/zh-TW/iters_a === RUN TestComprehensiveTranslations/zh-TW/iters_b === RUN TestComprehensiveTranslations/zh-TW/javascript_required === RUN TestComprehensiveTranslations/zh-TW/js_calculating === RUN TestComprehensiveTranslations/zh-TW/js_calculating_difficulty === RUN TestComprehensiveTranslations/zh-TW/js_calculation_error === RUN TestComprehensiveTranslations/zh-TW/js_calculation_error_msg === RUN TestComprehensiveTranslations/zh-TW/js_challenge_error === RUN TestComprehensiveTranslations/zh-TW/js_challenge_error_msg === RUN TestComprehensiveTranslations/zh-TW/js_context_not_secure === RUN TestComprehensiveTranslations/zh-TW/js_context_not_secure_msg === RUN TestComprehensiveTranslations/zh-TW/js_cookies_error === RUN TestComprehensiveTranslations/zh-TW/js_done_took === RUN TestComprehensiveTranslations/zh-TW/js_finished_reading === RUN TestComprehensiveTranslations/zh-TW/js_iterations === RUN TestComprehensiveTranslations/zh-TW/js_missing_feature === RUN TestComprehensiveTranslations/zh-TW/js_speed === RUN TestComprehensiveTranslations/zh-TW/js_success === RUN TestComprehensiveTranslations/zh-TW/js_verification_longer === RUN TestComprehensiveTranslations/zh-TW/js_web_crypto_error === RUN TestComprehensiveTranslations/zh-TW/js_web_workers_error === RUN TestComprehensiveTranslations/zh-TW/jshelter_note === RUN TestComprehensiveTranslations/zh-TW/loading === RUN TestComprehensiveTranslations/zh-TW/made_with === RUN TestComprehensiveTranslations/zh-TW/making_sure_not_bot === RUN TestComprehensiveTranslations/zh-TW/mascot_design === RUN TestComprehensiveTranslations/zh-TW/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/zh-TW/oh_noes === RUN TestComprehensiveTranslations/zh-TW/protected_by === RUN TestComprehensiveTranslations/zh-TW/protected_from === RUN TestComprehensiveTranslations/zh-TW/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/zh-TW/redirect_not_parseable === RUN TestComprehensiveTranslations/zh-TW/see_dronebl_lookup === RUN TestComprehensiveTranslations/zh-TW/simplified_explanation === RUN TestComprehensiveTranslations/zh-TW/static_check_endpoint === RUN TestComprehensiveTranslations/zh-TW/time === RUN TestComprehensiveTranslations/zh-TW/time_a === RUN TestComprehensiveTranslations/zh-TW/time_b === RUN TestComprehensiveTranslations/zh-TW/try_again === RUN TestComprehensiveTranslations/zh-TW/version_info === RUN TestComprehensiveTranslations/zh-TW/why_am_i_seeing === RUN TestComprehensiveTranslations/zh-TW/you_are_not_a_bot === RUN TestComprehensiveTranslations/sv === RUN TestComprehensiveTranslations/sv/access_denied === RUN TestComprehensiveTranslations/sv/ai_companies_explanation === RUN TestComprehensiveTranslations/sv/algorithm === RUN TestComprehensiveTranslations/sv/anubis_compromise === RUN TestComprehensiveTranslations/sv/authorization_required === RUN TestComprehensiveTranslations/sv/benchmark_requires_js === RUN TestComprehensiveTranslations/sv/benchmarking_anubis === RUN TestComprehensiveTranslations/sv/celphase === RUN TestComprehensiveTranslations/sv/client_error_browser === RUN TestComprehensiveTranslations/sv/compare === RUN TestComprehensiveTranslations/sv/connection_security === RUN TestComprehensiveTranslations/sv/contact_webmaster === RUN TestComprehensiveTranslations/sv/cookies_disabled === RUN TestComprehensiveTranslations/sv/difficulty === RUN TestComprehensiveTranslations/sv/dronebl_entry === RUN TestComprehensiveTranslations/sv/failed_to_sign_jwt === RUN TestComprehensiveTranslations/sv/go_home === RUN TestComprehensiveTranslations/sv/hack_purpose === RUN TestComprehensiveTranslations/sv/internal_server_error === RUN TestComprehensiveTranslations/sv/invalid_invocation === RUN TestComprehensiveTranslations/sv/invalid_redirect === RUN TestComprehensiveTranslations/sv/iters === RUN TestComprehensiveTranslations/sv/iters_a === RUN TestComprehensiveTranslations/sv/iters_b === RUN TestComprehensiveTranslations/sv/javascript_required === RUN TestComprehensiveTranslations/sv/js_calculating === RUN TestComprehensiveTranslations/sv/js_calculating_difficulty === RUN TestComprehensiveTranslations/sv/js_calculation_error === RUN TestComprehensiveTranslations/sv/js_calculation_error_msg === RUN TestComprehensiveTranslations/sv/js_challenge_error === RUN TestComprehensiveTranslations/sv/js_challenge_error_msg === RUN TestComprehensiveTranslations/sv/js_context_not_secure === RUN TestComprehensiveTranslations/sv/js_context_not_secure_msg === RUN TestComprehensiveTranslations/sv/js_cookies_error === RUN TestComprehensiveTranslations/sv/js_done_took === RUN TestComprehensiveTranslations/sv/js_finished_reading === RUN TestComprehensiveTranslations/sv/js_iterations === RUN TestComprehensiveTranslations/sv/js_missing_feature === RUN TestComprehensiveTranslations/sv/js_speed === RUN TestComprehensiveTranslations/sv/js_success === RUN TestComprehensiveTranslations/sv/js_verification_longer === RUN TestComprehensiveTranslations/sv/js_web_crypto_error === RUN TestComprehensiveTranslations/sv/js_web_workers_error === RUN TestComprehensiveTranslations/sv/jshelter_note === RUN TestComprehensiveTranslations/sv/loading === RUN TestComprehensiveTranslations/sv/made_with === RUN TestComprehensiveTranslations/sv/making_sure_not_bot === RUN TestComprehensiveTranslations/sv/mascot_design === RUN TestComprehensiveTranslations/sv/missing_required_forwarded_headers === RUN TestComprehensiveTranslations/sv/oh_noes === RUN TestComprehensiveTranslations/sv/protected_by === RUN TestComprehensiveTranslations/sv/protected_from === RUN TestComprehensiveTranslations/sv/redirect_domain_not_allowed === RUN TestComprehensiveTranslations/sv/redirect_not_parseable === RUN TestComprehensiveTranslations/sv/see_dronebl_lookup === RUN TestComprehensiveTranslations/sv/simplified_explanation === RUN TestComprehensiveTranslations/sv/static_check_endpoint === RUN TestComprehensiveTranslations/sv/time === RUN TestComprehensiveTranslations/sv/time_a === RUN TestComprehensiveTranslations/sv/time_b === RUN TestComprehensiveTranslations/sv/try_again === RUN TestComprehensiveTranslations/sv/version_info === RUN TestComprehensiveTranslations/sv/why_am_i_seeing === RUN TestComprehensiveTranslations/sv/you_are_not_a_bot --- PASS: TestComprehensiveTranslations (0.03s) --- PASS: TestComprehensiveTranslations/cs (0.00s) --- PASS: TestComprehensiveTranslations/cs/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/cs/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/cs/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/cs/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/cs/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/cs/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/cs/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/cs/celphase (0.00s) --- PASS: TestComprehensiveTranslations/cs/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/cs/compare (0.00s) --- PASS: TestComprehensiveTranslations/cs/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/cs/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/cs/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/cs/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/cs/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/cs/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/cs/go_home (0.00s) --- PASS: TestComprehensiveTranslations/cs/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/cs/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/cs/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/cs/iters (0.00s) --- PASS: TestComprehensiveTranslations/cs/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/cs/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/cs/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_success (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/cs/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/cs/loading (0.00s) --- PASS: TestComprehensiveTranslations/cs/made_with (0.00s) --- PASS: TestComprehensiveTranslations/cs/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/cs/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/cs/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/cs/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/cs/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/cs/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/cs/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/cs/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/cs/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/cs/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/cs/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/cs/time (0.00s) --- PASS: TestComprehensiveTranslations/cs/time_a (0.00s) --- PASS: TestComprehensiveTranslations/cs/time_b (0.00s) --- PASS: TestComprehensiveTranslations/cs/try_again (0.00s) --- PASS: TestComprehensiveTranslations/cs/version_info (0.00s) --- PASS: TestComprehensiveTranslations/cs/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/cs/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/de (0.00s) --- PASS: TestComprehensiveTranslations/de/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/de/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/de/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/de/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/de/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/de/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/de/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/de/celphase (0.00s) --- PASS: TestComprehensiveTranslations/de/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/de/compare (0.00s) --- PASS: TestComprehensiveTranslations/de/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/de/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/de/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/de/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/de/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/de/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/de/go_home (0.00s) --- PASS: TestComprehensiveTranslations/de/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/de/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/de/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/de/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/de/iters (0.00s) --- PASS: TestComprehensiveTranslations/de/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/de/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/de/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/de/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/de/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/de/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/de/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/de/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/de/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/de/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/de/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/de/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/de/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/de/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/de/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/de/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/de/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/de/js_success (0.00s) --- PASS: TestComprehensiveTranslations/de/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/de/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/de/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/de/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/de/loading (0.00s) --- PASS: TestComprehensiveTranslations/de/made_with (0.00s) --- PASS: TestComprehensiveTranslations/de/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/de/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/de/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/de/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/de/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/de/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/de/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/de/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/de/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/de/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/de/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/de/time (0.00s) --- PASS: TestComprehensiveTranslations/de/time_a (0.00s) --- PASS: TestComprehensiveTranslations/de/time_b (0.00s) --- PASS: TestComprehensiveTranslations/de/try_again (0.00s) --- PASS: TestComprehensiveTranslations/de/version_info (0.00s) --- PASS: TestComprehensiveTranslations/de/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/de/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/en (0.00s) --- PASS: TestComprehensiveTranslations/en/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/en/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/en/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/en/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/en/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/en/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/en/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/en/celphase (0.00s) --- PASS: TestComprehensiveTranslations/en/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/en/compare (0.00s) --- PASS: TestComprehensiveTranslations/en/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/en/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/en/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/en/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/en/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/en/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/en/go_home (0.00s) --- PASS: TestComprehensiveTranslations/en/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/en/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/en/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/en/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/en/iters (0.00s) --- PASS: TestComprehensiveTranslations/en/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/en/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/en/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/en/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/en/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/en/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/en/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/en/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/en/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/en/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/en/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/en/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/en/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/en/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/en/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/en/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/en/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/en/js_success (0.00s) --- PASS: TestComprehensiveTranslations/en/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/en/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/en/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/en/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/en/loading (0.00s) --- PASS: TestComprehensiveTranslations/en/made_with (0.00s) --- PASS: TestComprehensiveTranslations/en/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/en/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/en/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/en/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/en/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/en/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/en/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/en/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/en/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/en/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/en/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/en/time (0.00s) --- PASS: TestComprehensiveTranslations/en/time_a (0.00s) --- PASS: TestComprehensiveTranslations/en/time_b (0.00s) --- PASS: TestComprehensiveTranslations/en/try_again (0.00s) --- PASS: TestComprehensiveTranslations/en/version_info (0.00s) --- PASS: TestComprehensiveTranslations/en/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/en/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/es (0.00s) --- PASS: TestComprehensiveTranslations/es/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/es/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/es/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/es/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/es/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/es/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/es/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/es/celphase (0.00s) --- PASS: TestComprehensiveTranslations/es/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/es/compare (0.00s) --- PASS: TestComprehensiveTranslations/es/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/es/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/es/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/es/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/es/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/es/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/es/go_home (0.00s) --- PASS: TestComprehensiveTranslations/es/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/es/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/es/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/es/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/es/iters (0.00s) --- PASS: TestComprehensiveTranslations/es/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/es/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/es/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/es/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/es/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/es/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/es/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/es/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/es/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/es/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/es/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/es/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/es/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/es/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/es/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/es/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/es/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/es/js_success (0.00s) --- PASS: TestComprehensiveTranslations/es/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/es/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/es/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/es/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/es/loading (0.00s) --- PASS: TestComprehensiveTranslations/es/made_with (0.00s) --- PASS: TestComprehensiveTranslations/es/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/es/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/es/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/es/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/es/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/es/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/es/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/es/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/es/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/es/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/es/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/es/time (0.00s) --- PASS: TestComprehensiveTranslations/es/time_a (0.00s) --- PASS: TestComprehensiveTranslations/es/time_b (0.00s) --- PASS: TestComprehensiveTranslations/es/try_again (0.00s) --- PASS: TestComprehensiveTranslations/es/version_info (0.00s) --- PASS: TestComprehensiveTranslations/es/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/es/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/et (0.00s) --- PASS: TestComprehensiveTranslations/et/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/et/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/et/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/et/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/et/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/et/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/et/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/et/celphase (0.00s) --- PASS: TestComprehensiveTranslations/et/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/et/compare (0.00s) --- PASS: TestComprehensiveTranslations/et/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/et/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/et/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/et/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/et/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/et/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/et/go_home (0.00s) --- PASS: TestComprehensiveTranslations/et/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/et/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/et/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/et/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/et/iters (0.00s) --- PASS: TestComprehensiveTranslations/et/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/et/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/et/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/et/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/et/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/et/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/et/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/et/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/et/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/et/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/et/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/et/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/et/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/et/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/et/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/et/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/et/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/et/js_success (0.00s) --- PASS: TestComprehensiveTranslations/et/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/et/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/et/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/et/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/et/loading (0.00s) --- PASS: TestComprehensiveTranslations/et/made_with (0.00s) --- PASS: TestComprehensiveTranslations/et/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/et/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/et/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/et/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/et/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/et/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/et/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/et/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/et/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/et/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/et/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/et/time (0.00s) --- PASS: TestComprehensiveTranslations/et/time_a (0.00s) --- PASS: TestComprehensiveTranslations/et/time_b (0.00s) --- PASS: TestComprehensiveTranslations/et/try_again (0.00s) --- PASS: TestComprehensiveTranslations/et/version_info (0.00s) --- PASS: TestComprehensiveTranslations/et/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/et/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/fi (0.00s) --- PASS: TestComprehensiveTranslations/fi/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/fi/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fi/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/fi/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/fi/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/fi/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/fi/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/fi/celphase (0.00s) --- PASS: TestComprehensiveTranslations/fi/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/fi/compare (0.00s) --- PASS: TestComprehensiveTranslations/fi/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/fi/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/fi/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/fi/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fi/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/fi/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/fi/go_home (0.00s) --- PASS: TestComprehensiveTranslations/fi/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/fi/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/fi/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/fi/iters (0.00s) --- PASS: TestComprehensiveTranslations/fi/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/fi/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/fi/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_success (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/fi/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/fi/loading (0.00s) --- PASS: TestComprehensiveTranslations/fi/made_with (0.00s) --- PASS: TestComprehensiveTranslations/fi/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/fi/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/fi/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/fi/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/fi/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/fi/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/fi/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/fi/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/fi/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/fi/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fi/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/fi/time (0.00s) --- PASS: TestComprehensiveTranslations/fi/time_a (0.00s) --- PASS: TestComprehensiveTranslations/fi/time_b (0.00s) --- PASS: TestComprehensiveTranslations/fi/try_again (0.00s) --- PASS: TestComprehensiveTranslations/fi/version_info (0.00s) --- PASS: TestComprehensiveTranslations/fi/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/fi/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/fil (0.00s) --- PASS: TestComprehensiveTranslations/fil/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/fil/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fil/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/fil/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/fil/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/fil/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/fil/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/fil/celphase (0.00s) --- PASS: TestComprehensiveTranslations/fil/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/fil/compare (0.00s) --- PASS: TestComprehensiveTranslations/fil/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/fil/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/fil/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/fil/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fil/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/fil/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/fil/go_home (0.00s) --- PASS: TestComprehensiveTranslations/fil/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/fil/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/fil/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/fil/iters (0.00s) --- PASS: TestComprehensiveTranslations/fil/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/fil/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/fil/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_success (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/fil/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/fil/loading (0.00s) --- PASS: TestComprehensiveTranslations/fil/made_with (0.00s) --- PASS: TestComprehensiveTranslations/fil/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/fil/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/fil/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/fil/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/fil/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/fil/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/fil/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/fil/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/fil/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/fil/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fil/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/fil/time (0.00s) --- PASS: TestComprehensiveTranslations/fil/time_a (0.00s) --- PASS: TestComprehensiveTranslations/fil/time_b (0.00s) --- PASS: TestComprehensiveTranslations/fil/try_again (0.00s) --- PASS: TestComprehensiveTranslations/fil/version_info (0.00s) --- PASS: TestComprehensiveTranslations/fil/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/fil/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/fr (0.00s) --- PASS: TestComprehensiveTranslations/fr/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/fr/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fr/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/fr/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/fr/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/fr/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/fr/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/fr/celphase (0.00s) --- PASS: TestComprehensiveTranslations/fr/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/fr/compare (0.00s) --- PASS: TestComprehensiveTranslations/fr/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/fr/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/fr/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/fr/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fr/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/fr/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/fr/go_home (0.00s) --- PASS: TestComprehensiveTranslations/fr/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/fr/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/fr/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/fr/iters (0.00s) --- PASS: TestComprehensiveTranslations/fr/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/fr/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/fr/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_success (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/fr/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/fr/loading (0.00s) --- PASS: TestComprehensiveTranslations/fr/made_with (0.00s) --- PASS: TestComprehensiveTranslations/fr/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/fr/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/fr/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/fr/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/fr/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/fr/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/fr/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/fr/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/fr/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/fr/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/fr/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/fr/time (0.00s) --- PASS: TestComprehensiveTranslations/fr/time_a (0.00s) --- PASS: TestComprehensiveTranslations/fr/time_b (0.00s) --- PASS: TestComprehensiveTranslations/fr/try_again (0.00s) --- PASS: TestComprehensiveTranslations/fr/version_info (0.00s) --- PASS: TestComprehensiveTranslations/fr/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/fr/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/is (0.00s) --- PASS: TestComprehensiveTranslations/is/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/is/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/is/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/is/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/is/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/is/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/is/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/is/celphase (0.00s) --- PASS: TestComprehensiveTranslations/is/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/is/compare (0.00s) --- PASS: TestComprehensiveTranslations/is/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/is/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/is/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/is/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/is/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/is/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/is/go_home (0.00s) --- PASS: TestComprehensiveTranslations/is/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/is/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/is/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/is/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/is/iters (0.00s) --- PASS: TestComprehensiveTranslations/is/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/is/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/is/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/is/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/is/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/is/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/is/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/is/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/is/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/is/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/is/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/is/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/is/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/is/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/is/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/is/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/is/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/is/js_success (0.00s) --- PASS: TestComprehensiveTranslations/is/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/is/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/is/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/is/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/is/loading (0.00s) --- PASS: TestComprehensiveTranslations/is/made_with (0.00s) --- PASS: TestComprehensiveTranslations/is/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/is/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/is/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/is/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/is/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/is/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/is/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/is/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/is/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/is/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/is/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/is/time (0.00s) --- PASS: TestComprehensiveTranslations/is/time_a (0.00s) --- PASS: TestComprehensiveTranslations/is/time_b (0.00s) --- PASS: TestComprehensiveTranslations/is/try_again (0.00s) --- PASS: TestComprehensiveTranslations/is/version_info (0.00s) --- PASS: TestComprehensiveTranslations/is/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/is/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/it (0.00s) --- PASS: TestComprehensiveTranslations/it/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/it/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/it/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/it/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/it/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/it/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/it/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/it/celphase (0.00s) --- PASS: TestComprehensiveTranslations/it/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/it/compare (0.00s) --- PASS: TestComprehensiveTranslations/it/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/it/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/it/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/it/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/it/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/it/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/it/go_home (0.00s) --- PASS: TestComprehensiveTranslations/it/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/it/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/it/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/it/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/it/iters (0.00s) --- PASS: TestComprehensiveTranslations/it/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/it/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/it/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/it/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/it/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/it/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/it/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/it/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/it/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/it/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/it/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/it/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/it/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/it/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/it/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/it/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/it/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/it/js_success (0.00s) --- PASS: TestComprehensiveTranslations/it/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/it/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/it/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/it/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/it/loading (0.00s) --- PASS: TestComprehensiveTranslations/it/made_with (0.00s) --- PASS: TestComprehensiveTranslations/it/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/it/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/it/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/it/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/it/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/it/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/it/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/it/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/it/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/it/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/it/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/it/time (0.00s) --- PASS: TestComprehensiveTranslations/it/time_a (0.00s) --- PASS: TestComprehensiveTranslations/it/time_b (0.00s) --- PASS: TestComprehensiveTranslations/it/try_again (0.00s) --- PASS: TestComprehensiveTranslations/it/version_info (0.00s) --- PASS: TestComprehensiveTranslations/it/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/it/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/ja (0.00s) --- PASS: TestComprehensiveTranslations/ja/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/ja/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/ja/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/ja/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/ja/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/ja/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/ja/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/ja/celphase (0.00s) --- PASS: TestComprehensiveTranslations/ja/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/ja/compare (0.00s) --- PASS: TestComprehensiveTranslations/ja/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/ja/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/ja/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/ja/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/ja/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/ja/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/ja/go_home (0.00s) --- PASS: TestComprehensiveTranslations/ja/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/ja/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/ja/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/ja/iters (0.00s) --- PASS: TestComprehensiveTranslations/ja/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/ja/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/ja/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_success (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/ja/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/ja/loading (0.00s) --- PASS: TestComprehensiveTranslations/ja/made_with (0.00s) --- PASS: TestComprehensiveTranslations/ja/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/ja/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/ja/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/ja/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/ja/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/ja/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/ja/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/ja/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/ja/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/ja/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/ja/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/ja/time (0.00s) --- PASS: TestComprehensiveTranslations/ja/time_a (0.00s) --- PASS: TestComprehensiveTranslations/ja/time_b (0.00s) --- PASS: TestComprehensiveTranslations/ja/try_again (0.00s) --- PASS: TestComprehensiveTranslations/ja/version_info (0.00s) --- PASS: TestComprehensiveTranslations/ja/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/ja/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/lt (0.00s) --- PASS: TestComprehensiveTranslations/lt/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/lt/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/lt/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/lt/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/lt/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/lt/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/lt/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/lt/celphase (0.00s) --- PASS: TestComprehensiveTranslations/lt/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/lt/compare (0.00s) --- PASS: TestComprehensiveTranslations/lt/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/lt/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/lt/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/lt/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/lt/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/lt/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/lt/go_home (0.00s) --- PASS: TestComprehensiveTranslations/lt/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/lt/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/lt/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/lt/iters (0.00s) --- PASS: TestComprehensiveTranslations/lt/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/lt/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/lt/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_success (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/lt/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/lt/loading (0.00s) --- PASS: TestComprehensiveTranslations/lt/made_with (0.00s) --- PASS: TestComprehensiveTranslations/lt/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/lt/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/lt/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/lt/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/lt/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/lt/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/lt/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/lt/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/lt/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/lt/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/lt/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/lt/time (0.00s) --- PASS: TestComprehensiveTranslations/lt/time_a (0.00s) --- PASS: TestComprehensiveTranslations/lt/time_b (0.00s) --- PASS: TestComprehensiveTranslations/lt/try_again (0.00s) --- PASS: TestComprehensiveTranslations/lt/version_info (0.00s) --- PASS: TestComprehensiveTranslations/lt/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/lt/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/nb (0.00s) --- PASS: TestComprehensiveTranslations/nb/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/nb/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nb/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/nb/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/nb/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/nb/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/nb/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/nb/celphase (0.00s) --- PASS: TestComprehensiveTranslations/nb/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/nb/compare (0.00s) --- PASS: TestComprehensiveTranslations/nb/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/nb/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/nb/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/nb/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nb/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/nb/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/nb/go_home (0.00s) --- PASS: TestComprehensiveTranslations/nb/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/nb/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/nb/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/nb/iters (0.00s) --- PASS: TestComprehensiveTranslations/nb/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/nb/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/nb/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_success (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/nb/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/nb/loading (0.00s) --- PASS: TestComprehensiveTranslations/nb/made_with (0.00s) --- PASS: TestComprehensiveTranslations/nb/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/nb/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/nb/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/nb/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/nb/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/nb/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/nb/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/nb/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/nb/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/nb/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nb/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/nb/time (0.00s) --- PASS: TestComprehensiveTranslations/nb/time_a (0.00s) --- PASS: TestComprehensiveTranslations/nb/time_b (0.00s) --- PASS: TestComprehensiveTranslations/nb/try_again (0.00s) --- PASS: TestComprehensiveTranslations/nb/version_info (0.00s) --- PASS: TestComprehensiveTranslations/nb/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/nb/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/nl (0.00s) --- PASS: TestComprehensiveTranslations/nl/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/nl/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nl/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/nl/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/nl/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/nl/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/nl/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/nl/celphase (0.00s) --- PASS: TestComprehensiveTranslations/nl/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/nl/compare (0.00s) --- PASS: TestComprehensiveTranslations/nl/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/nl/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/nl/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/nl/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nl/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/nl/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/nl/go_home (0.00s) --- PASS: TestComprehensiveTranslations/nl/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/nl/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/nl/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/nl/iters (0.00s) --- PASS: TestComprehensiveTranslations/nl/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/nl/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/nl/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_success (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/nl/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/nl/loading (0.00s) --- PASS: TestComprehensiveTranslations/nl/made_with (0.00s) --- PASS: TestComprehensiveTranslations/nl/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/nl/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/nl/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/nl/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/nl/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/nl/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/nl/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/nl/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/nl/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/nl/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nl/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/nl/time (0.00s) --- PASS: TestComprehensiveTranslations/nl/time_a (0.00s) --- PASS: TestComprehensiveTranslations/nl/time_b (0.00s) --- PASS: TestComprehensiveTranslations/nl/try_again (0.00s) --- PASS: TestComprehensiveTranslations/nl/version_info (0.00s) --- PASS: TestComprehensiveTranslations/nl/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/nl/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/nn (0.00s) --- PASS: TestComprehensiveTranslations/nn/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/nn/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nn/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/nn/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/nn/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/nn/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/nn/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/nn/celphase (0.00s) --- PASS: TestComprehensiveTranslations/nn/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/nn/compare (0.00s) --- PASS: TestComprehensiveTranslations/nn/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/nn/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/nn/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/nn/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nn/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/nn/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/nn/go_home (0.00s) --- PASS: TestComprehensiveTranslations/nn/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/nn/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/nn/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/nn/iters (0.00s) --- PASS: TestComprehensiveTranslations/nn/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/nn/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/nn/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_success (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/nn/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/nn/loading (0.00s) --- PASS: TestComprehensiveTranslations/nn/made_with (0.00s) --- PASS: TestComprehensiveTranslations/nn/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/nn/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/nn/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/nn/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/nn/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/nn/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/nn/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/nn/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/nn/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/nn/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/nn/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/nn/time (0.00s) --- PASS: TestComprehensiveTranslations/nn/time_a (0.00s) --- PASS: TestComprehensiveTranslations/nn/time_b (0.00s) --- PASS: TestComprehensiveTranslations/nn/try_again (0.00s) --- PASS: TestComprehensiveTranslations/nn/version_info (0.00s) --- PASS: TestComprehensiveTranslations/nn/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/nn/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/celphase (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/compare (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/go_home (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/iters (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_success (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/loading (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/made_with (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/time (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/time_a (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/time_b (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/try_again (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/version_info (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/pt-BR/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/ru (0.00s) --- PASS: TestComprehensiveTranslations/ru/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/ru/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/ru/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/ru/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/ru/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/ru/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/ru/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/ru/celphase (0.00s) --- PASS: TestComprehensiveTranslations/ru/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/ru/compare (0.00s) --- PASS: TestComprehensiveTranslations/ru/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/ru/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/ru/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/ru/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/ru/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/ru/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/ru/go_home (0.00s) --- PASS: TestComprehensiveTranslations/ru/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/ru/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/ru/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/ru/iters (0.00s) --- PASS: TestComprehensiveTranslations/ru/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/ru/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/ru/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_success (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/ru/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/ru/loading (0.00s) --- PASS: TestComprehensiveTranslations/ru/made_with (0.00s) --- PASS: TestComprehensiveTranslations/ru/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/ru/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/ru/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/ru/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/ru/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/ru/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/ru/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/ru/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/ru/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/ru/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/ru/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/ru/time (0.00s) --- PASS: TestComprehensiveTranslations/ru/time_a (0.00s) --- PASS: TestComprehensiveTranslations/ru/time_b (0.00s) --- PASS: TestComprehensiveTranslations/ru/try_again (0.00s) --- PASS: TestComprehensiveTranslations/ru/version_info (0.00s) --- PASS: TestComprehensiveTranslations/ru/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/ru/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/tr (0.00s) --- PASS: TestComprehensiveTranslations/tr/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/tr/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/tr/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/tr/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/tr/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/tr/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/tr/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/tr/celphase (0.00s) --- PASS: TestComprehensiveTranslations/tr/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/tr/compare (0.00s) --- PASS: TestComprehensiveTranslations/tr/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/tr/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/tr/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/tr/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/tr/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/tr/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/tr/go_home (0.00s) --- PASS: TestComprehensiveTranslations/tr/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/tr/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/tr/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/tr/iters (0.00s) --- PASS: TestComprehensiveTranslations/tr/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/tr/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/tr/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_success (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/tr/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/tr/loading (0.00s) --- PASS: TestComprehensiveTranslations/tr/made_with (0.00s) --- PASS: TestComprehensiveTranslations/tr/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/tr/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/tr/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/tr/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/tr/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/tr/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/tr/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/tr/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/tr/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/tr/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/tr/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/tr/time (0.00s) --- PASS: TestComprehensiveTranslations/tr/time_a (0.00s) --- PASS: TestComprehensiveTranslations/tr/time_b (0.00s) --- PASS: TestComprehensiveTranslations/tr/try_again (0.00s) --- PASS: TestComprehensiveTranslations/tr/version_info (0.00s) --- PASS: TestComprehensiveTranslations/tr/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/tr/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/uk (0.00s) --- PASS: TestComprehensiveTranslations/uk/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/uk/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/uk/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/uk/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/uk/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/uk/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/uk/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/uk/celphase (0.00s) --- PASS: TestComprehensiveTranslations/uk/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/uk/compare (0.00s) --- PASS: TestComprehensiveTranslations/uk/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/uk/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/uk/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/uk/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/uk/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/uk/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/uk/go_home (0.00s) --- PASS: TestComprehensiveTranslations/uk/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/uk/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/uk/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/uk/iters (0.00s) --- PASS: TestComprehensiveTranslations/uk/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/uk/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/uk/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_success (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/uk/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/uk/loading (0.00s) --- PASS: TestComprehensiveTranslations/uk/made_with (0.00s) --- PASS: TestComprehensiveTranslations/uk/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/uk/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/uk/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/uk/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/uk/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/uk/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/uk/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/uk/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/uk/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/uk/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/uk/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/uk/time (0.00s) --- PASS: TestComprehensiveTranslations/uk/time_a (0.00s) --- PASS: TestComprehensiveTranslations/uk/time_b (0.00s) --- PASS: TestComprehensiveTranslations/uk/try_again (0.00s) --- PASS: TestComprehensiveTranslations/uk/version_info (0.00s) --- PASS: TestComprehensiveTranslations/uk/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/uk/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/vi (0.00s) --- PASS: TestComprehensiveTranslations/vi/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/vi/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/vi/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/vi/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/vi/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/vi/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/vi/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/vi/celphase (0.00s) --- PASS: TestComprehensiveTranslations/vi/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/vi/compare (0.00s) --- PASS: TestComprehensiveTranslations/vi/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/vi/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/vi/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/vi/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/vi/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/vi/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/vi/go_home (0.00s) --- PASS: TestComprehensiveTranslations/vi/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/vi/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/vi/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/vi/iters (0.00s) --- PASS: TestComprehensiveTranslations/vi/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/vi/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/vi/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_success (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/vi/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/vi/loading (0.00s) --- PASS: TestComprehensiveTranslations/vi/made_with (0.00s) --- PASS: TestComprehensiveTranslations/vi/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/vi/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/vi/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/vi/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/vi/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/vi/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/vi/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/vi/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/vi/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/vi/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/vi/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/vi/time (0.00s) --- PASS: TestComprehensiveTranslations/vi/time_a (0.00s) --- PASS: TestComprehensiveTranslations/vi/time_b (0.00s) --- PASS: TestComprehensiveTranslations/vi/try_again (0.00s) --- PASS: TestComprehensiveTranslations/vi/version_info (0.00s) --- PASS: TestComprehensiveTranslations/vi/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/vi/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/celphase (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/compare (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/go_home (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/iters (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_success (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/loading (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/made_with (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/time (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/time_a (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/time_b (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/try_again (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/version_info (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/zh-CN/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/celphase (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/compare (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/go_home (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/iters (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_success (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/loading (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/made_with (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/time (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/time_a (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/time_b (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/try_again (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/version_info (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/zh-TW/you_are_not_a_bot (0.00s) --- PASS: TestComprehensiveTranslations/sv (0.00s) --- PASS: TestComprehensiveTranslations/sv/access_denied (0.00s) --- PASS: TestComprehensiveTranslations/sv/ai_companies_explanation (0.00s) --- PASS: TestComprehensiveTranslations/sv/algorithm (0.00s) --- PASS: TestComprehensiveTranslations/sv/anubis_compromise (0.00s) --- PASS: TestComprehensiveTranslations/sv/authorization_required (0.00s) --- PASS: TestComprehensiveTranslations/sv/benchmark_requires_js (0.00s) --- PASS: TestComprehensiveTranslations/sv/benchmarking_anubis (0.00s) --- PASS: TestComprehensiveTranslations/sv/celphase (0.00s) --- PASS: TestComprehensiveTranslations/sv/client_error_browser (0.00s) --- PASS: TestComprehensiveTranslations/sv/compare (0.00s) --- PASS: TestComprehensiveTranslations/sv/connection_security (0.00s) --- PASS: TestComprehensiveTranslations/sv/contact_webmaster (0.00s) --- PASS: TestComprehensiveTranslations/sv/cookies_disabled (0.00s) --- PASS: TestComprehensiveTranslations/sv/difficulty (0.00s) --- PASS: TestComprehensiveTranslations/sv/dronebl_entry (0.00s) --- PASS: TestComprehensiveTranslations/sv/failed_to_sign_jwt (0.00s) --- PASS: TestComprehensiveTranslations/sv/go_home (0.00s) --- PASS: TestComprehensiveTranslations/sv/hack_purpose (0.00s) --- PASS: TestComprehensiveTranslations/sv/internal_server_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/invalid_invocation (0.00s) --- PASS: TestComprehensiveTranslations/sv/invalid_redirect (0.00s) --- PASS: TestComprehensiveTranslations/sv/iters (0.00s) --- PASS: TestComprehensiveTranslations/sv/iters_a (0.00s) --- PASS: TestComprehensiveTranslations/sv/iters_b (0.00s) --- PASS: TestComprehensiveTranslations/sv/javascript_required (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_calculating (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_calculating_difficulty (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_calculation_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_calculation_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_challenge_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_challenge_error_msg (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_context_not_secure (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_context_not_secure_msg (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_cookies_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_done_took (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_finished_reading (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_iterations (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_missing_feature (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_speed (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_success (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_verification_longer (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_web_crypto_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/js_web_workers_error (0.00s) --- PASS: TestComprehensiveTranslations/sv/jshelter_note (0.00s) --- PASS: TestComprehensiveTranslations/sv/loading (0.00s) --- PASS: TestComprehensiveTranslations/sv/made_with (0.00s) --- PASS: TestComprehensiveTranslations/sv/making_sure_not_bot (0.00s) --- PASS: TestComprehensiveTranslations/sv/mascot_design (0.00s) --- PASS: TestComprehensiveTranslations/sv/missing_required_forwarded_headers (0.00s) --- PASS: TestComprehensiveTranslations/sv/oh_noes (0.00s) --- PASS: TestComprehensiveTranslations/sv/protected_by (0.00s) --- PASS: TestComprehensiveTranslations/sv/protected_from (0.00s) --- PASS: TestComprehensiveTranslations/sv/redirect_domain_not_allowed (0.00s) --- PASS: TestComprehensiveTranslations/sv/redirect_not_parseable (0.00s) --- PASS: TestComprehensiveTranslations/sv/see_dronebl_lookup (0.00s) --- PASS: TestComprehensiveTranslations/sv/simplified_explanation (0.00s) --- PASS: TestComprehensiveTranslations/sv/static_check_endpoint (0.00s) --- PASS: TestComprehensiveTranslations/sv/time (0.00s) --- PASS: TestComprehensiveTranslations/sv/time_a (0.00s) --- PASS: TestComprehensiveTranslations/sv/time_b (0.00s) --- PASS: TestComprehensiveTranslations/sv/try_again (0.00s) --- PASS: TestComprehensiveTranslations/sv/version_info (0.00s) --- PASS: TestComprehensiveTranslations/sv/why_am_i_seeing (0.00s) --- PASS: TestComprehensiveTranslations/sv/you_are_not_a_bot (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/localization 0.045s === RUN TestRemoteAddrChecker === RUN TestRemoteAddrChecker/match_ipv4 === RUN TestRemoteAddrChecker/match_ipv4_in_ipv6 === RUN TestRemoteAddrChecker/match_ipv4_in_ipv6_hex === RUN TestRemoteAddrChecker/match_ipv6 === RUN TestRemoteAddrChecker/not_match_ipv4 === RUN TestRemoteAddrChecker/not_match_ipv6 === RUN TestRemoteAddrChecker/no_ip_set === RUN TestRemoteAddrChecker/invalid_ip --- PASS: TestRemoteAddrChecker (0.00s) --- PASS: TestRemoteAddrChecker/match_ipv4 (0.00s) --- PASS: TestRemoteAddrChecker/match_ipv4_in_ipv6 (0.00s) --- PASS: TestRemoteAddrChecker/match_ipv4_in_ipv6_hex (0.00s) --- PASS: TestRemoteAddrChecker/match_ipv6 (0.00s) --- PASS: TestRemoteAddrChecker/not_match_ipv4 (0.00s) --- PASS: TestRemoteAddrChecker/not_match_ipv6 (0.00s) --- PASS: TestRemoteAddrChecker/no_ip_set (0.00s) --- PASS: TestRemoteAddrChecker/invalid_ip (0.00s) === RUN TestHeaderMatchesChecker === RUN TestHeaderMatchesChecker/match === RUN TestHeaderMatchesChecker/not_match === RUN TestHeaderMatchesChecker/not_present === RUN TestHeaderMatchesChecker/invalid_regex --- PASS: TestHeaderMatchesChecker (0.00s) --- PASS: TestHeaderMatchesChecker/match (0.00s) --- PASS: TestHeaderMatchesChecker/not_match (0.00s) --- PASS: TestHeaderMatchesChecker/not_present (0.00s) --- PASS: TestHeaderMatchesChecker/invalid_regex (0.00s) === RUN TestHeaderExistsChecker === RUN TestHeaderExistsChecker/match === RUN TestHeaderExistsChecker/not_match --- PASS: TestHeaderExistsChecker (0.00s) --- PASS: TestHeaderExistsChecker/match (0.00s) --- PASS: TestHeaderExistsChecker/not_match (0.00s) === RUN TestPathChecker_XOriginalURI === RUN TestPathChecker_XOriginalURI/X-Original-URI_matches_regex_(with_trailing_space_-_current_typo) === RUN TestPathChecker_XOriginalURI/X-Original-URI_doesn't_match,_falls_back_to_URL.Path === RUN TestPathChecker_XOriginalURI/Neither_X-Original-URI_nor_URL.Path_match === RUN TestPathChecker_XOriginalURI/Empty_X-Original-URI,_URL.Path_matches === RUN TestPathChecker_XOriginalURI/Complex_regex_matching_X-Original-URI --- PASS: TestPathChecker_XOriginalURI (0.00s) --- PASS: TestPathChecker_XOriginalURI/X-Original-URI_matches_regex_(with_trailing_space_-_current_typo) (0.00s) --- PASS: TestPathChecker_XOriginalURI/X-Original-URI_doesn't_match,_falls_back_to_URL.Path (0.00s) --- PASS: TestPathChecker_XOriginalURI/Neither_X-Original-URI_nor_URL.Path_match (0.00s) --- PASS: TestPathChecker_XOriginalURI/Empty_X-Original-URI,_URL.Path_matches (0.00s) --- PASS: TestPathChecker_XOriginalURI/Complex_regex_matching_X-Original-URI (0.00s) === RUN TestDefaultPolicyMustParse --- PASS: TestDefaultPolicyMustParse (0.03s) === RUN TestGoodConfigs === RUN TestGoodConfigs/allow_everyone.json === RUN TestGoodConfigs/allow_everyone.json/with-thoth === RUN TestGoodConfigs/allow_everyone.json/without-thoth === RUN TestGoodConfigs/allow_everyone.yaml === RUN TestGoodConfigs/allow_everyone.yaml/with-thoth === RUN TestGoodConfigs/allow_everyone.yaml/without-thoth === RUN TestGoodConfigs/block_cf_workers.json === RUN TestGoodConfigs/block_cf_workers.json/with-thoth === RUN TestGoodConfigs/block_cf_workers.json/without-thoth === RUN TestGoodConfigs/block_cf_workers.yaml === RUN TestGoodConfigs/block_cf_workers.yaml/with-thoth === RUN TestGoodConfigs/block_cf_workers.yaml/without-thoth === RUN TestGoodConfigs/challenge_cloudflare.yaml === RUN TestGoodConfigs/challenge_cloudflare.yaml/with-thoth === RUN TestGoodConfigs/challenge_cloudflare.yaml/without-thoth {"time":"2025-12-29T14:01:42.87807275Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":171},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"asn","settings":{"match":[13335]}} === RUN TestGoodConfigs/challengemozilla.json === RUN TestGoodConfigs/challengemozilla.json/with-thoth === RUN TestGoodConfigs/challengemozilla.json/without-thoth === RUN TestGoodConfigs/challengemozilla.yaml === RUN TestGoodConfigs/challengemozilla.yaml/with-thoth === RUN TestGoodConfigs/challengemozilla.yaml/without-thoth === RUN TestGoodConfigs/dns-ttl-custom.yaml === RUN TestGoodConfigs/dns-ttl-custom.yaml/with-thoth === RUN TestGoodConfigs/dns-ttl-custom.yaml/without-thoth === RUN TestGoodConfigs/entropy.yaml === RUN TestGoodConfigs/entropy.yaml/with-thoth === RUN TestGoodConfigs/entropy.yaml/without-thoth === RUN TestGoodConfigs/everything_blocked.json === RUN TestGoodConfigs/everything_blocked.json/with-thoth === RUN TestGoodConfigs/everything_blocked.json/without-thoth === RUN TestGoodConfigs/everything_blocked.yaml === RUN TestGoodConfigs/everything_blocked.yaml/with-thoth === RUN TestGoodConfigs/everything_blocked.yaml/without-thoth === RUN TestGoodConfigs/geoip_us.yaml === RUN TestGoodConfigs/geoip_us.yaml/with-thoth === RUN TestGoodConfigs/geoip_us.yaml/without-thoth {"time":"2025-12-29T14:01:42.885627958Z","level":"WARN","source":{"function":"github.com/TecharoHQ/anubis/lib/policy.ParseConfig","file":"github.com/TecharoHQ/anubis/lib/policy/policy.go","line":180},"msg":"You have specified a Thoth specific check but you have no Thoth client configured. Please read https://anubis.techaro.lol/docs/admin/thoth for more information","at":"config-validate","check":"geoip","settings":{"countries":["US"]}} === RUN TestGoodConfigs/git_client.json === RUN TestGoodConfigs/git_client.json/with-thoth === RUN TestGoodConfigs/git_client.json/without-thoth === RUN TestGoodConfigs/git_client.yaml === RUN TestGoodConfigs/git_client.yaml/with-thoth === RUN TestGoodConfigs/git_client.yaml/without-thoth === RUN TestGoodConfigs/import_filesystem.json === RUN TestGoodConfigs/import_filesystem.json/with-thoth === RUN TestGoodConfigs/import_filesystem.json/without-thoth === RUN TestGoodConfigs/import_filesystem.yaml === RUN TestGoodConfigs/import_filesystem.yaml/with-thoth === RUN TestGoodConfigs/import_filesystem.yaml/without-thoth === RUN TestGoodConfigs/import_keep_internet_working.json === RUN TestGoodConfigs/import_keep_internet_working.json/with-thoth === RUN TestGoodConfigs/import_keep_internet_working.json/without-thoth === RUN TestGoodConfigs/import_keep_internet_working.yaml === RUN TestGoodConfigs/import_keep_internet_working.yaml/with-thoth === RUN TestGoodConfigs/import_keep_internet_working.yaml/without-thoth === RUN TestGoodConfigs/impressum.yaml === RUN TestGoodConfigs/impressum.yaml/with-thoth === RUN TestGoodConfigs/impressum.yaml/without-thoth === RUN TestGoodConfigs/logging-file.yaml === RUN TestGoodConfigs/logging-file.yaml/with-thoth === RUN TestGoodConfigs/logging-file.yaml/without-thoth === RUN TestGoodConfigs/logging-stdio.yaml === RUN TestGoodConfigs/logging-stdio.yaml/with-thoth === RUN TestGoodConfigs/logging-stdio.yaml/without-thoth === RUN TestGoodConfigs/no-thresholds.yaml === RUN TestGoodConfigs/no-thresholds.yaml/with-thoth === RUN TestGoodConfigs/no-thresholds.yaml/without-thoth === RUN TestGoodConfigs/old_xesite.json === RUN TestGoodConfigs/old_xesite.json/with-thoth === RUN TestGoodConfigs/old_xesite.json/without-thoth === RUN TestGoodConfigs/opengraph_all_good.yaml === RUN TestGoodConfigs/opengraph_all_good.yaml/with-thoth === RUN TestGoodConfigs/opengraph_all_good.yaml/without-thoth === RUN TestGoodConfigs/simple-weight.yaml === RUN TestGoodConfigs/simple-weight.yaml/with-thoth === RUN TestGoodConfigs/simple-weight.yaml/without-thoth === RUN TestGoodConfigs/status-codes-paranoid.json === RUN TestGoodConfigs/status-codes-paranoid.json/with-thoth === RUN TestGoodConfigs/status-codes-paranoid.json/without-thoth === RUN TestGoodConfigs/status-codes-paranoid.yaml === RUN TestGoodConfigs/status-codes-paranoid.yaml/with-thoth === RUN TestGoodConfigs/status-codes-paranoid.yaml/without-thoth === RUN TestGoodConfigs/status-codes-rfc.json === RUN TestGoodConfigs/status-codes-rfc.json/with-thoth === RUN TestGoodConfigs/status-codes-rfc.json/without-thoth === RUN TestGoodConfigs/status-codes-rfc.yaml === RUN TestGoodConfigs/status-codes-rfc.yaml/with-thoth === RUN TestGoodConfigs/status-codes-rfc.yaml/without-thoth === RUN TestGoodConfigs/thresholds.yaml === RUN TestGoodConfigs/thresholds.yaml/with-thoth === RUN TestGoodConfigs/thresholds.yaml/without-thoth === RUN TestGoodConfigs/weight-no-weight.yaml === RUN TestGoodConfigs/weight-no-weight.yaml/with-thoth === RUN TestGoodConfigs/weight-no-weight.yaml/without-thoth --- PASS: TestGoodConfigs (0.05s) --- PASS: TestGoodConfigs/allow_everyone.json (0.00s) --- PASS: TestGoodConfigs/allow_everyone.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/allow_everyone.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/block_cf_workers.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/challenge_cloudflare.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/challengemozilla.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/dns-ttl-custom.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/entropy.yaml (0.00s) --- PASS: TestGoodConfigs/entropy.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/entropy.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/everything_blocked.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/geoip_us.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.json (0.00s) --- PASS: TestGoodConfigs/git_client.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.yaml (0.00s) --- PASS: TestGoodConfigs/git_client.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/git_client.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_filesystem.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/import_keep_internet_working.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/impressum.yaml (0.00s) --- PASS: TestGoodConfigs/impressum.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/impressum.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/logging-file.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/logging-stdio.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/no-thresholds.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/old_xesite.json (0.00s) --- PASS: TestGoodConfigs/old_xesite.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/old_xesite.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/opengraph_all_good.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/simple-weight.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-paranoid.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.json/without-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/status-codes-rfc.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/thresholds.yaml (0.00s) --- PASS: TestGoodConfigs/thresholds.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/thresholds.yaml/without-thoth (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml/with-thoth (0.00s) --- PASS: TestGoodConfigs/weight-no-weight.yaml/without-thoth (0.00s) === RUN TestBadConfigs === RUN TestBadConfigs/badregexes.json policy_test.go:85: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` bot 2: config: bot entry for "headers-bad" is not valid: config.Bot: must set either user_agent_regex, path_regex, headers_regex, or remote_addresses === RUN TestBadConfigs/badregexes.yaml policy_test.go:85: config is not valid: bot 0: config: bot entry for "path-bad" is not valid: config.Bot: invalid path regex error parsing regexp: missing closing ): `a(b` bot 1: config: bot entry for "user-agent-bad" is not valid: config.Bot: invalid user agent regex error parsing regexp: missing closing ): `a(b` === RUN TestBadConfigs/dns-ttl-custom.yaml policy_test.go:85: can't parse policy config YAML ../config/testdata/bad/dns-ttl-custom.yaml: error unmarshaling JSON: while decoding JSON: json: cannot unmarshal string into Go struct field DnsTTL.dns_ttl.reverse of type int === RUN TestBadConfigs/import_and_bot.json policy_test.go:85: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestBadConfigs/import_and_bot.yaml policy_test.go:85: config is not valid: bot 0: config.BotOrImport: can't set bot rules and import values at the same time === RUN TestBadConfigs/import_invalid_file.json policy_test.go:85: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestBadConfigs/import_invalid_file.yaml policy_test.go:85: config is not valid: bot 0: config.ImportStatement: invalid source file: (data)/does-not-exist-fake-file.yaml: open does-not-exist-fake-file.yaml: file does not exist === RUN TestBadConfigs/impressum-no-footer.yaml policy_test.go:85: errors validating policy config ../config/testdata/bad/impressum-no-footer.yaml: config: missing value: impressum footer must be defined === RUN TestBadConfigs/impressum-no-page-contents.yaml policy_test.go:85: errors validating policy config ../config/testdata/bad/impressum-no-page-contents.yaml: config: missing value: impressum page title must be defined config: missing value: impressum body title must be defined === RUN TestBadConfigs/invalid.json policy_test.go:85: config is not valid: bot 0: config.BotOrImport: rule definition is invalid, you must set either bot rules or an import statement, not both === RUN TestBadConfigs/invalid.yaml policy_test.go:85: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/logging-invalid-sink.yaml policy_test.go:85: config is not valid: config: must define at least one (1) bot rule config.Logging: invalid sink: sink nope is unknown to me === RUN TestBadConfigs/logging-no-parameters.yaml policy_test.go:85: config is not valid: config: must define at least one (1) bot rule config.Logging: missing value parameters in logging block logging file config is nil, why are you calling this? === RUN TestBadConfigs/multiple_expression_types.json policy_test.go:85: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestBadConfigs/multiple_expression_types.yaml policy_test.go:85: config is not valid: bot 0: config: bot entry for "multiple-expression-types" is not valid: config: expression block can't contain multiple expression types === RUN TestBadConfigs/nobots.json policy_test.go:85: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/nobots.yaml policy_test.go:85: config is not valid: config: must define at least one (1) bot rule === RUN TestBadConfigs/opengraph_bad_ttl.yaml policy_test.go:85: config is not valid: config.OpenGraph: invalid OpenGraph configuration config.OpenGraph: ttl does not parse as a Duration, see https://pkg.go.dev/time#ParseDuration (formatted like 5m -> 5 minutes, 2h -> 2 hours, etc): ParseDuration("taco") returned: time: invalid duration "taco" === RUN TestBadConfigs/regex_ends_newline.json policy_test.go:85: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestBadConfigs/regex_ends_newline.yaml policy_test.go:85: config is not valid: bot 0: config: bot entry for "user-agent-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): user agent regex: "Mozilla\n" bot 1: config: bot entry for "path-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): path regex: "^/evil/.*$\n" bot 2: config: bot entry for "headers-ends-newline" is not valid: config.Bot: regular expression ends with newline (try >- instead of > in yaml): header CF-Worker regex: ".*\n" === RUN TestBadConfigs/status-codes-0.json policy_test.go:85: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestBadConfigs/status-codes-0.yaml policy_test.go:85: config is not valid: status codes not valid: config.StatusCode: status code not valid, must be between 100 and 599: challenge is 0 config.StatusCode: status code not valid, must be between 100 and 599: deny is 0 === RUN TestBadConfigs/threshold-challenge-without-challenge.yaml policy_test.go:85: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestBadConfigs/thresholds.yaml policy_test.go:85: config is not valid: threshold 0: config: threshold entry for "extreme-suspicion" is not valid: config.Threshold: a threshold cannot have the WEIGH action === RUN TestBadConfigs/unparseable.json policy_test.go:85: can't parse policy config YAML ../config/testdata/bad/unparseable.json: error converting YAML to JSON: yaml: did not find expected node content === RUN TestBadConfigs/unparseable.yaml policy_test.go:85: can't parse policy config YAML ../config/testdata/bad/unparseable.yaml: error converting YAML to JSON: yaml: did not find expected node content --- PASS: TestBadConfigs (0.01s) --- PASS: TestBadConfigs/badregexes.json (0.00s) --- PASS: TestBadConfigs/badregexes.yaml (0.00s) --- PASS: TestBadConfigs/dns-ttl-custom.yaml (0.00s) --- PASS: TestBadConfigs/import_and_bot.json (0.00s) --- PASS: TestBadConfigs/import_and_bot.yaml (0.00s) --- PASS: TestBadConfigs/import_invalid_file.json (0.00s) --- PASS: TestBadConfigs/import_invalid_file.yaml (0.00s) --- PASS: TestBadConfigs/impressum-no-footer.yaml (0.00s) --- PASS: TestBadConfigs/impressum-no-page-contents.yaml (0.00s) --- PASS: TestBadConfigs/invalid.json (0.00s) --- PASS: TestBadConfigs/invalid.yaml (0.00s) --- PASS: TestBadConfigs/logging-invalid-sink.yaml (0.00s) --- PASS: TestBadConfigs/logging-no-parameters.yaml (0.00s) --- PASS: TestBadConfigs/multiple_expression_types.json (0.00s) --- PASS: TestBadConfigs/multiple_expression_types.yaml (0.00s) --- PASS: TestBadConfigs/nobots.json (0.00s) --- PASS: TestBadConfigs/nobots.yaml (0.00s) --- PASS: TestBadConfigs/opengraph_bad_ttl.yaml (0.00s) --- PASS: TestBadConfigs/regex_ends_newline.json (0.00s) --- PASS: TestBadConfigs/regex_ends_newline.yaml (0.00s) --- PASS: TestBadConfigs/status-codes-0.json (0.00s) --- PASS: TestBadConfigs/status-codes-0.yaml (0.00s) --- PASS: TestBadConfigs/threshold-challenge-without-challenge.yaml (0.00s) --- PASS: TestBadConfigs/thresholds.yaml (0.00s) --- PASS: TestBadConfigs/unparseable.json (0.00s) --- PASS: TestBadConfigs/unparseable.yaml (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/policy 0.106s === RUN TestListCheck_AndSemantics === RUN TestListCheck_AndSemantics/all_true === RUN TestListCheck_AndSemantics/one_false === RUN TestListCheck_AndSemantics/error_propagates --- PASS: TestListCheck_AndSemantics (0.00s) --- PASS: TestListCheck_AndSemantics/all_true (0.00s) --- PASS: TestListCheck_AndSemantics/one_false (0.00s) --- PASS: TestListCheck_AndSemantics/error_propagates (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/policy/checker 0.008s === RUN TestBotEnvironment === RUN TestBotEnvironment/missingHeader === RUN TestBotEnvironment/missingHeader/missing-header === RUN TestBotEnvironment/missingHeader/existing-header === RUN TestBotEnvironment/missingHeader/case-sensitive === RUN TestBotEnvironment/missingHeader/empty-headers === RUN TestBotEnvironment/missingHeader/real-world-sec-ch-ua === RUN TestBotEnvironment/missingHeader/browser-with-sec-ch-ua === RUN TestBotEnvironment/missingHeader/function-compilation === RUN TestBotEnvironment/segments === RUN TestBotEnvironment/segments/simple === RUN TestBotEnvironment/segments/two_segments_without_trailing_slash === RUN TestBotEnvironment/segments/at_least_two_segments === RUN TestBotEnvironment/segments/at_most_two_segments === RUN TestBotEnvironment/segments/invalid === RUN TestBotEnvironment/segments/invalid/segments_of_headers === RUN TestBotEnvironment/segments/invalid/invalid_path_type environment_test.go:241: no such overload: segments(int) === RUN TestBotEnvironment/segments/invalid/invalid_path environment_test.go:241: path does not start with / === RUN TestBotEnvironment/segments/function-compilation === RUN TestBotEnvironment/regexSafe === RUN TestBotEnvironment/regexSafe/complex-test === RUN TestBotEnvironment/regexSafe/backslash-test === RUN TestBotEnvironment/regexSafe/function-compilation === RUN TestBotEnvironment/dnsFunctions === RUN TestBotEnvironment/dnsFunctions/reverseDNS === RUN TestBotEnvironment/dnsFunctions/reverseDNS/success === RUN TestBotEnvironment/dnsFunctions/reverseDNS/not-found === RUN TestBotEnvironment/dnsFunctions/reverseDNS/error 2025/12/29 14:01:42 ERROR DNS: reverse lookup failed addr=error-addr err="some dns error" === RUN TestBotEnvironment/dnsFunctions/lookupHost === RUN TestBotEnvironment/dnsFunctions/lookupHost/success === RUN TestBotEnvironment/dnsFunctions/lookupHost/not-found === RUN TestBotEnvironment/dnsFunctions/lookupHost/error 2025/12/29 14:01:42 ERROR DNS: forward lookup failed host=error-host err="some dns error" === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS/success 2025/12/29 14:01:42 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS/failure 2025/12/29 14:01:42 INFO DNS: could not confirm original IP in forward lookups addr=1.2.3.4 === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS/reverse-lookup-fails 2025/12/29 14:01:42 ERROR DNS: reverse lookup failed addr=1.1.1.1 err="reverse lookup failed" === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS/success-with-pattern 2025/12/29 14:01:42 INFO DNS: forward lookup confirmed original IP name=dns.google addr=8.8.8.8 === RUN TestBotEnvironment/dnsFunctions/verifyFCrDNS/failure-with-pattern === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv4 === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6 === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6-full === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6-loopback === RUN TestBotEnvironment/dnsFunctions/arpaReverseIP/invalid-ip --- PASS: TestBotEnvironment (0.01s) --- PASS: TestBotEnvironment/missingHeader (0.00s) --- PASS: TestBotEnvironment/missingHeader/missing-header (0.00s) --- PASS: TestBotEnvironment/missingHeader/existing-header (0.00s) --- PASS: TestBotEnvironment/missingHeader/case-sensitive (0.00s) --- PASS: TestBotEnvironment/missingHeader/empty-headers (0.00s) --- PASS: TestBotEnvironment/missingHeader/real-world-sec-ch-ua (0.00s) --- PASS: TestBotEnvironment/missingHeader/browser-with-sec-ch-ua (0.00s) --- PASS: TestBotEnvironment/missingHeader/function-compilation (0.00s) --- PASS: TestBotEnvironment/segments (0.00s) --- PASS: TestBotEnvironment/segments/simple (0.00s) --- PASS: TestBotEnvironment/segments/two_segments_without_trailing_slash (0.00s) --- PASS: TestBotEnvironment/segments/at_least_two_segments (0.00s) --- PASS: TestBotEnvironment/segments/at_most_two_segments (0.00s) --- PASS: TestBotEnvironment/segments/invalid (0.00s) --- PASS: TestBotEnvironment/segments/invalid/segments_of_headers (0.00s) --- PASS: TestBotEnvironment/segments/invalid/invalid_path_type (0.00s) --- PASS: TestBotEnvironment/segments/invalid/invalid_path (0.00s) --- PASS: TestBotEnvironment/segments/function-compilation (0.00s) --- PASS: TestBotEnvironment/regexSafe (0.00s) --- PASS: TestBotEnvironment/regexSafe/complex-test (0.00s) --- PASS: TestBotEnvironment/regexSafe/backslash-test (0.00s) --- PASS: TestBotEnvironment/regexSafe/function-compilation (0.00s) --- PASS: TestBotEnvironment/dnsFunctions (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/reverseDNS (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/reverseDNS/success (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/reverseDNS/not-found (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/reverseDNS/error (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/lookupHost (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/lookupHost/success (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/lookupHost/not-found (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/lookupHost/error (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS/success (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS/failure (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS/reverse-lookup-fails (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS/success-with-pattern (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/verifyFCrDNS/failure-with-pattern (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv4 (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6 (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6-full (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP/ipv6-loopback (0.00s) --- PASS: TestBotEnvironment/dnsFunctions/arpaReverseIP/invalid-ip (0.00s) === RUN TestThresholdEnvironment === RUN TestThresholdEnvironment/weight-variable-available === RUN TestThresholdEnvironment/weight-variable-false-case === RUN TestThresholdEnvironment/missingHeader-not-available --- PASS: TestThresholdEnvironment (0.00s) --- PASS: TestThresholdEnvironment/weight-variable-available (0.00s) --- PASS: TestThresholdEnvironment/weight-variable-false-case (0.00s) --- PASS: TestThresholdEnvironment/missingHeader-not-available (0.00s) === RUN TestNewEnvironment === RUN TestNewEnvironment/randInt-function-compilation === RUN TestNewEnvironment/randInt-range-validation === RUN TestNewEnvironment/strings-extension-size === RUN TestNewEnvironment/strings-extension-contains === RUN TestNewEnvironment/strings-extension-startsWith --- PASS: TestNewEnvironment (0.00s) --- PASS: TestNewEnvironment/randInt-function-compilation (0.00s) --- PASS: TestNewEnvironment/randInt-range-validation (0.00s) --- PASS: TestNewEnvironment/strings-extension-size (0.00s) --- PASS: TestNewEnvironment/strings-extension-contains (0.00s) --- PASS: TestNewEnvironment/strings-extension-startsWith (0.00s) === RUN TestHTTPHeaders === RUN TestHTTPHeaders/contains-existing-header === RUN TestHTTPHeaders/not-contains-missing-header === RUN TestHTTPHeaders/get-existing-header === RUN TestHTTPHeaders/not-get-missing-header --- PASS: TestHTTPHeaders (0.00s) --- PASS: TestHTTPHeaders/contains-existing-header (0.00s) --- PASS: TestHTTPHeaders/not-contains-missing-header (0.00s) --- PASS: TestHTTPHeaders/get-existing-header (0.00s) --- PASS: TestHTTPHeaders/not-get-missing-header (0.00s) === RUN TestURLValues === RUN TestURLValues/contains-existing-key === RUN TestURLValues/not-contains-missing-key === RUN TestURLValues/get-existing-key === RUN TestURLValues/not-get-missing-key --- PASS: TestURLValues (0.00s) --- PASS: TestURLValues/contains-existing-key (0.00s) --- PASS: TestURLValues/not-contains-missing-key (0.00s) --- PASS: TestURLValues/get-existing-key (0.00s) --- PASS: TestURLValues/not-get-missing-key (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/policy/expressions 0.026s === RUN TestJSON --- PASS: TestJSON (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/store 0.005s ? github.com/TecharoHQ/anubis/lib/store/all [no test files] === RUN TestImpl bbolt_test.go:13: /tmp/TestImpl3594253515/001/db === RUN TestImpl/basic_get_set_delete === PAUSE TestImpl/basic_get_set_delete === RUN TestImpl/expires === PAUSE TestImpl/expires === CONT TestImpl/basic_get_set_delete === CONT TestImpl/expires --- PASS: TestImpl (0.00s) --- PASS: TestImpl/basic_get_set_delete (0.00s) --- PASS: TestImpl/expires (0.16s) === RUN TestFactoryValid === RUN TestFactoryValid/bad_config === RUN TestFactoryValid/invalid_config === RUN TestFactoryValid/invalid_config/missing_path --- PASS: TestFactoryValid (0.00s) --- PASS: TestFactoryValid/bad_config (0.00s) --- PASS: TestFactoryValid/invalid_config (0.00s) --- PASS: TestFactoryValid/invalid_config/missing_path (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/store/bbolt 0.161s === RUN TestImpl === RUN TestImpl/basic_get_set_delete === PAUSE TestImpl/basic_get_set_delete === RUN TestImpl/expires === PAUSE TestImpl/expires === CONT TestImpl/basic_get_set_delete === CONT TestImpl/expires --- PASS: TestImpl (0.00s) --- PASS: TestImpl/basic_get_set_delete (0.00s) --- PASS: TestImpl/expires (0.16s) PASS ok github.com/TecharoHQ/anubis/lib/store/memory 0.160s === RUN TestImpl === RUN TestImpl/basic_get_set_delete === PAUSE TestImpl/basic_get_set_delete === RUN TestImpl/expires === PAUSE TestImpl/expires === CONT TestImpl/basic_get_set_delete === CONT TestImpl/expires --- PASS: TestImpl (0.00s) --- PASS: TestImpl/basic_get_set_delete (0.00s) --- PASS: TestImpl/expires (0.16s) === RUN TestKeyNormalization --- PASS: TestKeyNormalization (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/store/s3api 0.163s ? github.com/TecharoHQ/anubis/lib/store/storetest [no test files] === RUN TestImpl testing.go:26: Recovered from panic: rootless Docker not found. Docker is not running. Testcontainers can't perform is work without it --- SKIP: TestImpl (0.00s) === RUN TestFactoryValid === RUN TestFactoryValid/empty_config === RUN TestFactoryValid/valid_URL_only === RUN TestFactoryValid/invalid_URL === RUN TestFactoryValid/valid_sentinel_config === RUN TestFactoryValid/sentinel_missing_masterName === RUN TestFactoryValid/sentinel_missing_addr === RUN TestFactoryValid/sentinel_empty_addr === RUN TestFactoryValid/sentinel_missing_password === RUN TestFactoryValid/sentinel_with_optional_fields === RUN TestFactoryValid/sentinel_single_address_(not_array) === RUN TestFactoryValid/sentinel_mixed_empty_and_valid_addresses --- PASS: TestFactoryValid (0.00s) --- PASS: TestFactoryValid/empty_config (0.00s) --- PASS: TestFactoryValid/valid_URL_only (0.00s) --- PASS: TestFactoryValid/invalid_URL (0.00s) --- PASS: TestFactoryValid/valid_sentinel_config (0.00s) --- PASS: TestFactoryValid/sentinel_missing_masterName (0.00s) --- PASS: TestFactoryValid/sentinel_missing_addr (0.00s) --- PASS: TestFactoryValid/sentinel_empty_addr (0.00s) --- PASS: TestFactoryValid/sentinel_missing_password (0.00s) --- PASS: TestFactoryValid/sentinel_with_optional_fields (0.00s) --- PASS: TestFactoryValid/sentinel_single_address_(not_array) (0.00s) --- PASS: TestFactoryValid/sentinel_mixed_empty_and_valid_addresses (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/store/valkey 0.028s === RUN TestASNChecker asnchecker_test.go:16: using mock thoth === RUN TestASNChecker/{1.1.1.1_true_false} === RUN TestASNChecker/{2.2.2.2_false_false} === RUN TestASNChecker/{taco_false_false} 2025/12/29 14:01:42 ERROR error contacting thoth, please contact support err="ParseAddr(\"taco\"): unable to parse IP" actionable=true === RUN TestASNChecker/{127.0.0.1_false_false} --- PASS: TestASNChecker (0.00s) --- PASS: TestASNChecker/{1.1.1.1_true_false} (0.00s) --- PASS: TestASNChecker/{2.2.2.2_false_false} (0.00s) --- PASS: TestASNChecker/{taco_false_false} (0.00s) --- PASS: TestASNChecker/{127.0.0.1_false_false} (0.00s) === RUN TestGeoIPChecker geoipchecker_test.go:15: using mock thoth === RUN TestGeoIPChecker/{1.1.1.1_true_false} === RUN TestGeoIPChecker/{2.2.2.2_false_false} === RUN TestGeoIPChecker/{taco_false_false} 2025/12/29 14:01:42 ERROR error contacting thoth, please contact support err="ParseAddr(\"taco\"): unable to parse IP" actionable=true === RUN TestGeoIPChecker/{127.0.0.1_false_false} --- PASS: TestGeoIPChecker (0.00s) --- PASS: TestGeoIPChecker/{1.1.1.1_true_false} (0.00s) --- PASS: TestGeoIPChecker/{2.2.2.2_false_false} (0.00s) --- PASS: TestGeoIPChecker/{taco_false_false} (0.00s) --- PASS: TestGeoIPChecker/{127.0.0.1_false_false} (0.00s) === RUN TestNew thoth_test.go:31: using mock thoth --- PASS: TestNew (0.00s) PASS ok github.com/TecharoHQ/anubis/lib/thoth 0.011s ? github.com/TecharoHQ/anubis/lib/thoth/thothmock [no test files] ? github.com/TecharoHQ/anubis/utils/cmd/backoff-retry [no test files] ? github.com/TecharoHQ/anubis/web [no test files] ? github.com/TecharoHQ/anubis/xess [no test files] >>> anubis: Entering fakeroot... libfakeroot internal error: payload not recognized! >>> anubis-doc*: Running split function doc... 'usr/share/licenses' -> '/home/buildozer/aports/community/anubis/pkg/anubis-doc/usr/share/licenses' >>> anubis-doc*: Preparing subpackage anubis-doc... >>> anubis-doc*: Running postcheck for anubis-doc >>> anubis-openrc*: Running split function openrc... libfakeroot internal error: payload not recognized! 'etc/conf.d' -> '/home/buildozer/aports/community/anubis/pkg/anubis-openrc/etc/conf.d' 'etc/init.d' -> '/home/buildozer/aports/community/anubis/pkg/anubis-openrc/etc/init.d' >>> anubis-openrc*: Preparing subpackage anubis-openrc... >>> anubis-openrc*: Running postcheck for anubis-openrc >>> anubis*: Running postcheck for anubis >>> anubis*: Preparing package anubis... >>> anubis*: Stripping binaries >>> anubis*: Scanning shared objects >>> anubis-doc*: Tracing dependencies... >>> anubis-doc*: Package size: 1.0 KB >>> anubis-doc*: Compressing data... >>> anubis-doc*: Create checksum... >>> anubis-doc*: Create anubis-doc-1.24.0-r0.apk >>> anubis-openrc*: Tracing dependencies... >>> anubis-openrc*: Package size: 294.0 B >>> anubis-openrc*: Compressing data... >>> anubis-openrc*: Create checksum... >>> anubis-openrc*: Create anubis-openrc-1.24.0-r0.apk >>> anubis*: Tracing dependencies... so:libc.musl-x86_64.so.1 >>> anubis*: Package size: 39.2 MB >>> anubis*: Compressing data... >>> anubis*: Create checksum... >>> anubis*: Create anubis-1.24.0-r0.apk >>> anubis: Build complete at Mon, 29 Dec 2025 14:01:47 +0000 elapsed time 0h 0m 36s >>> anubis: Cleaning up srcdir >>> anubis: Cleaning up pkgdir >>> anubis: Uninstalling dependencies... (1/2) Purging .makedepends-anubis (20251229.140112) (2/2) Purging go (1.25.5-r0) Executing busybox-1.37.0-r30.trigger OK: 441.2 MiB in 107 packages >>> anubis: Updating the community/x86_64 repository index... >>> anubis: Signing the index...