lithtml 0.8.0

A lightweight and fast HTML parser for Rust, designed to handle both full HTML documents and fragments efficiently.
Documentation
use indoc::indoc;
use insta::assert_json_snapshot;
use lithtml::{Dom, Result};

#[test]
fn it_can_parse_document_with_just_text() -> Result<()> {
    let html = "hello world";
    let dom = Dom::parse(html)?;
    assert_json_snapshot!(dom);
    Ok(())
}

#[test]
fn it_can_parse_document_with_text_and_line_breaks() -> Result<()> {
    let html = indoc!(
        r"
        hello world
        here's another line for you!
        The end
    "
    );
    let dom = Dom::parse(html)?;
    assert_json_snapshot!(dom);
    Ok(())
}

#[test]
fn it_can_parse_document_with_multiple_text_elements() -> Result<()> {
    let html = indoc!(
        r"
        hello world
        here's another line for you!
        <div/>
        The end
    "
    );
    let dom = Dom::parse(html)?;
    assert_json_snapshot!(dom);
    Ok(())
}

#[test]
fn it_can_parse_text_with_chevron() -> Result<()> {
    let html = indoc!(r"hello <> world");
    let dom = Dom::parse(html)?;
    assert_json_snapshot!(dom);
    Ok(())
}

#[test]
fn it_can_parse_text_in_paragraph_with_weird_formatting() -> Result<()> {
    let html = indoc!(
        r"
        <p>
            This is a <b>para</b>gra<b>ph</b> with some<i> weird </i> formatting.
        </p>
    "
    );
    let dom = Dom::parse(html)?;
    assert_json_snapshot!(dom);
    Ok(())
}