ChangeLog

CHANGES

  • pre-commit: Bump version

  • Drop remaining pin of elasticsearch

  • Remove Python 3.8 support

  • Unpin for newer elasticsearch versions

  • Replace deprecated constant_time_compare

  • Bump hacking to latest

  • Update bandit to 1.7.x

4.2.0

  • reno: Update master for unmaintained/victoria

  • Update python classifier in setup.cfg

  • List up extra requirements for drivers

  • Move oslo.config to normal requirements

  • Declare Python 3.10 support

4.1.0

  • profiler: add python requests profile

4.0.0

  • add support of otlp exporter

  • devstack: remove jaeger container on unstack

  • [profiler] hmac_key should be secret

  • jaeger: introduce process tags’ option for tracer

  • jaeger: introduce service name prefix

  • jaeger: fix driver initialization for tests

  • setup.cfg: Replace dashes with underscores

  • Change StrictRedis usage to Redis

  • tox: Add functional-py38, functional-py39 envs

  • remove unicode prefix from code

  • Fix formattiing of release list

3.4.3

  • Make some revisions in the document

  • Update CI to use unversioned jobs template

  • Fix api index and module index

3.4.2

  • Set manila config opts in devstack

3.4.1

  • Uncap PrettyTable

  • Move flake8 as a pre-commit local target

  • Use TOX_CONSTRAINTS_FILE

  • Dropping lower constraints testing

  • Remove six

  • Use py3 as the default runtime for tox

  • Adding pre-commit

  • ignore reno generated artifacts

  • Add Python3 wallaby unit tests

  • Update master for stable/victoria

3.4.0

  • Fix StopIteration error on Ubuntu Focal

  • Bump bandit version

3.3.0

  • switch to importlib.metadata to find package version

3.2.2

  • Fix empty ‘args’ and ‘kwargs’ when using ‘hide_args’ with Jaeger

3.2.1

  • drop mock from lower-constraints

3.2.0

  • Fix pep8 failures

  • Switch to newer openstackdocstheme and reno versions

  • Bump default tox env from py37 to py38

  • Add py38 package metadata

  • Enforce order of import statements

  • Use unittest.mock instead of third party mock

  • Add Python3 victoria unit tests

  • Update master for stable/ussuri

3.1.0

  • Update hacking for Python3

  • Start README.rst with a better title

3.0.0

  • [ussuri][goal] Drop python 2.7 support and testing

2.9.0

  • Switch to Ussuri jobs

  • Update master for stable/train

  • Handle driver initialization errors to avoid service crash

2.8.2

  • Add Python 3 Train unit tests

2.8.1

  • Bring env OSPROFILER_CONNECTION_STRING into effect

  • Support standalone placement in the devstack

2.8.0

  • Automatic configuration of SQLAlchemy driver in DevStack

  • change function list_traces of mongodb module

  • Replace git.openstack.org URLs with opendev.org URLs

  • Fix elasticsearch version in python requirements

2.7.0

  • Minimum versions of databases with JSON data type support

  • OpenDev Migration Patch

  • Dropping the py35 testing

  • Optimize storage schema for Redis driver

  • Allow OSPROFILER_TRACE_SQLALCHEMY to be overridden

  • Rename OSProfiler-enabled Tempest job

  • Don’t fail if sqlalchemy driver fails to initialize

  • Update master for stable/stein

2.6.0

  • Add sqlalchemy collector

  • Change python3.5 job to python3.7 job on Stein+

  • Use $STACK_USER variable in install_jaeger function

  • Add support for mongodb backend in devstack plugin

  • Reload keystone to apply osprofiler config

  • Do not insert osprofiler filter into Neutron api-paste pipeline

  • Allow test path to be overridden

2.5.2

  • In case of an error, always add message

  • Change http to https in reference link

  • [devstack] Add support for elasticsearch backend

  • Change openstack-dev to openstack-discuss

  • Configure Jaeger collector in DevStack

2.5.1

  • Update min tox version to 2.0

  • In DevStack install Redis client library via pip, not as system package

  • When shortening span-ids, check if they’re already short

  • Don’t quote {posargs} in tox.ini

2.5.0

  • build universal wheels

  • Collect traces from Tempest job

  • Add a job to run full Tempest with enabled profiler

  • Make tracing of SQL statements configurable in DevStack plugin

2.4.1

  • Use templates for cover and lower-constraints

  • add password for connecting redis-sentinel

  • add lib-forward-testing-python3 test job

  • add python 3.6 unit test job

  • import zuul job settings from project-config

  • Update reno for stable/rocky

  • Switch to stestr

2.3.0

  • Add release note link in README

  • Make profiler.clean() public method

2.2.0

  • opts: Fix invalid rST formatting

  • Put ‘db’ parameter back and provide a deprecation warning before remove

  • Add minimum version and fix dulwich issue

  • fix tox python3 overrides

  • Update documentation & usage for redis driver

  • Allow user to specify password for Redis connection

  • OSprofiler with Jaeger Tracing as backend

2.1.0

  • Fix typo

  • Remove lower bound from requirements

  • Trivial: Update pypi url to new url

  • Add lower-constraints job

  • set default python to python3

