-
Notifications
You must be signed in to change notification settings - Fork 293
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
#1380 support explicitly set scale of zero for datetime2 #1381
Conversation
I've mentioned my misgivings on the issue so I won't repeat them here. |
I've two different points to discuss (supporting existing behaviour and tests), so I'll do them in two separate comments. Regarding the existing behaviour and minimising the impact of a change, I think it is still worth discussing and maybe coming to a consensus. There are three realistic options I see:
Then there is a second dimension of netfx vs netcore. With all the work to merge code bases I suspect there is not a lot of appetite to diverge behavior on the NETFRAMEWORK switch but it's worth asking. It seems anecdotally to me at least that the threshold for breaking changes is higher in netfx than netcore but not sure if that is actually policy or where I'd find out. There could be an option to retain existing behavior on netfx as default with an op-in switch for the correct behaviour and just the correct behaviour on netcore? (the SqlParameter class is not yet common across netfx and netcore) Your thoughts? |
There's a PR for it, #1354 but PR's aren't merged in order so whichever gets merged first the other will need to resolve the conflicts.
My opinion is that we should minimize the observable differences between netcore and netfx so whatever is done it should be the same. We have plenty of problems between windows and linux implementation at the network layer which it's not obvious to users why they are different, it's just easier for everyone to avoid that sort of situation.
My choice would be #2 (Do 1 and create an AppContextSwitch to opt-in to the existing behaviour.) but it's down to the team decision, I just hang around here because I have no hobbies. |
As for tests, I did try :) The SqlParameter class is sealed and the methods involved here are all internal or private apart from the Scale property itself which already returns whatever value is set so I couldn't write a failing test with the current code. I followed the callers of GetActualScale to see if I could get to it by proxy and again I was blocked by the SqlCommand class being sealed and relevant methods being internal. Beyond that I was getting to the point of just about having to execute a command with a valid connection and trying to interrogate the produced sql which is pretty far from unit test land. Removing the sealed attribute would allow me to create a derived class for testing but implications for existing code that may depend on the SqlParameter being sealed are unknown so not comfortable with that approach. So the simplest approach to being able to test this is to add an "[assembly: InternalsVisibleTo("FunctionalTests")]" attribute. I'll head down that road unless it is likely to get rejected? |
I wouldn't think there is a sensible way to add a functional test (functional tests don't require a database, manual tests do) because as you've said it requires either surface area changes or internal shenanigans which are better avoided. You can just add a test case to the ManualTests which writes a value to the database like your original issue report and then verify that the scale has been correctly written can't you? |
@EamonHetherton currently we are on code freeze due to our next GA release. We will resume back on PRs after release. |
I concur that this is beyond ridiculous. 99.999% of code that relies on the default just uses As a compromise: what about only making this change if the |
...datetimeoffset and time