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

click: ignore click based servers #3174

Merged
merged 5 commits into from
Jan 9, 2025

Conversation

xrmx
Copy link
Contributor

@xrmx xrmx commented Jan 7, 2025

Description

We don't want to create a root span for long running processes like development web servers otherwise all requests would have the same trace id which is unfortunate.

Fixes #3171
Fixes #3172

Type of change

Please delete options that are not relevant.

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • This change requires a documentation update

How Has This Been Tested?

Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration

  • tox -e py310-test-instrumentation-flask

Does This PR Require a Core Repo Change?

  • Yes. - Link to PR:
  • No.

Checklist:

See contributing.md for styleguide, changelog guidelines, and more.

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

We don't want to create a root span for long running processes like servers
otherwise all requests would have the same trace id which is unfortunate.
@xrmx xrmx force-pushed the disable-click-for-webservers branch from 0c1fbde to 770a6e3 Compare January 7, 2025 15:00
@xrmx xrmx marked this pull request as ready for review January 7, 2025 15:00
@xrmx xrmx requested a review from a team as a code owner January 7, 2025 15:13
Copy link
Contributor

@codefromthecrypt codefromthecrypt left a comment

Choose a reason for hiding this comment

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

Thanks, this can avoid big surprises

xrmx and others added 2 commits January 8, 2025 09:27
@xrmx xrmx requested a review from tammy-baylis-swi January 8, 2025 08:50
Copy link
Contributor

@tammy-baylis-swi tammy-baylis-swi left a comment

Choose a reason for hiding this comment

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

Thank you 😺

@xrmx xrmx merged commit 908437d into open-telemetry:main Jan 9, 2025
674 checks passed
Comment on lines +172 to +177
@click.command("uvicorn")
def command_uvicorn():
pass

runner = CliRunner()
result = runner.invoke(command_uvicorn)
Copy link
Contributor

@Kludex Kludex Jan 10, 2025

Choose a reason for hiding this comment

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

I think we could just call from uvicorn.main import main as uvicorn_command and use it instead of mocking it. Flask is not being mocked.


Please do not ask me to create an issue. I'm good. 🙏

Copy link
Contributor Author

Choose a reason for hiding this comment

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

If you look at the code flask is recognized by checking a parameter type since the command name run is pretty generic. uvicorn name is pretty unique..

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.

TraceID is the same for all spans Flask spans should be kind Server
5 participants