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

Support for SqlServer JSON Fields #166

Merged

Conversation

quisitive-crogers
Copy link

Added a common string -> IDataItem method
Added support for processing JSON data from SQL Query
Updated the Readme.md

Added support for processing JSON data from SQL Query
Updated the Readme.md
@philnach
Copy link
Collaborator

philnach commented Mar 2, 2025

@quisitive-crogers , can you take a look at the merge conflicts and then we can review your change?

@philnach philnach self-requested a review March 2, 2025 21:42
@quisitive-crogers
Copy link
Author

@quisitive-crogers , can you take a look at the merge conflicts and then we can review your change?

Done!

@philnach
Copy link
Collaborator

Thanks, I'll re-take a look at the PR later today.

@philnach philnach self-assigned this Mar 11, 2025
@philnach philnach added the enhancement New feature or request label Mar 11, 2025
Copy link
Collaborator

@philnach philnach left a comment

Choose a reason for hiding this comment

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

Thanks for the fast turnaround and fixing the formatting.

@philnach
Copy link
Collaborator

philnach commented Mar 12, 2025

@quisitive-crogers, looks like tests are failing with your change. Can you take a look?

You should be able to reproduce the failure by running: dotnet test --no-build --verbosity normal, you should also be able to run the "Build and Test all .NET..." action from your fork as well.

Here's the failure:

  Failed TestReadAsyncWithParameters [17 ms]
  Error Message:
   Test method Cosmos.DataTransfer.SqlServerExtension.UnitTests.SqlServerDataSourceExtensionTests.TestReadAsyncWithParameters threw exception: 
System.AggregateException: Configuration for SqlServerSourceSettings is invalid (Missing settings of type SqlServerSourceSettings) (The `ConnectionString` field is required.) (Either `QueryText` or `FilePath` are required!) ---> System.Exception: Missing settings of type SqlServerSourceSettings
  Stack Trace:
      at Cosmos.DataTransfer.Interfaces.ValidationExtensions.Validate[T](T settings) in /__w/data-migration-desktop-tool/data-migration-desktop-tool/Interfaces/Cosmos.DataTransfer.Interfaces/ValidationExtensions.cs:line 34
   at Cosmos.DataTransfer.SqlServerExtension.SqlServerDataSourceExtension.ReadAsync(IConfiguration config, ILogger logger, String queryText, DbParameter[] parameters, DbConnection connection, DbProviderFactory dbProviderFactory, CancellationToken cancellationToken)+MoveNext() in /__w/data-migration-desktop-tool/data-migration-desktop-tool/Extensions/SqlServer/Cosmos.DataTransfer.SqlServerExtension/SqlServerDataSourceExtension.cs:line 48
   at Cosmos.DataTransfer.SqlServerExtension.SqlServerDataSourceExtension.ReadAsync(IConfiguration config, ILogger logger, String queryText, DbParameter[] parameters, DbConnection connection, DbProviderFactory dbProviderFactory, CancellationToken cancellationToken)+MoveNext() in /__w/data-migration-desktop-tool/data-migration-desktop-tool/Extensions/SqlServer/Cosmos.DataTransfer.SqlServerExtension/SqlServerDataSourceExtension.cs:line 81
   at Cosmos.DataTransfer.SqlServerExtension.SqlServerDataSourceExtension.ReadAsync(IConfiguration config, ILogger logger, String queryText, DbParameter[] parameters, DbConnection connection, DbProviderFactory dbProviderFactory, CancellationToken cancellationToken)+System.Threading.Tasks.Sources.IValueTaskSource<System.Boolean>.GetResult()
   at System.Linq.AsyncEnumerable.<TryGetFirst>g__Core|95_0[TSource](IAsyncEnumerable`1 source, CancellationToken cancellationToken) in /_/Ix.NET/Source/System.Linq.Async/System/Linq/Operators/FirstOrDefault.cs:line 130
   at System.Linq.AsyncEnumerable.<TryGetFirst>g__Core|95_0[TSource](IAsyncEnumerable`1 source, CancellationToken cancellationToken) in /_/Ix.NET/Source/System.Linq.Async/System/Linq/Operators/FirstOrDefault.cs:line 132
   at System.Linq.AsyncEnumerable.<FirstAsync>g__Core|87_0[TSource](IAsyncEnumerable`1 source, CancellationToken cancellationToken) in /_/Ix.NET/Source/System.Linq.Async/System/Linq/Operators/First.cs:line 31
   at Cosmos.DataTransfer.SqlServerExtension.UnitTests.SqlServerDataSourceExtensionTests.TestReadAsyncWithParameters() in /__w/data-migration-desktop-tool/data-migration-desktop-tool/Extensions/SqlServer/Cosmos.DataTransfer.SqlServerExtension.UnitTests/SqlServerDataSourceExtensionTests.cs:line 69

@quisitive-crogers
Copy link
Author

@quisitive-crogers, looks like tests are failing with your change. Can you take a look?

Fixed. Not sure those are really appropriate as unit tests, but for the time being, I just got them working again.

Copy link
Collaborator

@philnach philnach left a comment

Choose a reason for hiding this comment

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

Sorry, took me a bit to understand myself why it was failing. I see the break was because we are now validating the SqlServerExtensions settings. Good addition!

@philnach philnach merged commit b86cdac into AzureCosmosDB:main Mar 14, 2025
2 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants