You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
o3de/AutomatedTesting/Gem/PythonTests/physics/C12905528_ForceRegion_WithN...

82 lines
3.0 KiB
Python

"""
Copyright (c) Contributors to the Open 3D Engine Project.
For complete copyright and license terms please see the LICENSE at the root of this distribution.
SPDX-License-Identifier: Apache-2.0 OR MIT
Test case ID : C12905528
Test Case Title : Check that user is warned if non-trigger collider component is used with force region
"""
# fmt: off
class Tests():
create_test_entity = ("Entity created successfully", "Failed to create Entity")
add_physx_force_region = ("PhysX Force Region component added", "Failed to add PhysX Force Region component")
add_physx_collider = ("PhysX Collider component added", "Failed to add PhysX Collider component")
warnings_found = ("Warnings found in logs", "No warnings found in logs")
# fmt: on
def run():
"""
Summary:
Create entity with PhysX Force Region component. Check that user is warned if new PhysX Collider component is
added to Entity.
Expected Behavior:
User is warned by message in the console that the PhysX Collider component was not marked as a trigger
Test Steps:
1) Load the empty level
2) Create test entity
3) Add PhysX Force Region component
4) Start the Tracer to catch any errors and warnings
5) Add PhysX Collider component to the Entity
6) Verify there is warning in the logs
Note:
- This test file must be called from the Open 3D Engine Editor command terminal
- Any passed and failed tests are written to the Editor.log file.
Parsing the file or running a log_monitor are required to observe the test results.
:return: None
"""
# Helper file Imports
import ImportPathHelper as imports
from editor_python_test_tools.editor_entity_utils import EditorEntity
from editor_python_test_tools.utils import Report
imports.init()
from editor_python_test_tools.utils import TestHelper as helper
from editor_python_test_tools.utils import Tracer
helper.init_idle()
# 1) Load the empty level
helper.open_level("Physics", "Base")
# 2) Create test entity
test_entity = EditorEntity.create_editor_entity("TestEntity")
Report.result(Tests.create_test_entity, test_entity.id.IsValid())
# 3) Add PhysX Force Region component
test_entity.add_component("PhysX Force Region")
Report.result(Tests.add_physx_force_region, test_entity.has_component("PhysX Force Region"))
# 4) Start the Tracer to catch any errors and warnings
with Tracer() as section_tracer:
# 5) Add the PhysX Collider component
test_entity.add_component("PhysX Collider")
Report.result(Tests.add_physx_collider, test_entity.has_component("PhysX Collider"))
# ) Verify there is warning in the logs
success_condition = section_tracer.has_warnings
# Checking if warning exist and the exact warning is caught in the expected lines in Test file
Report.result(Tests.warnings_found, success_condition)
if __name__ == "__main__":
run()