Adding log.gd

This commit is contained in:
Dan Baker 2024-05-02 09:36:31 +01:00
parent eb32d6614e
commit 4522259397
547 changed files with 46844 additions and 0 deletions

View file

@ -0,0 +1,161 @@
extends GdUnitTestSuite
var _current_iterations : Dictionary
var _expected_iterations: Dictionary
# a simple test fuzzer where provided a hard coded value set
class TestFuzzer extends Fuzzer:
var _data := [0, 1, 2, 3, 4, 5, 6, 23, 8, 9]
func next_value():
return _data.pop_front()
func max_value() -> int:
return 10
func min_value() -> int:
return 1
func fuzzer() -> Fuzzer:
return Fuzzers.rangei(min_value(), max_value())
func before():
# define expected iteration count
_expected_iterations = {
"test_fuzzer_has_same_instance_peer_iteration" : 10,
"test_multiple_fuzzers_inject_value_with_seed" : 10,
"test_fuzzer_iterations_default" : Fuzzer.ITERATION_DEFAULT_COUNT,
"test_fuzzer_iterations_custom_value" : 234,
"test_fuzzer_inject_value" : 100,
"test_multiline_fuzzer_args": 23,
}
# inital values
_current_iterations = {
"test_fuzzer_has_same_instance_peer_iteration" : 0,
"test_multiple_fuzzers_inject_value_with_seed" : 0,
"test_fuzzer_iterations_default" : 0,
"test_fuzzer_iterations_custom_value" : 0,
"test_fuzzer_inject_value" : 0,
"test_multiline_fuzzer_args": 0,
}
func after():
for test_case in _expected_iterations.keys():
var current = _current_iterations[test_case]
var expected = _expected_iterations[test_case]
assert_int(current).override_failure_message("Expecting %s itertions but is %s checked test case %s" % [expected, current, test_case]).is_equal(expected)
var _fuzzer_instance_before : Fuzzer = null
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_has_same_instance_peer_iteration(fuzzer=TestFuzzer.new(), fuzzer_iterations = 10):
_current_iterations["test_fuzzer_has_same_instance_peer_iteration"] += 1
assert_object(fuzzer).is_not_null()
if _fuzzer_instance_before != null:
assert_that(fuzzer).is_same(_fuzzer_instance_before)
_fuzzer_instance_before = fuzzer
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_iterations_default(fuzzer := Fuzzers.rangei(-23, 22)):
_current_iterations["test_fuzzer_iterations_default"] += 1
assert_object(fuzzer).is_not_null()
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_iterations_custom_value(fuzzer := Fuzzers.rangei(-23, 22), fuzzer_iterations = 234, fuzzer_seed = 100):
_current_iterations["test_fuzzer_iterations_custom_value"] += 1
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_inject_value(fuzzer := Fuzzers.rangei(-23, 22), fuzzer_iterations = 100):
_current_iterations["test_fuzzer_inject_value"] += 1
assert_object(fuzzer).is_not_null()
assert_int(fuzzer.next_value()).is_between(-23, 22)
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_with_timeout(fuzzer := Fuzzers.rangei(-23, 22), fuzzer_iterations = 20, timeout = 100):
discard_error_interupted_by_timeout()
assert_int(fuzzer.next_value()).is_between(-23, 22)
if fuzzer.iteration_index() == 10:
await await_millis(100)
# we not expect more than 10 iterations it should be interuptead by a timeout
assert_int(fuzzer.iteration_index()).is_less_equal(10)
var expected_value := [22, 3, -14, -16, 21, 20, 4, -23, -19, -5]
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_inject_value_with_seed(fuzzer := Fuzzers.rangei(-23, 22), fuzzer_iterations = 10, fuzzer_seed = 187772):
assert_object(fuzzer).is_not_null()
var iteration_index = fuzzer.iteration_index()-1
var current = fuzzer.next_value()
var expected = expected_value[iteration_index]
assert_int(iteration_index).is_between(0, 9).is_less(10)
assert_int(current)\
.override_failure_message("Expect value %s checked test iteration %s\n but was %s" % [expected, iteration_index, current])\
.is_equal(expected)
var expected_value_a := [22, -14, 21, 4, -19, -11, 5, 21, -6, -9]
var expected_value_b := [35, 38, 34, 39, 35, 41, 37, 35, 34, 39]
@warning_ignore("shadowed_variable", "unused_parameter")
func test_multiple_fuzzers_inject_value_with_seed(fuzzer_a := Fuzzers.rangei(-23, 22), fuzzer_b := Fuzzers.rangei(33, 44), fuzzer_iterations = 10, fuzzer_seed = 187772):
_current_iterations["test_multiple_fuzzers_inject_value_with_seed"] += 1
assert_object(fuzzer_a).is_not_null()
assert_object(fuzzer_b).is_not_null()
var iteration_index_a = fuzzer_a.iteration_index()-1
var current_a = fuzzer_a.next_value()
var expected_a = expected_value_a[iteration_index_a]
assert_int(iteration_index_a).is_between(0, 9).is_less(10)
assert_int(current_a).is_between(-23, 22)
assert_int(current_a)\
.override_failure_message("Expect value %s checked test iteration %s\n but was %s" % [expected_a, iteration_index_a, current_a])\
.is_equal(expected_a)
var iteration_index_b = fuzzer_b.iteration_index()-1
var current_b = fuzzer_b.next_value()
var expected_b = expected_value_b[iteration_index_b]
assert_int(iteration_index_b).is_between(0, 9).is_less(10)
assert_int(current_b).is_between(33, 44)
assert_int(current_b)\
.override_failure_message("Expect value %s checked test iteration %s\n but was %s" % [expected_b, iteration_index_b, current_b])\
.is_equal(expected_b)
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_error_after_eight_iterations(fuzzer=TestFuzzer.new(), fuzzer_iterations = 10):
assert_object(fuzzer).is_not_null()
# should fail after 8 iterations
if fuzzer.iteration_index() == 8:
assert_failure(func(): assert_int(fuzzer.next_value()).is_between(0, 9)) \
.is_failed() \
.has_message("Expecting:\n '23'\n in range between\n '0' <> '9'")
else:
assert_int(fuzzer.next_value()).is_between(0, 9)
@warning_ignore("shadowed_variable", "unused_parameter")
func test_fuzzer_custom_func(fuzzer=fuzzer()):
assert_object(fuzzer).is_not_null()
assert_int(fuzzer.next_value()).is_between(1, 10)
@warning_ignore("shadowed_variable", "unused_parameter")
func test_multiline_fuzzer_args(
fuzzer_a := Fuzzers.rangev2(Vector2(-47, -47), Vector2(47, 47)),
fuzzer_b := Fuzzers.rangei(0, 9),
fuzzer_iterations = 23):
assert_object(fuzzer_a).is_not_null()
assert_object(fuzzer_b).is_not_null()
_current_iterations["test_multiline_fuzzer_args"] += 1

