blob: 9456ccc85959fc03ca0ec35d8027b02b423826e5 [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#import "ios/web/public/test/js_test_util.h"
#import <WebKit/WebKit.h>
#include "base/logging.h"
#include "base/mac/bundle_locations.h"
#include "base/strings/sys_string_conversions.h"
#import "base/test/ios/wait_util.h"
#import "ios/web/js_messaging/page_script_util.h"
#import "ios/web/public/deprecated/crw_js_injection_manager.h"
#import "ios/web/public/deprecated/crw_js_injection_receiver.h"
#include "testing/gtest/include/gtest/gtest.h"
#if !defined(__has_feature) || !__has_feature(objc_arc)
#error "This file requires ARC support."
#endif
using base::test::ios::kWaitForJSCompletionTimeout;
using base::test::ios::kWaitForPageLoadTimeout;
using base::test::ios::WaitUntilConditionOrTimeout;
namespace web {
namespace test {
id ExecuteJavaScript(CRWJSInjectionManager* manager, NSString* script) {
__block NSString* result = nil;
__block NSError* error = nil;
__block bool completed = false;
[manager executeJavaScript:script
completionHandler:^(id execution_result, NSError* execution_error) {
result = [execution_result copy];
error = [execution_error copy];
completed = true;
}];
BOOL success = WaitUntilConditionOrTimeout(kWaitForJSCompletionTimeout, ^{
return completed;
});
// Log stack trace to provide some context.
EXPECT_TRUE(success && !error)
<< "CRWJSInjectionManager failed to complete javascript execution.\n"
<< base::SysNSStringToUTF8(
[[NSThread callStackSymbols] componentsJoinedByString:@"\n"])
<< "error: \n"
<< base::SysNSStringToUTF8(error.description);
return result;
}
id ExecuteJavaScript(CRWJSInjectionReceiver* receiver, NSString* script) {
CRWJSInjectionManager* manager =
[[CRWJSInjectionManager alloc] initWithReceiver:receiver];
return ExecuteJavaScript(manager, script);
}
id ExecuteJavaScript(WKWebView* web_view, NSString* script) {
return ExecuteJavaScript(web_view, script, nil);
}
id ExecuteJavaScript(WKWebView* web_view,
NSString* script,
NSError* __autoreleasing* error) {
__block id result;
__block bool completed = false;
__block NSError* block_error = nil;
SCOPED_TRACE(base::SysNSStringToUTF8(script));
[web_view evaluateJavaScript:script
completionHandler:^(id script_result, NSError* script_error) {
result = [script_result copy];
block_error = [script_error copy];
completed = true;
}];
BOOL success = WaitUntilConditionOrTimeout(kWaitForJSCompletionTimeout, ^{
return completed;
});
// Log stack trace to provide some context.
EXPECT_TRUE(success) << "WKWebView failed to complete javascript execution.\n"
<< base::SysNSStringToUTF8([[NSThread callStackSymbols]
componentsJoinedByString:@"\n"]);
if (error) {
*error = block_error;
}
return result;
}
bool LoadHtml(WKWebView* web_view, NSString* html, NSURL* base_url) {
[web_view loadHTMLString:html baseURL:base_url];
return WaitUntilConditionOrTimeout(kWaitForPageLoadTimeout, ^{
return !web_view.loading;
});
}
bool WaitForInjectedScripts(WKWebView* web_view) {
return WaitUntilConditionOrTimeout(kWaitForJSCompletionTimeout, ^{
return !![ExecuteJavaScript(web_view, @"!!__gCrWeb") isEqual:@YES];
});
}
NSString* GetPageScript(NSString* script_file_name) {
return web::GetPageScript(script_file_name);
}
} // namespace test
} // namespace web