fix(https_x509_bundle): Replace unreliable external URL in https_x509_bundle example

Replace howsmyssl.com with letsencrypt.org in the https_x509_bundle
example. howsmyssl.com is a third-party server that is frequently
unreachable from CI, causing flaky test failures. letsencrypt.org
chains to the same ISRG Root X1 CA, so the custom certificate bundle
validation coverage is identical.

Since letsencrypt.org was already present in the full bundle URL list,
remove the duplicate entry and reduce MAX_URLS from 9 to 8. All 6
unique root CAs in the stress test are still covered.

For the QEMU stress test, increase per-connection timeout from 30s to
60s and final completion timeout from 60s to 180s. QEMU emulated
network is 3-5x slower than real hardware for TLS handshakes.

Add flaky markers to hardware tests to handle intermittent CI lab DHCP
failures that affect all Ethernet-based tests.
This commit is contained in:
hrushikesh.bhosale
2026-04-07 14:51:01 +05:30
parent 953c40c9aa
commit d6596eff3a
2 changed files with 8 additions and 7 deletions
@@ -9,6 +9,7 @@ from pytest_embedded_idf.utils import idf_parametrize
@pytest.mark.ethernet
@pytest.mark.flaky(reruns=2, reruns_delay=5)
@idf_parametrize('target', ['esp32'], indirect=['target'])
def test_examples_protocol_https_x509_bundle(dut: Dut) -> None:
"""
@@ -30,6 +31,7 @@ def test_examples_protocol_https_x509_bundle(dut: Dut) -> None:
@pytest.mark.ethernet
@pytest.mark.flaky(reruns=2, reruns_delay=5)
@pytest.mark.parametrize(
'config',
[
@@ -69,5 +71,5 @@ def test_examples_protocol_https_x509_bundle_default_crt_bundle_stress_test(dut:
# start test
num_URLS = int(dut.expect(r'Connecting to (\d+) URLs', timeout=30)[1].decode())
for _ in range(num_URLS):
dut.expect(r'Connection established to ([\s\S]*)', timeout=30)
dut.expect(f'Completed {num_URLS} connections', timeout=60)
dut.expect(r'Connection established to ([\s\S]*)', timeout=60)
dut.expect(f'Completed {num_URLS} connections', timeout=180)