119 lines
4.4 KiB
C++
119 lines
4.4 KiB
C++
#include "app_core/app_input.h"
|
|
#include "test_harness.h"
|
|
|
|
#include <cmath>
|
|
|
|
namespace {
|
|
|
|
void pointer_plan_normalizes_coordinates_and_routes_designer_first(pp::tests::Harness& harness)
|
|
{
|
|
const auto plan = pp::app::plan_app_pointer_dispatch(100.0F, 50.0F, 2.0F, true, true);
|
|
|
|
PP_EXPECT(harness, plan);
|
|
PP_EXPECT(harness, plan.value().request_redraw);
|
|
PP_EXPECT(harness, plan.value().dispatch_designer_first);
|
|
PP_EXPECT(harness, plan.value().dispatch_main_if_not_consumed);
|
|
PP_EXPECT(harness, plan.value().normalized_x == 50.0F);
|
|
PP_EXPECT(harness, plan.value().normalized_y == 25.0F);
|
|
}
|
|
|
|
void pointer_plan_rejects_invalid_zoom_or_coordinates(pp::tests::Harness& harness)
|
|
{
|
|
PP_EXPECT(harness, !pp::app::plan_app_pointer_dispatch(100.0F, 50.0F, 0.0F, true, true));
|
|
PP_EXPECT(harness, !pp::app::plan_app_pointer_dispatch(std::nanf(""), 50.0F, 1.0F, true, true));
|
|
}
|
|
|
|
void mouse_cancel_preserves_designer_first_routing(pp::tests::Harness& harness)
|
|
{
|
|
const auto designer = pp::app::plan_app_mouse_cancel_dispatch(true, true);
|
|
const auto main = pp::app::plan_app_mouse_cancel_dispatch(false, true);
|
|
|
|
PP_EXPECT(harness, designer.request_redraw);
|
|
PP_EXPECT(harness, designer.dispatch_designer_first);
|
|
PP_EXPECT(harness, designer.dispatch_main_if_not_consumed);
|
|
PP_EXPECT(harness, !main.dispatch_designer_first);
|
|
PP_EXPECT(harness, main.dispatch_main_if_not_consumed);
|
|
}
|
|
|
|
void gesture_plan_computes_midpoint_distance_and_delta(pp::tests::Harness& harness)
|
|
{
|
|
const auto plan = pp::app::plan_app_gesture_dispatch(
|
|
0.0F,
|
|
0.0F,
|
|
6.0F,
|
|
8.0F,
|
|
0.0F,
|
|
0.0F,
|
|
3.0F,
|
|
4.0F,
|
|
2.0F,
|
|
true);
|
|
|
|
PP_EXPECT(harness, plan);
|
|
PP_EXPECT(harness, plan.value().dispatch_main);
|
|
PP_EXPECT(harness, plan.value().normalized_x == 1.5F);
|
|
PP_EXPECT(harness, plan.value().normalized_y == 2.0F);
|
|
PP_EXPECT(harness, plan.value().distance == 10.0F);
|
|
PP_EXPECT(harness, plan.value().distance_delta == 5.0F);
|
|
PP_EXPECT(harness, plan.value().position_delta_x == 1.5F);
|
|
PP_EXPECT(harness, plan.value().position_delta_y == 2.0F);
|
|
}
|
|
|
|
void gesture_plan_rejects_invalid_input(pp::tests::Harness& harness)
|
|
{
|
|
PP_EXPECT(
|
|
harness,
|
|
!pp::app::plan_app_gesture_dispatch(
|
|
0.0F,
|
|
0.0F,
|
|
1.0F,
|
|
1.0F,
|
|
0.0F,
|
|
0.0F,
|
|
1.0F,
|
|
1.0F,
|
|
-1.0F,
|
|
true));
|
|
}
|
|
|
|
void key_plan_tracks_state_and_vr_spacebar_sync(pp::tests::Harness& harness)
|
|
{
|
|
const auto down = pp::app::plan_app_key_down_dispatch(true, true, true);
|
|
const auto ordinary = pp::app::plan_app_key_down_dispatch(true, false, true);
|
|
const auto up = pp::app::plan_app_key_up_dispatch(true);
|
|
|
|
PP_EXPECT(harness, down.dispatch_main);
|
|
PP_EXPECT(harness, down.set_key_down);
|
|
PP_EXPECT(harness, down.sync_vr_camera_rotation);
|
|
PP_EXPECT(harness, ordinary.set_key_down);
|
|
PP_EXPECT(harness, !ordinary.sync_vr_camera_rotation);
|
|
PP_EXPECT(harness, up.dispatch_main);
|
|
PP_EXPECT(harness, !up.set_key_down);
|
|
}
|
|
|
|
void simple_input_plan_tracks_main_layout_availability(pp::tests::Harness& harness)
|
|
{
|
|
const auto available = pp::app::plan_app_main_input_dispatch(true);
|
|
const auto missing = pp::app::plan_app_main_input_dispatch(false);
|
|
|
|
PP_EXPECT(harness, available.request_redraw);
|
|
PP_EXPECT(harness, available.dispatch_main);
|
|
PP_EXPECT(harness, missing.request_redraw);
|
|
PP_EXPECT(harness, !missing.dispatch_main);
|
|
}
|
|
|
|
} // namespace
|
|
|
|
int main()
|
|
{
|
|
pp::tests::Harness harness;
|
|
harness.run("pointer plan normalizes coordinates and routes designer first", pointer_plan_normalizes_coordinates_and_routes_designer_first);
|
|
harness.run("pointer plan rejects invalid zoom or coordinates", pointer_plan_rejects_invalid_zoom_or_coordinates);
|
|
harness.run("mouse cancel preserves designer first routing", mouse_cancel_preserves_designer_first_routing);
|
|
harness.run("gesture plan computes midpoint distance and delta", gesture_plan_computes_midpoint_distance_and_delta);
|
|
harness.run("gesture plan rejects invalid input", gesture_plan_rejects_invalid_input);
|
|
harness.run("key plan tracks state and VR spacebar sync", key_plan_tracks_state_and_vr_spacebar_sync);
|
|
harness.run("simple input plan tracks main layout availability", simple_input_plan_tracks_main_layout_availability);
|
|
return harness.finish();
|
|
}
|