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

Protect access to Span implementation #1188

Merged
merged 3 commits into from
Oct 6, 2020

Conversation

ahlaw
Copy link
Contributor

@ahlaw ahlaw commented Oct 1, 2020

Description

Span now throws a TypeError in the constructor, and all instances of Span must now be instantiated by _Span constructor. The was implemented by overriding the __new__ constructor in the Span class.

Fixes #1000

Type of change

Please delete options that are not relevant.

  • Breaking change (fix or feature that would cause existing functionality to not work as expected)

How Has This Been Tested?

  • Unit test to verify an exception will be thrown when the constructor is called without the additional argument
  • Tox suite to check no existing functionality has been broken

Checklist:

  • Followed the style guidelines of this project
  • Unit tests have been added
  • Documentation has been updated

@ahlaw ahlaw requested a review from a team October 1, 2020 00:20
@ahlaw ahlaw force-pushed the 1000-private-sdk-span branch from 099c76a to 5c065ac Compare October 2, 2020 04:31
Copy link
Contributor

@owais owais left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

opentelemetry-sdk/src/opentelemetry/sdk/trace/__init__.py Outdated Show resolved Hide resolved
Copy link
Member

@aabmass aabmass left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice I like this approach!

Copy link
Contributor

@codeboten codeboten left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One suggested change based on @owais's comment. Otherwise this change looks good

@ahlaw ahlaw requested a review from codeboten October 5, 2020 19:39
@ahlaw ahlaw force-pushed the 1000-private-sdk-span branch from beac2a3 to c33530f Compare October 6, 2020 19:53
@codeboten codeboten merged commit 6fac795 into open-telemetry:master Oct 6, 2020
@ahlaw ahlaw deleted the 1000-private-sdk-span branch October 7, 2020 18:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implementations MUST NOT allow callers to create Spans directly
4 participants