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

[Schema Registry] Add pluggable serializer #36926

Merged
merged 39 commits into from
Jul 25, 2023

Conversation

m-redding
Copy link
Member

Adds a pluggable schema serializer to Azure.Data.SchemaRegistry. This is primarily for use with JSON schema and data serialization but is general enough to work with any serialization type.

Contributing to the Azure SDK

Please see our CONTRIBUTING.md if you are not familiar with contributing to this repository or have questions.

For specific information about pull request etiquette and best practices, see this section.

@azure-sdk
Copy link
Collaborator

azure-sdk commented Jun 8, 2023

API change check

APIView has identified API level changes in this PR and created following API reviews.

Azure.Data.SchemaRegistry
Azure.Core
Azure.Core.Experimental
Microsoft.Azure.Data.SchemaRegistry.ApacheAvro

Copy link
Member

@jsquire jsquire left a comment

Choose a reason for hiding this comment

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

Looks great!

@m-redding m-redding marked this pull request as ready for review June 21, 2023 16:03
jsquire
jsquire previously approved these changes Jun 28, 2023
@jsquire jsquire dismissed their stale review June 28, 2023 15:50

pending feedback, since there is still churn

Copy link
Member

@jsquire jsquire left a comment

Choose a reason for hiding this comment

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

I left a couple of minor comments. Outside of possibly needing to adjust the Experimental namespaces, I'm comfortable going to beta with the implementation.

