Add unit testing for core.gd (partial #11)
This commit is contained in:
parent
fbbb889296
commit
9608d6b0ab
5 changed files with 181 additions and 1 deletions
3
addons/besseretests_config.gd
Normal file
3
addons/besseretests_config.gd
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
extends Node
|
||||||
|
|
||||||
|
var test_directory: String = "res://tests/unit"
|
2
dist/submodules/besseretests
vendored
2
dist/submodules/besseretests
vendored
|
@ -1 +1 @@
|
||||||
Subproject commit f8c5e4e1623860a02a13b963fa630df302a07591
|
Subproject commit 6dda982c466af2d3d55639405995e5a4ab4f4316
|
14
tests/custom_module.gd
Normal file
14
tests/custom_module.gd
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
extends CoreBaseModule
|
||||||
|
|
||||||
|
@onready var suite: BessereTestsTest = get_node_or_null("/root/suite_core")
|
||||||
|
|
||||||
|
func _initialize() -> void:
|
||||||
|
logger.info("tests/custom_module.gd", "Module has been initialized")
|
||||||
|
suite.callback = "_initialize"
|
||||||
|
|
||||||
|
func _pull_config() -> void:
|
||||||
|
logger.info("tests/custom_module.gd", "The configuration has been updated")
|
||||||
|
suite.callback = "_pull_config"
|
||||||
|
|
||||||
|
func hello_test() -> String:
|
||||||
|
return "Hello Test!"
|
142
tests/unit/core.gd
Normal file
142
tests/unit/core.gd
Normal file
|
@ -0,0 +1,142 @@
|
||||||
|
extends BessereTestsTest
|
||||||
|
|
||||||
|
# Callbacks
|
||||||
|
var callback: String = ""
|
||||||
|
|
||||||
|
# Utils
|
||||||
|
var utils: Node = CoreTestUtils.new()
|
||||||
|
|
||||||
|
func before_all() -> void: add_child(utils)
|
||||||
|
func after_all() -> void: remove_child(utils)
|
||||||
|
|
||||||
|
# Unload framework after each test
|
||||||
|
func after_each() -> void: utils.unload_framework()
|
||||||
|
|
||||||
|
# Initialization test
|
||||||
|
func test_initialization() -> void:
|
||||||
|
# Init CORE
|
||||||
|
await utils.load_framework()
|
||||||
|
|
||||||
|
# Check
|
||||||
|
if !utils.is_framework_loaded():
|
||||||
|
test_status = 2
|
||||||
|
test_message = "utils.is_framework_loaded() returned 'false'"
|
||||||
|
|
||||||
|
test_status = 0
|
||||||
|
test_message = "Framework did initialize correctly"
|
||||||
|
|
||||||
|
# Custom module support
|
||||||
|
func test_custom_module_support() -> void:
|
||||||
|
# Init CORE
|
||||||
|
var config: CoreConfiguration = CoreConfiguration.new()
|
||||||
|
config.custom_modules = true
|
||||||
|
var core: Core = await utils.load_framework(config)
|
||||||
|
|
||||||
|
# Load module
|
||||||
|
var module: CoreBaseModule = CoreBaseModule.new()
|
||||||
|
module.set_script(load("res://tests/custom_module.gd"))
|
||||||
|
|
||||||
|
# Register module
|
||||||
|
core.register_custom_module("test_module", module)
|
||||||
|
await utils.wait_process_time()
|
||||||
|
|
||||||
|
# Check if registered
|
||||||
|
if callback != "_initialize" and callback != "_pull_config":
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Module did not register"
|
||||||
|
elif core.get_node_or_null("Custom Modules/test_module") == null:
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Could not find module node"
|
||||||
|
|
||||||
|
# Get module
|
||||||
|
var module_get: CoreBaseModule = core.get_custom_module("test_module")
|
||||||
|
if module_get == null:
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Got null from get_custom_module method"
|
||||||
|
if module_get != module:
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Got invalid node from get_custom_module method"
|
||||||
|
|
||||||
|
# Get string
|
||||||
|
if module.hello_test() != "Hello Test!":
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Module did not return test string"
|
||||||
|
|
||||||
|
# Unregister module
|
||||||
|
core.unregister_custom_module("test_module")
|
||||||
|
await utils.wait_process_time()
|
||||||
|
|
||||||
|
# Check if unregistered
|
||||||
|
if core.get_node_or_null("Custom Modules/test_module") == null:
|
||||||
|
test_status = 0
|
||||||
|
test_message = "Successfully registered, got, used and unregistered a custom module"
|
||||||
|
|
||||||
|
func test_reload_config() -> void:
|
||||||
|
# Variables
|
||||||
|
var config: CoreConfiguration = CoreConfiguration.new()
|
||||||
|
|
||||||
|
# Init CORE
|
||||||
|
var core: Core = await utils.load_framework()
|
||||||
|
|
||||||
|
# Update some keys and reload
|
||||||
|
config.logger_colored = false
|
||||||
|
config.logger_level = CoreTypes.LoggerLevel.NONE
|
||||||
|
config.logui_enabled = false
|
||||||
|
|
||||||
|
core.reload_configuration(config)
|
||||||
|
await utils.wait_process_time()
|
||||||
|
|
||||||
|
# Check config
|
||||||
|
if core.config != config:
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Got invalid node from config variable"
|
||||||
|
|
||||||
|
# Check config in modules
|
||||||
|
if core.logger.config_colored != false or core.logger.config_level != CoreTypes.LoggerLevel.NONE or core.logui.background.visible != false:
|
||||||
|
test_status = 2
|
||||||
|
test_message = "Configuration did not apply all values correctly"
|
||||||
|
|
||||||
|
test_status = 0
|
||||||
|
test_message = "Framework applied all modified keys correctly"
|
||||||
|
|
||||||
|
func test_formatted_string() -> void:
|
||||||
|
# Init CORE
|
||||||
|
var core: Core = await utils.load_framework()
|
||||||
|
|
||||||
|
# Variables
|
||||||
|
var test_type: String
|
||||||
|
var test_type_technical: String
|
||||||
|
var test_semantic: Array[int] = core.get_version_semantic()
|
||||||
|
var test_devmode: String
|
||||||
|
var test_headless: String
|
||||||
|
var test_custommodules: String
|
||||||
|
# test_type & test_type_technical
|
||||||
|
match(core.version_type):
|
||||||
|
CoreTypes.VersionType.RELEASE:
|
||||||
|
test_type = "Release"
|
||||||
|
test_type_technical = "r"
|
||||||
|
CoreTypes.VersionType.RELEASECANDIDATE:
|
||||||
|
test_type = "Release Candidate"
|
||||||
|
test_type_technical = "rc"
|
||||||
|
CoreTypes.VersionType.BETA:
|
||||||
|
test_type = "Beta"
|
||||||
|
test_type_technical = "b"
|
||||||
|
CoreTypes.VersionType.ALPHA:
|
||||||
|
test_type = "Alpha"
|
||||||
|
test_type_technical = "a"
|
||||||
|
# test_devmode
|
||||||
|
if core.is_devmode(): test_devmode = "Enabled"
|
||||||
|
else: test_devmode = "Disabled"
|
||||||
|
# test_headless
|
||||||
|
if core.config.headless: test_headless = "Enabled"
|
||||||
|
else: test_headless = "Disabled"
|
||||||
|
# test_custommodules
|
||||||
|
if core.config.custom_modules: test_custommodules = "Enabled"
|
||||||
|
else: test_custommodules = "Disabled"
|
||||||
|
|
||||||
|
var test_raw: String = "version=%version% typerelease=%version_type% semantic=%version_semantic% type=%type% type_technical=%type_technical% devmode=%devmode% headless=%headless% custommodules=%custommodules% HELLO TEST! #TransRightsAreHumanRights"
|
||||||
|
var test_formatted: String = "version=" + str(core.version_version) + " typerelease=" + str(core.version_typerelease) + " semantic=" + str(test_semantic[0]) + "." + str(test_semantic[1]) + "." + str(test_semantic[2]) + " type=" + test_type + " type_technical=" + test_type_technical + " devmode=" + test_devmode + " headless=" + test_headless + " custommodules=" + test_custommodules + " HELLO TEST! #TransRightsAreHumanRights"
|
||||||
|
|
||||||
|
# Compare
|
||||||
|
if await core.get_formatted_string(test_raw) != test_formatted: test_status = 2
|
||||||
|
else: test_status = 0
|
21
tests/utils.gd
Normal file
21
tests/utils.gd
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
extends Node
|
||||||
|
class_name CoreTestUtils
|
||||||
|
|
||||||
|
var core: Core
|
||||||
|
|
||||||
|
# Framework management
|
||||||
|
func load_framework(config: CoreConfiguration = CoreConfiguration.new()) -> Core:
|
||||||
|
core = Core.new(config)
|
||||||
|
get_tree().root.add_child(core)
|
||||||
|
await get_tree().process_frame
|
||||||
|
await core.complete_init()
|
||||||
|
return core
|
||||||
|
|
||||||
|
func unload_framework() -> void:
|
||||||
|
if is_framework_loaded(): get_tree().root.remove_child(core)
|
||||||
|
core = null
|
||||||
|
|
||||||
|
func is_framework_loaded() -> bool: return get_node_or_null("/root/CORE") != null
|
||||||
|
|
||||||
|
# Helper functions
|
||||||
|
func wait_process_time() -> void: await get_tree().create_timer(0.1).timeout
|
Loading…
Reference in a new issue