diff options
Diffstat (limited to 'modules/gdscript/tests')
19 files changed, 188 insertions, 17 deletions
| diff --git a/modules/gdscript/tests/gdscript_test_runner.cpp b/modules/gdscript/tests/gdscript_test_runner.cpp index 6c346acb7e..15131afde7 100644 --- a/modules/gdscript/tests/gdscript_test_runner.cpp +++ b/modules/gdscript/tests/gdscript_test_runner.cpp @@ -479,9 +479,9 @@ GDScriptTest::TestResult GDScriptTest::execute_test_code(bool p_is_generating) {  		result.output = get_text_for_status(result.status) + "\n";  		const List<GDScriptParser::ParserError> &errors = parser.get_errors(); -		for (const GDScriptParser::ParserError &E : errors) { -			result.output += E.message + "\n"; // TODO: line, column? -			break; // Only the first error since the following might be cascading. +		if (!errors.is_empty()) { +			// Only the first error since the following might be cascading. +			result.output += errors[0].message + "\n"; // TODO: line, column?  		}  		if (!p_is_generating) {  			result.passed = check_output(result.output); @@ -498,9 +498,9 @@ GDScriptTest::TestResult GDScriptTest::execute_test_code(bool p_is_generating) {  		result.output = get_text_for_status(result.status) + "\n";  		const List<GDScriptParser::ParserError> &errors = parser.get_errors(); -		for (const GDScriptParser::ParserError &E : errors) { -			result.output += E.message + "\n"; // TODO: line, column? -			break; // Only the first error since the following might be cascading. +		if (!errors.is_empty()) { +			// Only the first error since the following might be cascading. +			result.output += errors[0].message + "\n"; // TODO: line, column?  		}  		if (!p_is_generating) {  			result.passed = check_output(result.output); diff --git a/modules/gdscript/tests/scripts/parser/features/class.gd b/modules/gdscript/tests/scripts/parser/features/class.gd index 6652f85ad9..af24b32322 100644 --- a/modules/gdscript/tests/scripts/parser/features/class.gd +++ b/modules/gdscript/tests/scripts/parser/features/class.gd @@ -21,5 +21,5 @@ func test():  	assert(test_sub.number == 25)  # From Test.  	assert(test_sub.other_string == "bye")  # From TestSub. -	TestConstructor.new() -	TestConstructor.new(500) +	var _test_constructor = TestConstructor.new() +	_test_constructor = TestConstructor.new(500) diff --git a/modules/gdscript/tests/scripts/parser/features/dictionary.out b/modules/gdscript/tests/scripts/parser/features/dictionary.out index 5f999f573a..e1eeb46f78 100644 --- a/modules/gdscript/tests/scripts/parser/features/dictionary.out +++ b/modules/gdscript/tests/scripts/parser/features/dictionary.out @@ -7,8 +7,8 @@ null  false  empty array  zero Vector2i -{22:{4:["nesting", "arrays"]}} -{4:["nesting", "arrays"]} +{ 22: { 4: ["nesting", "arrays"] } } +{ 4: ["nesting", "arrays"] }  ["nesting", "arrays"]  nesting  arrays diff --git a/modules/gdscript/tests/scripts/parser/features/dictionary_lua_style.out b/modules/gdscript/tests/scripts/parser/features/dictionary_lua_style.out index 5143d040a9..553d40d953 100644 --- a/modules/gdscript/tests/scripts/parser/features/dictionary_lua_style.out +++ b/modules/gdscript/tests/scripts/parser/features/dictionary_lua_style.out @@ -1,2 +1,2 @@  GDTEST_OK -{"a":1, "b":2, "with spaces":3, "2":4} +{ "a": 1, "b": 2, "with spaces": 3, "2": 4 } diff --git a/modules/gdscript/tests/scripts/parser/features/dictionary_mixed_syntax.out b/modules/gdscript/tests/scripts/parser/features/dictionary_mixed_syntax.out index dd28609850..cf79845f53 100644 --- a/modules/gdscript/tests/scripts/parser/features/dictionary_mixed_syntax.out +++ b/modules/gdscript/tests/scripts/parser/features/dictionary_mixed_syntax.out @@ -1,2 +1,2 @@  GDTEST_OK -{"hello":{"world":{"is":"beautiful"}}} +{ "hello": { "world": { "is": "beautiful" } } } diff --git a/modules/gdscript/tests/scripts/parser/features/nested_dictionary.out b/modules/gdscript/tests/scripts/parser/features/nested_dictionary.out index 8b8c33202f..508f0ff217 100644 --- a/modules/gdscript/tests/scripts/parser/features/nested_dictionary.out +++ b/modules/gdscript/tests/scripts/parser/features/nested_dictionary.out @@ -1,5 +1,5 @@  GDTEST_OK -{8:{"key":"value"}} -{"key":"value"} +{ 8: { "key": "value" } } +{ "key": "value" }  value  value diff --git a/modules/gdscript/tests/scripts/parser/warnings/return_value_discarded.out b/modules/gdscript/tests/scripts/parser/warnings/return_value_discarded.out index d73c5eb7cd..13f759dd46 100644 --- a/modules/gdscript/tests/scripts/parser/warnings/return_value_discarded.out +++ b/modules/gdscript/tests/scripts/parser/warnings/return_value_discarded.out @@ -1 +1,5 @@  GDTEST_OK +>> WARNING +>> Line: 6 +>> RETURN_VALUE_DISCARDED +>> The function 'i_return_int()' returns a value, but this value is never used. diff --git a/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.gd b/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.gd new file mode 100644 index 0000000000..29d8501b78 --- /dev/null +++ b/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.gd @@ -0,0 +1,11 @@ +class Player: +	var x = 3 + +func test(): +	# These should not emit a warning. +	var _player = Player.new() +	print(String.num_uint64(8589934592)) # 2 ^ 33 + +	# This should emit a warning. +	var some_string = String() +	print(some_string.num_uint64(8589934592)) # 2 ^ 33 diff --git a/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.out b/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.out new file mode 100644 index 0000000000..3933a35178 --- /dev/null +++ b/modules/gdscript/tests/scripts/parser/warnings/static_called_on_instance.out @@ -0,0 +1,7 @@ +GDTEST_OK +>> WARNING +>> Line: 11 +>> STATIC_CALLED_ON_INSTANCE +>> The function 'num_uint64()' is a static function but was called from an instance. Instead, it should be directly called from the type: 'String.num_uint64()'. +8589934592 +8589934592 diff --git a/modules/gdscript/tests/scripts/runtime/features/chain_assignment_works.out b/modules/gdscript/tests/scripts/runtime/features/chain_assignment_works.out index 5e7ccf534a..22929bf636 100644 --- a/modules/gdscript/tests/scripts/runtime/features/chain_assignment_works.out +++ b/modules/gdscript/tests/scripts/runtime/features/chain_assignment_works.out @@ -1,6 +1,6 @@  GDTEST_OK -{1:(2, 0)} -{3:(4, 0)} +{ 1: (2, 0) } +{ 3: (4, 0) }  [[(5, 0)]]  [[(6, 0)]]  [[(7, 0)]] diff --git a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.gd b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.gd index c6645c2c34..809d0d28a9 100644 --- a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.gd +++ b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.gd @@ -69,6 +69,10 @@ func test():  	value = Transform3D()  	print(value == null) +	# Projection +	value = Projection() +	print(value == null) +  	# Color  	value = Color()  	print(value == null) diff --git a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.out b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.out index 639f6027b9..27423ab8e7 100644 --- a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.out +++ b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-equals-null.out @@ -33,3 +33,4 @@ false  false  false  false +false diff --git a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.gd b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.gd index ee622bf22f..f46afb0f18 100644 --- a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.gd +++ b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.gd @@ -69,6 +69,10 @@ func test():  	value = Transform3D()  	print(value != null) +	# Projection +	value = Projection() +	print(value != null) +  	# Color  	value = Color()  	print(value != null) diff --git a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.out b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.out index d1e332afba..a11c47854a 100644 --- a/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.out +++ b/modules/gdscript/tests/scripts/runtime/features/compare-builtin-not-equals-null.out @@ -33,3 +33,4 @@ true  true  true  true +true diff --git a/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.gd b/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.gd new file mode 100644 index 0000000000..e24137a20d --- /dev/null +++ b/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.gd @@ -0,0 +1,60 @@ +func test(): +	# All combinations of 1/2/3 arguments, each being int/float. + +	for number in range(5): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(5.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + + +	for number in range(1, 5): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1, 5.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + + +	for number in range(1, 5, 2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1, 5, 2.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1, 5.2, 2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1, 5.2, 2.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5, 2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5.2, 2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5, 2.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	for number in range(1.2, 5.2, 2.2): +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") diff --git a/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.out b/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.out new file mode 100644 index 0000000000..d73c5eb7cd --- /dev/null +++ b/modules/gdscript/tests/scripts/runtime/features/range_optimized_in_for_has_int_iterator.out @@ -0,0 +1 @@ +GDTEST_OK diff --git a/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.gd b/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.gd new file mode 100644 index 0000000000..63c3b84305 --- /dev/null +++ b/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.gd @@ -0,0 +1,77 @@ +func test(): +	# All combinations of 1/2/3 arguments, each being int/float. +	# Store result in variable to ensure actual array is created (avoid `for` + `range` optimization). + +	var result + +	result = range(5) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(5.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + + +	result = range(1, 5) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1, 5.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + + +	result = range(1, 5, 2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1, 5, 2.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1, 5.2, 2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1, 5.2, 2.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5, 2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5.2, 2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5, 2.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") + +	result = range(1.2, 5.2, 2.2) +	for number in result: +		if typeof(number) != TYPE_INT: +			print("Number returned from `range` was not an int!") diff --git a/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.out b/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.out new file mode 100644 index 0000000000..d73c5eb7cd --- /dev/null +++ b/modules/gdscript/tests/scripts/runtime/features/range_returns_ints.out @@ -0,0 +1 @@ +GDTEST_OK diff --git a/modules/gdscript/tests/scripts/runtime/features/stringify.out b/modules/gdscript/tests/scripts/runtime/features/stringify.out index d4468737a5..1f33de00cc 100644 --- a/modules/gdscript/tests/scripts/runtime/features/stringify.out +++ b/modules/gdscript/tests/scripts/runtime/features/stringify.out @@ -21,7 +21,7 @@ hello/world  RID(0)  Node::get_name  Node::[signal]property_list_changed -{"hello":123} +{ "hello": 123 }  ["hello", 123]  [255, 0, 1]  [-1, 0, 1] |