Skip to content
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

switch to new json library #24523

Open
ebadi opened this issue May 13, 2022 · 13 comments
Open

switch to new json library #24523

ebadi opened this issue May 13, 2022 · 13 comments
Labels
bounty bug development related to the openpilot development experience good first issue Feasible for new contributers PC Issues related to running openpilot on PC

Comments

@ebadi
Copy link
Contributor

ebadi commented May 13, 2022

Describe the bug

I updated logmessaged.py as below to see why I keep receiving an error message when I execute manager.py.

    if level >= log_level:
      print("record:::",record)    
      log_handler.emit(record)

Below is the result, the json message that is sent by logmessaged.py is not formatted correctly and https://github.com/commaai/openpilot/blob/master/common/logging_extra.py#L100 cannot parse it. (this part is not valid: {"created": 1652444715,3936491, ...)

((openpilot) ) hamid@hamid:~/openpilot/selfdrive/manager$ PASSIVE=0 NOSENSOR=1 USE_WEBCAM=1 ./manager.py
selfdrive/loggerd/bootlog.cc: bootlog to /home/hamid/.comma/media/0/realdata/boot/2022-05-13--14-25-13
missing public key: /home/hamid/.comma/persist/comma/id_rsa.pub
selfdrive/logmessaged.py: needs update
record::: {"created": 1652444715,3936491, "ctx": {"daemon": "soundd", "device": "pc", "dirty": true, "dongle_id": "UnregisteredDevice", "version": "0.8.14"}, "filename": "selfdrive/ui/soundd/sound.cc", "funcname": "Sound::Sound(QObject *)", "levelnum": 20, "lineno": 16, "msg": "default audio device:  \"\""}
--- Logging error ---
Traceback (most recent call last):
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/logging/__init__.py", line 1085, in emit
    msg = self.format(record)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/logging/__init__.py", line 929, in format
    return fmt.format(record)
  File "/home/hamid/openpilot/common/logging_extra.py", line 100, in format
    v = json.loads(record)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/json/__init__.py", line 357, in loads
    return _default_decoder.decode(s)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/json/decoder.py", line 337, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/json/decoder.py", line 353, in raw_decode
    obj, end = self.scan_once(s, idx)
json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 24 (char 23)
Call stack:
  File "./manager.py", line 205, in <module>
    main()
  File "./manager.py", line 182, in main
    manager_thread()
  File "./manager.py", line 134, in manager_thread
    ensure_running(managed_processes.values(), False, params=params, CP=sm['carParams'], not_run=ignore)
  File "/home/hamid/openpilot/selfdrive/manager/process.py", line 313, in ensure_running
    p.start()
  File "/home/hamid/openpilot/selfdrive/manager/process.py", line 245, in start
    self.proc.start()
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/process.py", line 121, in start
    self._popen = self._Popen(self)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/context.py", line 224, in _Popen
    return _default_context.get_context().Process._Popen(process_obj)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/context.py", line 277, in _Popen
    return Popen(process_obj)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/popen_fork.py", line 19, in __init__
    self._launch(process_obj)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/popen_fork.py", line 75, in _launch
    code = process_obj._bootstrap(parent_sentinel=child_r)
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/process.py", line 315, in _bootstrap
    self.run()
  File "/home/hamid/.pyenv/versions/3.8.10/lib/python3.8/multiprocessing/process.py", line 108, in run
    self._target(*self._args, **self._kwargs)
  File "/home/hamid/openpilot/selfdrive/manager/process.py", line 43, in launcher
    getattr(mod, 'main')()
  File "/home/hamid/openpilot/selfdrive/logmessaged.py", line 29, in main
    log_handler.emit(record)
Unable to print the message and arguments - possible formatting error.
Use the traceback above to help find the error.
record::: {"msg": "System time valid", "ctx": {}, "level": "INFO", "levelnum": 20, "name": "swaglog", "filename": "manager.py", "lineno": 31, "pathname": "./manager.py", "module": "manager", "funcName": "manager_init", "host": "hamid", "process": 11907, "thread": 140079618852672, "threadName": "MainThread", "created": 1652444713.9832933}
record::: {"msg": "missing public key: /home/hamid/.comma/persist/comma/id_rsa.pub", "ctx": {}, "level": "WARNING", "levelnum": 30, "name": "swaglog", "filename": "manager.py", "lineno": 83, "pathname": "./manager.py", "module": "manager", "funcName": "manager_init", "host": "hamid", "process": 11907, "thread": 140079618852672, "threadName": "MainThread", "created": 1652444714.1361263}
record::: {"msg": "starting process ui", "ctx": {"dongle_id": "UnregisteredDevice", "version": "0.8.14", "dirty": true, "device": "pc"}, "level": "INFO", "levelnum": 20, "name": "swaglog", "filename": "manager.py", "lineno": 171, "pathname": "./manager.py", "module": "manager", "funcName": "main", "host": "hamid", "process": 11907, "thread": 140079618852672, "threadName": "MainThread", "created": 1652444714.969782}
record::: {"msg": "preimporting selfdrive.locationd.calibrationd", "ctx": {"dongle_id": "UnregisteredDevice", "version": "0.8.14", "dirty": true, "device": "pc"}, "level": "INFO", "levelnum": 20, "name": "swaglog", "filename": "manager.py", "lineno": 102, "pathname": "./manager.py", "module": "manager", "funcName": "manager_prepare", "host": "hamid", "process": 11907, "thread": 140079618852672, "threadName": "MainThread", "created": 1652444714.9746444}

