How to write unittests for logs¶
Writting unittests in telemetry is hard and can take a long time as it is usually something that you look at, not something that is easily unit tested. To counter that, the telemetry framework provides a scheme framework. A scheme is the representation of the expected way the logs should look.
For example, you could write the following scheme to check for two logs, one CRITICAL
with message "Some
critical message"
and parameters { "param": "1", "request": "GET /path" }
, and the other one ERROR
with
message "Some error message"
and no parameters.
CRITICAL "Some critical message" [param:1][request:GET /path]
ERROR Some error message
Once you have your scheme, you can call VirtualLogRecords.verify_from_scheme
with the scheme of your string
to verify that the latest logs are the same as the logs you expect (if there are additional parameters in your
logs, they wont fail the result). For example, you could do the following
assert VirtualLogRecords.verify_from_scheme("""
CRITICAL "Some critical message" [param:1][request:GET /path]
ERROR Some error message
""")
If you want to simplify debugging in case of a test failure, you can provider a test verbosity to the method,
either LogTestVerbosity.ONLY_ERROR
or LogTestVerbosity.FULL
. The ONLY_ERROR
mode will print the
first logs that differ and why they differ, and the FULL
verbosity will print the logs found in scheme format,
the expected logs in scheme format and the error message.
Advanced Testing¶
Note
This is not the recommended way to do unit testing on logs as it can lead to really long code to check that the logs are the same as what you expects.
The test logging is handled by a custom logging handler of type TestLoggingHandler
.
You can get the test handler that is used in the configuration using telemetry.logging.get_test_handler()
It provides twos methods, get_sent_records
and clear
to allow you to retrieve the records and clear
them once you don’t need them anymore.