regression-test-project/Autoload/Autoload.gd

57 lines
2.0 KiB
GDScript3
Raw Normal View History

2020-08-05 11:03:11 +02:00
extends Node
const screen_size = Vector2(1024, 600)
2020-10-29 08:52:56 +01:00
2021-05-18 06:57:08 +02:00
var start_time: int
var last_time: int
2021-05-18 06:57:08 +02:00
const PRINT_TIME_EVERY_MILISECONDS: int = 5000
var time_to_print_next_time: int = PRINT_TIME_EVERY_MILISECONDS
2020-08-05 11:03:11 +02:00
2021-05-18 06:57:08 +02:00
var time_to_show: int = 25 * 1000 # How long test works in miliseconds
2020-08-05 11:03:11 +02:00
2021-05-18 06:57:08 +02:00
var time_for_each_step: int = -1
var can_be_closed: bool = true
2020-11-17 19:21:50 +01:00
# Each scene runs alone
2021-05-18 06:57:08 +02:00
const alone_steps: Array = [
2021-09-18 20:59:24 +02:00
"res://CreatingAllThings/CreatingAllThings.tscn",
2021-03-15 15:41:38 +01:00
"res://Nodes/Nodes.tscn",
2020-11-17 19:21:50 +01:00
"res://Physics/2D/Physics2D.tscn",
"res://Physics/3D/Physics3D.tscn",
2022-01-05 19:35:38 +01:00
# "res://ReparentingDeleting/ReparentingDeleting.tscn", Not always reproducible
"res://AutomaticBugs/FunctionExecutor.tscn", # Only need to run once
2020-11-17 19:21:50 +01:00
]
2021-05-18 06:57:08 +02:00
func _init():
2022-03-20 09:00:05 +01:00
start_time = Time.get_ticks_msec()
2021-05-18 06:57:08 +02:00
2020-11-17 19:21:50 +01:00
# In case when user doesn't provide time
2021-02-13 13:44:18 +01:00
time_for_each_step = time_to_show / (alone_steps.size())
2021-05-18 06:57:08 +02:00
2020-08-05 11:03:11 +02:00
for argument in OS.get_cmdline_args():
2021-05-18 06:57:08 +02:00
if argument.is_valid_float(): # Ignore all non numeric arguments
2021-01-12 09:06:16 +01:00
time_to_show = int(argument.to_float() * 1000)
2021-02-13 13:44:18 +01:00
time_for_each_step = time_to_show / (alone_steps.size())
2021-05-18 06:57:08 +02:00
print("Time set to: " + str(time_to_show / 1000.0) + " seconds with " + str(alone_steps.size()) + " steps, each step will take " + str(time_for_each_step / 1000.0) + " seconds.")
2022-01-05 19:35:38 +01:00
break # We only need to take first numeric argument
2020-08-05 11:03:11 +02:00
func _process(delta: float) -> void:
2022-03-20 09:52:33 +01:00
var current_run_time: int = Time.get_ticks_msec() - start_time
2021-05-18 06:57:08 +02:00
2022-01-05 19:35:38 +01:00
# While loop instead simple if, because will allow to properly flush results under heavy operations(e.g. Thread sanitizer)
2021-05-18 06:57:08 +02:00
while current_run_time > time_to_print_next_time:
2020-12-04 13:50:02 +01:00
print("Test is running now " + str(int(time_to_print_next_time / 1000)) + " seconds")
time_to_print_next_time += PRINT_TIME_EVERY_MILISECONDS
2021-05-18 06:57:08 +02:00
if current_run_time > time_to_show && can_be_closed:
2020-12-26 10:41:59 +01:00
print("######################## Ending test ########################")
#hack to make sure the engine always quits no matter what, because doing this will throw an exception
get_tree().quit()
get_tree().quit()
2020-08-05 11:03:11 +02:00
get_tree().quit()
2022-01-05 19:35:38 +01:00