A preview of an OMF client library
Project description
OMF Python Library Sample
Version: 0.1.1_preview
This sample library requires Python 3.7+. You can download Python here.
About the library
The python OMF library is an introductory language-specific example of writing OMF Messages against OMF endpoints. It is intended as instructional samples only and are not for production use.
The library can be obtained by running: pip install omf_sample_library_preview
Other language libraries and samples are available on the AVEVA GitHub Organization.
Testing
The library is tested using PyTest. To test locally, make sure that PyTest is installed, then navigate to the Tests directory and run the test classes by executing
python -m pytest {testclass}
where {testclass} is the name of a test class, for example ./test_omfclient.py.
Optionally to run end to end tests, rename the appsettings.placeholder.json file to appsettings.json and populate the fields, (This file is included in the gitignore and will not be pushed to a remote repository), then run
python -m pytest {testclass} --e2e True
Logging
Every request made by the library is logged using the standard Python logging library. If the client application using the library creates a logger, then library will log to it at the following levels:
Level | Usage |
---|---|
Error | any non 200-level response code, along with the error message |
Info | all request urls and verbs all response status codes |
Debug | data payload and all request headers (Authorization header value redacted) response content and all response headers |
The process for creating a logger is described in the Logging HOWTO documentation.
An example walkthrough is shown here:
Logger Creation Example
To initiate logging, the client must create a logger, defining a log file, a desired log level, and default formatting:
# Step 0 - set up logger
log_file = 'logfile.txt'
log_level = logging.INFO
logging.basicConfig(filename=log_file, encoding='utf-8', level=log_level, datefmt='%Y-%m-%d %H:%M:%S',
format='%(asctime)s %(module)16s,line: %(lineno)4d %(levelname)8s | %(message)s')
This creates a logger object that streams any logged messages to the desired output. The libraries called by the client, including this ADH Sample Library Python
, that have implemented logging will send their messages to this logger automatically.
The log level specified will result in any log at that level or higher to be logged. For example, INFO
captures INFO
, WARNING
, ERROR
, and CRITICAL
, but ignores DEBUG
.
Logger Usage Example
To change the log level after creation, the level can be set using the following command
logging.getLogger().setLevel(logging.DEBUG)
This concept is particularly helpful when debugging a specific call within the application. Logging can be changed before and after a call to the library in order to provide debug logs for that specific call only, without flooding the logs with debug entries for every other call to the library.
An example of this can be seen here.
# Step 4 - Retrieve the data view
original_level = logging.getLogger().level
logging.getLogger().setLevel(logging.DEBUG)
container_service.createContainers(omf_containers)
logging.getLogger().setLevel(original_level)
Note that the original level was recorded, logging was set to debug, the createContainers
call was performed, then logging was set to its previous level. The logs will contain debug message for only this call, and all other calls before and after will be logged with their original level.
Developed using Python 3.10.1
For the main AVEVA samples page ReadMe
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for omf_sample_library_preview-0.1.1rc0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88587b9a644d1703b8a4af65a2bafcd2a4e1c220b1f53624dc1a258f2f469006 |
|
MD5 | 90e05c299937de4f96ba855754f0c620 |
|
BLAKE2b-256 | 2bc5831e16331a883ec4d388c012874d5b30da3a39cd98e2f452fd9a14084852 |
Hashes for omf_sample_library_preview-0.1.1rc0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a584b716390658827cb3a1d54bdd525e97df67e3d4716f7f74ed8b60e7c8435a |
|
MD5 | 2ce44383e86e8d3da25f45dcb2cd05f6 |
|
BLAKE2b-256 | 94e39f4ac3edda881f8a255140ba29a38213f8bd5a2fe6c93904442f4597e782 |