* fix: grpc server ValueError when using unix sockets
with some grpc implementations the full .peer address is available
for unix sockets, which includes the socket path. it seems that
in versions of grpc prior to 1.53.0, the full path is returned by
`context.peer()`. rather than change the dependency of the instrumentation,
this updates it to more gracefully handle the case of the socket path
being present or absent.
Fixes#3393
* add changelog entry
---------
Co-authored-by: Riccardo Magliocchetti <riccardo.magliocchetti@gmail.com>
* botocore: add some more content to the README
This is taken from __init__.py documentation.
* Move the content to the README since it's not really code specific
* Add link to examples
* Apply suggestions from code review
Co-authored-by: Emídio Neto <9735060+emdneto@users.noreply.github.com>
---------
Co-authored-by: Emídio Neto <9735060+emdneto@users.noreply.github.com>
* botocore: test invokemodel tool calls against amazon nova
* botocore: handle amazon nova tool calls events for InvokeModelWithResponseStream
* Update documentation
* Update Changelog
* Please pylint
* Cleanup
* Reduce branches in tool calls tests
Instead pass down a per-model object that implements the peculiar part.
And fix recording of amazon.nova stream no content test.
* Move stream content extraction for tool calls tests to a couple of helpers
* Add instrumentation example to logging
* Add example output to logging instrumentation example
* Fix logging instrumentation example and output
* Fixing rst syntax for logging instrumentation examples
---------
Co-authored-by: Emídio Neto <9735060+emdneto@users.noreply.github.com>
Co-authored-by: Riccardo Magliocchetti <riccardo.magliocchetti@gmail.com>
* Remove bespoke request mocker. Replace with direct mocking of the underlying API.
* Refactor fake credentials to enable reuse.
* Add module to test end to end with a real client.
* Add redaction and minimal OTel mocking/testing in the e2e test.
* Fix wording of the documentation.
* Remove vcr migration from TODOs.
* Improve redaction and test naming.
* Minor tweaks in the code generation. Add casette files.
* Reformat with ruff.
* Fix lint and gzip issue.
* Reformat with ruff.
* Prevent fix for Python 3.9 from breaking tests in other versions.
* Record update in changelog.
* Don't double iterate when redacting by changing the value.
Co-authored-by: Aaron Abbott <aaronabbott@google.com>
---------
Co-authored-by: Aaron Abbott <aaronabbott@google.com>
* Handle empty strings
Safer check for a trailing semicolon that could handle
empty strings as well.
* Updated CHANGELOG.md
* Test for empty SQL strings in sqlcommenter
---------
Co-authored-by: Riccardo Magliocchetti <riccardo.magliocchetti@gmail.com>
* instrumentation: rename experimental to development in README
To match the current semantic conventions naming.
* Update generate_instrumentation_readme.py
* Update README.md
* Run generate
* Update the README too
Instead of expecting an entry in a specific bucket, just sum all of them
and assert we have the correct number of entries.
Co-authored-by: Shalev Roda <65566801+shalevr@users.noreply.github.com>
* Begin instrumentation of GenAI SDK.
* Snapshot current state.
* Created minimal tests and got first test to pass.
* Added test for span attributes.
* Ensure that token counts work.
* Add more tests.
* Make it easy to turn off instrumentation for streaming and async to allow for rapid iteration.
* Add licenses and fill out main README.rst.
* Add a changelog file.
* Fill out 'requirements.txt' and 'README.rst' for the manual instrumentation example.
* Add missing exporter dependency for the manual instrumentation example.
* Fill out rest of the zero-code example.
* Add minimal tests for async, streaming cases.
* Update sync test to use indirection on top of 'client.models.generate_content' to simplify test reuse.
* Fix ruff check issues.
* Add subproject to top-level project build mechanism.
* Simplify invocation of pylint.
* Fix 'make test' command and lint issues.
* Add '.dev' suffix to version per feedback on pull request #3256
* Fix README.rst files for the examples.
* Add specific versions for the examples.
* Revamp 'make test' to not require local 'tox.ini' configuration.
* Extend separators per review comment.
Co-authored-by: Riccardo Magliocchetti <riccardo.magliocchetti@gmail.com>
* Fix version conflict caused by non-hermetic requirements.
* Fix typo on the comment line.
* Add test for the use of the 'vertex_ai' system, and improve how this system is determined.
* Factor out testing logic to enable sharing with the async code.
* Addressed minor lint issues.
* Make it clearer that nonstreaming_base is a helper module that is not invoked directly.
* Integrate feedback from related pull request #3268.
* Update workflows with 'tox -e generate-workflows'.
* Improve data model and add some rudimentary type checking.
* Accept only 'true' for a true value to align with other code.
* Update the scope name used.
* Add **kwargs to patched methods to prevent future breakage due to the addition of future keyword arguments.
* Remove redundant list conversion in call to "sorted".
Co-authored-by: Aaron Abbott <aaronabbott@google.com>
* Reformat with 'tox -e ruff'.
* Fix failing lint workflow.
* Fix failing lint workflow.
* Exclude Google GenAI instrumentation from the bootstrap code for now.
* Minor improvements to the tooling shell files.
* Fix typo flagged by codespell spellchecker.
* Increase alignment with broader repo practices.
* Add more TODOs and documentation to clarify the intended work scope.
* Remove unneeded accessor from OTelWrapper.
* Add more comments to the tests.
* Reformat with ruff.
* Change 'desireable' to 'desirable' per codespell spellchecker.
* Make tests pass without pythonpath
* Fix new lint errors showing up after change
* Revert "Fix new lint errors showing up after change"
This reverts commit 567adc62a706035ad8ac5e29316c7a6f8d4c7909.
pylint ignore instead
* Add TODO item required/requested from code review.
Co-authored-by: Aaron Abbott <aaronabbott@google.com>
* Simplify changelog per PR feedback.
* Remove square brackets from model name in span name per PR feedback.
* Checkpoint current state.
* Misc test cleanup. Now that scripts are invoked solely through pytest via tox, remove main functions and hash bang lines.
* Improve quality of event logging.
* Implement streaming support in RequestsMocker, get tests passing again.
* Add test with multiple responses.
* Remove support for async and streaming from TODOs, since this is now addressed.
* Increase testing coverage for streaming.
* Reformat with ruff.
* Add minor version bump with changelog.
* Change TODOs to bulleted list.
* Update per PR feedback
Co-authored-by: Aaron Abbott <aaronabbott@google.com>
* Restructure streaming async logic to begin execution earlier.
* Reformat with ruff.
* Disable pylint check for catching broad exception. Should be allowed given exception is re-raised.
* Simplify async streaming solution per PR comment.
---------
Co-authored-by: Riccardo Magliocchetti <riccardo.magliocchetti@gmail.com>
Co-authored-by: Aaron Abbott <aaronabbott@google.com>