@m-redding m-redding merged commit 902abfb into Azure:main Jul 25, 2023
bharat-kalyan-namburi pushed a commit that referenced this pull request Aug 7, 2023
* CODEOWNERS: Fix OpenAI PR Label (#37558)

Fixing the label applied for OpenAI pull requests.

* Azure Core API feedback (#37557)

* [AzureMonitorExporter] Add support new Messaging semantics - Request/Dependency Telemetry (#37508)

* PR feedback  + tests.

* [AzureMonitorExporter] Add support new Messaging semantics - Request / Dependency Telemetry

* Fix test

* New changes

* nits

* Remove unused method.

* Fix message sematics to support Azure SDK.

* Self-review fix

* Fix build + Test Fix

* readme (#37556)

* Increment version for core releases (#37559)

* Increment package version after release of Azure.Core.Experimental

* Increment package version after release of Azure.Core

* update autorest to point to new swagger specs (#37565)

- make UnassignJobRequest internal

* [ACR] Upgrade Azure.Core dependency (#37561)

* [ACR] Fix Azure.Core package dependency

* Increment package version after release of Azure.Containers.ContainerRegistry (#37569)

* prepare AzureMonitorExporter and AzureMonitorDistro for release (#37503)

* run prepare-release script

* remove newline

* update timestamp

* update distro for Azure Activity Sources

* move section

* Update CHANGELOG.md

* [JobRouter] Use internal setters (#37570)

* Set ai.user.useragent to userAgentOriginal (#37571)

* Set ai.user.useragent to userAgentOriginal

* Update sdk/monitor/Azure.Monitor.OpenTelemetry.Exporter/src/Customizations/Models/TelemetryItem.cs

Co-authored-by: Timothy Mothra <[email protected]>

* fix build

---------

Co-authored-by: Timothy Mothra <[email protected]>

* [ACS JobRouter] Missing usage of Azure.Etag in RouterQueueItem (#37573)

* missing usage of Azure.Etag in RouterQueueItem

* remove empty classes

* remove setter of ScheduleAndSuspendMode from JobMatchingMode

* Fix code generation for EmailAttachment serialization (#37524)

* Add directive to use Content for contentInBase64 property

* Update link to specification file

* Remove obsolete ContentInBase64 property

* Bump version of subscription (#36355)

* test

* update

* remove date from tag

* Update api version of subscriptin for tests

* Revert "Update api version of subscriptin for tests"

This reverts commit dbbafd1.

* update

* Remove api-version of tenant for test

* remove api-version

* prepare release

* Increment version for maps releases (#37575)

* Increment package version after release of Azure.Maps.Geolocation

* Increment package version after release of Azure.Maps.Routing

* Increment package version after release of Azure.Maps.Common

* Increment package version after release of Azure.Maps.Rendering

* Increment package version after release of Azure.Maps.Search

* [Azure Communication Services][CallAutomation]Create Customcontext class (#37548)

* create Customcontext class

* fix UT

* update api

* for groupcall, create both headers by default

* fix comments

* update api

* Updated automation script used in docker scenario (#37447)

* Updated automation script used in docker scenario

* Pass in spec root dir to dotnet build

* Revert analyzer version change

* Ignore removing specification for pipeline scenario

* Fix typo 'Comsmos' to 'Cosmos' (#37588)

The namespace `Microsoft.Azure.Cosmos.Table` has been erroneously copied around as `Microsoft.Azure.Comsmos.Table`.

* Increment version for webpubsub releases (#37580)

* Increment package version after release of Microsoft.Azure.WebJobs.Extensions.WebPubSub

* Increment package version after release of Microsoft.Azure.WebPubSub.AspNetCore

* Increment package version after release of Azure.ResourceManager (#37576)

* [Event Hubs] Migration Guide Tweaks (#37591)

The focus of these changes is to update the client hierarchy and status
of the legacy packages, while tuning some of the phrasing of the migration guide.

* Use property reference type (#37542)

* Use property reference type

* docs

* Add ctor attributes

* Make discriminator property public

* remove attribute args

* Try referenceType

* Revert attribute changes and add model factory

* Add ref docs

* [MetricsAdvisor] Removed AZC0007 NoWarn option (#37595)

* Increment package version after release of Azure.Core.Expressions.DataFactory (#37599)

* Fix standard metric for updated semantic conv (#37603)

* Update version of github-event-processor (#37602)

Co-authored-by: James Suplizio <[email protected]>

* update readme to include Azure SDK support (#37606)

* update readme to include Azure SDK support

* changelog

* fix md error

* Generated sdk from updated spec - Ngfw (#36881)

* Microsoft.GraphServices add new SDK version for stable swagger spec (#37105)

* Add new SDK generation for stable swagger spec

* Run dotnet build /t:GenerateTests

* Change project settings and re-record session

* Remove duplicate packages

* Upload run to assets repo

* regenerate code and rerun tests

* Rerun tests and upload to assets repo

* address comments

* change version in changelog

* readd beta version in changelog

* Remove unreleased tag from changelog

* Add date to 1.0.0 version

* remove empty sections

* polish

---------

Co-authored-by: Wei Hu (from Dev Box) <[email protected]>

* Increment version for monitor releases (#37613)

* Increment package version after release of Azure.Monitor.OpenTelemetry.Exporter

* Increment package version after release of Azure.Monitor.OpenTelemetry.AspNetCore

* Update AutoRest C# version to 3.0.0-beta.20230713.1 (#37612)

* Update Generator Version 3.0.0-beta.20230713.1

* Update SDK codes

* Update Generator Version 3.0.0-beta.20230714.1 (#37617)

* DefaultAzureCredentialOptions.TenantId now overrides the environment when selecting EnvironmentCredential (#37537)

* update MSAL dependencies (#37589)

* Update readme file link to documentation  (#37583)

* readme

* readme

* readme

* readme

* Increment package version after release of Azure.ResourceManager.PaloAltoNetworks.Ngfw (#37610)

* Add IsSupportLoggingEnabled property to TokenCredentialOptions (#37463)

* [Event Hubs] Upgrade management package (#37568)

* [Event Hubs] Upgrade management package

The focus of these changes is to update the management package used by
test infrastructure to manage ephemeral resources for test isolation.
The current generation management package has reached GA and the legacy
package is now deprecated.

* Removing unused Polly reference in Processor.Perf

* Fixing order of references to be alphabetical

* Fixing Experimental references and applying minor PR feedback

* Removing property that will be obsolete in the future but is not in the current package to appease CI

* Enable MSA Passthrough for WAM (#37567)

* Fix DataFactory README and bump central version (#37624)

* Fix DataFactory README and bump central version

* fix spacing

* moving off activity extensions (#37597)

* Update AutoRest C# version to 3.0.0-beta.20230714.2 (#37626)

* Update Generator Version 3.0.0-beta.20230714.2

* Update SDK codes

* Update SDK codes

* Regen DF api

* Apply config to synapse

---------

Co-authored-by: JoshLove-msft <[email protected]>

* Sync eng/common directory with azure-sdk-tools for PR 6521 (#37627)

* Use System.Threading.Mutex to make threadsafe

* Rename test, add comments

---------

Co-authored-by: Mike Harder <[email protected]>

* Ignore api-version for mgmt tests (#37582)

* Update Generator Version 3.0.0-beta.20230714.3 (#37636)

Co-authored-by: Arthur Ma <[email protected]>

* Remove workaround for final-state-schema (#37641)

* Update Generator Version 3.0.0-beta.20230717.1 (#37647)

* Health bot tests (#35979)

* Analysis tests (#37065)

* Disable deprecated track 1 SDKs from building (#37655)

These are generating CG alerts unnecessary and are both deprecated in
favor of Azure Monitor Query SDK.

* Add missing service label entries to CODEOWNERS (#37638)

* Update Microsoft.Rest.ClientRuntime (#37654)

* Update Microsoft.Rest.ClientRuntime

Updates a couple perf projects to use the newest
Microsoft.Rest.ClientRuntime for CVE-2022-26907.

* Fix xUnit2000 test warning-as-error

* Disable PR pipelines for deprecated packages

* Update StorageRequestFailedDetailsParser to handle inexact type (#37648)

* Update StorageRequestFailedDetailsParser.cs

* Update StorageRequestFailedDetailsParser.cs

* update release dates (#37658)

* [Event Grid] [Event Hubs] [Service Bus] [Storage] Adding ActivitySource and migrating all DiagnosticScope.ActivityKind references (#37600)

* migrating to system diagnostics

* fixing method signature and fixing storage test

* pipeline fix

* fixing pipeline 2

* Update Microsoft.Azure.WebJobs.Extensions.ServiceBus.csproj

* update dependency

* fix

* [FormRecognizer] Updated tests after recent service deployment (#37618)

* fix Azure.Core reference (#37659)

* AsyncAutoResetEvent enhancement (#35593)

- Use Task.CompltedTask
- Let class sealed

* [JobRouter] Fix TTL (#37662)

* [Storage] [DataMovement] Made the respective members `public` to `protected internal` members (#37604)

* Changed all valid members of the StorageResource class to either protected or protected internal

* Updated Changelog

* PR comments

* Increment version for identity releases (#37664)

* PostgreSQL Flexible server added support for new api version 2023-03-01-preview which includes some new features and bug fixes (#36788)

Co-authored-by: Chengming <[email protected]>
Co-authored-by: Wei Hu <[email protected]>
Co-authored-by: Dapeng Zhang <[email protected]>

* Skip ApiCompat for SDK automation (#37688)

* Increment package version after release of Azure.ResourceManager.PostgreSql (#37690)

* Remove myself as a codeowner (#37656)

* [CODEOWNERS] Fix Operational Insights label (#37693)

The focus of these changes is to update the CODEOWNERS registration to match the expected label.

* Remove deprecated StorSimple 8000 series SDK (#37678)

Relates to #37660

* Remove deprecated Search SDKs (#37677)

Relates to #37660

* Refactor operation for new schema (#37657)

* Remove deprecated Graph SDK (#37673)

Relates to #37660

* Remove deprecated Event Grid SDK (#37671)

Relates to #37660

* Remove deprecated Container Registry SDK (#37670)

Relates to #37660

* Remove deprecated Attestation SDK (#37669)

Relates to #37660

* Remove deprecated Operational Insights SDK (#37668)

Relates to #37660

* Remove deprecated Application Insights SDK (#37667)

Relates to #37660

* `DataMovementTestBase` pull out shared functionality (#37493)

* move job part plan file utility out of testbase

* file util

* remove empty setup method

* pull out and rename enum

* remove dmlibtestbase from rehydrate tests

* remove recordings

* Set operation name for consumer spans (#37696)

* Set operation name for consumer spans

* refactor

* fix test

* DataMovement `DataTransfer` links back to owning `TransferManager` (#37695)

* add link DataTransfer -> TransferManager

* exportapi

* Juntuchen/callback uri override (#37652)

* added logic to pass callbackUri override

* updated api

* Update autorest.md

* Update autorest.md

* Azure OpenAI: add capabilities up through 2023-07-01-preview (#37539)

* squashed commit for omnibus changes

* restore stringent sig= sanitizers for image urls

* Update to consume content_filter_results in Completions; test support

* snap to official .tsp and add image generation model factory support

* swap chat tests to gpt-4 for contemporary Azure Chat Functions support

* codegen update: properly address optionality of filter categories for function_call responses via tsp

* add missing test recording

* Incorporate PR feedback using a new PR typespec commit hash. Thanks, Jose!

* merge #37536 changes

* PR feedback (+ analyzer accepts for var/not-var)

* Missing Role on modified test

* Add one more snippet collection, this time for Chat Functions

* proactive removal of GetStream helper; changelog; cleanup of unused code

* snap to latest merged .tsp (matching previous PR commit, should be no change whatsoever)

* PR feedback. Thank you yet again, Jose!

* Avoid test failures for known issue (#37714)

* Sync eng/common directory with azure-sdk-tools for PR 6530 (#37697)

* Update-DocsMsMetadata.ps1 can fail the build on invalid packages

* Better error handling and logging

* Review feedback

---------

Co-authored-by: Daniel Jurek <[email protected]>

* Update location ip mapping (#37707)

* Update location ip mapping

* update changelog

* reword

* refactor

* address pr feedback

* remove client ip

* fix link issue

* finalize changelog for 2023-07 release (#37723)

* Mark internal classes sealed (#37724)

* Mark internal classes sealed

* exporters

* Dev credentials retain AuthenticationFailedException behavior outside of DAC (#37725)

* Enable customerizing webview for interactive authentication (#34095)

* update deps for spelling tool (#37728)

Co-authored-by: Jeff Fisher <[email protected]>

* Fall back to management link when settling non-session message (#37704)

* Fall back to management link when settling non-session message

* fix typo

* fix test

* Remove deprecated Purview SDK (#37675)

Relates to #37660

* Update Generator Version 3.0.0-beta.20230719.1 (#37731)

* [Core] Updating System.Diagnostics.DiagnosticSource types usage (#37661)

* last phase

* PR feedback

* fixing supports activity source method)

* simplifying dispose

* [ACS JobRouter Pre-release] Execute prelease script (#37594)

* missing usage of Azure.Etag in RouterQueueItem

* add features added section in changelog for pre-release script

* Pre-release

* fix typo

* update changelog

---------

Co-authored-by: williamzhao87 <[email protected]>

* Use events for lock lost notification (#37643)

* Set up CI with Azure Pipelines

[skip ci]

* Update azure-pipelines.yml for Azure Pipelines

* Update azure-pipelines.yml for Azure Pipelines

* Update LineCounter.csproj

* Update azure-pipelines.yml for Azure Pipelines

* Use events for lock lost notification

* docs

* docs

* PR fb

* Fix

* Ensure CT registration is disposed when callback completes

* Fix tests

* Remove superfluous registration

* Update sdk/servicebus/Azure.Messaging.ServiceBus/src/Processor/ProcessMessageEventArgs.cs

* Update docs

* Update AutoRest C# version to 3.0.0-beta.20230719.2 (#37743)

* Sync eng/common directory with azure-sdk-tools for PR 6544 (#37735)

* Only save package properties for track 2 packages (prevents overwrites of track 2 package info by track 1 packages)

* Only overwrite if the package is track 2

---------

Co-authored-by: Daniel Jurek <[email protected]>

* Update AutoRest C# version to 3.0.0-beta.20230719.3 (#37746)

- Update Generator Version 3.0.0-beta.20230719.3
- Update SDK codes
- fix issues in `Azure.Communication.CallAutomation`
  - remove setting repeatability headers logic
  - remove `RepeatabilityHeaders` and its tests since it's not used anymore
- fix issues in `Azure.Communication.CallingServer`
  - fix wrong swagger definition for `Repeatability-First-Sent`
  - change test case base to add repeatability headers into `IgnoredHeaders`
  - update test recordings to add repeatability request headers
- fix issues in `Azure.Communication.Chat`
  - add customization codes to keep existing public interface which expose repeatability request id as parameter
  - regen codes
- fix broken codes in `Azure.Communication.Rooms`
- fix issues in `Azure.Health.Insights.CancerProfiling`
  - update API signature
  - add repeatability headers into `IgnoredHeaders` in test case
  - re-record test cases
- fix issues in `Azure.Health.Insights.ClinicalMatching`
  - update API signature
  - add repeatability headers into `IgnoredHeaders` in test case
  - re-record test cases
- fix api signature of `Azure.Analytics.Purview.Sharing`

---------

Co-authored-by: archerzz <[email protected]>
Co-authored-by: Mingzhe Huang <[email protected]>

* Update Content Safety sample1 analyze text (#37747)

* [Consumption] Fix `meterId` empty format issue (#37718)

* fix `meterId` empty format issue

* delete `mgmt-debug` config

* nullable all `meterID` related class

* add  PriceSheetProperties to nullable config

* Update CHANGELOG.md

* Update CHANGELOG.md

* Increment package version after release of Azure.AI.OpenAI (#37730)

* Update Generator Version 3.0.0-beta.20230720.1 (#37751)

* Updated client constructors to ensure authentication is property being added to ClientConfiguration (#37710)

* Revert bad merge (#37757)

* [JobRouter] Bug bash fixes (#37754)

* Addressed initial API review feedback (#37756)

* Remove deprecated Key Vault SDKs (#37665)

* Remove deprecated Key Vault SDKs

Relates to #37660

* Continue to ignore track 1 management until deprecated

* Move track 1 snippets to track 2

* Fix snippet compilation

* [Communication] Migrated recordings to the assets repo (#37711)

* Revert "[Communication] Migrated recordings to the assets repo (#37711)" (#37766)

This reverts commit ec6bc3b.

* Remove assertions from KV perf tests (#37762)

Fixes #29370

* [ElasticSan] Preview refresh of ElasticSan API version 2022-12-01 (#37717)

* preview refresh of ElasticSan

* ran export API

* Updated recording sessions

* update changelog

* generate sample code for mysql (#37365)

* Generate sample code for ResourceManager (#37550)

* Update AutoRest C# version to 3.0.0-beta.20230721.1 (#37770)

Co-authored-by: ArcturusZhang <[email protected]>

* [FormRecognizer] Cleaning up tests (1/?) (#37705)

* Storage STG 90 (#36974)

* Added migration guide (#37577)

* Migration guide added

Added migration guide from WindowsAzure.ServiceBus to Azure.Messaging.ServiceBus

* Update README.md

Added WindowsAzure.ServiceBus migration guide to README

* Update MigrationGuide-WindowsAzure-ServiceBus.md

Fixed typo

* Updated code snippets

* Update MigrationGuide-WindowsAzure-ServiceBus.md

* Apply suggestions from code review

Co-authored-by: Jesse Squire <[email protected]>

* Renamed migration guide for WindowsAzure.ServiceBus

* File rename

* Updated link to migration guide

* Update sdk/servicebus/Azure.Messaging.ServiceBus/MigrationGuide_WindowsAzureServiceBus.md

Co-authored-by: Madalyn Redding <[email protected]>

---------

Co-authored-by: Jesse Squire <[email protected]>
Co-authored-by: Madalyn Redding <[email protected]>

* Update README Mocking links (#37776)

* Update README Mocking links

* Fix broken docs link

* Fix for failing RenameAsync_SourceSasCredentialDestSasUri live tests (#37779)

* include AAD in the logger messages (#37782)

* Update CODEOWNERS for Identity (#37783)

* update swagger and add support for transfer in group call (#37701)

* update swagger and add support for transfer in group call

* add null check for event mapping

* update netstandard2.0.cs

* Update TransferToParticipantOptions.cs

fix comment format

* Update TransferToParticipantOptions.cs

remove tailing space

* [Storage] Migrating recordings to the assets repo (#37118)

* Edit pass on Azure.Identity troubleshooting guide (#37788)

* [OpenAI] Fix typo 'stanard' to 'standard' (#37791)

* Generate sample code for postgresql (#37399)

* generate sample for postgresql

* update samples

* update samples

* regenerate latest code and sample

* remove 'generated' folder

* add back Generated folder with correct case

* revert unnecessary change in mysql

* support generate samples for ArmResourceExtension's operation (#37685)

* Planned maintenance - package - 2023 - 04 (#34932)

* Update AutoRest C# version to 3.0.0-beta.20230723.1 (#37796)

* Increment package version after release of Azure.ResourceManager.Maintenance (#37799)

* Support DataFactoryElement in Sample Generation (#37774)

* Remove deprecated Web Sites SDK (#37680)

Relates to #37660

* Remove deprecated Traffic Manager SDK (#37679)

Relates to #37660

* add test for encryptiondata key casing (#37702)

* add AADSTS50020 to troubleshooting doc (#37786)

* Set DOCKER_BUILDKIT to 1 in stress deploy image build (#37785)

Co-authored-by: Ben Broderick Phillips <[email protected]>

* Fix reclassify (#37810)

* Add samples demonstrating usage of lock lost events (#37814)

* Add samples demonstrating usage of lock lost events

* Update sdk/servicebus/Azure.Messaging.ServiceBus/samples/Sample13_AdvancedConfiguration.md

Co-authored-by: Jesse Squire <[email protected]>

* PR fb

* md file

---------

Co-authored-by: Jesse Squire <[email protected]>

* Make x509 certificate script from azure-sdk-for-net common to repos (#37811)

Co-authored-by: Ben Broderick Phillips <[email protected]>

* Update mocking guidance links (#37806)

* Update mocking guidance links

* Delete unused code snippet

* [AzureMonitorExporter] Remove "sampleRate" tag from SamplingResult (#37765)

* remove sampling tag

* remove tag

* pr feedback: if != 100

* add extra check for SampleRate != 100f

* remove nullable from method paramaters. update tests.

* Upgrade autorest.csharp to 3.0.0-beta.20230724.1 (#37798)

* Update Generator Version 3.0.0-alpha.20230723.2

* Update SDK codes

* Update SDK codes

* update

* update

---------

Co-authored-by: pshao25 <[email protected]>

* Increment package version after release of Azure.ResourceManager.GraphServices (#37822)

* Fix IMDS parsing invalid json (#37805)

* [JobRouter] Fix job/queue/worker updates (#37835)

* Update DataMovement READMEs (#37590)

* starting point readme

* re-added missed extensions samples

* handling failures

* fix readme verification

* fixes

* spelling

* add samples to validation

* update snippets base package

* blobs samples generated

* [Schema Registry] Add pluggable serializer (#36926)

* add code and tests

* updates

* new tests, doc updates, cleanup

* sample update

* move Lru cache to core

* API gen

* md updates

* doc

* trying to fix merge conflict

* feedback

* fix

* updating snippets

* Update sdk/core/Azure.Core/src/Serialization/SchemaValidator.cs

Co-authored-by: Jesse Squire <[email protected]>

* Apply suggestions from code review

Co-authored-by: Jesse Squire <[email protected]>

* feedback/ regenerating snippets

* removing unneeded md links

* Update sdk/schemaregistry/Azure.Data.SchemaRegistry/samples/Sample02_Serialization.md

Co-authored-by: Christopher Scott <[email protected]>

* WIP - feedback part 1

* updates

* additional tests, more feedback, api changes support

* trying to fix indentation

* trying to fix indentations 2

* pipeline fix

* test

* updating nullable annotations

* WIP feedback

* feedback 1

* feedback 2

* more feedback

* tweaking docs

* pipeline fixes

* change namespace from Azure.Core.Experimental to just Azure.Core

* fixes

* update exception logic

* update schema validator aggregate exception message

* test fix

* tweak sample

---------

Co-authored-by: Jesse Squire <[email protected]>
Co-authored-by: Christopher Scott <[email protected]>

* [AzureMonitorExporter] fix SDK version (#37807)

* fix SDK version

* guard against excessively length

* changelog

* add truncate

* changelog

* Added core types needed by CloudMachine incubation to Azure.Core.Experimental (#37787)

* Added core types needed by CloudMachine incubation

* removed config as it's harder than I thought and we don't need it now

* PR feedback

* PR feedback

* removed config package

* more PR feedback fixes

* PR feedback

* fixed test bug

* updated API files

* updates APIs

* [Service Bus] Migration guide tweaks (#37839)

* [Service Bus] Migration guide tweaks

The focus of these changes is to revise some of the phrasing and streamline
some of the explanations for migration scenarios.

* Fixing broken link

* Update sdk/servicebus/Azure.Messaging.ServiceBus/MigrationGuide.md

Co-authored-by: Christopher Scott <[email protected]>

* Fixing typo

---------

Co-authored-by: Christopher Scott <[email protected]>

* Update AutoRest C# version to 3.0.0-beta.20230725.1 (#37830)

* [AzureMonitorExporter] Integration of OpenTelemetry Resource Detectors (#37837)

* Add Resource Detector

* Update changelog

* SetResourceBuilder to ConfigureResource

* Fix test

* Update changelog

* Fix build issue.

* [JobRouter] Remove worker constructor (#37860)

* Move X509Certificate2 module to eng/common (#37812)

* Move X509Certificate2 module to eng/common

* Use eng/common certificate functions in keyvault test-resources-post.ps1

* Use PSScriptRoot for importing x509 module

* Sofiar/add pagination (#37856)

* Add pagination to endpoints and tests

* Add pagination tests

* Update recordings

* Update old recordings

* Remove unused test

* Add to ChangeLog

* Add validation for pages with less than 2 numbers

* Add geographic area codes as pages test

* Naive implementation of allowing env override (#37780)

* naive implementation of allowing env override

Co-authored-by: Christopher Scott <[email protected]>

* [AzureMonitorExporter] Add Truncation to ContextTags (#37843)

* truncate Tags

* fix typo

* remove usused consts

* remove some Truncates

* apimanagement - 2022-08-01 - track1 sdk  (#34639)

* Update Generator Version 3.0.0-beta.20230726.2 (#37853)

* Remove deprecated Hybrid Data SDK (#37674)

Relates to #37660

* [FormRecognizer] Removed IgnoreServiceError attributes and overrode IsEnvironmentReady method (#37858)

* [Compute] API version 2023-01- 02 track2 (#37316)

* Increment package version after release of Azure.ResourceManager.DataProtectionBackup (#37871)

* Enabled STG 90 live tests (#37857)

* [Service Bus] ReadMe DI Snippets (#37863)

The focus of these changes is to convert the dependency injection examples
in the README to be snippet-driven.  In addition, an example for registering
SubClients was also added, as this has been a frequent inquiry.

* [AzureMonitorDistro] update resource detector (#37881)

* update resource detector

* changelog

* revent

* fix changelog

* Increase Rooms .Net SDK code coverage (#37866)

* Increase Rooms .Net SDK code coverage

* List Room get first two pages

---------

Co-authored-by: Minnie Liu <[email protected]>

* [ACS JobRouter] Execute prelease script (#37845)

* missing usage of Azure.Etag in RouterQueueItem

* add features added section in changelog for pre-release script

* Pre-release

* update changelog

* update changelog

* change release date to 27

---------

Co-authored-by: williamzhao87 <[email protected]>

* Pass Assets Directory in CI (#37868)

* When running in CI, pass a different temp dir for each proxy invocation to clone assets within

* [Service Bus] Clarifiy ScheduledEnqueueTime (#37861)

* [Service Bus] Clarifiy ScheduledEnqueueTime 

The focus of these changes is to clarify how scheduled messages work.

* Increment package version after release of Azure.Communication.JobRouter (#37885)

* Migrated remaining recordings to the assets repo (#37838)

* Fix Delete Invalid Room Test case (#37887)

* Increase Rooms .Net SDK code coverage

* List Room get first two pages

* Fix delete invalid room test

* Remove unneeded recordings

---------

Co-authored-by: Minnie Liu <[email protected]>

* Remove workaround for common-types (#37875)

* prepare release for compute (#37895)

* Vbs elastic pool changes and regenerating sdk for sql (#37312)

* generate client code and add tests for vbs elastic pools

* add generated file

* add more generated files for fixing errors

* add more generated files for fixing errors

* fix failover group errors

* update autorest.md file

* fix pipeline errors

* Update samples

* Mitigate breaking changes, example pending change

* Update

* recordings pushed to assets repo

* minor

* Export API

* updated CHANGELOG

* remove session records folder

* add back tag

* Update

* revert not needed changes

* update

* Prepare release

* revert minor change

* address PR feedback

* new recordings pushed to assets repo

* address more feedback

* update

---------

Co-authored-by: Wei Hu <[email protected]>

* [CosmosDB] Changes for Rest API Version 2023-03-15-preview (#36950)

* [CosmosDB] Changes for Rest API Version 2023-03-15-preview

* add tests for connection strings changes

* Save changes

* Save changes

* saving work

* saving work

* saving work

* saving work

* Save Recordings

* Save Recordings

* adding materializedview tests

* Save Recordings

* resolving comments

* Save changes

* Save changes

* Save Recordings

* Save Recordings

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* saving work

* Renames

* Operation Rename

* Address code comments.

* Address code changes.

* error fix.

* Export API

* Update

* rename ConnectionString

---------

Co-authored-by: Carolyn Jackson <[email protected]>
Co-authored-by: Chandrasekhar Gunturi <[email protected]>
Co-authored-by: Himanshu Sunil Dhawale <[email protected]>
Co-authored-by: himanshudhawale <[email protected]>
Co-authored-by: Wei Hu <[email protected]>

* Increment package version after release of Azure.ResourceManager.Compute (#37896)

* Mark NullableResponseOfT.Value as nullable (#35560)

* [ACS][CallAutomation] Updates to be aligned with GA version (#37543)

* Updates to be aligned with GA version

* ChannelAffinity access modifier update

* Updated api file

* Fixing tests

* Removed double newline

---------

Co-authored-by: Min Woo Lee 🧊 <[email protected]>

* [Event Hubs] Move T1 migration guide snippets (#37908)

* [Event Hubs] Move T1 migration guide snippets

The focus of these changes is to move the migration snippets demonstrating
use of `Microsoft.Azure.EventHubs` to the `Azure.Messaging.EventHubs` test
projects.  This consolidates the build pipeline used for validating the
snippets and allows for removal of the T1 code once the library is formally
retired.

* Update Statsbeat attach allowed values (#37909)

* Sync eng/common directory with azure-sdk-tools for PR 6518 (#37706)

* Bump test proxy version
* remove interim fix
* move proxy transition-scripts folder to onboarding

Co-authored-by: Bill Wert <[email protected]>
Co-authored-by: Scott Beddall <[email protected]>

* cleanup todos (#37913)

* Add Tests and Recordings for CallDialog API (#37663)

* Added dialog tests to SDK

* Updated live test and added recordings

* Added missing test cases for dialog api

* Added recordings to live tests

* Sanitize the botappid

* Updated tests and added working recordings

* Updated sanitizer and recordings

* Remove potentially conflicting sanitizer

* Updated sanitizer and recordings

* Revert "Updated sanitizer and recordings"

This reverts commit 8c71204.

* Revert "Remove potentially conflicting sanitizer"

This reverts commit d65ef0d.

* Revert "Updated sanitizer and recordings"

This reverts commit e0eb4e6.

* Updated sanitizer and recordings

* SDK Updated with latest version of Network cloud API 2023-07-01 (#37722)

* Release Azure.ResourceManager.ManagedNetworkFabric for first GA (#37726)

* Increment package version after release of Azure.ResourceManager.ManagedNetworkFabric (#37917)

* [Messaging] Mocking sample annotation (#37910)

The focus of these changes is to annotate the mocking samples for Event Hubs
and Service Bus with a call-out to the general Azure SDK unit testing and
mocking article.

While the article is focused around HTTP services and
does not replace these dedicated samples, the additional context and examples
may be helpful to developers.

* Tag Synapse.Artifacts to package-artifacts-composite-v7 (#37303)

* Tag Aynapse.Artifacts to package-artifacts-composite-v7

* Update

* update

* update

* update

* Add change log

* Add sdk change for nrp version 2023-04-01 (#37784)

* Increment version for cosmosdb releases (#37923)

* Prepare for release ElasticSan 1.0.0-beta.4 (#37926)

* Increment package version after release of Azure.ResourceManager.ElasticSan (#37929)

* Increment package version after release of Azure.Analytics.Synapse.Artifacts (#37924)

* Increment package version after release of Azure.ResourceManager.Sql (#37922)

* Increment package version after release of Azure.ResourceManager.Network (#37931)

* [AzureMonitorExporter] cleanup Todos (part2): add EventSource to AspNetCore (#37914)

* add EventSource to AspNetCore and cleanup

* update message

* Add Standard metrics for messaging (#37940)

* standard metrics for messaging

* revert change

* Added support for `BlobsOptions.MaxDequeueCount` (#37836)

* [OpenAI] Improve treatment of connection exceptions during streaming (#37888)

* Add AMQP constructor to ServiceBusMessage (#37951)

* Fixed issue where pagianted parameter was being sent with DataLakeFil… (#37934)

* Added RehydratePendingToCold to ArchiveStatus (#37889)

* Add support for custom objects within the dialogContext (#37947)

* Sync eng/common directory with azure-sdk-tools for PR 6611 (#37938)

* update dotnet dev cert being shipped with the proxy to renew for another year
* update suppression file

---------

Co-authored-by: Scott Beddall <[email protected]>

* Abdulhakim/Do not allow null or empty actions (#37737)

* Marked empty/null actions as failed

* replaced tabs with spaces

* Updated spacing

* Replaced tab with spaces

* Updates based on feedback

* Updated Validation Logic

* WIP Added test cases for OneOrMoreRequiredAttribute

* Added test case for EnumberableItemsNotNull Attribute

* Feedback updates

* Updates based on PR feedback

* Sort 'using' lists and removed unapplicable data annotation

* Adding necessary updates to merge with azure main

* Removed xUnit reference now that we are using NUnit tests

* removed Update-Snippets.ps1 changes and will rebase

* Removing requirement for response object in request to not perform early validation

* Added null check and test for response before marking as failed

* Updated exception to validation exception and corrected test

* Changed back to argument null exception

* Added response validation exception type

* Ran script to add partial class for ResponseValidationException

* Update sdk/entra/Microsoft.Azure.WebJobs.Extensions.AuthenticationEvents/src/AuthenticationEventResource.resx

Adding a missing period

Co-authored-by: Jesse Squire <[email protected]>

* Added period

---------

Co-authored-by: Jesse Squire <[email protected]>

* [Search] Vector Search Updates For August Preview (#37948)

Vector Search updates

* Update Generator Version 3.0.0-beta.20230801.1 (#37959)

* [StorageMover] Upgrade to API version 2023-07-01-preview  (#37928)

* [DataFactory] Polish and prepare for new beta release (#37958)

* Increment package version after release of Azure.ResourceManager.DataFactory (#37981)

* Enable IdenticalDialogsTest and add Recordings (#37976)

* Use TrySetCanceled and TrySetResult to avoid finalizing the task twice (#37984)

* Mark package as In Release (#37990)

* Update azd credential order in DAC (#37986)

* extra logging for PartialSuccess (#37915)

* [AzureMonitorExporter] api feedback (#37996)

* merge Extensions classes

* update Options class

* changelog

* update public api

* remove nullables from public api

* changelog

* changelog

* export public api

* reset enum integer

* Update AutoRest C# version to 3.0.0-beta.20230801.2 (#37974)

* Update Generator Version 3.0.0-beta.20230801.2

* Update SDK codes

* Update SDK samples m*,n*,o*,p*,q*,r*

* Rename and update

---------

Co-authored-by: Wei Hu <[email protected]>

* Update AutoRest C# version to 3.0.0-beta.20230803.1 (#38003)

* Update Generator Version 3.0.0-beta.20230803.1

* Update SDK codes

* Update SDK codes

* Update SDK codes

* Update SDK codes

* Workload Identity Support for AzureComponentFactory (#37944)

* First pass

* Updated changelog and added comment

* Update sdk/extensions/Microsoft.Extensions.Azure/CHANGELOG.md

---------

Co-authored-by: Jesse Squire <[email protected]>

* [Storage] [DataMovement] Renamed API from API Arch Board Feedback (#37935)

* Renamed API from API Arch Board Feedback

* Export API and Update Snippetes

* Ignore new sample tests (#38005)

* [DO NOT MERGE]Per-action callback Uri feature name updates (#37842)

* name update

* fixed a bug

* Entra - Make Source field in payload required (#37966)

* Marked empty/null actions as failed

* replaced tabs with spaces

* Updated spacing

* Replaced tab with spaces

* Updates based on feedback

* Updated Validation Logic

* WIP Added test cases for OneOrMoreRequiredAttribute

* Added test case for EnumberableItemsNotNull Attribute

* Feedback updates

* Updates based on PR feedback

* Sort 'using' lists and removed unapplicable data annotation

* Adding necessary updates to merge with azure main

* Removed xUnit reference now that we are using NUnit tests

* removed Update-Snippets.ps1 changes and will rebase

* Added null check and test for response before marking as failed

* Updated exception to validation exception and corrected test

* Changed back to argument null exception

* Added response validation exception type

* Update sdk/entra/Microsoft.Azure.WebJobs.Extensions.AuthenticationEvents/src/AuthenticationEventResource.resx

Adding a missing period

Co-authored-by: Jesse Squire <[email protected]>

* Added period

* Added not null check for source field in payload

* Changed source attribute to required

* Sorted usings

* Added test scenarios for AuthenticationEventMetadata

* Added big fix to changelog

* Refactored test case for consistency with existing tests and added links to changelog

* Added assertions for exception messages and removed links to bugs

* Ran scripts to update netstandard2.0 class

---------

Co-authored-by: Jesse Squire <[email protected]>

* Sync eng/common directory with azure-sdk-tools for PR 6670 (#38008)

* bump the proxy version

* updating version proxy consumed by framework

---------

Co-authored-by: Scott Beddall <[email protected]>

* Enable Test Proxy logging in Test Framework (#37994)

* Add AMQP constructor to ServiceBusMessage

* Enable logging for test proxy integration

* Clean up

* readme

* add section

* revert default

* Add locking

* Add AspNetCore Info logging

* reduce delay to 20ms

* Put all proxy logging behind flag instead of allowing loglevel config

* Fix wrapping

* Split out CheckForErrors to make it sync

* [AzureMonitorExporter] Refactor Environment Variables (#38012)

* refactor Env Vars

* cleanup

* Upgrade containerapps SDK to 2023-04-01-preview (#37930)

* upgrade

* update

* update

* fix ci

* Update AutoRest C# version to 3.0.0-beta.20230804.1 (#38029)

Co-authored-by: Arcturus Zhang <[email protected]>

* Update AuthenticationEventMetadataTests.cs (#38038)

Fixing a string that, while local only to the test instance, contains a secret that is causing security alerts.

* Fix MessageLockLost event test (#38021)

* Fix MessageLockLost event test

* wrap in try/finally

* Don't close the receiver/processor when StopAsync is called (#38035)

* Enable Server Busy test (#38043)

* [ACS][GA1] Clean Commit (#36550)

* clean commit

* Updated comments on start recording options

---------

Co-authored-by: Min Woo Lee 🧊 <[email protected]>

* add single playsource PlayOptions constructor overload (#36825)

* fix playtoalloptions error

* update api surface

* Updating verison name

* Increment package version after release of Azure.Communication.CallAutomation (#37059)

* Callautomation/release/beta2 features (#37485)

Beta 2 features implementation of PMA BETA2_2023_06_15_preview contract:

SendDtmf
DtmfSubscription
PlayTTS
PlaySSML
Recognize Choices
Recognize Freeform
Mute
BYO Cogsvc changes for Answer/CreateCall

* Beta 2 feedback changes(sdk specific only) (#37876)

* Beta 2 feedback changes(sdk specific only)

* make remaining ABR updates

* update media event reason codes

* address pr comments

* update tests

---------

Co-authored-by: abhishesingh-msft <[email protected]>
Co-authored-by: Adam Tazi <[email protected]>

* Updated autorest generated code as per beta2 swagger

* Removed unwated classes and updaed some classes as per beta2

* Updated sendDtmfTones tests

* Removed ApiCompatVersion

* Fixed buid issues

* Renamed class to CommunicationCallAutomationModelFactory

* Updated API contract

* Updated live tests

---------

Co-authored-by: Jesse Squire <[email protected]>
Co-authored-by: Christopher Scott <[email protected]>
Co-authored-by: Rajkumar Rangaraj <[email protected]>
Co-authored-by: reutgross <[email protected]>
Co-authored-by: Azure SDK Bot <[email protected]>
Co-authored-by: Rajarshi Sarkar <[email protected]>
Co-authored-by: ShivangiReja <[email protected]>
Co-authored-by: Timothy Mothra <[email protected]>
Co-authored-by: williamzhao87 <[email protected]>
Co-authored-by: Vishwesh Bankwar <[email protected]>
Co-authored-by: Aleksandr Riabov <[email protected]>
Co-authored-by: Wei Hu <[email protected]>
Co-authored-by: Fang Chen - Microsoft <[email protected]>
Co-authored-by: Ray Chen <[email protected]>
Co-authored-by: RichardAtMoverDk <[email protected]>
Co-authored-by: JoshLove-msft <[email protected]>
Co-authored-by: Caio Saldanha <[email protected]>
Co-authored-by: James Suplizio <[email protected]>
Co-authored-by: Vibhuti-Sharma-Microsoft <[email protected]>
Co-authored-by: amatukmolina <[email protected]>
Co-authored-by: Wei Hu (from Dev Box) <[email protected]>
Co-authored-by: Madalyn Redding <[email protected]>
Co-authored-by: Mike Harder <[email protected]>
Co-authored-by: Arthur Ma <[email protected]>
Co-authored-by: mcgallan <[email protected]>
Co-authored-by: Heath Stewart <[email protected]>
Co-authored-by: Ming Han Teh <[email protected]>
Co-authored-by: Weihan Li <[email protected]>
Co-authored-by: Amanda Nguyen <[email protected]>
Co-authored-by: ambrahma <[email protected]>
Co-authored-by: Chengming <[email protected]>
Co-authored-by: Dapeng Zhang <[email protected]>
Co-authored-by: David R. Williamson <[email protected]>
Co-authored-by: Jocelyn <[email protected]>
Co-authored-by: Juntu Chen <[email protected]>
Co-authored-by: Travis Wilson <[email protected]>
Co-authored-by: Daniel Jurek <[email protected]>
Co-authored-by: Jin Lei <[email protected]>
Co-authored-by: Jeff Fisher <[email protected]>
Co-authored-by: williamzhao87 <[email protected]>
Co-authored-by: archerzz <[email protected]>
Co-authored-by: Mingzhe Huang <[email protected]>
Co-authored-by: MinjueWu <[email protected]>
Co-authored-by: Chengming <[email protected]>
Co-authored-by: Sean McCullough <[email protected]>
Co-authored-by: yifanz7 <[email protected]>
Co-authored-by: Rodge Fu <[email protected]>
Co-authored-by: Eldert Grootenboer <[email protected]>
Co-authored-by: Jesse Squire <[email protected]>
Co-authored-by: Scott Addie <[email protected]>
Co-authored-by: huachuandeng <[email protected]>
Co-authored-by: CT <[email protected]>
Co-authored-by: Harshit Shrivastava <[email protected]>
Co-authored-by: Ben Broderick Phillips <[email protected]>
Co-authored-by: pshao25 <[email protected]>
Co-authored-by: Christopher Scott <[email protected]>
Co-authored-by: Krzysztof Cwalina <[email protected]>
Co-authored-by: sofiar-msft <[email protected]>
Co-authored-by: Scott Beddall <[email protected]>
Co-authored-by: Samir Solanki <[email protected]>
Co-authored-by: Haider Agha <[email protected]>
Co-authored-by: minnieliu <[email protected]>
Co-authored-by: Minnie Liu <[email protected]>
Co-authored-by: vidit-msft <[email protected]>
Co-authored-by: Srinikhil Naravamakula <[email protected]>
Co-authored-by: Carolyn Jackson <[email protected]>
Co-authored-by: Chandrasekhar Gunturi <[email protected]>
Co-authored-by: Himanshu Sunil Dhawale <[email protected]>
Co-authored-by: himanshudhawale <[email protected]>
Co-authored-by: minwoolee-msft <[email protected]>
Co-authored-by: Min Woo Lee 🧊 <[email protected]>
Co-authored-by: Bill Wert <[email protected]>
Co-authored-by: Scott Beddall <[email protected]>
Co-authored-by: calvinkwtang <[email protected]>
Co-authored-by: Priya Shet <[email protected]>
Co-authored-by: Mohana-Krishna-Nali <[email protected]>
Co-authored-by: Joanna-Yang-Art <[email protected]>
Co-authored-by: hakimms <[email protected]>
Co-authored-by: Marcin Elantkowski <[email protected]>
Co-authored-by: Will Sugarman <[email protected]>
Co-authored-by: Zunli Hu <[email protected]>
Co-authored-by: Adam Tazi <[email protected]>
Co-authored-by: Adam Tazi <[email protected]>
Co-authored-by: abhishesingh-msft <[email protected]>
Co-authored-by: abhishesingh-msft <[email protected]>
Copy link
Contributor

@danielmarbach danielmarbach left a comment

Choose a reason for hiding this comment

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

I know this comes out of the blue so I apologize. I was learning the registry a bit closer and stumbled over this PR which totally got me nerd sniped. I understand if this has no priority whatsoever but I felt l better write down some of my thoughts instead of keeping them for myself.

Comment on lines +90 to +101
if (_serializerOptions.Format == SchemaFormat.Avro)
{
_mimeType = AvroMimeType;
}
else if (_serializerOptions.Format == SchemaFormat.Json)
{
_mimeType = JsonMimeType;
}
else
{
_mimeType = CustomMimeType;
}
Copy link
Contributor

Choose a reason for hiding this comment

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

I was lurking around because I'm learning more about the registry and figured I'd directly ask here on the PR about some of the design decisions.

Is there a reason why the mime types are hardcoded here instead of being associated with the schema format and the applied to the options? If the schema format is set on the options then I would expect the mime type should also be set on the options. This is especially true for the custom schema and it's associated mime types. If both can be controlled independently from each other then Format and MimeType should be distinct options. If not then I would expect the Format be some kind of union type between the schema and the mime-type.

I haven't spent a lot of time on this code base so it is quite likely my input is entirely invalid.

Copy link
Member

Choose a reason for hiding this comment

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

Format and MimeType have a 1:1 correspondence. The user selects the format that they want, and based on the format we infer the correct MimeType.

Copy link
Contributor

Choose a reason for hiding this comment

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

That is what I thought and that's why I was thinking having the format being a union type that when set also automatically sets the mime type would move the format and mime type together and wouldn't have to be special coded anymore here.

public TMessage Serialize<TMessage, TData>(
TData data,
CancellationToken cancellationToken = default) where TMessage : MessageContent, new()
=> (TMessage)SerializeInternalAsync(data, typeof(TData), typeof(TMessage), false, cancellationToken).EnsureCompleted();
Copy link
Contributor

Choose a reason for hiding this comment

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

Why is this doing sync over async given the internally used ObjectSerializer provides both a synchronous and an asynchronous path? I mean I see the async flag but that seems to be still a risky thing considering the async method has to properly check it everywhere to avoid any yielding which then leads to sync over async.

Copy link
Member

Choose a reason for hiding this comment

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

This is a common pattern that we use to avoid a lot of duplicated code. We have a private/internal method that is called for both sync and async code paths and pass the async flag based on where it is being called from. So this isn't actually sync over async because for the sync path the task will be completed.

try
{
// Attempt to deserialize
var dataStream = data.ToStream();
Copy link
Contributor

Choose a reason for hiding this comment

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

Does the stream need to be wrapped in an using? Haven't look at the implementation details of BinaryData.ToStream

Copy link
Member Author

Choose a reason for hiding this comment

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

I looked into it, and I believe that it does. Thank you! I can make a fix for that.

: SerializeInternalAsync(data, dataType, false, cancellationToken).EnsureCompleted();

message.Data = bd;
message.ContentType = $"{_mimeType}+{retrievedSchemaId}";
Copy link
Contributor

Choose a reason for hiding this comment

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

Isn't this string also LRU cache-able?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yeah that's true we could also do a mapping from contentType --> schema, rather than schemaId --> schema. Since we would need the schemaId to interact with the service if it's not cached, I think it felt more natural to go with the schemaId --> schema mapping.

Copy link
Contributor

Choose a reason for hiding this comment

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

I was mostly thinking from the angle of having to do a string concatenation on the hot path that could be avoided potentially

private const string JsonMimeType = "application/json";
private const string AvroMimeType = "avro/binary";
private const string CustomMimeType = "text/plain";
private const int CacheCapacity = 128;
Copy link
Contributor

Choose a reason for hiding this comment

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

Would it make sense to move the default to the options and make it configurable since it seems to be highly dependent on the application usage scenarios?

Copy link
Member

Choose a reason for hiding this comment

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

We can do this in the future if customers run into issues, but we felt it wasn't necessary to do right off the bat.

/// The data did not adhere to the specified schema, or the schema itself was invalid. The inner exception will hold more detailed information about
/// the exception.
/// </exception>
public async ValueTask<MessageContent> SerializeAsync(
Copy link
Contributor

Choose a reason for hiding this comment

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

Wild thought: Given that most serializers Serialize methods serialize into some mutable state that is passed into the serializer method and MessageContent is mutable why not leave the creation of this type to the caller? This would remove the need to play MessageContent factory. Seems to also more aligned with the general "serialization" seam.

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 an interesting idea. This class was originally written as a separate JSON-specific serializer package that was meant to accompany the existing Avro serializer package. However, for various reasons we ended up here with a pretty general serialization package. Since we can't do built-in serialization, the main value is interacting with the service and then setting MessageContent-specific values like ContentType using the cache. If we generalized it more then I think we may end up losing some of the value.
(Hopefully I understood your idea correctly)

Copy link
Contributor

Choose a reason for hiding this comment

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

@m-redding sorry for the late reply.

(Hopefully I understood your idea correctly)

I sometimes myself don't understand what I'm suggesting ;) Let me try to explain things a bit better. I find this API quite confusing

            MessageContent content = await serializer.SerializeAsync<MessageContent, Employee>(employee);

I have to specify the message type but when I read the XML documentation and look at the code TMessage> is always constraint to be having a parameter less constructor and at least deriving from MessageContent. The actual underlying implementation then has to act as a factory to create the TMessage type. My point was that most serialization APIs are designed to receive the destination where to write the serialized content to as a parameter to the method. With that in mind I was thinking the whole thing could be changed to something like

            var content = new MessageContent(); // or any from MessageContent derived type
            await serializer.SerializeAsync(content, employee);

and you are saving the customers from having to declare all those generic types because they can be inferred and you are even make it possible for derived types to have any constructors because it is no longer the responsibility of the serialize method to be the factory.

The APIs could then be simplified to

        public async ValueTask SerializeAsync<TMessage, TData>(
           TMessage message,
            TData data,
            CancellationToken cancellationToken = default) where TMessage : MessageContent
            => await SerializeInternalAsync(message, data, typeof(TData), true, cancellationToken).ConfigureAwait(false);

// rest left out because I'm lazy

        internal async ValueTask SerializeInternalAsync(
            MessageContent content,
            object data,
            Type dataType,
            bool async,
            CancellationToken cancellationToken)
        {

Copy link
Contributor

Choose a reason for hiding this comment

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

@m-redding hopefully this explanation is better. Let me know what you think

Copy link
Member Author

Choose a reason for hiding this comment

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

Thank you so much! Your suggestion makes a lot more sense to me now. I really like the API you suggested. The design decisions for this were mostly aimed at trying to align with the Avro serializer. However, the Avro serializer is trying to solve a bit of a different problem, so it's not a problem to diverge.
I think it'd be cool to try and implement the scenario you mentioned here, so I'll work on a prototype. Then I can also talk to Jesse and Josh and see what their thoughts are on the difference in the API.

Copy link
Member Author

@m-redding m-redding Oct 4, 2023

Choose a reason for hiding this comment

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

Is this along the lines of what you had in mind: #39097 ? @danielmarbach

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants