| Crates.io | html-compare-rs |
| lib.rs | html-compare-rs |
| version | 0.3.0 |
| created_at | 2024-11-26 05:38:37.499286+00 |
| updated_at | 2024-12-05 21:02:13.806559+00 |
| description | A library for comparing HTML with configurable comparison options |
| homepage | |
| repository | https://github.com/systemsoverload/html-compare-rs |
| max_upload_size | |
| id | 1461214 |
| size | 45,534 |
A Rust library for comparing HTML content with configurable comparison options. Useful for testing HTML output while ignoring differences that don't affect the rendered result.
Just cargo add --dev html-compare-rs or add this to your Cargo.toml:
[dev-dependencies]
html-compare-rs = "0.1.0"
use html_compare_rs::{assert_html_eq, HtmlCompareOptions};
// Basic comparison
assert_html_eq!(
"<div><p>Hello</p></div>",
"<div>\n <p>Hello</p>\n</div>"
);
// Custom comparison options
assert_html_eq!(
"<div class='test'><p>First</p><p>Second</p></div>",
"<div class='different'><p>Second</p><p>First</p></div>",
HtmlCompareOptions {
ignore_attributes: true,
ignore_sibling_order: true,
..Default::default()
}
);
The library provides both a programmatic API and test assertions:
use html_compare_rs::{HtmlComparer, assert_html_eq};
// Using the assertion macro (recommended for tests)
assert_html_eq!(
"<div><p>Hello</p></div>",
"<div><p>Hello</p></div>"
);
// Using the API directly
let comparer = HtmlComparer::new();
assert!(comparer.compare(
"<div><p>Hello</p></div>",
"<div><p>Hello</p></div>"
).is_ok());
Control how HTML is compared with HtmlCompareOptions:
use html_compare_rs::{HtmlCompareOptions, assert_html_eq};
let options = HtmlCompareOptions {
// Ignore whitespace between elements (default: true)
ignore_whitespace: true,
// Ignore all HTML attributes (default: false)
ignore_attributes: false,
// Ignore specific attributes
ignored_attributes: {
let mut set = std::collections::HashSet::new();
set.insert("class".to_string());
set
},
// Ignore text content (default: false)
ignore_text: false,
// Ignore HTML comments (default: true)
ignore_comments: true,
// Ignore sibling element order (default: false)
ignore_sibling_order: false,
};
assert_html_eq!(
"<div class='a'>First</div>",
"<div class='b'>First</div>",
options
);
Common comparison configurations are available as presets:
use html_compare_rs::{assert_html_eq, presets};
// Relaxed comparison - ignores formatting, attributes, and order
assert_html_eq!(
"<div class='a'><p>First</p><p>Second</p></div>",
"<div class='b'><p>Second</p><p>First</p></div>",
presets::relaxed()
);
// Strict comparison - only ignores whitespace
assert_html_eq!(
"<div class='test'>Content</div>",
"<div class='test'>Content</div>",
presets::strict()
);
// Markdown comparison - ignores IDs but preserves other attributes
assert_html_eq!(
"<h1 id='header-1'>Title</h1>",
"<h1 id='different'>Title</h1>",
presets::markdown()
);
By default, the library follows standard HTML whitespace rules:
ignore_whitespace is trueassert_html_eq!(
"<p>Hello World</p>",
"<p>Hello World</p>"
);
assert_html_eq!(
"<div>\n <p>\n Hello\n </p>\n</div>",
"<div><p>Hello</p></div>"
);
When comparisons fail, detailed error messages help identify the differences:
use html_compare_rs::assert_html_eq;
// This will panic with a detailed error message:
assert_html_eq!(
"<div class='test'>Content</div>",
"<div class='different'>Content</div>"
);
// Error:
// HTML comparison failed:
// Node mismatch: Attributes mismatch...
//
// left HTML:
// <div class='test'>Content</div>
//
// right HTML:
// <div class='different'>Content</div>
//
// options: ...
This project is licensed under the MIT License - see the LICENSE file for details.