Uh oh!
There was an error while loading. Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork 34k
Closed
Labels
stdlibStandard Library Python modules in the Lib/ directoryStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or errorAn unexpected behavior, bug, or error
Description
Bug report
LogRecord.msecs returns an incorrect value when timestamp (self.ct) value has exactly 100ms.
One liner check:
assertint((1677793338.100_000_0-int(1677793338.100_000_0)) *1000) +0.0==100.0The issue is binary representation of "0.1" / floating point error:
>>># Definition of LogRecord.msecs:>>># https://github.com/python/cpython/blob/12011dd8bafa6867f2b4a8a9e8e54cb0fbf006e4/Lib/logging/__init__.py#L343>>># int((ct - int(ct)) * 1000) + 0.0>>>ct=1677793338.100_000_0>>>ct1677793338.1>>>ct-int(ct) 0.09999990463256836>>> _ *100099.99990463256836>>>int(_) 99>>> _ +0.099.0Your environment
- CPython versions tested on:
- 3.10.9
- 3.11.2
- Operating system and architecture:
- Custom company OS based on Debian Testing
- 64-bit
Discussion
I think switching to time.time_ns when setting the creation time might be one solution.
Linked PRs
vacosti and arhadthedev
Metadata
Metadata
Assignees
Labels
stdlibStandard Library Python modules in the Lib/ directoryStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or errorAn unexpected behavior, bug, or error
Projects
Status
Done