-
Notifications
You must be signed in to change notification settings - Fork 24
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
add guard in lua against nil group from dead unit #232
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks a lot for the PR, highly appreciated!
lua/DCS-gRPC/exporters/object.lua
Outdated
@@ -45,6 +45,7 @@ GRPC.exporters.rawTransform = function(object) | |||
end | |||
|
|||
GRPC.exporters.group = function(group) | |||
if type(group) ~= "table" and getmetatable(group) ~= Group then return {} end |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think returning {}
might lead to effects harder to debug than the current error we get. I haven't tested it, but I'd guess this would simply set all fields of the group to their default / undefined value which is probably unexpected in most cases.
Without giving it too much thought (so please feel free to challenge my suggestion), I think the following might be a better solution:
- explicitly define the
group
property asoptional
. - handle the possibility of
getGroup
returningnil
in the unit export
Wdyt?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I initially set it with return nil, but then I suspected that someone might try and iterate over a table. but you are correct. it will force someone to put some guards on his end if.
I'm unfamiliar grpc, reading your response, it's obvious that returning nil and specifying optional in the proto file is the correct way to go.
I'll make the changes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I really don't like marking the group property as optional as we have now complicated the handling of every client (and will probably break existing clients who are expecting group to always be there) for a, frankly stupid and god-knows-if-ED-are-going-to-do-something-about-it edge-case..
I haven't heard anyone complaining about missing events (that would have these nil
s and are currently not being published) so my question is.
What is the goal of this change?
- Just stop the error messages appearing?
- Publishing essential events that are currently not being published and being skipped due to the error?
If the former then this is an overkill solution and we could reduce the error verbosity for it. If the latter then I think I would like to explore others before we make a change that effects every event with a unit in it.
Options:
- Create a
DeadUnit
/UnitWithoutGroup
object instead and only use it for those events that need it. - ???
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fair point. I wouldn't mind reducing the DeadEvent down to just containing the unit's name instead of a whole unit object. At least in my use-cases, that is all I would need to cleanup state about the units I track in my clients. I'd probably even prefer it over a UnitWithoutGroup
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, I wouldn't be one complaining about missing Dead
events, as I don't trust ED to fire that reliably anyway. So instead, I just consider a unit dead whenever I fetch information for it and receive a not found error 🤪
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm currently trying to debug something on my end. I suspect it has something to do with the grpc throwing LUA errors on parse, but I'll need to be very targeted in my testing, so I'll build a simple test mission tonight and do some tests.
as to how it will be resolved eventually, I trust your judgment for choosing the correct path. but I want to first determine if it's a real issue, as I suspect, or purely cosmetic.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok,
I'm circling back to this one.
I've got a unit testing mission for my project. I had everything green before installing gRPC.
After compiling from a clean main branch. Tests started failing and the dcs.log was filled with odd nil events from gRPC. Once i re applied this fix, tests are green again.
Do you have any recommendations about a proper methodology to ensure grpc errors do not break the dcs event handler?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
whats the word on this? Fox3 has been using gRPC, and anything i dynamically spawn, when it dies triggers this error....
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't see how gRPC breaks the events on the next event listener.
It initially might have, but all events are wrapped in a xpcall function to make sure that if anything goes in the gRPC lua layer it doesn't cascade down.
Could you specify what events are skipped or have a way to replicate it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fnslayeroc
This error might appear in the logs, but does something functionally break?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See comment @ #232 (comment)
In 2.8.2 ED has changed the behaviour of :getGroup() for units. and it will return nil for dead units.
https://wiki.hoggit.us/view/DCS_func_getGroup
in current version, you would get an empty group and feed it to the exporter class which throws errors in dcs.log
The proposed change tests if the incoming group object is indeed a group (based on lua metatable) and return an empty table if it fails