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

U/eojeah/otel-semantic-attributes-http #129

Merged
merged 9 commits into from
Jul 4, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ jobs:
strategy:
fail-fast: false
matrix:
python-version: ['3.7', '3.8']
python-version: ['3.8', '3.10', '3.11', '3.12']

steps:
- uses: actions/checkout@v2
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,4 @@ dist/
venv
tags
*.swp
.idea/
11 changes: 5 additions & 6 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,19 +1,18 @@
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v0.9.1
rev: v4.5.0
hooks:
- id: trailing-whitespace
- id: end-of-file-fixer
- id: autopep8-wrapper
- id: check-json
files: \.(bowerrc|jshintrc|json)$
- id: check-yaml
- id: debug-statements
- id: name-tests-test
exclude: tests/acceptance/test_helper.py
- id: requirements-txt-fixer
- repo: https://gitlab.com/pycqa/flake8
rev: 5.0.4
- repo: https://github.com/pycqa/flake8
rev: 7.0.0
hooks:
- id: flake8
args:
Expand All @@ -23,9 +22,9 @@ repos:
rev: v0.3.5
hooks:
- id: reorder-python-imports
language_version: python3.7
language_version: python3.8
- repo: https://github.com/asottile/pyupgrade
rev: v2.38.2
hooks:
- id: pyupgrade
args: ['--py37-plus']
args: ['--py38-plus']
35 changes: 0 additions & 35 deletions .travis.yml

This file was deleted.

2 changes: 1 addition & 1 deletion mypy.ini
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[mypy]
python_version = 3.7
python_version = 3.8
pretty = true
show_error_codes = true
show_error_context = true
Expand Down
44 changes: 41 additions & 3 deletions pyramid_zipkin/request_helper.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
from pyramid.request import Request
from pyramid.response import Response

from pyramid_zipkin.version import __version__


DEFAULT_REQUEST_TRACING_PERCENT = 0.5

Expand Down Expand Up @@ -165,15 +167,51 @@ def get_binary_annotations(
:param response: the Pyramid response object
:returns: binary annotation dict of {str: str}
"""
route = request.matched_route.pattern if request.matched_route else ''

annotations = {
'http.request.method': request.method,
'network.protocol.version': request.http_version,
'url.path': request.path,
'server.address': request.server_name,
'server.port': str(request.server_port),
'url.scheme': request.scheme,
'http.uri': request.path,
'http.uri.qs': request.path_qs,
'http.route': route,
'otel.library.name': __name__.split('.')[0],
'otel.library.version': __version__,
}

if request.user_agent:
annotations['user_agent.original'] = request.user_agent

if request.query_string:
annotations["url.query"] = request.query_string

if request.matched_route:
annotations['http.route'] = request.matched_route.pattern

if request.client_addr:
annotations['client.address'] = request.client_addr

if response:
annotations['response_status_code'] = str(response.status_code)
status_code = response.status_code
if isinstance(status_code, int):
annotations['http.response.status_code'] = str(status_code)
annotations['response_status_code'] = str(status_code)
if 100 <= status_code < 200:
annotations['otel.status_code'] = 'Unset'
elif 200 <= status_code < 300:
annotations['otel.status_code'] = 'Ok'
elif 300 <= status_code < 500:
annotations['otel.status_code'] = 'Unset'
else:
annotations['otel.status_code'] = 'Error'

else:
annotations['otel.status_code'] = 'Error'
annotations['otel.status_description'] = (
f'Non-integer HTTP status code: {repr(status_code)}'
)

settings = request.registry.settings
if 'zipkin.set_extra_binary_annotations' in settings:
Expand Down
10 changes: 8 additions & 2 deletions pyramid_zipkin/tween.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import functools
import traceback
import warnings
from collections import namedtuple
from typing import Any
Expand Down Expand Up @@ -196,10 +197,15 @@ def tween(request: Request) -> Response:
try:
response = handler(request)
except Exception as e:
exception_type = type(e).__name__
exception_stacktrace = traceback.format_exc()
zipkin_context.update_binary_annotations({
'error.type': type(e).__name__,
'response_status_code': '500'
'error.type': exception_type,
'response_status_code': '500',
'http.response.status_code': '500',
Rob-Johnson marked this conversation as resolved.
Show resolved Hide resolved
'exception.stacktrace': exception_stacktrace,
})
zipkin_context.add_annotation(exception_type)
raise e
finally:
if zipkin_settings.use_pattern_as_span_name \
Expand Down
1 change: 1 addition & 0 deletions pyramid_zipkin/version.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
__version__ = '2.2.0'
1 change: 1 addition & 0 deletions requirements-dev.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,5 @@ coverage
mypy
ordereddict
pytest
tox
webtest
7 changes: 3 additions & 4 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@
from setuptools import find_packages
from setuptools import setup

__version__ = '2.2.0'
version = exec(open('pyramid_zipkin/version.py').read())

setup(
name='pyramid_zipkin',
version=__version__,
version=version,
provides=["pyramid_zipkin"],
author='Yelp, Inc.',
author_email='[email protected]',
Expand All @@ -28,8 +28,7 @@
"Topic :: Software Development :: Libraries :: Python Modules",
"License :: OSI Approved :: Apache Software License",
"Operating System :: OS Independent",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
],
python_requires=">=3.7",
python_requires=">=3.8",
)
16 changes: 16 additions & 0 deletions tests/acceptance/app/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,20 @@ def client_error(dummy_request):
return response


@view_config(route_name='redirect', renderer='json')
def redirect(dummy_request):
response = Response('Redirectional')
response.status_int = 302
return response


@view_config(route_name='information_route', renderer='json')
def information_route(dummy_request):
response = Response('Informational')
response.status_int = 199
return response


def main(global_config, **settings):
""" Very basic pyramid app """
settings['service_name'] = 'acceptance_service'
Expand All @@ -114,6 +128,8 @@ def main(global_config, **settings):

config.add_route('server_error', '/server_error')
config.add_route('client_error', '/client_error')
config.add_route('information_route', '/information_route')
config.add_route('redirect', '/redirect')

config.scan()

Expand Down
12 changes: 12 additions & 0 deletions tests/acceptance/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

import pytest

from pyramid_zipkin.version import __version__


@pytest.fixture
def default_trace_id_generator(dummy_request):
Expand All @@ -24,7 +26,17 @@ def get_span():
'http.uri': '/sample',
'http.uri.qs': '/sample',
'http.route': '/sample',
'url.path': '/sample',
'url.scheme': 'http',
'network.protocol.version': 'HTTP/1.0',
'server.address': 'localhost',
'server.port': '80',
'response_status_code': '200',
'http.response.status_code': '200',
'http.request.method': 'GET',
'otel.status_code': 'Ok',
'otel.library.version': __version__,
'otel.library.name': 'pyramid_zipkin',
},
'name': 'GET /sample',
'traceId': '17133d482ba4f605',
Expand Down
Loading
Loading