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

VertexAI emit user, system, and assistant events #3203

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

aabmass
Copy link
Member

@aabmass aabmass commented Jan 23, 2025

Description

Part of #3041, follow up to #3192

Adds Gen AI events for model input to the VertexAI instrumentation. These are system event, user event, and assistant event.

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?

Added test cases for the various log events with OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT varied true and false.

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

@aabmass aabmass force-pushed the vertex-1-events branch 2 times, most recently from 208af92 to 5033da7 Compare January 23, 2025 06:17
@aabmass aabmass changed the title VertexAI emit user events VertexAI emit user, system, and assistant events Jan 23, 2025
@aabmass aabmass marked this pull request as ready for review January 23, 2025 06:22
@aabmass aabmass requested a review from a team as a code owner January 23, 2025 06:22
# message_to_event(message, capture_content)
# )
) as span:
if span.is_recording():
Copy link
Contributor

Choose a reason for hiding this comment

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

Not sure log emitting should be governed by span recording

Copy link
Member Author

Choose a reason for hiding this comment

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

This is copied from openai-v2:

if span.is_recording():
for message in kwargs.get("messages", []):
event_logger.emit(
message_to_event(message, capture_content)
)

I can see the merit both ways, created #3207 to discuss in GenAI SIG

cc @lmolkova

Copy link
Member

Choose a reason for hiding this comment

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

We are currently making an implicit assumption that events are recorded as part of a span, but the specification does not explicitly require this—though all the examples at the end show events within spans. It might be worth updating the specification to clarify this expectation either way.

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.

10 participants