mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Add error code to CefResponse (issue #1845)
This commit is contained in:
		| @@ -78,7 +78,8 @@ typedef struct _cef_resource_handler_t { | |||||||
|   // (0) or the specified number of bytes have been read. Use the |response| |   // (0) or the specified number of bytes have been read. Use the |response| | ||||||
|   // object to set the mime type, http status code and other optional header |   // object to set the mime type, http status code and other optional header | ||||||
|   // values. To redirect the request to a new URL set |redirectUrl| to the new |   // values. To redirect the request to a new URL set |redirectUrl| to the new | ||||||
|   // URL. |   // URL. If an error occured while setting up the request you can call | ||||||
|  |   // set_error() on |response| to indicate the error condition. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *get_response_headers)( |   void (CEF_CALLBACK *get_response_headers)( | ||||||
|       struct _cef_resource_handler_t* self, struct _cef_response_t* response, |       struct _cef_resource_handler_t* self, struct _cef_response_t* response, | ||||||
|   | |||||||
| @@ -60,6 +60,18 @@ typedef struct _cef_response_t { | |||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *is_read_only)(struct _cef_response_t* self); |   int (CEF_CALLBACK *is_read_only)(struct _cef_response_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Get the response error code. Returns ERR_NONE if there was no error. | ||||||
|  |   /// | ||||||
|  |   cef_errorcode_t (CEF_CALLBACK *get_error)(struct _cef_response_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Set the response error code. This can be used by custom scheme handlers to | ||||||
|  |   // return errors during initial request processing. | ||||||
|  |   /// | ||||||
|  |   void (CEF_CALLBACK *set_error)(struct _cef_response_t* self, | ||||||
|  |       cef_errorcode_t error); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Get the response status code. |   // Get the response status code. | ||||||
|   /// |   /// | ||||||
|   | |||||||
| @@ -71,7 +71,8 @@ class CefResourceHandler : public virtual CefBase { | |||||||
|   // false or the specified number of bytes have been read. Use the |response| |   // false or the specified number of bytes have been read. Use the |response| | ||||||
|   // object to set the mime type, http status code and other optional header |   // object to set the mime type, http status code and other optional header | ||||||
|   // values. To redirect the request to a new URL set |redirectUrl| to the new |   // values. To redirect the request to a new URL set |redirectUrl| to the new | ||||||
|   // URL. |   // URL. If an error occured while setting up the request you can call | ||||||
|  |   // SetError() on |response| to indicate the error condition. | ||||||
|   /// |   /// | ||||||
|   /*--cef()--*/ |   /*--cef()--*/ | ||||||
|   virtual void GetResponseHeaders(CefRefPtr<CefResponse> response, |   virtual void GetResponseHeaders(CefRefPtr<CefResponse> response, | ||||||
|   | |||||||
| @@ -62,6 +62,19 @@ class CefResponse : public virtual CefBase { | |||||||
|   /*--cef()--*/ |   /*--cef()--*/ | ||||||
|   virtual bool IsReadOnly() =0; |   virtual bool IsReadOnly() =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Get the response error code. Returns ERR_NONE if there was no error. | ||||||
|  |   /// | ||||||
|  |   /*--cef(default_retval=ERR_NONE)--*/ | ||||||
|  |   virtual cef_errorcode_t GetError() = 0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Set the response error code. This can be used by custom scheme handlers | ||||||
|  |   // to return errors during initial request processing. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual void SetError(cef_errorcode_t error) = 0; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Get the response status code. |   // Get the response status code. | ||||||
|   /// |   /// | ||||||
|   | |||||||
| @@ -366,6 +366,17 @@ void CefResourceRequestJob::SendHeaders() { | |||||||
|   // Get header information from the handler. |   // Get header information from the handler. | ||||||
|   handler_->GetResponseHeaders(response_, remaining_bytes_, redirectUrl); |   handler_->GetResponseHeaders(response_, remaining_bytes_, redirectUrl); | ||||||
|   receive_headers_end_ = base::TimeTicks::Now(); |   receive_headers_end_ = base::TimeTicks::Now(); | ||||||
|  |  | ||||||
|  |   if (response_->GetError() != ERR_NONE) { | ||||||
|  |     const URLRequestStatus& status = | ||||||
|  |         URLRequestStatus::FromError(response_->GetError()); | ||||||
|  |     if (status.status() == URLRequestStatus::CANCELED || | ||||||
|  |         status.status() == URLRequestStatus::FAILED) { | ||||||
|  |       NotifyStartError(status); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   if (!redirectUrl.empty()) { |   if (!redirectUrl.empty()) { | ||||||
|     std::string redirectUrlStr = redirectUrl; |     std::string redirectUrlStr = redirectUrl; | ||||||
|     redirect_url_ = GURL(redirectUrlStr); |     redirect_url_ = GURL(redirectUrlStr); | ||||||
|   | |||||||
| @@ -35,7 +35,8 @@ CefRefPtr<CefResponse> CefResponse::Create() { | |||||||
| // CefResponseImpl ------------------------------------------------------------ | // CefResponseImpl ------------------------------------------------------------ | ||||||
|  |  | ||||||
| CefResponseImpl::CefResponseImpl() | CefResponseImpl::CefResponseImpl() | ||||||
|   : status_code_(0), |   : error_code_(ERR_NONE), | ||||||
|  |     status_code_(0), | ||||||
|     read_only_(false) { |     read_only_(false) { | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -44,6 +45,17 @@ bool CefResponseImpl::IsReadOnly() { | |||||||
|   return read_only_; |   return read_only_; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cef_errorcode_t CefResponseImpl::GetError() { | ||||||
|  |   base::AutoLock lock_scope(lock_); | ||||||
|  |   return error_code_; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefResponseImpl::SetError(cef_errorcode_t error) { | ||||||
|  |   base::AutoLock lock_scope(lock_); | ||||||
|  |   CHECK_READONLY_RETURN_VOID(); | ||||||
|  |   error_code_ = error; | ||||||
|  | } | ||||||
|  |  | ||||||
| int CefResponseImpl::GetStatus() { | int CefResponseImpl::GetStatus() { | ||||||
|   base::AutoLock lock_scope(lock_); |   base::AutoLock lock_scope(lock_); | ||||||
|   return status_code_; |   return status_code_; | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ class CefResponseImpl : public CefResponse { | |||||||
|  |  | ||||||
|   // CefResponse methods. |   // CefResponse methods. | ||||||
|   bool IsReadOnly() override; |   bool IsReadOnly() override; | ||||||
|  |   cef_errorcode_t GetError() override; | ||||||
|  |   void SetError(cef_errorcode_t error) override; | ||||||
|   int GetStatus() override; |   int GetStatus() override; | ||||||
|   void SetStatus(int status) override; |   void SetStatus(int status) override; | ||||||
|   CefString GetStatusText() override; |   CefString GetStatusText() override; | ||||||
| @@ -45,6 +47,7 @@ class CefResponseImpl : public CefResponse { | |||||||
|   void SetReadOnly(bool read_only); |   void SetReadOnly(bool read_only); | ||||||
|  |  | ||||||
|  protected: |  protected: | ||||||
|  |   cef_errorcode_t error_code_; | ||||||
|   int status_code_; |   int status_code_; | ||||||
|   CefString status_text_; |   CefString status_text_; | ||||||
|   CefString mime_type_; |   CefString mime_type_; | ||||||
|   | |||||||
| @@ -45,6 +45,33 @@ int CEF_CALLBACK response_is_read_only(struct _cef_response_t* self) { | |||||||
|   return _retval; |   return _retval; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cef_errorcode_t CEF_CALLBACK response_get_error(struct _cef_response_t* self) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return ERR_NONE; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   cef_errorcode_t _retval = CefResponseCppToC::Get(self)->GetError(); | ||||||
|  |  | ||||||
|  |   // Return type: simple | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CEF_CALLBACK response_set_error(struct _cef_response_t* self, | ||||||
|  |     cef_errorcode_t error) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   CefResponseCppToC::Get(self)->SetError( | ||||||
|  |       error); | ||||||
|  | } | ||||||
|  |  | ||||||
| int CEF_CALLBACK response_get_status(struct _cef_response_t* self) { | int CEF_CALLBACK response_get_status(struct _cef_response_t* self) { | ||||||
|   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
| @@ -209,6 +236,8 @@ void CEF_CALLBACK response_set_header_map(struct _cef_response_t* self, | |||||||
|  |  | ||||||
| CefResponseCppToC::CefResponseCppToC() { | CefResponseCppToC::CefResponseCppToC() { | ||||||
|   GetStruct()->is_read_only = response_is_read_only; |   GetStruct()->is_read_only = response_is_read_only; | ||||||
|  |   GetStruct()->get_error = response_get_error; | ||||||
|  |   GetStruct()->set_error = response_set_error; | ||||||
|   GetStruct()->get_status = response_get_status; |   GetStruct()->get_status = response_get_status; | ||||||
|   GetStruct()->set_status = response_set_status; |   GetStruct()->set_status = response_set_status; | ||||||
|   GetStruct()->get_status_text = response_get_status_text; |   GetStruct()->get_status_text = response_get_status_text; | ||||||
|   | |||||||
| @@ -43,6 +43,32 @@ bool CefResponseCToCpp::IsReadOnly() { | |||||||
|   return _retval?true:false; |   return _retval?true:false; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | cef_errorcode_t CefResponseCToCpp::GetError() { | ||||||
|  |   cef_response_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, get_error)) | ||||||
|  |     return ERR_NONE; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   cef_errorcode_t _retval = _struct->get_error(_struct); | ||||||
|  |  | ||||||
|  |   // Return type: simple | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefResponseCToCpp::SetError(cef_errorcode_t error) { | ||||||
|  |   cef_response_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, set_error)) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   _struct->set_error(_struct, | ||||||
|  |       error); | ||||||
|  | } | ||||||
|  |  | ||||||
| int CefResponseCToCpp::GetStatus() { | int CefResponseCToCpp::GetStatus() { | ||||||
|   cef_response_t* _struct = GetStruct(); |   cef_response_t* _struct = GetStruct(); | ||||||
|   if (CEF_MEMBER_MISSING(_struct, get_status)) |   if (CEF_MEMBER_MISSING(_struct, get_status)) | ||||||
|   | |||||||
| @@ -31,6 +31,8 @@ class CefResponseCToCpp | |||||||
|  |  | ||||||
|   // CefResponse methods. |   // CefResponse methods. | ||||||
|   bool IsReadOnly() OVERRIDE; |   bool IsReadOnly() OVERRIDE; | ||||||
|  |   cef_errorcode_t GetError() OVERRIDE; | ||||||
|  |   void SetError(cef_errorcode_t error) OVERRIDE; | ||||||
|   int GetStatus() OVERRIDE; |   int GetStatus() OVERRIDE; | ||||||
|   void SetStatus(int status) OVERRIDE; |   void SetStatus(int status) OVERRIDE; | ||||||
|   CefString GetStatusText() OVERRIDE; |   CefString GetStatusText() OVERRIDE; | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ class TestResults { | |||||||
|     url.clear(); |     url.clear(); | ||||||
|     html.clear(); |     html.clear(); | ||||||
|     status_code = 0; |     status_code = 0; | ||||||
|  |     response_error_code = ERR_NONE; | ||||||
|  |     expected_error_code = ERR_NONE; | ||||||
|     redirect_url.clear(); |     redirect_url.clear(); | ||||||
|     sub_url.clear(); |     sub_url.clear(); | ||||||
|     sub_html.clear(); |     sub_html.clear(); | ||||||
| @@ -48,6 +50,11 @@ class TestResults { | |||||||
|   std::string html; |   std::string html; | ||||||
|   int status_code; |   int status_code; | ||||||
|  |  | ||||||
|  |   // Error code set on the response. | ||||||
|  |   cef_errorcode_t response_error_code; | ||||||
|  |   // Error code expected in OnLoadError. | ||||||
|  |   cef_errorcode_t expected_error_code; | ||||||
|  |  | ||||||
|   // Used for testing redirects |   // Used for testing redirects | ||||||
|   std::string redirect_url; |   std::string redirect_url; | ||||||
|  |  | ||||||
| @@ -165,6 +172,8 @@ class TestSchemeHandler : public TestHandler { | |||||||
|                    const CefString& errorText, |                    const CefString& errorText, | ||||||
|                    const CefString& failedUrl) override { |                    const CefString& failedUrl) override { | ||||||
|     test_results_->got_error.yes(); |     test_results_->got_error.yes(); | ||||||
|  |     // Check that the error code matches the expectation. | ||||||
|  |     EXPECT_EQ(errorCode, test_results_->expected_error_code); | ||||||
|     DestroyTest(); |     DestroyTest(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -239,6 +248,10 @@ class ClientSchemeHandler : public CefResourceHandler { | |||||||
|         callback->Continue(); |         callback->Continue(); | ||||||
|       } |       } | ||||||
|       return true; |       return true; | ||||||
|  |     } else if (test_results_->response_error_code != ERR_NONE) { | ||||||
|  |       // Propagate the error code. | ||||||
|  |       callback->Continue(); | ||||||
|  |       return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // Response was canceled. |     // Response was canceled. | ||||||
| @@ -268,6 +281,8 @@ class ClientSchemeHandler : public CefResourceHandler { | |||||||
|       } |       } | ||||||
|     } else if (!test_results_->redirect_url.empty()) { |     } else if (!test_results_->redirect_url.empty()) { | ||||||
|       redirectUrl = test_results_->redirect_url; |       redirectUrl = test_results_->redirect_url; | ||||||
|  |     } else if (test_results_->response_error_code != ERR_NONE) { | ||||||
|  |       response->SetError(test_results_->response_error_code); | ||||||
|     } else { |     } else { | ||||||
|       response->SetStatus(test_results_->status_code); |       response->SetStatus(test_results_->status_code); | ||||||
|  |  | ||||||
| @@ -527,6 +542,7 @@ TEST(SchemeHandlerTest, Registration) { | |||||||
|   g_TestResults.got_request.reset(); |   g_TestResults.got_request.reset(); | ||||||
|   g_TestResults.got_read.reset(); |   g_TestResults.got_read.reset(); | ||||||
|   g_TestResults.got_output.reset(); |   g_TestResults.got_output.reset(); | ||||||
|  |   g_TestResults.expected_error_code = ERR_UNKNOWN_URL_SCHEME; | ||||||
|   handler->ExecuteTest(); |   handler->ExecuteTest(); | ||||||
|  |  | ||||||
|   EXPECT_TRUE(g_TestResults.got_error); |   EXPECT_TRUE(g_TestResults.got_error); | ||||||
| @@ -540,10 +556,12 @@ TEST(SchemeHandlerTest, Registration) { | |||||||
|   WaitForIOThread(); |   WaitForIOThread(); | ||||||
|  |  | ||||||
|   g_TestResults.got_error.reset(); |   g_TestResults.got_error.reset(); | ||||||
|  |   g_TestResults.expected_error_code = ERR_NONE; | ||||||
|   handler->ExecuteTest(); |   handler->ExecuteTest(); | ||||||
|  |  | ||||||
|   ReleaseAndWaitForDestructor(handler); |   ReleaseAndWaitForDestructor(handler); | ||||||
|  |  | ||||||
|  |   EXPECT_FALSE(g_TestResults.got_error); | ||||||
|   EXPECT_TRUE(g_TestResults.got_request); |   EXPECT_TRUE(g_TestResults.got_request); | ||||||
|   EXPECT_TRUE(g_TestResults.got_read); |   EXPECT_TRUE(g_TestResults.got_read); | ||||||
|   EXPECT_TRUE(g_TestResults.got_output); |   EXPECT_TRUE(g_TestResults.got_output); | ||||||
| @@ -629,6 +647,25 @@ TEST(SchemeHandlerTest, CustomStandardErrorResponse) { | |||||||
|   ClearTestSchemes(); |   ClearTestSchemes(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Test that a custom standard scheme can return a CEF error code in the response. | ||||||
|  | TEST(SchemeHandlerTest, CustomStandardErrorCodeResponse) { | ||||||
|  |   RegisterTestScheme("customstd", "test"); | ||||||
|  |   g_TestResults.url = "customstd://test/run.html"; | ||||||
|  |   g_TestResults.response_error_code = ERR_FILE_TOO_BIG; | ||||||
|  |   g_TestResults.expected_error_code = ERR_FILE_TOO_BIG; | ||||||
|  |  | ||||||
|  |   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); | ||||||
|  |   handler->ExecuteTest(); | ||||||
|  |   ReleaseAndWaitForDestructor(handler); | ||||||
|  |  | ||||||
|  |   EXPECT_TRUE(g_TestResults.got_request); | ||||||
|  |   EXPECT_FALSE(g_TestResults.got_read); | ||||||
|  |   EXPECT_FALSE(g_TestResults.got_output); | ||||||
|  |   EXPECT_TRUE(g_TestResults.got_error); | ||||||
|  |  | ||||||
|  |   ClearTestSchemes(); | ||||||
|  | } | ||||||
|  |  | ||||||
| // Test that a custom nonstandard scheme can return an error code. | // Test that a custom nonstandard scheme can return an error code. | ||||||
| TEST(SchemeHandlerTest, CustomNonStandardErrorResponse) { | TEST(SchemeHandlerTest, CustomNonStandardErrorResponse) { | ||||||
|   RegisterTestScheme("customnonstd", std::string()); |   RegisterTestScheme("customnonstd", std::string()); | ||||||
| @@ -653,6 +690,7 @@ TEST(SchemeHandlerTest, CustomNonStandardErrorResponse) { | |||||||
| TEST(SchemeHandlerTest, CustomStandardNameNotHandled) { | TEST(SchemeHandlerTest, CustomStandardNameNotHandled) { | ||||||
|   RegisterTestScheme("customstd", "test"); |   RegisterTestScheme("customstd", "test"); | ||||||
|   g_TestResults.url = "customstd2://test/run.html"; |   g_TestResults.url = "customstd2://test/run.html"; | ||||||
|  |   g_TestResults.expected_error_code = ERR_UNKNOWN_URL_SCHEME; | ||||||
|  |  | ||||||
|   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); |   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); | ||||||
|   handler->ExecuteTest(); |   handler->ExecuteTest(); | ||||||
| @@ -661,6 +699,7 @@ TEST(SchemeHandlerTest, CustomStandardNameNotHandled) { | |||||||
|   EXPECT_FALSE(g_TestResults.got_request); |   EXPECT_FALSE(g_TestResults.got_request); | ||||||
|   EXPECT_FALSE(g_TestResults.got_read); |   EXPECT_FALSE(g_TestResults.got_read); | ||||||
|   EXPECT_FALSE(g_TestResults.got_output); |   EXPECT_FALSE(g_TestResults.got_output); | ||||||
|  |   EXPECT_TRUE(g_TestResults.got_error); | ||||||
|  |  | ||||||
|   ClearTestSchemes(); |   ClearTestSchemes(); | ||||||
| } | } | ||||||
| @@ -670,6 +709,7 @@ TEST(SchemeHandlerTest, CustomStandardNameNotHandled) { | |||||||
| TEST(SchemeHandlerTest, CustomNonStandardNameNotHandled) { | TEST(SchemeHandlerTest, CustomNonStandardNameNotHandled) { | ||||||
|   RegisterTestScheme("customnonstd", std::string()); |   RegisterTestScheme("customnonstd", std::string()); | ||||||
|   g_TestResults.url = "customnonstd2:some%20value"; |   g_TestResults.url = "customnonstd2:some%20value"; | ||||||
|  |   g_TestResults.expected_error_code = ERR_UNKNOWN_URL_SCHEME; | ||||||
|  |  | ||||||
|   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); |   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); | ||||||
|   handler->ExecuteTest(); |   handler->ExecuteTest(); | ||||||
| @@ -678,6 +718,7 @@ TEST(SchemeHandlerTest, CustomNonStandardNameNotHandled) { | |||||||
|   EXPECT_FALSE(g_TestResults.got_request); |   EXPECT_FALSE(g_TestResults.got_request); | ||||||
|   EXPECT_FALSE(g_TestResults.got_read); |   EXPECT_FALSE(g_TestResults.got_read); | ||||||
|   EXPECT_FALSE(g_TestResults.got_output); |   EXPECT_FALSE(g_TestResults.got_output); | ||||||
|  |   EXPECT_TRUE(g_TestResults.got_error); | ||||||
|  |  | ||||||
|   ClearTestSchemes(); |   ClearTestSchemes(); | ||||||
| } | } | ||||||
| @@ -687,6 +728,7 @@ TEST(SchemeHandlerTest, CustomNonStandardNameNotHandled) { | |||||||
| TEST(SchemeHandlerTest, CustomStandardDomainNotHandled) { | TEST(SchemeHandlerTest, CustomStandardDomainNotHandled) { | ||||||
|   RegisterTestScheme("customstd", "test"); |   RegisterTestScheme("customstd", "test"); | ||||||
|   g_TestResults.url = "customstd://noexist/run.html"; |   g_TestResults.url = "customstd://noexist/run.html"; | ||||||
|  |   g_TestResults.expected_error_code = ERR_FAILED; | ||||||
|  |  | ||||||
|   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); |   CefRefPtr<TestSchemeHandler> handler = new TestSchemeHandler(&g_TestResults); | ||||||
|   handler->ExecuteTest(); |   handler->ExecuteTest(); | ||||||
| @@ -695,6 +737,7 @@ TEST(SchemeHandlerTest, CustomStandardDomainNotHandled) { | |||||||
|   EXPECT_FALSE(g_TestResults.got_request); |   EXPECT_FALSE(g_TestResults.got_request); | ||||||
|   EXPECT_FALSE(g_TestResults.got_read); |   EXPECT_FALSE(g_TestResults.got_read); | ||||||
|   EXPECT_FALSE(g_TestResults.got_output); |   EXPECT_FALSE(g_TestResults.got_output); | ||||||
|  |   EXPECT_TRUE(g_TestResults.got_error); | ||||||
|  |  | ||||||
|   ClearTestSchemes(); |   ClearTestSchemes(); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user