Merge pull request #81305 from YuriSizov/theme-fix-tests-shadowing

Fix ThemeDB initialization in tests
This commit is contained in:
Yuri Sizov 2023-09-05 15:14:27 +02:00
commit 36cc4754f5
6 changed files with 45 additions and 28 deletions

View File

@ -570,9 +570,15 @@ Error Main::test_setup() {
ResourceLoader::load_path_remaps(); ResourceLoader::load_path_remaps();
// Initialize ThemeDB early so that scene types can register their theme items.
// Default theme will be initialized later, after modules and ScriptServer are ready.
initialize_theme_db();
register_scene_types(); register_scene_types();
register_driver_types(); register_driver_types();
register_scene_singletons();
initialize_modules(MODULE_INITIALIZATION_LEVEL_SCENE); initialize_modules(MODULE_INITIALIZATION_LEVEL_SCENE);
GDExtensionManager::get_singleton()->initialize_extensions(GDExtension::INITIALIZATION_LEVEL_SCENE); GDExtensionManager::get_singleton()->initialize_extensions(GDExtension::INITIALIZATION_LEVEL_SCENE);
@ -588,9 +594,7 @@ Error Main::test_setup() {
register_platform_apis(); register_platform_apis();
// Theme needs modules to be initialized so that sub-resources can be loaded. // Theme needs modules to be initialized so that sub-resources can be loaded.
initialize_theme_db(); theme_db->initialize_theme_noproject();
theme_db->initialize_theme();
register_scene_singletons();
initialize_navigation_server(); initialize_navigation_server();
@ -2561,9 +2565,15 @@ Error Main::setup2() {
OS::get_singleton()->benchmark_begin_measure("scene"); OS::get_singleton()->benchmark_begin_measure("scene");
// Initialize ThemeDB early so that scene types can register their theme items.
// Default theme will be initialized later, after modules and ScriptServer are ready.
initialize_theme_db();
register_scene_types(); register_scene_types();
register_driver_types(); register_driver_types();
register_scene_singletons();
initialize_modules(MODULE_INITIALIZATION_LEVEL_SCENE); initialize_modules(MODULE_INITIALIZATION_LEVEL_SCENE);
GDExtensionManager::get_singleton()->initialize_extensions(GDExtension::INITIALIZATION_LEVEL_SCENE); GDExtensionManager::get_singleton()->initialize_extensions(GDExtension::INITIALIZATION_LEVEL_SCENE);
@ -2581,11 +2591,6 @@ Error Main::setup2() {
register_platform_apis(); register_platform_apis();
// Theme needs modules to be initialized so that sub-resources can be loaded.
// Default theme is initialized later, after ScriptServer is ready.
initialize_theme_db();
register_scene_singletons();
GLOBAL_DEF_BASIC(PropertyInfo(Variant::STRING, "display/mouse_cursor/custom_image", PROPERTY_HINT_FILE, "*.png,*.webp"), String()); GLOBAL_DEF_BASIC(PropertyInfo(Variant::STRING, "display/mouse_cursor/custom_image", PROPERTY_HINT_FILE, "*.png,*.webp"), String());
GLOBAL_DEF_BASIC("display/mouse_cursor/custom_image_hotspot", Vector2()); GLOBAL_DEF_BASIC("display/mouse_cursor/custom_image_hotspot", Vector2());
GLOBAL_DEF_BASIC("display/mouse_cursor/tooltip_position_offset", Point2(10, 10)); GLOBAL_DEF_BASIC("display/mouse_cursor/tooltip_position_offset", Point2(10, 10));

View File

@ -91,6 +91,18 @@ void ThemeDB::initialize_theme_noproject() {
} }
} }
void ThemeDB::finalize_theme() {
if (!RenderingServer::get_singleton()) {
WARN_PRINT("Finalizing theme when there is no RenderingServer is an error; check the order of operations.");
}
default_theme.unref();
fallback_font.unref();
fallback_icon.unref();
fallback_stylebox.unref();
}
// Universal fallback Theme resources. // Universal fallback Theme resources.
void ThemeDB::set_default_theme(const Ref<Theme> &p_default) { void ThemeDB::set_default_theme(const Ref<Theme> &p_default) {

View File

@ -61,6 +61,7 @@ protected:
public: public:
void initialize_theme(); void initialize_theme();
void initialize_theme_noproject(); void initialize_theme_noproject();
void finalize_theme();
// Universal Theme resources // Universal Theme resources

View File

@ -43,8 +43,8 @@
namespace TestViewport { namespace TestViewport {
class NotificationControl : public Control { class NotificationControlViewport : public Control {
GDCLASS(NotificationControl, Control); GDCLASS(NotificationControlViewport, Control);
protected: protected:
void _notification(int p_what) { void _notification(int p_what) {
@ -63,11 +63,11 @@ public:
bool mouse_over = false; bool mouse_over = false;
}; };
// `NotificationControl`-derived class that additionally // `NotificationControlViewport`-derived class that additionally
// - allows start Dragging // - allows start Dragging
// - stores mouse information of last event // - stores mouse information of last event
class DragStart : public NotificationControl { class DragStart : public NotificationControlViewport {
GDCLASS(DragStart, NotificationControl); GDCLASS(DragStart, NotificationControlViewport);
public: public:
MouseButton last_mouse_button; MouseButton last_mouse_button;
@ -93,9 +93,9 @@ public:
} }
}; };
// `NotificationControl`-derived class that acts as a Drag and Drop target. // `NotificationControlViewport`-derived class that acts as a Drag and Drop target.
class DragTarget : public NotificationControl { class DragTarget : public NotificationControlViewport {
GDCLASS(DragTarget, NotificationControl); GDCLASS(DragTarget, NotificationControlViewport);
public: public:
Variant drag_data; Variant drag_data;

View File

@ -38,8 +38,8 @@
namespace TestWindow { namespace TestWindow {
class NotificationControl : public Control { class NotificationControlWindow : public Control {
GDCLASS(NotificationControl, Control); GDCLASS(NotificationControlWindow, Control);
protected: protected:
void _notification(int p_what) { void _notification(int p_what) {
@ -69,7 +69,7 @@ TEST_CASE("[SceneTree][Window]") {
w->set_content_scale_size(Size2i(200, 200)); w->set_content_scale_size(Size2i(200, 200));
w->set_content_scale_mode(Window::CONTENT_SCALE_MODE_CANVAS_ITEMS); w->set_content_scale_mode(Window::CONTENT_SCALE_MODE_CANVAS_ITEMS);
w->set_content_scale_aspect(Window::CONTENT_SCALE_ASPECT_KEEP); w->set_content_scale_aspect(Window::CONTENT_SCALE_ASPECT_KEEP);
NotificationControl *c = memnew(NotificationControl); NotificationControlWindow *c = memnew(NotificationControlWindow);
w->add_child(c); w->add_child(c);
c->set_size(Size2i(100, 100)); c->set_size(Size2i(100, 100));
c->set_position(Size2i(-50, -50)); c->set_position(Size2i(-50, -50));

View File

@ -212,7 +212,6 @@ struct GodotTestCaseListener : public doctest::IReporter {
PhysicsServer2D *physics_server_2d = nullptr; PhysicsServer2D *physics_server_2d = nullptr;
NavigationServer3D *navigation_server_3d = nullptr; NavigationServer3D *navigation_server_3d = nullptr;
NavigationServer2D *navigation_server_2d = nullptr; NavigationServer2D *navigation_server_2d = nullptr;
ThemeDB *theme_db = nullptr;
void test_case_start(const doctest::TestCaseData &p_in) override { void test_case_start(const doctest::TestCaseData &p_in) override {
reinitialize(); reinitialize();
@ -238,6 +237,10 @@ struct GodotTestCaseListener : public doctest::IReporter {
RenderingServerDefault::get_singleton()->init(); RenderingServerDefault::get_singleton()->init();
RenderingServerDefault::get_singleton()->set_render_loop_enabled(false); RenderingServerDefault::get_singleton()->set_render_loop_enabled(false);
// ThemeDB requires RenderingServer to initialize the default theme.
// So we have to do this for each test case.
ThemeDB::get_singleton()->initialize_theme_noproject();
physics_server_3d = PhysicsServer3DManager::get_singleton()->new_default_server(); physics_server_3d = PhysicsServer3DManager::get_singleton()->new_default_server();
physics_server_3d->init(); physics_server_3d->init();
@ -252,9 +255,6 @@ struct GodotTestCaseListener : public doctest::IReporter {
memnew(InputMap); memnew(InputMap);
InputMap::get_singleton()->load_default(); InputMap::get_singleton()->load_default();
theme_db = memnew(ThemeDB);
theme_db->initialize_theme_noproject();
memnew(SceneTree); memnew(SceneTree);
SceneTree::get_singleton()->initialize(); SceneTree::get_singleton()->initialize();
if (!DisplayServer::get_singleton()->has_feature(DisplayServer::Feature::FEATURE_SUBWINDOWS)) { if (!DisplayServer::get_singleton()->has_feature(DisplayServer::Feature::FEATURE_SUBWINDOWS)) {
@ -294,11 +294,6 @@ struct GodotTestCaseListener : public doctest::IReporter {
memdelete(SceneTree::get_singleton()); memdelete(SceneTree::get_singleton());
} }
if (theme_db) {
memdelete(theme_db);
theme_db = nullptr;
}
if (navigation_server_3d) { if (navigation_server_3d) {
memdelete(navigation_server_3d); memdelete(navigation_server_3d);
navigation_server_3d = nullptr; navigation_server_3d = nullptr;
@ -326,6 +321,10 @@ struct GodotTestCaseListener : public doctest::IReporter {
} }
if (RenderingServer::get_singleton()) { if (RenderingServer::get_singleton()) {
// ThemeDB requires RenderingServer to finalize the default theme.
// So we have to do this for each test case.
ThemeDB::get_singleton()->finalize_theme();
RenderingServer::get_singleton()->sync(); RenderingServer::get_singleton()->sync();
RenderingServer::get_singleton()->global_shader_parameters_clear(); RenderingServer::get_singleton()->global_shader_parameters_clear();
RenderingServer::get_singleton()->finish(); RenderingServer::get_singleton()->finish();