2.0.0

  • Filter traces that contain error/exception

  • Zuul: Remove project name

  • Update reno for stable/queens

  • Unify and fix `list_traces` function

  • Add initial ‘trace list’ command

  • Remove Ceilometer support

  • Check profiler instance before initialize

  • update sphinx-doc links

  • Initialize osprofiler in Nova Cell configs

  • Add oslo.serialization into requirements

1.15.1

  • Cleanup test-requirements

1.15.0

  • Update the invalid doc links to the right ones in osprofiler docs

  • Add filter for OSprofiler html output

  • Add kwargs to WsgiMiddleware __init__

  • Make collector configurable in DevStack plugin

  • Add functional test for Redis driver

  • Remove setting of version/release from releasenotes

  • Add Zuul job for functional testing

1.14.0

  • Extend messaging driver to support reporting

  • Handle and report SQLAlchemy errors

1.13.0

  • Remove dependency on oslo.log library

1.12.0

  • Do not require OpenStack authentication to run osprofiler CLI

  • Make dependency on oslo.messaging runtime only

  • Make test_notifier independent of test case execution order

  • Add function/sql results to trace info

  • Improve unit test coverage

  • Remove unused parameters from Profiler class

  • Add loading local static files option of template.html

  • Update reno for stable/pike

1.11.0

  • Update URLs in documents according to document migration

  • doc: Fix formatting

  • rearrange existing documentation to fit the new standard layout

  • Switch from oslosphinx to openstackdocstheme

  • Enable warning-is-error in doc build

  • Update .gitignore

1.10.1

  • Expose connection_string parameter into DevStack plugin

1.10.0

  • Cleanup code of DevStack plugin

  • Improve error reporting for Ceilometer driver

  • Replace oslo.messaging.get_transport with get_notification_transport

1.9.1

  • devstack: use project conf file env variables

1.9.0

  • Fix error message for invalid trace

  • Remove unused imports

1.8.0

  • Switch to “topics” keyword for messaging driver

  • Add zun to devstack config

  • Python 3.4 support is removed

1.7.0

  • Highlight last trace for OSprofiler html output

1.6.0

  • Add magnum to devstack config

  • Add Jaeger to list of similar projects

  • [Fix gate]Update test requirement

  • fix an outdated link for zipkin

  • Change some bindings to one-time bindings

  • Revert “Change list_opts to dictionary style”

  • Move implemeted specs to implemented directory

  • Remove extra white spaces in json output

  • Increase angular digest iteration limit

  • devstack: make option hmac_keys configurable

  • Update reno for stable/ocata

  • Change list_opts to dictionary style

  • Fix mistake in split meta string

  • Fix enabling order specify in README.rst

1.5.0

  • Add py35 tox virtualenv

  • Add functional test for notifier backend

  • Upgrade libraries, add highlight for JSON data

  • Fix syntax in JS, JSON indent with 4 spaces

  • Pass oslo.messaging kwargs only for “messaging://”

  • Organize unit tests under tests/unit folder

  • Use uuidutils instead of uuid.uuid4()

  • Use oslo_utils.uuidutils.is_uuid_like

  • Error out for invalid trace ID

  • Re-format html template

  • Replace six.iteritems() with .items()

  • Show team and repo badges on README

  • Fix import order

  • Move hacking checks outside tests

  • Visualize trace output as graph

  • Remove print statement

  • Pretty print json output

  • Add exception to trace point details

  • Add a redis driver

  • Replace logging with oslo_log

  • Add Log Insight driver

  • Add reno for release notes management

  • Use method constant_time_compare from oslo.utils

  • Update documentation to the latest state

  • Update dependencies’ version from project requirements

  • Update devstack plugin readme to enable Panko

  • Enable devstack to configure OSProfiler for Senlin project

  • Add .idea folder to .gitignore

  • Heat and Cinder now use new style conf

  • Fix the issue that ChangeLog not found when building docs

  • Add AUTHORS and ChangeLog to .gitignore

  • Update the driver path in th doc

  • Use an env variable for connection string default

  • Fix a doc typo

  • Update homepage with developer documentation page

  • Trivial: Remove vim header from source files

  • [doc]Add description for multi-backend URI

  • Add Elasticsearch driver

  • Remove old notifiers

1.4.0

  • Add tests for mongodb driver

  • Add connection string usage to osprofiler-cli

  • Add overall profiler stats by operation

  • Fix typos on spec directory

  • Fix title of index page

  • Add MongoDB driver

  • OSprofiler initialization method

  • Add Ceilometer driver

  • Add backward compatible drivers structure

  • Expose osprofiler middleware as entrypoint

  • Remove discover from test-requirements

  • Fix typo: ‘Olso’ to ‘Oslo’

  • Don’t set html_last_updated_fmt without git

  • Add exception type to stop trace info

