regression-test-project/README.md
2021-02-23 19:12:20 +01:00

3.2 KiB

Godot regression test project

This repository contains Godot project which is tested in offical Godot repository(3.2 branch)

It aims to be complex project, which will allow to find crashes, leaks and invalid memory writes before PR is merged.

Sadly it can't find automatically any logic errors.

Reproduce bugs

If CI find bug, you can easily without much effort check which scene cause problems(stacktrace, address or leak sanitizer log will be available).

All main scenes are independent of each other(only Autoload.gd is required), so it is easy to disable some for testing.

To create minimal test scene:

  • Look at the console output - there is printed info about current used scene
  • If you run Start.tscn scene(which run other scenes in queue) then you can modify list of scenes which needs to be run in Autoload.gd by commenting records in alone_steps or all_in_one array(just like in picture) Zrzut ekranu z 2021-01-13 11-52-41

How it works?

Autoload

There is only one scene which is loaded when project starts - "Autoload.gd". It handle exiting project after selected number of seconds

When opening any scene, automatically time to exit is set.

If running projet with e.g. this parameters

godot 20 

Then time is set to 20 seconds so it means that if scenes is 10 (EACH in alone_steps array + one for ALL scenes in all_in_one array), then each scene will be show for 2 seconds

Checking All scenes at once

There are two scenes which opens all scenes:

  • All.tscn - opens all scenes at once
  • Start.tscn - opens each scene one by one

"Safe" Fuzzer

Available inside AutomaticBugs directory, check all methods with specific arguments in allowed classes.
During calculations, to output should be written informations about current classes and executed functions with arguments e.g.

############### CLASS ############### - PopupMenu
add_icon_radio_check_shortcut
Parameters [[InputEventMouseMotion:12379], [SoftBody:12380], -109, True]

This fuzzer should in most situations be safe to use, because always use same set of arguments in functions, and objects are cleared before executing next function.

This tool is developed in external repository - https://github.com/qarmin/Qarminer.

AIO

This are scenes which only opens once, because there is no need to open it more times - used to check loading of specific types of nodes or executing its _ready functions.

MainScenes

Collections of all nodes, which are after some time simply removed and added to scene.

ReparentingDeleting

This scene randomly reparent, add or delete nodes inside it, to check correctness this operations.

Other Scenes

Each other scenes checks specific types of nodes like lights, rendering, physics, text.

Epilepsy Warning

Due using by project a lot of functions from each type of Node, screen may flicker, images and objects may change randomly color and size which may lead some users to health problems.

Problems with project

If you have problem with this project e.g. in CI, just ping me -> @qarmin <- and after that I will try help to fix issues which you have with it or add exception to project.