Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(70)

Side by Side Diff: Tools/TestWebKitAPI/Tests/WebKit2/CanHandleRequest.cpp

Issue 13602008: Remove non-chromium code from TestWebKitAPI (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 /*
2 * Copyright (C) 2011 Apple Inc. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23 * THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26 #include "config.h"
27 #include "PlatformUtilities.h"
28 #include "PlatformWebView.h"
29 #include <WebKit2/WKContextPrivate.h>
30
31 namespace TestWebKitAPI {
32
33 static bool didReceiveMessage;
34 static bool canHandleRequest;
35
36 static void didReceiveMessageFromInjectedBundle(WKContextRef, WKStringRef messag eName, WKTypeRef body, const void*)
37 {
38 didReceiveMessage = true;
39
40 EXPECT_WK_STREQ("DidCheckCanHandleRequest", messageName);
41 EXPECT_EQ(WKBooleanGetTypeID(), WKGetTypeID(body));
42
43 canHandleRequest = WKBooleanGetValue(static_cast<WKBooleanRef>(body));
44 }
45
46 static void setInjectedBundleClient(WKContextRef context)
47 {
48 WKContextInjectedBundleClient injectedBundleClient;
49 memset(&injectedBundleClient, 0, sizeof(injectedBundleClient));
50 injectedBundleClient.didReceiveMessageFromInjectedBundle = didReceiveMessage FromInjectedBundle;
51
52 WKContextSetInjectedBundleClient(context, &injectedBundleClient);
53 }
54
55 TEST(WebKit2, CanHandleRequest)
56 {
57 WKRetainPtr<WKContextRef> context = adoptWK(Util::createContextForInjectedBu ndleTest("CanHandleRequestTest"));
58 setInjectedBundleClient(context.get());
59
60 WKContextRegisterURLSchemeAsEmptyDocument(context.get(), Util::toWK("emptysc heme").get());
61
62 PlatformWebView webView(context.get());
63
64 WKPageLoadURL(webView.page(), adoptWK(Util::createURLForResource("simple", " html")).get());
65
66 WKContextPostMessageToInjectedBundle(context.get(), Util::toWK("CheckCanHand leRequest").get(), 0);
67 Util::run(&didReceiveMessage);
68 EXPECT_TRUE(canHandleRequest);
69 }
70
71 } // namespace TestWebKitAPI
OLDNEW
« no previous file with comments | « Tools/TestWebKitAPI/Tests/WebKit2/AboutBlankLoad.cpp ('k') | Tools/TestWebKitAPI/Tests/WebKit2/CanHandleRequest_Bundle.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698