.github/workflows | ||
.import | ||
AIO | ||
Autoload | ||
AutomaticBugs | ||
MainScenes | ||
misc | ||
Physics | ||
Rendering | ||
ReparentingDeleting | ||
Text | ||
.gitignore | ||
All.tscn | ||
Environment.tres | ||
export_presets.cfg | ||
Godot4Update.sh | ||
icon.png | ||
icon.png.import | ||
project.godot | ||
README.md | ||
Start.gd | ||
Start.tscn |
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 inAutoload.gd
by commenting records inalone_steps
orall_in_one
array(just like in picture)
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.