-
Notifications
You must be signed in to change notification settings - Fork 232
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
Error "first item not found anywhere" is unclear does not indicate the name of the item #207
Comments
Thank you for reporting this unclear error message. When you report something about what happens when running WireWiz, it will be much easier for others to reproduce the same state if you include more information when submitting an issue. However, in your case I'm able to reproduce the same error message using e.g. this YAML input that contains a connection to non-existing connectors/cables: connections:
- - X: 1
- Y: 1 In a more realistic scenario, this error can easily happen when misspelling a connector/cable name. I agree that it will help the user to know the name of the item that is not found, and that this name is expected to be found in the set of connectors or cables. The exception is raised here: https://github.com/formatc1702/WireViz/blob/606ddbf9775da6300299640501083acfaef42077/src/wireviz/wireviz.py#L91 I suggest changing this to something like: raise Exception(f'Connection {cindex} item {first_item} is not in neither connectors nor cables') Where for cindex, connection in enumerate(yaml_data['connections'], start=1): There are also several other exceptions in WireViz that need improvements like this. Maybe we should raise a more general issue to identify more of them? |
Yes. More user-friendly, helpful, and standardized (in terms of grammar) error messages have been on my mind for a while. If @hyphz doesn't mind, I will hijack this issue and generalize as @kvid as suggested. Thanks! Edit: The YAML parsing is being completely refactored in #186, so any attempts to improve the code should start from that branch, or wait until that PR is merged into |
If there was a way to have a machine-readable link of the error output to the YAML input, this would highly improve the usability in nanangp/vscode-wireviz-preview @nanangp see also #305 (comment) |
In PR #251 I've replaced some |
Sure. That will definitely help, but still not refer to the actual line number from the YAML input. Therefore, I am linking this to the parser replacement issue: #223 (comment) |
@kvid wrote:
Please take a look at Structlog. It can act as a drop-in replacement, while offering full configurability. See the demonstration of what an exception could look like: In combination with this, you could even output logs in machine readable format using YAML: |
To avoid errors like #426 shows, we should raise a if not isinstance(attribs, dict):
raise TypeError(f"Expecting a dict value for '{key}' in '{sec}', but got {type(attribs)}:\n{attribs}") |
It would be very helpful to list the name of the item that is not found, and the meaning of the error message is not clear at the moment (the first item of what?).
The text was updated successfully, but these errors were encountered: