Skip to content

[dotnet] Improve handling for missing status code in HTTP interception #15935

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

Open
wants to merge 3 commits into
base: trunk
Choose a base branch
from

Conversation

RenderMichael
Copy link
Contributor

@RenderMichael RenderMichael commented Jun 23, 2025

User description

🔗 Related Issues

Related to (but does not close) #15844

Minor breaking change here, but it is warranted; sometimes the HTTP status code is not present (such as the repro in the linked issue).

💥 What does this PR do?

This PR handles situations where no HTTP status code was returned by a given HTTP call.

🔄 Types of changes

  • Breaking change (fix or feature that would cause existing functionality to change)

PR Type

Bug fix


Description

  • Handle missing HTTP status codes in DevTools network interception

  • Change StatusCode property from long to long? for nullable support

  • Update DevTools versions v135, v136, v137 to use GetValueOrDefault()

  • Fix potential null reference exceptions in network response handling


Changes walkthrough 📝

Relevant files
Bug fix
V135Network.cs
Handle null status codes in v135 network                                 

dotnet/src/webdriver/DevTools/v135/V135Network.cs

  • Change ResponseCode assignment to use GetValueOrDefault() method
  • Handle cases where StatusCode might be null in request fulfillment
  • +1/-1     
    V136Network.cs
    Handle null status codes in v136 network                                 

    dotnet/src/webdriver/DevTools/v136/V136Network.cs

  • Change ResponseCode assignment to use GetValueOrDefault() method
  • Handle cases where StatusCode might be null in request fulfillment
  • +1/-1     
    V137Network.cs
    Handle null status codes in v137 network                                 

    dotnet/src/webdriver/DevTools/v137/V137Network.cs

  • Change ResponseCode assignment to use GetValueOrDefault() method
  • Remove GetValueOrDefault() from StatusCode assignment in event handler
  • Handle cases where StatusCode might be null in both contexts
  • +2/-2     
    Enhancement
    HttpResponseData.cs
    Make StatusCode property nullable                                               

    dotnet/src/webdriver/HttpResponseData.cs

  • Change StatusCode property type from long to long?
  • Make status code nullable to handle missing values
  • +1/-1     
    NetworkResponseReceivedEventArgs.cs
    Make ResponseStatusCode property nullable                               

    dotnet/src/webdriver/NetworkResponseReceivedEventArgs.cs

  • Change ResponseStatusCode property type from long to long?
  • Make response status code nullable in event arguments
  • +1/-1     

    Need help?
  • Type /help how to ... in the comments thread for any questions about Qodo Merge usage.
  • Check out the documentation for more information.
  • Copy link
    Contributor

    PR Reviewer Guide 🔍

    Here are some key observations to aid the review process:

    🎫 Ticket compliance analysis ✅

    15844 - PR Code Verified

    Compliant requirements:

    • Store the Status Code returned by GoToUrl method
    • Make status code accessible through ChromeDriver properties

    Requires further human verification:

    • Provide a reliable way to know if authentication succeeded or failed
    • Avoid the need for double HTTP calls to verify authentication status

    ⏱️ Estimated effort to review: 2 🔵🔵⚪⚪⚪
    🧪 No relevant tests
    🔒 No security concerns identified
    ⚡ Recommended focus areas for review

    Default Value

    Using GetValueOrDefault() without specifying a default value means null status codes will become 0, which could be misleading as 0 is not a valid HTTP status code. Consider using a more explicit default or handling null cases differently.

        ResponseCode = responseData.StatusCode.GetValueOrDefault(),
    };
    Inconsistent Handling

    The change removes GetValueOrDefault() from line 357 but adds it to line 195 in the same file. This creates inconsistent null handling patterns within the same class for similar operations.

    StatusCode = e.ResponseStatusCode,
    ErrorReason = e.ResponseErrorReason?.ToString()

    Copy link
    Contributor

    qodo-merge-pro bot commented Jun 23, 2025

    PR Code Suggestions ✨

    Explore these optional code suggestions:

    CategorySuggestion                                                                                                                                    Impact
    General
    Use meaningful default status code
    Suggestion Impact:The commit addressed the same issue but used a different approach - instead of providing a default value of 200, it used the null-forgiving operator to access the Value property directly, assuming StatusCode is not null

    code diff:

    -            ResponseCode = responseData.StatusCode.GetValueOrDefault(),
    +            ResponseCode = responseData.StatusCode!.Value,

    Consider providing a meaningful default status code instead of 0. HTTP status
    code 0 is not a valid HTTP status and may cause issues with downstream
    processing or client expectations.

    dotnet/src/webdriver/DevTools/v135/V135Network.cs [195]

    -ResponseCode = responseData.StatusCode.GetValueOrDefault(),
    +ResponseCode = responseData.StatusCode.GetValueOrDefault(200),

    [Suggestion processed]

    Suggestion importance[1-10]: 8

    __

    Why: The suggestion correctly points out that using GetValueOrDefault() on the nullable StatusCode will default to 0, which is not a valid HTTP status code. This could lead to unexpected behavior downstream. Proposing a valid default like 200 significantly improves the correctness and robustness of the error handling.

    Medium
    • Update

    @@ -192,7 +192,7 @@ public override async Task ContinueRequestWithResponse(HttpRequestData requestDa
    var commandSettings = new FulfillRequestCommandSettings()
    {
    RequestId = requestData.RequestId,
    ResponseCode = responseData.StatusCode,
    ResponseCode = responseData.StatusCode ?? throw new ArgumentException("Response data status code cannot be missing", nameof(responseData)),
    Copy link
    Contributor Author

    Choose a reason for hiding this comment

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

    Best to throw loudly instead of concealing issues

    @nvborisenko
    Copy link
    Member

    We should investigate deeper, I have reproduced it locally and see strange behavior. I also tried the same in BiDi implementation, and see correct behavior.

    So when we see the following:

    networkInterceptor.NetworkResponseReceived += (sender, args) =>
    {
        Console.WriteLine($"Received HTTP response: {args.ResponseUrl} with status code: {args.ResponseStatusCode}");
    };
    Received HTTP response: https://testpages.eviltester.com/styled/auth/basic-auth-results.html with status code: 0
    

    What I understand we should not see ResponseStatusCode = 0, it is absolutely incorrect? I am pretty sure any response has to have StatusCode.

    Gathered some logs:

    BiDi, NavigateAsync command throws:

    BiDi RCV <-- {"error":"unknown error","id":5,"message":"net::ERR_TOO_MANY_RETRIES","stacktrace":"Error\n    at new UnknownErrorException (\u003Canonymous>:65:5038)\n    at BrowsingContextImpl.navigate (\u003Canonymous>:663:13017)\n    at async #processCommand (\u003Canonymous>:485:4132)\n    at async CommandProcessor.processCommand (\u003Canonymous>:485:9243)","type":"error"}
    

    CDP, classic NavigateAsync command success:

    DevToolsSession: CDP RCV << {"method":"Fetch.authRequired","params":{"requestId":"interception-job-1.0","request":{"url":"https://testpages.eviltester.com/styled/auth/basic-auth-results.html","method":"GET","headers":{"Accept":"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7","Upgrade-Insecure-Requests":"1","User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","sec-ch-ua":"\"Google Chrome\";v=\"137\", \"Chromium\";v=\"137\", \"Not/A)Brand\";v=\"24\"","sec-ch-ua-mobile":"?0","sec-ch-ua-platform":"\"Windows\""},"initialPriority":"VeryHigh","referrerPolicy":"strict-origin-when-cross-origin"},"frameId":"5E6E4763E35AD55436C03593D6B44491","resourceType":"Document","authChallenge":{"source":"Server","origin":"https://testpages.eviltester.com","scheme":"basic","realm":""}},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.088 TRACE DevToolsSession: CDP SND >> 37 Fetch.continueWithAuth: {"requestId":"interception-job-1.0","authChallengeResponse":{"response":"ProvideCredentials","username":"authorized","password":"password002"}}
    20:43:48.088 TRACE DevToolsSession: CDP RCV << {"id":37,"result":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.141 TRACE DevToolsSession: CDP RCV << {"method":"Fetch.authRequired","params":{"requestId":"interception-job-1.0","request":{"url":"https://testpages.eviltester.com/styled/auth/basic-auth-results.html","method":"GET","headers":{"Accept":"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7","Upgrade-Insecure-Requests":"1","User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","sec-ch-ua":"\"Google Chrome\";v=\"137\", \"Chromium\";v=\"137\", \"Not/A)Brand\";v=\"24\"","sec-ch-ua-mobile":"?0","sec-ch-ua-platform":"\"Windows\""},"initialPriority":"VeryHigh","referrerPolicy":"strict-origin-when-cross-origin"},"frameId":"5E6E4763E35AD55436C03593D6B44491","resourceType":"Document","authChallenge":{"source":"Server","origin":"https://testpages.eviltester.com","scheme":"basic","realm":""}},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.141 TRACE DevToolsSession: CDP SND >> 38 Fetch.continueWithAuth: {"requestId":"interception-job-1.0","authChallengeResponse":{"response":"ProvideCredentials","username":"authorized","password":"password002"}}
    20:43:48.141 TRACE DevToolsSession: CDP RCV << {"id":38,"result":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.195 TRACE DevToolsSession: CDP RCV << {"method":"Fetch.authRequired","params":{"requestId":"interception-job-1.0","request":{"url":"https://testpages.eviltester.com/styled/auth/basic-auth-results.html","method":"GET","headers":{"Accept":"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7","Upgrade-Insecure-Requests":"1","User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","sec-ch-ua":"\"Google Chrome\";v=\"137\", \"Chromium\";v=\"137\", \"Not/A)Brand\";v=\"24\"","sec-ch-ua-mobile":"?0","sec-ch-ua-platform":"\"Windows\""},"initialPriority":"VeryHigh","referrerPolicy":"strict-origin-when-cross-origin"},"frameId":"5E6E4763E35AD55436C03593D6B44491","resourceType":"Document","authChallenge":{"source":"Server","origin":"https://testpages.eviltester.com","scheme":"basic","realm":""}},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.195 TRACE DevToolsSession: CDP SND >> 39 Fetch.continueWithAuth: {"requestId":"interception-job-1.0","authChallengeResponse":{"response":"ProvideCredentials","username":"authorized","password":"password002"}}
    20:43:48.195 TRACE DevToolsSession: CDP RCV << {"id":39,"result":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.248 TRACE DevToolsSession: CDP RCV << {"method":"Fetch.authRequired","params":{"requestId":"interception-job-1.0","request":{"url":"https://testpages.eviltester.com/styled/auth/basic-auth-results.html","method":"GET","headers":{"Accept":"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7","Upgrade-Insecure-Requests":"1","User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","sec-ch-ua":"\"Google Chrome\";v=\"137\", \"Chromium\";v=\"137\", \"Not/A)Brand\";v=\"24\"","sec-ch-ua-mobile":"?0","sec-ch-ua-platform":"\"Windows\""},"initialPriority":"VeryHigh","referrerPolicy":"strict-origin-when-cross-origin"},"frameId":"5E6E4763E35AD55436C03593D6B44491","resourceType":"Document","authChallenge":{"source":"Server","origin":"https://testpages.eviltester.com","scheme":"basic","realm":""}},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.248 TRACE DevToolsSession: CDP SND >> 40 Fetch.continueWithAuth: {"requestId":"interception-job-1.0","authChallengeResponse":{"response":"ProvideCredentials","username":"authorized","password":"password002"}}
    20:43:48.257 TRACE DevToolsSession: CDP RCV << {"id":40,"result":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.257 TRACE DevToolsSession: CDP RCV << {"method":"Fetch.requestPaused","params":{"requestId":"interception-job-1.0","request":{"url":"https://testpages.eviltester.com/styled/auth/basic-auth-results.html","method":"GET","headers":{"Accept":"text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7","Upgrade-Insecure-Requests":"1","User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","sec-ch-ua":"\"Google Chrome\";v=\"137\", \"Chromium\";v=\"137\", \"Not/A)Brand\";v=\"24\"","sec-ch-ua-mobile":"?0","sec-ch-ua-platform":"\"Windows\""},"initialPriority":"VeryHigh","referrerPolicy":"strict-origin-when-cross-origin"},"frameId":"5E6E4763E35AD55436C03593D6B44491","resourceType":"Document","responseErrorReason":"Failed","networkId":"7191E989E519AF930DE921E01D2B533A"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.259 TRACE DevToolsSession: CDP SND >> 41 Fetch.continueResponse: {"requestId":"interception-job-1.0"}
    20:43:48.259 TRACE DevToolsSession: CDP RCV << {"id":41,"result":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.259 TRACE DevToolsSession: CDP RCV << {"method":"Network.loadingFailed","params":{"requestId":"7191E989E519AF930DE921E01D2B533A","timestamp":359678.315333,"type":"Document","errorText":"net::ERR_TOO_MANY_RETRIES","canceled":false},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.281 TRACE DevToolsSession: CDP RCV << {"method":"Network.policyUpdated","params":{},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.287 TRACE DevToolsSession: CDP RCV << {"method":"Network.dataReceived","params":{"requestId":"8CF616F93686CA6431AC7CEE44B184F2","timestamp":359678.335684,"dataLength":178027,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.287 TRACE DevToolsSession: CDP RCV << {"method":"Network.loadingFinished","params":{"requestId":"8CF616F93686CA6431AC7CEE44B184F2","timestamp":359678.337236,"encodedDataLength":178027},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.305 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestWillBeSent","params":{"requestId":"29668.2","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","documentURL":"chrome-error://chromewebdata/","request":{"url":"","method":"GET","headers":{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","Referer":""},"mixedContentType":"none","initialPriority":"Low","referrerPolicy":"strict-origin-when-cross-origin","isSameSite":false},"timestamp":359678.355545,"wallTime":1750700628.299777,"initiator":{"type":"parser","url":"chrome-error://chromewebdata/","lineNumber":1504,"columnNumber":647},"redirectHasExtraInfo":false,"type":"Image","frameId":"5E6E4763E35AD55436C03593D6B44491","hasUserGesture":false},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestServedFromCache","params":{"requestId":"29668.2"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.responseReceived","params":{"requestId":"29668.2","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","timestamp":359678.355643,"type":"Image","response":{"url":"","status":200,"statusText":"OK","headers":{"Content-Type":"image/png"},"mimeType":"image/png","charset":"","connectionReused":false,"connectionId":0,"fromDiskCache":false,"fromServiceWorker":false,"fromPrefetchCache":false,"encodedDataLength":0,"protocol":"data","securityState":"unknown"},"hasExtraInfo":false,"frameId":"5E6E4763E35AD55436C03593D6B44491"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.dataReceived","params":{"requestId":"29668.2","timestamp":359678.355657,"dataLength":3002,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.loadingFinished","params":{"requestId":"29668.2","timestamp":359678.355659,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestWillBeSent","params":{"requestId":"29668.3","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","documentURL":"chrome-error://chromewebdata/","request":{"url":"","method":"GET","headers":{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","Referer":""},"mixedContentType":"none","initialPriority":"Low","referrerPolicy":"strict-origin-when-cross-origin","isSameSite":false},"timestamp":359678.355867,"wallTime":1750700628.30007,"initiator":{"type":"parser","url":"chrome-error://chromewebdata/","lineNumber":1504,"columnNumber":647},"redirectHasExtraInfo":false,"type":"Image","frameId":"5E6E4763E35AD55436C03593D6B44491","hasUserGesture":false},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestServedFromCache","params":{"requestId":"29668.3"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.responseReceived","params":{"requestId":"29668.3","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","timestamp":359678.355932,"type":"Image","response":{"url":"","status":200,"statusText":"OK","headers":{"Content-Type":"image/png"},"mimeType":"image/png","charset":"","connectionReused":false,"connectionId":0,"fromDiskCache":false,"fromServiceWorker":false,"fromPrefetchCache":false,"encodedDataLength":0,"protocol":"data","securityState":"unknown"},"hasExtraInfo":false,"frameId":"5E6E4763E35AD55436C03593D6B44491"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.dataReceived","params":{"requestId":"29668.3","timestamp":359678.355947,"dataLength":4758,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.loadingFinished","params":{"requestId":"29668.3","timestamp":359678.355948,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestWillBeSent","params":{"requestId":"29668.4","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","documentURL":"chrome-error://chromewebdata/","request":{"url":"","method":"GET","headers":{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/137.0.0.0 Safari/537.36","Referer":""},"mixedContentType":"none","initialPriority":"Low","referrerPolicy":"strict-origin-when-cross-origin","isSameSite":false},"timestamp":359678.360549,"wallTime":1750700628.304761,"initiator":{"type":"parser","url":"chrome-error://chromewebdata/","lineNumber":1504,"columnNumber":648},"redirectHasExtraInfo":false,"type":"Image","frameId":"5E6E4763E35AD55436C03593D6B44491","hasUserGesture":false},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.requestServedFromCache","params":{"requestId":"29668.4"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.responseReceived","params":{"requestId":"29668.4","loaderId":"8CF616F93686CA6431AC7CEE44B184F2","timestamp":359678.360611,"type":"Image","response":{"url":"","status":200,"statusText":"OK","headers":{"Content-Type":"image/png"},"mimeType":"image/png","charset":"","connectionReused":false,"connectionId":0,"fromDiskCache":false,"fromServiceWorker":false,"fromPrefetchCache":false,"encodedDataLength":0,"protocol":"data","securityState":"unknown"},"hasExtraInfo":false,"frameId":"5E6E4763E35AD55436C03593D6B44491"},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.dataReceived","params":{"requestId":"29668.4","timestamp":359678.36062,"dataLength":170,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.306 TRACE DevToolsSession: CDP RCV << {"method":"Network.loadingFinished","params":{"requestId":"29668.4","timestamp":359678.360625,"encodedDataLength":0},"sessionId":"6B4AC932EA03763431CBD609C2EA47F6"}
    20:43:48.342 TRACE HttpCommandExecutor: << StatusCode: 200, ReasonPhrase: OK, Content: System.Net.Http.HttpConnectionResponseContent, Headers: 1
    20:43:48.342 DEBUG HttpCommandExecutor: Response: ( Success: )
    

    Given that BiDi workflow behaves predictable, we should look at CDP closer. Why networkInterceptor.NetworkResponseReceived event fired, and what info we get from remote end.

    @RenderMichael
    Copy link
    Contributor Author

    Check out my discovery in the original issue: #15844 (comment)

    DevTools does not get back any status code. The selenium side of things should handle that scenario.

    @nvborisenko
    Copy link
    Member

    Your comment is understandable: Insomnia is not a browser, it just sent request to remote end and got response (401). Browser works differently, and selenium relies on CDP. Let's look closer at CDP logs, and try to understand why we got response without status code.

    @nvborisenko
    Copy link
    Member

    why we got response without status code.

    This is really key point to investigate, in my head this is absolutely incorrect.

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

    Successfully merging this pull request may close these issues.

    3 participants