Extend app frame planning to tick and resize

This commit is contained in:
2026-06-05 06:23:00 +02:00
parent 48a4547f51
commit 548b6d3ae5
8 changed files with 205 additions and 24 deletions

View File

@@ -1,6 +1,8 @@
#include "app_core/app_frame.h"
#include "test_harness.h"
#include <cmath>
namespace {
void initial_surface_matches_legacy_default(pp::tests::Harness& harness)
@@ -63,6 +65,42 @@ void draw_plan_respects_vr_visibility_modes(pp::tests::Harness& harness)
PP_EXPECT(harness, !vr_only.draw_main_ui);
}
void tick_plan_selects_available_layouts(pp::tests::Harness& harness)
{
const auto both = pp::app::plan_app_frame_tick(true, true);
const auto main_only = pp::app::plan_app_frame_tick(false, true);
const auto none = pp::app::plan_app_frame_tick(false, false);
PP_EXPECT(harness, both.tick_designer_layout);
PP_EXPECT(harness, both.tick_main_layout);
PP_EXPECT(harness, !main_only.tick_designer_layout);
PP_EXPECT(harness, main_only.tick_main_layout);
PP_EXPECT(harness, !none.tick_designer_layout);
PP_EXPECT(harness, !none.tick_main_layout);
}
void resize_plan_projects_render_target_and_redraw(pp::tests::Harness& harness)
{
const auto plan = pp::app::plan_app_resize(1280.9F, 720.1F);
PP_EXPECT(harness, plan);
if (plan) {
PP_EXPECT(harness, plan.value().width == 1280.9F);
PP_EXPECT(harness, plan.value().height == 720.1F);
PP_EXPECT(harness, plan.value().render_target_width == 1280);
PP_EXPECT(harness, plan.value().render_target_height == 720);
PP_EXPECT(harness, plan.value().recreate_ui_render_target);
PP_EXPECT(harness, plan.value().request_redraw);
}
}
void resize_plan_rejects_invalid_dimensions(pp::tests::Harness& harness)
{
PP_EXPECT(harness, !pp::app::plan_app_resize(0.0F, 720.0F));
PP_EXPECT(harness, !pp::app::plan_app_resize(1280.0F, -1.0F));
PP_EXPECT(harness, !pp::app::plan_app_resize(std::nanf(""), 720.0F));
}
} // namespace
int main()
@@ -74,5 +112,8 @@ int main()
harness.run("draw plan selects canvas and UI passes", draw_plan_selects_canvas_and_ui_passes);
harness.run("draw plan skips missing canvas document", draw_plan_skips_missing_canvas_document);
harness.run("draw plan respects VR visibility modes", draw_plan_respects_vr_visibility_modes);
harness.run("tick plan selects available layouts", tick_plan_selects_available_layouts);
harness.run("resize plan projects render target and redraw", resize_plan_projects_render_target_and_redraw);
harness.run("resize plan rejects invalid dimensions", resize_plan_rejects_invalid_dimensions);
return harness.finish();
}