chromey 2.48.2

Concurrent chrome devtools protocol automation library for Rust
Documentation
//! Phase 2 smoke test: drive `Handler::run_parallel()` end-to-end against the
//! in-process CDP mock and assert that N pages each issuing M sequential
//! commands all round-trip cleanly. Mirrors `parallel_pages_smoke.rs` but
//! against the parallel driver.

#![cfg(feature = "parallel-handler")]

#[path = "support/cdp_mock.rs"]
mod cdp_mock;

use std::sync::Arc;
use std::time::Duration;

use chromiumoxide::handler::HandlerConfig;
use chromiumoxide::Browser;
use chromiumoxide_cdp::cdp::js_protocol::runtime::EvaluateParams;

#[tokio::test(flavor = "multi_thread", worker_threads = 4)]
async fn parallel_handler_round_trips_n_pages() {
    let mock = cdp_mock::CdpMock::spawn().await;
    let url = mock.ws_url();

    let cfg = HandlerConfig {
        request_timeout: Duration::from_secs(5),
        ..Default::default()
    };
    let (browser, handler) = Browser::connect_with_config(url, cfg)
        .await
        .expect("connect to mock");
    let _h = tokio::spawn(handler.run_parallel());
    let browser = Arc::new(browser);

    const PAGES: usize = 4;
    const CMDS_PER_PAGE: usize = 8;

    let mut create_tasks = Vec::with_capacity(PAGES);
    for _ in 0..PAGES {
        let b = browser.clone();
        create_tasks.push(tokio::spawn(async move {
            b.new_page("about:blank").await.expect("new_page")
        }));
    }
    let pages = futures_util::future::join_all(create_tasks)
        .await
        .into_iter()
        .map(|r| r.expect("join"))
        .collect::<Vec<_>>();

    let mut cmd_tasks = Vec::with_capacity(PAGES * CMDS_PER_PAGE);
    for page in &pages {
        for i in 0..CMDS_PER_PAGE {
            let p = page.clone();
            cmd_tasks.push(tokio::spawn(async move {
                p.execute(EvaluateParams::new(format!("'cmd-{i}'")))
                    .await
                    .map(|_| ())
            }));
        }
    }

    let results = futures_util::future::join_all(cmd_tasks).await;
    let mut ok = 0usize;
    for r in results {
        if r.expect("join").is_ok() {
            ok += 1;
        }
    }
    assert_eq!(
        ok,
        PAGES * CMDS_PER_PAGE,
        "all parallel commands across {PAGES} pages should succeed under run_parallel()"
    );

    drop(browser);
}