-
Notifications
You must be signed in to change notification settings - Fork 998
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
Code Coverage for DownloadFile Review 1St #12486
base: main
Are you sure you want to change the base?
Code Coverage for DownloadFile Review 1St #12486
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #12486 +/- ##
===================================================
+ Coverage 76.17780% 76.38367% +0.20586%
===================================================
Files 3193 3197 +4
Lines 640306 643038 +2732
Branches 47237 47377 +140
===================================================
+ Hits 487771 491176 +3405
+ Misses 149008 148329 -679
- Partials 3527 3533 +6
Flags with carried forward coverage won't be shown. Click here to find out more. |
Cleanup
Move test constants to separate module for future reuse
Move some constants around Rename some files that are shared between upload and download
Fix Upload logic to handle Web error 500
Correct a test
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would suggest factoring out the following files into a standalone PR:
SingleInstanceHelpers.vb
WindowsFormsApplicationBase.vb
Network.DownloadFile.vb
Interaction.vb
ClipboardProxy.vb
SingleInstanceHelpersTests.vb
TestUtilitiesTests.vb
PathSeparatorTestData.vb
VbFileCleanupTestBase.vb
They contain only cleanup changes and are ready to be merged while we discuss HTTPListener use within the team.
src/Microsoft.VisualBasic.Forms/src/Microsoft/VisualBasic/Devices/Network.UploadFile.vb
Outdated
Show resolved
Hide resolved
''' </summary> | ||
''' <returns><see langword="True"/> if an audio stream is available, otherwise <see langword="False"/>.</returns> | ||
''' <returns> | ||
''' see langword="True"/> if an audio <see cref="Stream"/> is available, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This could be a single line, it's not long enough to be broken.
|
||
Friend Function ProcessRequests() As HttpListener | ||
' Create a listener and add the prefixes. | ||
Dim listener As New HttpListener() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For my education, what is the purpose of WebClientCopy class?
src/Microsoft.VisualBasic.Forms/src/Microsoft/VisualBasic/Devices/NetworkUtilities.vb
Outdated
Show resolved
Hide resolved
_webClient.DownloadFile(address, destinationFileName) | ||
End If | ||
Catch ex As WebException | ||
If ex.Message.Contains("401") Then |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's usually good to keep the original exception for context. Why do we have to introduce our own messages? Can we set the original exception as the inner one?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
THe same comment applies to the Upload method.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
My WebServerListner is implemented with HTTPClient, the existing code expects WebClient Errors. This code translates the errors, so they are compatible with existing code. When WebClient and WebClientCopy go away and upload and download use HTTPClient the same translation will happen.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
WinForms only handle 2 specific Exceptions Timeout, Unauthorized plus a generic WebException.
When I run the existing code using WebClient I can get almost complete coverage of DownloadFile and UploadFile and the generic exception is never used. With HttpClient I handle the generic exception and use it for testing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hm, we shouldn't add new exceptions for testing purposes only. New exceptions is a breaking change and we need an apparent benefit gained from making such a change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's usually good to keep the original exception for context. Why do we have to introduce our own messages? Can we set the original exception as the inner one?
@Tanya-Solyanik
We are reproducing WebClient Exceptions, HttpClient returns HttpErrors. From what I can tell WinForms only cares about 3 WebClient Exceptions (Timeout, Unauthorized and a generic catch all which is not used by WinForms today).
I have no visibility into all the errors that WebClient can possibly throw but WinForms works consistently with know and unknown errors.
The goal is no breaking exception changes.
src/Microsoft.VisualBasic.Forms/tests/UnitTests/System/Windows/Forms/FileSystemProxyTests.vb
Outdated
Show resolved
Hide resolved
@Tanya-Solyanik #12730 is all the cleanup |
The server will now write issues as text to a public property ServerFault. The tests can then verify that there were no protocal issues except here expected.
Fix error in Progress Progress Dialog Labels Use Enum to define testing file sizes Get FileSize and URL from WebListner to allow 1 source of truth This will also allow easier testing with real file server
Replace corrupt PR12221
Proposed changes
Customer Impact
Regression?
Risk
-None
Test environment(s)
Microsoft Reviewers: Open in CodeFlow