-
Notifications
You must be signed in to change notification settings - Fork 8
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
Possible bug when handling / validating #17
Comments
Disregard the number of objects. It isn't that |
Hey, I'm glad you're finding it useful. Do you know if the write error var is set there? If it is It'd indicate grep had excited. On the other hand, the read might fail if grep had not interpreted the regex as expected and hadn't printed out the expected response line. There's also a 4 second timeout, is it possible that's being exceeded? If so you could bump it up to see if it helps. This coprocess communication is certainly fragile with bash, certainly could be edge cases lurking, perhaps on less used platforms. I recall you were using Solaris, is that the case for this? If you could find a way for me to reproduce the problem myself I can try to get to the bottom of it. |
Thanks for responding. The same scenario works fine on Solaris 11. I am seeing the error on Red Hat 8 and it does seem that grep has exited because the write error is set. I tried increasing the timeout as well |
That's interesting. Do you know if recent versions of red hat work? 8 was released 2019 so I would guess (without checking yet) that it is using bash 4.x. I've tested json.bash on the latest 4.x release but not older versions. I can probably try to find a VM or container image to try. Is this happening with any JSON content or a specific thing triggers it? |
Yes. It does, it doesn't seem to have ggrep however. I can get you some samples that trigger it along with the error tomorrow. |
Thanks for your patience. here is some debugging output. Let me know if this is helpful, thanks!
|
Sorry I've taken a while to get back to you on this! I was looking at the error you shared. All the JSON values listed in the second line are indeed valid, and I don't get an error when trying a json.bash command that merges & validates them. I need to try this with a Red Hat 8 to see if I can reproduce it there. I should have some time this weekend to do that. If you have any more info about the environment you see this in, and ideally a single command that triggers it that would be useful to debug this. |
It is a vanilla RHEL 8 installation, here are some additional details on the versioning etc. as well as the error.
|
This version of bash seems fine, the tests run on and pass with bash 4.4.19. I wonder if the version of grep you have is the problem. I've been testing on RHEL 8.9 using their docker image: https://hub.docker.com/r/redhat/ubi8 ( All the JSON in your error gets validated correctly if I put the objects into a file, one per line, and do: $ readarray -t group_array < /tmp/objects.json
$ json ...:json{:json}@group_array
# or
$ json.array ...:json[]@group_array And I've tried running the bats test suite in the same environment and that passes. Grep in this container is: $ grep --version
grep (GNU grep) 3.1
Copyright (C) 2017 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
Written by Mike Haertel and others, see <http://git.sv.gnu.org/cgit/grep.git/tree/AUTHORS>. Maybe you could try running the test suite in your machine? I could do it something like this from a RHEL container: $ dnf install git python3 diffutils jq
$ git clone https://github.com/h4l/json.bash.git ~/json.bash
$ git clone https://github.com/bats-core/bats-core.git ~/bats
$ cd ~/json.bash Run tests like this. By default I had one test failing due to Python being old (3.6) on this RHEL version: $ ~/bats/bin/bats json.bats
✓ json.buffer_output :: out stream :: in args
✓ json.buffer_output :: out stream :: in array
✓ json.buffer_output :: out array :: in array
✓ json.buffer_output :: out array :: in args
✓ json.buffer_output :: errors
✓ json.encode_string
✗ json.encode_string :: all bytes (other than zero)
(from function `assert_is_all_bytes_json' in file json.bats, line 123,
in test file json.bats, line 143)
`assert_is_all_bytes_json "${all_bytes_json:?}"' failed
File "<fstring>", line 1
(actual=)
^
SyntaxError: invalid syntax
[...]
✓ json.encode_number
✓ json validator :: resolves grep executable via JSON_BASH_GREP :: defaulting to ggrep then grep
✓ json validator :: resolves grep executable via JSON_BASH_GREP :: uses first defined command after splitting by : or the final undefined entry
✓ json validator :: reports validator grep process failing to start :: PID & FDs unset
✓ json validator :: reports validator grep process failing to start :: PID set, FDs unset
✓ json validator :: reports validator grep process failing to start :: PID unset, FDs set
✓ json validator :: reports validator grep process failing after start
✓ json validator :: reports validator grep process IO write error
✓ json validator :: reports validator grep process IO read error
✓ json validator :: validates valid JSON via arg
✓ json validator :: validates valid JSON via array
✓ json validator :: validates JSON with insignificant whitespace
✓ json validator :: detects invalid JSON via arg
✓ json validator :: detects invalid JSON via array
✓ json validator :: validates JSON sub-type
100 tests, 1 failure
This test will pass if you patch the json.bats file like this to support the old Python version: [root@27e27801a8bf json.bash]# git diff
diff --git a/json.bats b/json.bats
index 2f56d00..6392565 100644
--- a/json.bats
+++ b/json.bats
@@ -128,7 +128,7 @@ expected = "".join(chr(c) for c in range(1, 256))
if actual != expected:
raise AssertionError(
- f"Decoded JSON chars did not match:\n {actual=!r}\n{expected=!r}"
+ f"Decoded JSON chars did not match:\n actual={actual!r}\nexpected={expected!r}"
)
'
} I'm not sure how I can reproduce or fix this unless you can give me a script that specifically triggers the error in a known environment, like running the script in a particular container image. |
Well while the tests may indeed pass with GNU grep v3.1 & greater the |
Sorry I've not got back to you. I've tried the code from #14 in RHEL 8.0 and 8.9 via the container images To make any progress I need a literal exact artefact I can run that reproduces the issue. Could you make a Dockerfile that builds from the exact OS version you have an issue with and bundles the code that fails? That way I can run it and see what you're seeing. |
Thanks for following up, I am in the process of adding some test harness and test cause automation in hopes of simplifying what I have working. Part of this involves some sanitation of the data that will be used in the reporting. I mention this simply because I cleaned up the data and had to do some jenky hacks to print safely. The test harness should help ensure it isn't the data I am passing. Is there any way to keep this open a bit longer? Appreciate your time and a great library! |
Thanks for not giving up! Your plan sounds like a good approach. I'm happy to keep this open, no problem. Let me know what you find. |
First thanks for a useful library. It has cut JSON printing times substantially for my project.
I have come across some inconsistent behavior that seems to come from line.
When I examine the output of
_jv_response
it shows empty but the data found in_json_validator_out_fds[$$]
looks like valid file descriptors.What are some error conditions that would cause that to fail? When I look at the data being validated it looks like valid JSON objects.
When
ggrep
doesn't exist and a call tojson ...:json{:json}@group_entries
seems to be the error conditions. But as I said it is inconsistent. I think it may be the number of objects but am still in the process of hunting it downThe text was updated successfully, but these errors were encountered: