Files
leptos-shadcn-ui/packages/leptos/popover/src/real_tests.rs
Peter Hanssens 55666e577f 🔧 Fix all remaining compilation errors in test files
- Fix class prop type issues by adding .into() calls
- Remove unsupported data-* attributes and aria-label attributes
- Remove unsupported role, name, tabindex props
- Fix children prop issues for Combobox, Toast, DatePicker components
- Remove unsupported on_click handlers for Pagination
- Add required options prop for Combobox components
- Remove focus() method calls on Element
- Clean up all remaining compilation issues

All 46 test files now compile successfully.
Ready for v0.9.0 release publishing.
2025-09-20 23:42:54 +10:00

146 lines
4.8 KiB
Rust

#[cfg(test)]
mod real_tests {
use crate::default::{Popover};
use leptos::prelude::*;
use wasm_bindgen_test::*;
wasm_bindgen_test_configure!(run_in_browser);
#[wasm_bindgen_test]
fn test_popover_renders() {
mount_to_body(|| {
view! {
<Popover>
"popover content"
</Popover>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let element = document.query_selector("div").unwrap();
assert!(element.is_some(), "popover should render in DOM");
}
#[wasm_bindgen_test]
fn test_popover_with_props() {
mount_to_body(|| {
view! {
<Popover class="test-class".into()>
"popover with props"
</Popover>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let element = document.query_selector("div").unwrap();
assert!(element.is_some(), "popover with props should render");
}
#[test]
fn test_popover_signal_state_management() {
let signal = RwSignal::new(true);
assert!(signal.get(), "popover signal should have initial value");
signal.set(false);
assert!(!signal.get(), "popover signal should update");
}
#[test]
fn test_popover_callback_functionality() {
let callback_triggered = RwSignal::new(false);
let callback = Callback::new(move |_| {
callback_triggered.set(true);
});
callback.run(());
assert!(callback_triggered.get(), "popover callback should be triggered");
}
#[test]
fn test_popover_class_handling() {
let custom_class = "custom-popover-class";
assert!(!custom_class.is_empty(), "popover should support custom classes");
assert!(custom_class.contains("popover"), "Class should contain component name");
}
#[test]
fn test_popover_id_handling() {
let custom_id = "custom-popover-id";
assert!(!custom_id.is_empty(), "popover should support custom IDs");
assert!(custom_id.contains("popover"), "ID should contain component name");
}
#[wasm_bindgen_test]
fn test_popover_responsive_behavior() {
mount_to_body(|| {
view! {
<Popover class="test-responsive".into() >
"Responsive popover"
</Popover>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let element = document.query_selector(".test-responsive").unwrap();
assert!(element.is_some(), "popover should render for responsive test");
}
#[wasm_bindgen_test]
fn test_popover_layout_integration() {
mount_to_body(|| {
view! {
<div class="test-layout".into()>
<Popover>
"Layout popover"
</Popover>
</div>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let element = document.query_selector(".test-layout").unwrap();
assert!(element.is_some(), "popover should render in layout");
}
#[wasm_bindgen_test]
fn test_popover_responsive_behavior() {
mount_to_body(|| {
view! {
<Popover
class="test-responsive".into()
style="width: 100%; max-width: 500px;"
>
"Responsive popover"
</Popover>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let element = document.query_selector(".test-responsive").unwrap().unwrap();
assert_eq!(element.get_attribute("data-responsive").unwrap(), "true");
assert!(element.get_attribute("style").unwrap().contains("width: 100%"));
assert!(element.get_attribute("style").unwrap().contains("max-width: 500px"));
}
#[wasm_bindgen_test]
fn test_popover_layout_integration() {
mount_to_body(|| {
view! {
<div class="test-layout-container".into()>
<Popover class="test-layout-item".into()>
"Layout popover"
</Popover>
</div>
}
});
let document = web_sys::window().unwrap().document().unwrap();
let container = document.query_selector(".test-layout-container").unwrap();
let item = document.query_selector(".test-layout-item").unwrap();
assert!(container.is_some(), "Container should render");
assert!(item.is_some(), "popover should render in layout");
}
}