View file

@ -0,0 +1,34 @@
# GdUnit generated TestSuite
class_name StringFuzzerTest
extends GdUnitTestSuite
# TestSuite generated from
const __source = 'res://addons/gdUnit4/src/fuzzers/StringFuzzer.gd'
func test_extract_charset() -> void:
assert_str(StringFuzzer.extract_charset("abc").get_string_from_ascii()).is_equal("abc")
assert_str(StringFuzzer.extract_charset("abcDXG").get_string_from_ascii()).is_equal("abcDXG")
assert_str(StringFuzzer.extract_charset("a-c").get_string_from_ascii()).is_equal("abc")
assert_str(StringFuzzer.extract_charset("a-z").get_string_from_ascii()).is_equal("abcdefghijklmnopqrstuvwxyz")
assert_str(StringFuzzer.extract_charset("A-Z").get_string_from_ascii()).is_equal("ABCDEFGHIJKLMNOPQRSTUVWXYZ")
# range token at start
assert_str(StringFuzzer.extract_charset("-a-dA-D2-8+_").get_string_from_ascii()).is_equal("-abcdABCD2345678+_")
# range token at end
assert_str(StringFuzzer.extract_charset("a-dA-D2-8+_-").get_string_from_ascii()).is_equal("abcdABCD2345678+_-")
# range token in the middle
assert_str(StringFuzzer.extract_charset("a-d-A-D2-8+_").get_string_from_ascii()).is_equal("abcd-ABCD2345678+_")
func test_next_value() -> void:
var pattern := "a-cD-X+2-5"
var fuzzer := StringFuzzer.new(4, 128, pattern)
var r := RegEx.new()
r.compile("[%s]+" % pattern)
for i in 100:
var value :String = fuzzer.next_value()
# verify the generated value has a length in the configured min/max range
assert_int(value.length()).is_between(4, 128)
# using regex to remove_at all expected chars to verify the value only containing expected chars by is empty
assert_str(r.sub(value, "")).is_empty()

View file

@ -0,0 +1,10 @@
class_name TestExternalFuzzer
extends Fuzzer
func _init():
pass
func next_value() -> Variant:
return {}

View file

@ -0,0 +1,27 @@
extends RefCounted
const MIN_VALUE := -10
const MAX_VALUE := 22
class NestedFuzzer extends Fuzzer:
func _init():
pass
func next_value() -> Variant:
return {}
static func _s_max_value() -> int:
return MAX_VALUE
func min_value() -> int:
return MIN_VALUE
func get_fuzzer() -> Fuzzer:
return Fuzzers.rangei(min_value(), NestedFuzzer._s_max_value())
func non_fuzzer() -> Resource:
return Image.new()