p.s: the manger seems to continue working without any issue.

OS Version

20.04

openpilot version or commit

No response

Additional info

No response

@ebadi ebadi added the PC Issues related to running openpilot on PC label May 13, 2022
@pd0wm
Copy link
Contributor

pd0wm commented May 13, 2022

The create time in the cloudlog json is a double, which is converted to a string using snprintf here: https://github.com/commaai/openpilot/blob/master/third_party/json11/json11.cpp#L60

The problem is that this probably takes into account your current locale, producing output with a comma as a decimal separator. Which is not valid json.

a workaround would be to switch your system locale to something that uses a . as decimal separator.

relevant json11 issue: dropbox/json11#38

@pd0wm pd0wm changed the title json.decoder.JSONDecodeError in logmessaged.py cloudlog produces malformed json on systems with non US locale May 13, 2022
@pd0wm pd0wm added the bug label May 13, 2022
@ebadi
Copy link
Contributor Author

ebadi commented May 13, 2022

@pd0wm thanks, I confirm that the issue is correctly identified and your workaround fixed the issue. Feel free to close the issue if the issue is too minor to be fixed.
Thanks again.

@adeebshihadeh
Copy link
Contributor

Looks like json11 is no longer maintained. rapidjson seems like a good and mature alternative that may also give us a small speed improvement too.

@adeebshihadeh
Copy link
Contributor

https://github.com/nlohmann/json seems like a good one too

@adeebshihadeh adeebshihadeh changed the title cloudlog produces malformed json on systems with non US locale [$100 bounty] cloudlog produces malformed json on systems with non US locale Dec 12, 2023
@adeebshihadeh adeebshihadeh added good first issue Feasible for new contributers bounty labels Dec 12, 2023
@adeebshihadeh
Copy link
Contributor

Bounty is to fix this as simply as possible, and it seems like we'll need to switch libraries to do it (confirm this though). If we absolutely have to switch, https://github.com/nlohmann/json seems like the best options.

@adeebshihadeh adeebshihadeh changed the title [$100 bounty] cloudlog produces malformed json on systems with non US locale [$100 bounty] switch to new json library Dec 17, 2023
@jnewb1 jnewb1 moved this to Open in openpilot bounties Dec 18, 2023
@github-project-automation github-project-automation bot moved this from Open to Done in openpilot bounties Jan 23, 2024
@adeebshihadeh adeebshihadeh reopened this Feb 20, 2024
@adeebshihadeh
Copy link
Contributor

First attempt in #31093 had an issue with thneed.

@jnewb1 jnewb1 moved this from Done to Open in openpilot bounties Mar 13, 2024
@adeebshihadeh adeebshihadeh added the development related to the openpilot development experience label Jun 30, 2024
@adeebshihadeh adeebshihadeh changed the title [$100 bounty] switch to new json library switch to new json library Jul 7, 2024
@FiReLScar
Copy link

I’m new, is this still a bounty, if not can I still work on it. I’m looking for a software development job and rediscovered this company. I’d love to work here.

@FiReLScar
Copy link

And maybe I don't fully understand but why not just force a locale?

@HegdePratik
Copy link

Hello,
I noticed that this issue is still open and carries a bounty. I am interested in working on it. Could you please confirm if the issue is still active and if the bounty is available? Additionally, are there any specific requirements I should be aware of before proceeding?

@adeebshihadeh
Copy link
Contributor

And maybe I don't fully understand but why not just force a locale?

This is probably a good solution since we control both the read/write sides. Patch it into our json11 build?

@deanlee
Copy link
Contributor

deanlee commented Jan 10, 2025

This task should be easier now that #34261 has removed the thneed, which heavily relied on json11.

@FiReLScar
Copy link

I was working on my previous solution, but got caught on trying to build it, I absolutely hate Python so “scons” was a completely new thing to me, so I didn’t get to build my solution and test it, but anyways are we still going to use nlohmann’s json lib or just use my solution.

@Adonai-Technologies
Copy link

The issue arises because the JSON message generated by logmessaged.py is not properly formatted. Specifically, the created field in the log message contains an invalid value: 1652444715,3936491, which is not a valid JSON format. JSON requires a valid syntax for numbers, and 1652444715,3936491 is interpreted as an error.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bounty bug development related to the openpilot development experience good first issue Feasible for new contributers PC Issues related to running openpilot on PC
Projects
Status: Open
Development

No branches or pull requests

7 participants