-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[TRACKER] Unit tests to add or improve #43440
Comments
Hi me and a friend would like to take up some of these unit tests for a class project we have. Is there someone we can stay in touch with if we have questions? @Calinou |
@singher Thanks for your interest in contributing! I recommend joining the I also recommend writing a comment here when you're starting to write tests for one class. This way, we can avoid stepping on each other's toes. |
@Calinou perfect! Thank you so much for this opportunity. We will try our best to cover as many of those classes to test. |
I would like to tackle some of the test cases too and would start with the classes Ps.: First time contributor here! |
@MaxMutantMayer it's better to create separate PRs for each class, this eases the review process → potentially speeds up the merging process. 😉 Also, I'd focus on one thing at a time. |
@Xrayez Alright, makes sense. Thanks for clarification |
Noting for posterity that @Calinou found several issues with the JSON facilities not conforming to the spec. He purposely left these unit tests out of the PR to not confuse people, but I created a proposal to address this: godotengine/godot-proposals#1833 |
Hey if you don't mind I'm gonna take a crack at testing geometry 3D, it's also my first time contributing too :D |
I had to write initial test suite for |
Hello, I'm also looking to start contributing and am writing tests for |
I am going to see about writing unit tests for the |
Hey, I opened another PR for |
Hi there! I want to make my first time contribution to the project by writing unit tests for |
Nobody has started work on testing Marshalls yet, but I haven't been able to access that class from C++ since it's mostly intended to be used from GDScript. It might not be easy to test. |
I think it should be possible to test in either case, because core singletons are initialized in the test environment, I don't know exactly what might be a limitation for doing so. For |
Actually I thought about the strategy suggested by @Xrayez:
Anyway, gonna ask you details later here/in Freenode channel. Thanks. |
Hello everyone, interested in making my first contribution with tests for the |
Since we talk about Those are just some considerations if someone hadn't have much luck with testing |
Hi, if it hasn't been taken by others, I want to add some tests to Sky. |
This PR aims to help "fix" godotengine#43440
This PR aims to help "fix" godotengine#43440
Partially fixes godotengine#43440
Partially fixes godotengine#43440
This PR aims to help "fix" godotengine#43440 Also fixing a small typo on `SceneMultiplayer` docs.
This PR aims to help "fix" godotengine#43440
My Occluder shapes unit test should finally be ready to merge now, someone please take a look at it. |
Line coverage of all tests went up from 23% to 27.8% since Aug 2023 🤩 Great job everyone! |
Also, can i please work on unit tests for GLTFState/GLTFDocument? |
By the way, this has been ready to merge for a while, but a review is needed (: |
Partially fixes godotengine#43440
I've created a PR for GLTFDocument: #101136. @qwertychomp if you're still working on one yourself, feel free to continue - I'm a new contributor so if you have anything it's probably better. |
How do you calculate this? |
I've started working on UTs for Update: #101438 |
@fire |
I can try write tests for httprequest. |
There is already a PR open for Http request: |
FYI @mareknovakz
I wrote tests for |
I'm considering writing tests for VisibleOnScreenNotifier2D and 3D after a little research it looks like the problem would be emulating RendererCanvasCull::canvas_item_set_visibility_notifier and RendererCanvasCull::update_visibility_notifiers while the engine is in headless. Is that right? Can't these methods just be mocked? |
Working on unit tests for |
Since we have the technology from gltfdocument tests to save and load resources. How would we test StandardMaterial3D (and ORMMaterial3D)? I assume it would need to be headless? We could check existence of properties after save and load. Does’t seems satisfying since the result of a material is a shader stack resulting in a camera look. |
Our unit test coverage is currently fairly low. We'd like to increase our unit test coverage; any help is welcome.
Interested in writing new unit tests? See the unit tests documentation and compiling instructions.
If you have further questions, join the Godot Contributors Chat.
When opening a pull request, please link back to this issue (
#43440
) in the PR description so that we can keep track of it more easily.Classes to test
These classes are currently lacking in test coverage, and are therefore highest-priority for receiving unit tests. Deprecated classes are not listed.
Note
When a class is listed with "and" along a given list item, it should be submitted in the same pull request whenever possible. Tests for these classes can be in the same file or a different file depending on the size and complexity of the test suite. If in doubt, follow the file organization used in the original class implementation.
AnimationPlayer
#92649sizing, anchors andcontainer logic by checking control position and size after creating an UI layout. Test focus neighbor behavior using simulated input events (ui_focus_
actions). This class is complex, so tests for it can be split in multiple pull requests.Decal
#93463FontVariation
unit test #99687HeightMapShape3D
#95123HTTPRequest
#95224Node3D
#97143OptionButton
#93824PacketPeer
#95931Parallax2D
#95650ReflectionProbe
#97818 Add unit test for reflection_probe #97870Sky
#97512StreamPeer
andStreamPeerBuffer
#95784StyleBoxTexture
#95218Timer
autostart and paused behavior #97794Completed classes
These classes currently have good test coverage. Further improvements may be possible by testing methods that were added after the tests were merged.
is_position_behind()
and theproject_
/unproject_
methods in particularImageTexture
unit tests #88044Math::
namespace functions #48721Node
tests #71367Projection
#99125RandomNumberGenerator
#44560Vector4
/Vector4i
: Add missing methods and tests #64027Non-testable classes
These classes can't be unit-tested for technical reasons. Unit tests always run in headless mode, so they can't do things such as rendering scenes and checking the visual result.
CubeMap:Not testable without RenderingServer access.Shader:Not testable without RenderingServer access.The text was updated successfully, but these errors were encountered: