Skip to content

Conversation

@aygalinc
Copy link
Contributor

Proposed Changes

Add activity on connection creation.
In case of creation exception register an error event.

Types of Changes

What types of changes does your code introduce to this project?
Put an x in the boxes that apply

  • Bug fix (non-breaking change which fixes issue #NNNN)
  • [X ] New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause an observable behavior change in existing systems)
  • Documentation improvements (corrections, new content, etc)
  • Cosmetic change (whitespace, formatting, etc)

Refer to #1731

@aygalinc
Copy link
Contributor Author

@michaelklishin build seems broken due to some new CVE related to system text json ?

@lukebakken lukebakken force-pushed the feat/add_activity_on_connection branch from dc89271 to 177ccbd Compare December 11, 2024 18:17
@lukebakken
Copy link
Collaborator

@eerhardt - do you have time to review this PR? Thanks!

@lukebakken lukebakken added this to the 7.1.0 milestone Dec 11, 2024
@lukebakken lukebakken self-assigned this Dec 11, 2024
@lukebakken lukebakken force-pushed the feat/add_activity_on_connection branch from 6587ffe to 2a99147 Compare December 11, 2024 18:35
@aygalinc
Copy link
Contributor Author

@lukebakken when i implement the activity i create a new activity source but i m wondering if it s really usefull to have 3 ActivitySource and not use only one.

Copy link
Contributor

@eerhardt eerhardt left a comment

Choose a reason for hiding this comment

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

Is there any way to write some tests around this?

@lukebakken
Copy link
Collaborator

Thank you @eerhardt !!!

@lukebakken lukebakken force-pushed the feat/add_activity_on_connection branch from 2a99147 to c9b91a2 Compare December 13, 2024 19:41
@lukebakken
Copy link
Collaborator

@aygalinc just FYI, I rebased this on main to pick up my test suite fixes. Hopefully GHA will be green going forward.

@aygalinc
Copy link
Contributor Author

@eerhardt to the best of my knowledge Microsoft don't provide any testing support fort distributed tracing (contrary to metrics) . I do not find any test related to the other activity creation in rabbit. Maybe you have some resources that I miss to do this ?

@eerhardt
Copy link
Contributor

eerhardt commented Jan 6, 2025

@eerhardt to the best of my knowledge Microsoft don't provide any testing support fort distributed tracing (contrary to metrics) . I do not find any test related to the other activity creation in rabbit. Maybe you have some resources that I miss to do this ?

The main way I've seen it done is to hook listeners to the activity source, do the test, and then verify the activities were emitted as expected. Some examples:

  1. dotnet/aspire: https://github.com/dotnet/aspire/blob/44948254b69ea9777f01081df0cb411e54797d33/tests/Aspire.Components.Common.Tests/ConformanceTests.cs#L429-L453
  2. dotnet/aspnetcore: https://github.com/dotnet/aspnetcore/blob/67ae6c8b73e80fa5f499a069443c9844ca86c62a/src/SignalR/clients/csharp/Client/test/FunctionalTests/HubConnectionTests.Tracing.cs#L40-L56
  3. dotnet/runtime: https://github.com/dotnet/runtime/blob/38366f093a26bc84c01704e107df467ef807666d/src/libraries/Common/tests/System/Net/ActivityRecorder.cs

@lukebakken lukebakken modified the milestones: 7.1.0, 7.2.0 Jan 16, 2025
@aygalinc aygalinc force-pushed the feat/add_activity_on_connection branch from c9b91a2 to 9bb228a Compare April 23, 2025 20:00
@aygalinc aygalinc force-pushed the feat/add_activity_on_connection branch from ae71fbf to a057ae2 Compare April 23, 2025 20:42
@aygalinc
Copy link
Contributor Author

@lukebakken do you now if it's possible to explicitly add System.Diagnostics.DiagnosticSource in version 9.0 in order to gain access to AddException method as suggested by @paulomorgado ?

@aygalinc
Copy link
Contributor Author

@eerhardt I use the dotnet runtime approach in the test to capture Activity

@paulomorgado
Copy link
Contributor

@lukebakken do you now if it's possible to explicitly add System.Diagnostics.DiagnosticSource in version 9.0 in order to gain access to AddException method as suggested by @paulomorgado ?

It's safe to add.

@lukebakken lukebakken modified the milestones: 7.2.0, 7.3.0 May 12, 2025
@aygalinc
Copy link
Contributor Author

@eerhardt I check the code and I don't know what you envision on this use case : we can provide a list of endpoint the client will try to connect to one of them. Did we expect that each TCP connection will trigger a dedicated activity or we have a single activity with dedicated events that describe each TCP connection attempts?

@eerhardt
Copy link
Contributor

I'm not sure. My naive thoughts are that the CreateConnectionAsync creates a single Activity, and each connection attempt inside of it would be a child Activity. But I haven't given it any major thought. https://github.com/open-telemetry/semantic-conventions/tree/main/docs/messaging doesn't seem to have conventions for connection Activities, so that isn't much help.

@aygalinc
Copy link
Contributor Author

1 parent - 1 child activity per connection attempt : how an error is managed when the last attempt succeeded ? Individual Error should be attached to child activity but the activity who will be flag as error should be the parent one. In the actual design it is pretty complicated to have this behaviour from a bird eyes view. TCP connection establishment and open frame send are not so easy to correlate.

1 activity - 1 event per connection attempt: aggregated error is managed in the only activity. Activity does not contains so much useful information as they will be store in events (like ip, port etc) , can be a problem because some observability backend doesn't allowed to filter on event ( Tempo as example).

@aygalinc aygalinc force-pushed the feat/add_activity_on_connection branch from 0a2d604 to dbb0d4f Compare May 24, 2025 20:06
@aygalinc aygalinc force-pushed the feat/add_activity_on_connection branch from dbb0d4f to a5f655e Compare May 24, 2025 20:09
@aygalinc aygalinc force-pushed the feat/add_activity_on_connection branch from 202ec36 to d32a0e1 Compare May 24, 2025 21:23
@aygalinc
Copy link
Contributor Author

@eerhardt i have done an implem if you want to review.
I don't have a windows so it's hard for me to know what is not going well on windows test suite :)

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.

5 participants