1.3.0

  • Add hepler to trace sessions

  • doc: Log warning when can’t get informaiton from git

  • Add an error tip when trace_id is not found

  • Add a similar link with reference to similar projects/libraries

  • Continue work on standardizing osprofiler docs

  • Remove dead/broken link to example

  • Updates to doc conf.py to look the same as other projects

  • Clean thread local profiler object after usage

  • Improve unit test coverage

  • Avoid tracing class and static methods

  • Avoid multiple tracing when applying meta or class decorator

  • Remove outdated version

  • Dont claim copyright for future years

  • Use pkg_resources to get version

  • Enable bandit in gate

  • Fallback if git is absent

  • It’s unnecessary set deprecate group for option ‘enabled’

  • Add CONTRIBUTING.rst

1.2.0

  • Remove flake8 ignore list in tox.ini

1.1.0

  • run py34 tests before py27 to work around testr bug

  • stop making a copy of options discovered by config generator

  • Make class detection more accurate

1.0.1

  • Disable staticmethods tracing

1.0.0

  • Add fix for static and class methods in @trace_cls

  • Expose X-Trace-* constants

  • Add raw Ceilometer events support to DevStack plugin

  • Use raw data storage for events to collect more info

  • Use oslo.utils reflection and avoid refinding decorated name

  • Move osprofiler tests into osprofiler

  • Consolidate osprofiler options

  • Remove argparse from requirements

  • Add py34 to tox env list

  • Make profiler timestamp json.dumps friendly

  • Replace deprecated library function os.popen() with subprocess

  • Add DevStack plugin

0.4.0

  • Remove Py33 support

  • Make it possible to specify file path as a source for trace

  • Remove support for py26

  • Improve HTML reports performance

  • Fix TracedMeta class

  • Fix a couple of typos in doc strings

  • Fix Ceilometer parser to use events

  • remove python 2.6 trove classifier

  • Add TracedMeta class

  • Update requirements

  • Deprecated tox -downloadcache option removed

  • Fix enable/disable compatibility

  • Add hacking rules & fix hacking issues

0.3.1

  • Make api-paste.ini config optional

  • Fix minor typos in the multi-backend specification

  • Spec: Integration Testing

  • Spec: Better DevStack Integration

  • Spec: Multi Backend support

  • Spec: Optional options in api-paste.ini

  • Add specs base structure

  • Update .gitreview for new namespace

  • Fix date parsing when there’s not milliseconds in the date

  • Various cleanups

  • Remove version from setup.cfg

  • Stop using intersphinx

  • Rename doc environment to docs

  • Imporve generated trace html

  • Adding a hits to notice operator when trace not found

0.3.0

  • Cut version 0.3.0

  • add more unit tests

  • Allow N-keys (one should apply)

  • Some minor fixes in README.rst

  • ReadMe updates with CLI commands

  • Add entry point for OSProfiler, that display traces

  • Remove dead code

  • Add OSprofiler docs

  • Fix wrong code duplication in utils.itersubclasses()

  • Use compare_digest or an equivalent when available

0.2.5

  • Imporve read me

  • Fix issue with trace_cls

  • Add @profiler.trace_cls decorator

  • Prevent Messaging to resend failed notifications

  • Update README.rst with some small adjustments

  • Some grammar-related imprevements

0.2.4

  • Add alternative way to dissable middleware

  • Improve tracing of sqlalchemy

0.2.3

  • Fix ceilometer parse notifications

0.2.2

  • Improve a bit README.rst

  • Fix & improve trace decorator

  • Fix some typos in README.rst

0.2.1

  • Update README.rst

  • Add @profiler.trace decorator

  • Add missing tests for messaging notifer plugin

0.2.0

  • Add notifier plugin based on Ceilometer

  • Add base for notifier plugins

  • Make profiler.utils private

  • Improve ceilometer notifications getter

  • Move public methods to top of sqlalchemy module

  • Refactor web.add_trace_id_header()

  • Make a cleaner API for osporfiler

  • Add “_” to names of private methods

0.1.1

  • Remove unused libs from requirments and fix info in setup.cfg

0.1.0

  • Add extra docs in sqlalchemy module

  • Make hmac required argument in profiler.Profiler.init

  • Refactor WSGI.middleware and imporve test coverage

  • Improve test coverage

  • Improve README

  • Base64 encode the ‘X-Trace-Info’ header

  • Fix text requirements

  • Edit notifier.notify()

  • Add sanity tests for profiler and hmac usage

  • Imporve ceilometer parser

  • Split code sugar and logic in Profiler class

  • Simplify notifer API

  • Add git review file

  • Add in hmac signing/verification

  • Make name also use a deque

  • Use a collections.deque which has thread safe pop/append

0.0.1

  • Add work around if not all messages were consumed by ceilometer

  • Remove information about service in profiler

  • Add parser of ceilometer notifications

  • Fix setup.cfg python 2.6 is supported as well

  • Add possibility to disable sqlalchemy tracing

  • Fix WSGI middleware and add unit tests

  • Remove from sqlachemy.after_execute notifcation resutls and add UTs

  • Imporove profiler and add UTs

  • Update global requirments

  • Remove unused dependency from requirments.txt

  • Fix licenses

  • Fix pep

  • Add tracer for sqlalchemy

  • Add WSGI Middleware

  • Add profiler class

  • Init Strucutre of lib

  • Initial commit