autocommit 2022-05-02 00:00:45 CEST
This commit is contained in:
parent
04580c4aeb
commit
552c8a9950
8 changed files with 155 additions and 43 deletions
|
|
@ -1,8 +1,8 @@
|
|||
use {
|
||||
crate::{
|
||||
format::ARGB8888,
|
||||
it::{test_error::TestError, testrun::TestRun},
|
||||
theme::Color,
|
||||
rect::Rect,
|
||||
tree::Node,
|
||||
},
|
||||
std::rc::Rc,
|
||||
};
|
||||
|
|
@ -14,43 +14,26 @@ async fn test(run: Rc<TestRun>) -> Result<(), TestError> {
|
|||
run.backend.install_default();
|
||||
|
||||
let client = run.create_client().await?;
|
||||
let surface = client.comp.create_surface().await?;
|
||||
let xdg_surface = client.xdg.create_xdg_surface(surface.id).await?;
|
||||
let xdg_toplevel = xdg_surface.create_toplevel().await?;
|
||||
surface.commit();
|
||||
client.sync().await;
|
||||
|
||||
{
|
||||
let pool = client.shm.create_pool(0)?;
|
||||
let buffer = pool.create_buffer(0, 0, 0, 0, ARGB8888)?;
|
||||
xdg_surface.ack_configure(xdg_surface.last_serial.get());
|
||||
surface.attach(buffer.id);
|
||||
surface.commit();
|
||||
client.sync().await;
|
||||
}
|
||||
let window = client.create_window().await?;
|
||||
window.map().await?;
|
||||
|
||||
tassert_eq!(xdg_toplevel.width.get(), 800);
|
||||
tassert!(xdg_toplevel.height.get() >= 500);
|
||||
tassert_eq!(window.tl.width.get(), 800);
|
||||
tassert_eq!(
|
||||
window.tl.height.get(),
|
||||
600 - 2 * (run.state.theme.title_height.get() + 1)
|
||||
);
|
||||
|
||||
{
|
||||
let pool = client
|
||||
.shm
|
||||
.create_pool((xdg_toplevel.width.get() * xdg_toplevel.height.get() * 4) as _)?;
|
||||
let buffer = pool.create_buffer(
|
||||
tassert_eq!(
|
||||
window.tl.server.node_absolute_position(),
|
||||
Rect::new_sized(
|
||||
0,
|
||||
xdg_toplevel.width.get(),
|
||||
xdg_toplevel.height.get(),
|
||||
xdg_toplevel.width.get() * 4,
|
||||
ARGB8888,
|
||||
)?;
|
||||
buffer.fill(Color::from_rgba_straight(255, 0, 0, 100));
|
||||
xdg_surface.ack_configure(xdg_surface.last_serial.get());
|
||||
surface.attach(buffer.id);
|
||||
surface.commit();
|
||||
}
|
||||
|
||||
let screenshot = client.take_screenshot().await?;
|
||||
std::fs::write(format!("{}/screenshot.qoi", run.dir), screenshot)?;
|
||||
2 * (run.state.theme.title_height.get() + 1),
|
||||
window.tl.width.get(),
|
||||
window.tl.height.get(),
|
||||
)
|
||||
.unwrap()
|
||||
);
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
|
|
|||
38
src/it/tests/t0003_multi_window.rs
Normal file
38
src/it/tests/t0003_multi_window.rs
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
use {
|
||||
crate::{
|
||||
it::{test_error::TestError, testrun::TestRun},
|
||||
rect::Rect,
|
||||
tree::Node,
|
||||
},
|
||||
std::rc::Rc,
|
||||
};
|
||||
|
||||
testcase!();
|
||||
|
||||
/// Create and map two surfaces
|
||||
async fn test(run: Rc<TestRun>) -> Result<(), TestError> {
|
||||
run.backend.install_default();
|
||||
|
||||
let client = run.create_client().await?;
|
||||
|
||||
let window = client.create_window().await?;
|
||||
window.map().await?;
|
||||
|
||||
let window2 = client.create_window().await?;
|
||||
window2.map().await?;
|
||||
|
||||
let otop = 2 * (run.state.theme.title_height.get() + 1);
|
||||
let bw = run.state.theme.border_width.get();
|
||||
|
||||
tassert_eq!(
|
||||
window.tl.server.node_absolute_position(),
|
||||
Rect::new_sized(0, otop, (800 - bw) / 2, 600 - otop).unwrap()
|
||||
);
|
||||
|
||||
tassert_eq!(
|
||||
window2.tl.server.node_absolute_position(),
|
||||
Rect::new_sized((800 - bw) / 2 + bw, otop, (800 - bw) / 2, 600 - otop).unwrap()
|
||||
);
|
||||
|
||||
Ok(())
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue