<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[210268] trunk/Tools</title>
</head>
<body>
<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; }
#msg dl a { font-weight: bold}
#msg dl a:link { color:#fc3; }
#msg dl a:active { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://trac.webkit.org/projects/webkit/changeset/210268">210268</a></dd>
<dt>Author</dt> <dd>aestes@apple.com</dd>
<dt>Date</dt> <dd>2017-01-03 19:52:03 -0800 (Tue, 03 Jan 2017)</dd>
</dl>
<h3>Log Message</h3>
<pre>Place all the Cocoa WebCore API tests in the same directory
https://bugs.webkit.org/show_bug.cgi?id=166673
Reviewed by Michael Catanzaro.
* TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj:
* TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm: Renamed from Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm.
* TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm: Renamed from Tools/TestWebKitAPI/Tests/Cocoa/URLExtras.mm.
* TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm: Renamed from Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm.</pre>
<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkToolsChangeLog">trunk/Tools/ChangeLog</a></li>
<li><a href="#trunkToolsTestWebKitAPITestWebKitAPIxcodeprojprojectpbxproj">trunk/Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj</a></li>
</ul>
<h3>Added Paths</h3>
<ul>
<li>trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/</li>
<li><a href="#trunkToolsTestWebKitAPITestsWebCorecocoaSerializedCryptoKeyWrapmm">trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm</a></li>
<li><a href="#trunkToolsTestWebKitAPITestsWebCorecocoaURLExtrasmm">trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm</a></li>
<li><a href="#trunkToolsTestWebKitAPITestsWebCorecocoaWebCoreNSURLSessionmm">trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm</a></li>
</ul>
<h3>Removed Paths</h3>
<ul>
<li>trunk/Tools/TestWebKitAPI/Tests/Cocoa/</li>
<li><a href="#trunkToolsTestWebKitAPITestsWebCoreSerializedCryptoKeyWrapmm">trunk/Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm</a></li>
<li><a href="#trunkToolsTestWebKitAPITestsWebCoreWebCoreNSURLSessionmm">trunk/Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm</a></li>
</ul>
</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkToolsChangeLog"></a>
<div class="modfile"><h4>Modified: trunk/Tools/ChangeLog (210267 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/ChangeLog        2017-01-04 03:39:39 UTC (rev 210267)
+++ trunk/Tools/ChangeLog        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -1,3 +1,15 @@
</span><ins>+2017-01-03 Andy Estes <aestes@apple.com>
+
+ Place all the Cocoa WebCore API tests in the same directory
+ https://bugs.webkit.org/show_bug.cgi?id=166673
+
+ Reviewed by Michael Catanzaro.
+
+ * TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj:
+ * TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm: Renamed from Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm.
+ * TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm: Renamed from Tools/TestWebKitAPI/Tests/Cocoa/URLExtras.mm.
+ * TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm: Renamed from Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm.
+
</ins><span class="cx"> 2017-01-03 Tim Horton <timothy_horton@apple.com>
</span><span class="cx">
</span><span class="cx"> NSSpellChecker's recordResponse isn't called for unseen automatic corrections
</span></span></pre></div>
<a id="trunkToolsTestWebKitAPITestWebKitAPIxcodeprojprojectpbxproj"></a>
<div class="modfile"><h4>Modified: trunk/Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj (210267 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj        2017-01-04 03:39:39 UTC (rev 210267)
+++ trunk/Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -1099,7 +1099,7 @@
</span><span class="cx">                 93A427AC180DA60F00CD24D7 /* MoveOnly.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MoveOnly.h; sourceTree = "<group>"; };
</span><span class="cx">                 93A427AD180DA60F00CD24D7 /* RefLogger.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = RefLogger.h; sourceTree = "<group>"; };
</span><span class="cx">                 93A720E518F1A0E800A848E1 /* CalculationValue.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CalculationValue.cpp; sourceTree = "<group>"; };
</span><del>-                93A7EB3C18FA63A4009E7670 /* URLExtras.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = URLExtras.mm; path = ../Cocoa/URLExtras.mm; sourceTree = "<group>"; };
</del><ins>+                93A7EB3C18FA63A4009E7670 /* URLExtras.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = URLExtras.mm; sourceTree = "<group>"; };
</ins><span class="cx">                 93ABA80816DDAB91002DB2FA /* StringHasher.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = StringHasher.cpp; sourceTree = "<group>"; };
</span><span class="cx">                 93AF4ECA1506F035007FD57E /* NewFirstVisuallyNonEmptyLayoutForImages.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = NewFirstVisuallyNonEmptyLayoutForImages.cpp; sourceTree = "<group>"; };
</span><span class="cx">                 93AF4ECD1506F064007FD57E /* NewFirstVisuallyNonEmptyLayoutForImages_Bundle.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = NewFirstVisuallyNonEmptyLayoutForImages_Bundle.cpp; sourceTree = "<group>"; };
</span><span class="lines">@@ -1537,6 +1537,7 @@
</span><span class="cx">                 440A1D3614A01000008A66F2 /* WebCore */ = {
</span><span class="cx">                         isa = PBXGroup;
</span><span class="cx">                         children = (
</span><ins>+                                CD89D0371C4EDB1300040A04 /* cocoa */,
</ins><span class="cx">                                 7A909A6F1D877475007E10F8 /* AffineTransform.cpp */,
</span><span class="cx">                                 7A909A701D877475007E10F8 /* FloatPoint.cpp */,
</span><span class="cx">                                 7A909A711D877475007E10F8 /* FloatRect.cpp */,
</span><span class="lines">@@ -1544,7 +1545,6 @@
</span><span class="cx">                                 7A909A731D877475007E10F8 /* IntPoint.cpp */,
</span><span class="cx">                                 7A909A741D877475007E10F8 /* IntRect.cpp */,
</span><span class="cx">                                 7A909A751D877475007E10F8 /* IntSize.cpp */,
</span><del>-                                CD89D0371C4EDB1300040A04 /* cocoa */,
</del><span class="cx">                                 93A720E518F1A0E800A848E1 /* CalculationValue.cpp */,
</span><span class="cx">                                 7C3965051CDD74F90094DBB8 /* Color.cpp */,
</span><span class="cx">                                 7CB184C41AA3F2100066EDFD /* ContentExtensions.cpp */,
</span><span class="lines">@@ -2157,11 +2157,11 @@
</span><span class="cx">                 CD89D0371C4EDB1300040A04 /* cocoa */ = {
</span><span class="cx">                         isa = PBXGroup;
</span><span class="cx">                         children = (
</span><ins>+                                5769C50A1D9B0001000847FB /* SerializedCryptoKeyWrap.mm */,
</ins><span class="cx">                                 93A7EB3C18FA63A4009E7670 /* URLExtras.mm */,
</span><span class="cx">                                 CD89D0381C4EDB2A00040A04 /* WebCoreNSURLSession.mm */,
</span><del>-                                5769C50A1D9B0001000847FB /* SerializedCryptoKeyWrap.mm */,
</del><span class="cx">                         );
</span><del>-                        name = cocoa;
</del><ins>+                        path = cocoa;
</ins><span class="cx">                         sourceTree = "<group>";
</span><span class="cx">                 };
</span><span class="cx">                 CDC8E4981BC728AE00594FEC /* WebKit */ = {
</span></span></pre></div>
<a id="trunkToolsTestWebKitAPITestsWebCoreSerializedCryptoKeyWrapmm"></a>
<div class="delfile"><h4>Deleted: trunk/Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm (210267 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm        2017-01-04 03:39:39 UTC (rev 210267)
+++ trunk/Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -1,101 +0,0 @@
</span><del>-/*
- * Copyright (C) 2016 Apple Inc. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
- * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
- * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#import "config.h"
-
-#import <WebCore/SerializedCryptoKeyWrap.h>
-#import <wtf/MainThread.h>
-
-namespace TestWebKitAPI {
-
-// TODO: We should enable the following tests on iOS simulator once <rdar://problem/28534666> is fixed.
-// A seperate bug is filed about this: <rdar://problem/28507240>.
-#if !PLATFORM(IOS)
-class SerializedCryptoKeyWrapTest : public testing::Test {
-public:
- virtual void SetUp()
- {
- WTF::initializeMainThread();
- WebCore::deleteDefaultWebCryptoMasterKey();
- }
-
- virtual void TearDown()
- {
- WebCore::deleteDefaultWebCryptoMasterKey();
- }
-};
-
-TEST_F(SerializedCryptoKeyWrapTest, GetDefaultWebCryptoMasterKey)
-{
- Vector<uint8_t> masterKey1;
- EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey1));
-
- Vector<uint8_t> masterKey2;
- EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey2));
-
- EXPECT_TRUE(masterKey1 == masterKey2);
-}
-
-TEST_F(SerializedCryptoKeyWrapTest, DeleteDefaultWebCryptoMasterKey)
-{
- Vector<uint8_t> masterKey1;
- EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey1));
- EXPECT_TRUE(WebCore::deleteDefaultWebCryptoMasterKey());
-
- Vector<uint8_t> masterKey2;
- EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey2));
-
- EXPECT_TRUE(masterKey1 != masterKey2);
-}
-
-TEST_F(SerializedCryptoKeyWrapTest, SerializedCryptoKeyWrapUnwrap)
-{
- Vector<uint8_t> masterKey;
- EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey));
-
- Vector<uint8_t> cryptoKey(16, 1);
- Vector<uint8_t> wrappedKey;
- EXPECT_TRUE(WebCore::wrapSerializedCryptoKey(masterKey, cryptoKey, wrappedKey));
- EXPECT_TRUE(cryptoKey != wrappedKey);
- // ensure wrappedKey doesn't contain cryptoKey
- bool notContained = true;
- size_t limit = wrappedKey.size() - cryptoKey.size() + 1;
- for (size_t i = 0; i < limit; i++) {
- size_t j = 0;
- for (; j < cryptoKey.size() && wrappedKey[i + j] == cryptoKey[j]; j++) { }
- if (j >= cryptoKey.size()) {
- notContained = false;
- break;
- }
- }
- EXPECT_TRUE(notContained);
-
- Vector<uint8_t> unwrappedKey;
- EXPECT_TRUE(WebCore::unwrapSerializedCryptoKey(masterKey, wrappedKey, unwrappedKey));
- EXPECT_TRUE(unwrappedKey == cryptoKey);
-}
-#endif
-
-} // namespace TestWebKitAPI
</del></span></pre></div>
<a id="trunkToolsTestWebKitAPITestsWebCoreWebCoreNSURLSessionmm"></a>
<div class="delfile"><h4>Deleted: trunk/Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm (210267 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm        2017-01-04 03:39:39 UTC (rev 210267)
+++ trunk/Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -1,173 +0,0 @@
</span><del>-/*
- * Copyright (C) 2016 Apple Inc. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#import "config.h"
-
-#if !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 101100
-
-#import "PlatformUtilities.h"
-#import <JavaScriptCore/InitializeThreading.h>
-#import <WebKit/WebView.h>
-#import <WebCore/FrameLoadRequest.h>
-#import <WebCore/MainFrame.h>
-#import <WebCore/Page.h>
-#import <WebCore/PageConfiguration.h>
-#import <WebCore/Document.h>
-#import <WebCore/DocumentLoader.h>
-#import <WebCore/MediaResourceLoader.h>
-#import <WebCore/Settings.h>
-#import <WebCore/SubresourceLoader.h>
-#import <WebCore/WebCoreNSURLSession.h>
-#import <WebCore/ResourceLoader.h>
-#import <wtf/SchedulePair.h>
-
-static bool didLoadMainResource;
-static bool didRecieveResponse;
-static bool didRecieveData;
-static bool didComplete;
-static bool didInvalidate;
-
-static NSURL *documentURL = [[NSBundle mainBundle] URLForResource:@"simple" withExtension:@"html" subdirectory:@"TestWebKitAPI.resources"];
-static NSURL *resourceURL = [[NSBundle mainBundle] URLForResource:@"test" withExtension:@"mp4" subdirectory:@"TestWebKitAPI.resources"];
-
-@interface TestNSURLSessionLoaderDelegate : NSObject<WebFrameLoadDelegate>
-@end
-
-@implementation TestNSURLSessionLoaderDelegate
-- (void)webView:(WebView *)sender didCommitLoadForFrame:(WebFrame *)frame
-{
- UNUSED_PARAM(sender);
- UNUSED_PARAM(frame);
- didLoadMainResource = true;
-}
-@end
-
-@interface TestNSURLSessionDataDelegate : NSObject<NSURLSessionDataDelegate>
-@end
-
-@implementation TestNSURLSessionDataDelegate
-- (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didCompleteWithError:(nullable NSError *)error
-{
- didComplete = true;
-}
-
-- (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveResponse:(NSURLResponse *)response completionHandler:(void (^)(NSURLSessionResponseDisposition disposition))completionHandler
-{
- didRecieveResponse = true;
- completionHandler(NSURLSessionResponseAllow);
-}
-
-- (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveData:(NSData *)data
-{
- didRecieveData = true;
-
- NSData* directData = [NSData dataWithContentsOfURL:dataTask.originalRequest.URL];
- NSData* directSubdata = [directData subdataWithRange:NSMakeRange(dataTask.countOfBytesReceived - data.length, data.length)];
- ASSERT_TRUE([data isEqualToData:directSubdata]);
-}
-
-- (void)URLSession:(NSURLSession *)session didBecomeInvalidWithError:(nullable NSError *)error
-{
- didInvalidate = true;
-}
-@end
-
-using namespace WebCore;
-
-@interface WebView (WebViewInternalForTesting)
-- (WebCore::Frame*)_mainCoreFrame;
-@end
-
-namespace TestWebKitAPI {
-
-class WebCoreNSURLSessionTest : public testing::Test {
-public:
- WebView *view { nil };
- Frame* frame { nullptr };
- TestNSURLSessionDataDelegate *delegate { nil };
- RefPtr<MediaResourceLoader> loader;
-
- virtual void SetUp()
- {
-#if PLATFORM(IOS)
- JSC::initializeThreading();
-#endif
- view = [[WebView alloc] initWithFrame:NSZeroRect];
- view.frameLoadDelegate = [[[TestNSURLSessionLoaderDelegate alloc] init] autorelease];
-
- didLoadMainResource = false;
- view.mainFrameURL = documentURL.absoluteString;
- TestWebKitAPI::Util::run(&didLoadMainResource);
-
- delegate = [[TestNSURLSessionDataDelegate alloc] init];
- frame = [view _mainCoreFrame];
- loader = adoptRef(new MediaResourceLoader(*frame->document(), emptyString()));
- }
-
- virtual void TearDown()
- {
- [view release];
- [delegate release];
- loader = nullptr;
- }
-};
-
-TEST_F(WebCoreNSURLSessionTest, BasicOperation)
-{
- WebCoreNSURLSession* session = [[WebCoreNSURLSession alloc] initWithResourceLoader:*loader delegate:delegate delegateQueue:[NSOperationQueue mainQueue]];
- didRecieveResponse = false;
- didRecieveData = false;
- didComplete = false;
-
- NSURLSessionDataTask *task = [session dataTaskWithURL:resourceURL];
- [task resume];
-
- TestWebKitAPI::Util::run(&didRecieveResponse);
- TestWebKitAPI::Util::run(&didRecieveData);
- TestWebKitAPI::Util::run(&didComplete);
-
- didInvalidate = false;
-
- task = [session dataTaskWithURL:resourceURL];
- [task resume];
- [session finishTasksAndInvalidate];
-
- TestWebKitAPI::Util::run(&didInvalidate);
-
- [session release];
-}
-
-TEST_F(WebCoreNSURLSessionTest, InvalidateEmpty)
-{
- WebCoreNSURLSession* session = [[WebCoreNSURLSession alloc] initWithResourceLoader:*loader delegate:delegate delegateQueue:[NSOperationQueue mainQueue]];
- didInvalidate = false;
- [session finishTasksAndInvalidate];
- TestWebKitAPI::Util::run(&didInvalidate);
- [session release];
-}
-
-}
-
-#endif
</del></span></pre></div>
<a id="trunkToolsTestWebKitAPITestsWebCorecocoaSerializedCryptoKeyWrapmmfromrev210267trunkToolsTestWebKitAPITestsWebCoreSerializedCryptoKeyWrapmm"></a>
<div class="copfile"><h4>Copied: trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm (from rev 210267, trunk/Tools/TestWebKitAPI/Tests/WebCore/SerializedCryptoKeyWrap.mm) (0 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm         (rev 0)
+++ trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/SerializedCryptoKeyWrap.mm        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -0,0 +1,101 @@
</span><ins>+/*
+ * Copyright (C) 2016 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import "config.h"
+
+#import <WebCore/SerializedCryptoKeyWrap.h>
+#import <wtf/MainThread.h>
+
+namespace TestWebKitAPI {
+
+// TODO: We should enable the following tests on iOS simulator once <rdar://problem/28534666> is fixed.
+// A seperate bug is filed about this: <rdar://problem/28507240>.
+#if !PLATFORM(IOS)
+class SerializedCryptoKeyWrapTest : public testing::Test {
+public:
+ virtual void SetUp()
+ {
+ WTF::initializeMainThread();
+ WebCore::deleteDefaultWebCryptoMasterKey();
+ }
+
+ virtual void TearDown()
+ {
+ WebCore::deleteDefaultWebCryptoMasterKey();
+ }
+};
+
+TEST_F(SerializedCryptoKeyWrapTest, GetDefaultWebCryptoMasterKey)
+{
+ Vector<uint8_t> masterKey1;
+ EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey1));
+
+ Vector<uint8_t> masterKey2;
+ EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey2));
+
+ EXPECT_TRUE(masterKey1 == masterKey2);
+}
+
+TEST_F(SerializedCryptoKeyWrapTest, DeleteDefaultWebCryptoMasterKey)
+{
+ Vector<uint8_t> masterKey1;
+ EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey1));
+ EXPECT_TRUE(WebCore::deleteDefaultWebCryptoMasterKey());
+
+ Vector<uint8_t> masterKey2;
+ EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey2));
+
+ EXPECT_TRUE(masterKey1 != masterKey2);
+}
+
+TEST_F(SerializedCryptoKeyWrapTest, SerializedCryptoKeyWrapUnwrap)
+{
+ Vector<uint8_t> masterKey;
+ EXPECT_TRUE(WebCore::getDefaultWebCryptoMasterKey(masterKey));
+
+ Vector<uint8_t> cryptoKey(16, 1);
+ Vector<uint8_t> wrappedKey;
+ EXPECT_TRUE(WebCore::wrapSerializedCryptoKey(masterKey, cryptoKey, wrappedKey));
+ EXPECT_TRUE(cryptoKey != wrappedKey);
+ // ensure wrappedKey doesn't contain cryptoKey
+ bool notContained = true;
+ size_t limit = wrappedKey.size() - cryptoKey.size() + 1;
+ for (size_t i = 0; i < limit; i++) {
+ size_t j = 0;
+ for (; j < cryptoKey.size() && wrappedKey[i + j] == cryptoKey[j]; j++) { }
+ if (j >= cryptoKey.size()) {
+ notContained = false;
+ break;
+ }
+ }
+ EXPECT_TRUE(notContained);
+
+ Vector<uint8_t> unwrappedKey;
+ EXPECT_TRUE(WebCore::unwrapSerializedCryptoKey(masterKey, wrappedKey, unwrappedKey));
+ EXPECT_TRUE(unwrappedKey == cryptoKey);
+}
+#endif
+
+} // namespace TestWebKitAPI
</ins></span></pre></div>
<a id="trunkToolsTestWebKitAPITestsWebCorecocoaURLExtrasmmfromrev210267trunkToolsTestWebKitAPITestsCocoaURLExtrasmm"></a>
<div class="copfile"><h4>Copied: trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm (from rev 210267, trunk/Tools/TestWebKitAPI/Tests/Cocoa/URLExtras.mm) (0 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm         (rev 0)
+++ trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/URLExtras.mm        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -0,0 +1,149 @@
</span><ins>+/*
+ * Copyright (C) 2014 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import "config.h"
+
+#import <WebCore/WebCoreNSURLExtras.h>
+
+namespace TestWebKitAPI {
+
+static NSData *literalAsData(const char* literal)
+{
+ return [NSData dataWithBytes:literal length:strlen(literal)];
+}
+
+static const char* dataAsString(NSData *data)
+{
+ static char buffer[1000];
+ if ([data length] > sizeof(buffer) - 1)
+ return "ERROR";
+ if (memchr([data bytes], 0, [data length]))
+ return "ERROR";
+ memcpy(buffer, [data bytes], [data length]);
+ buffer[[data length]] = '\0';
+ return buffer;
+}
+
+static const char* originalDataAsString(NSURL *URL)
+{
+ return dataAsString(WebCore::originalURLData(URL));
+}
+
+static const char* userVisibleString(NSURL *URL)
+{
+ return [WebCore::userVisibleString(URL) UTF8String];
+}
+
+static NSURL *literalURL(const char* literal)
+{
+ return WebCore::URLWithData(literalAsData(literal), nil);
+}
+
+TEST(WebCore, URLExtras)
+{
+ EXPECT_STREQ("http://site.com", originalDataAsString(literalURL("http://site.com")));
+ EXPECT_STREQ("http://%77ebsite.com", originalDataAsString(literalURL("http://%77ebsite.com")));
+
+ EXPECT_STREQ("http://site.com", userVisibleString(literalURL("http://site.com")));
+ EXPECT_STREQ("http://%77ebsite.com", userVisibleString(literalURL("http://%77ebsite.com")));
+}
+
+TEST(WebCore, URLExtras_DivisionSign)
+{
+ // Selected the division sign as an example of a non-ASCII character that is allowed in host names, since it's a lookalike character.
+
+ // Code path similar to the one used when typing in a URL.
+ EXPECT_STREQ("http://site.xn--comothersite-kjb.org", originalDataAsString(WebCore::URLWithUserTypedString(@"http://site.com\xC3\xB7othersite.org", nil)));
+ EXPECT_STREQ("http://site.com\xC3\xB7othersite.org", userVisibleString(WebCore::URLWithUserTypedString(@"http://site.com\xC3\xB7othersite.org", nil)));
+
+ // Code paths similar to the ones used for URLs found in webpages or HTTP responses.
+ EXPECT_STREQ("http://site.com\xC3\xB7othersite.org", originalDataAsString(literalURL("http://site.com\xC3\xB7othersite.org")));
+ EXPECT_STREQ("http://site.com\xC3\xB7othersite.org", userVisibleString(literalURL("http://site.com\xC3\xB7othersite.org")));
+ EXPECT_STREQ("http://site.com%C3%B7othersite.org", originalDataAsString(literalURL("http://site.com%C3%B7othersite.org")));
+ EXPECT_STREQ("http://site.com\xC3\xB7othersite.org", userVisibleString(literalURL("http://site.com%C3%B7othersite.org")));
+
+ // Separate functions that deal with just a host name on its own.
+ EXPECT_STREQ("site.xn--comothersite-kjb.org", [WebCore::encodeHostName(@"site.com\xC3\xB7othersite.org") UTF8String]);
+ EXPECT_STREQ("site.com\xC3\xB7othersite.org", [WebCore::decodeHostName(@"site.com\xC3\xB7othersite.org") UTF8String]);
+}
+
+TEST(WebCore, URLExtras_Solidus)
+{
+ // Selected full width solidus, which looks like the solidus, which is the character that indicates the end of the host name.
+
+ // Code path similar to the one used when typing in a URL.
+ EXPECT_STREQ("http://site.com/othersite.org", originalDataAsString(WebCore::URLWithUserTypedString(@"http://site.com\xEF\xBC\x8Fothersite.org", nil)));
+ EXPECT_STREQ("http://site.com/othersite.org", userVisibleString(WebCore::URLWithUserTypedString(@"http://site.com\xEF\xBC\x8Fothersite.org", nil)));
+
+ // Code paths similar to the ones used for URLs found in webpages or HTTP responses.
+ EXPECT_STREQ("http://site.com\xEF\xBC\x8Fothersite.org", originalDataAsString(literalURL("http://site.com\xEF\xBC\x8Fothersite.org")));
+ EXPECT_STREQ("http://site.com%EF%BC%8Fothersite.org", userVisibleString(literalURL("http://site.com\xEF\xBC\x8Fothersite.org")));
+ EXPECT_STREQ("http://site.com%EF%BC%8Fothersite.org", originalDataAsString(literalURL("http://site.com%EF%BC%8Fothersite.org")));
+ EXPECT_STREQ("http://site.com%EF%BC%8Fothersite.org", userVisibleString(literalURL("http://site.com%EF%BC%8Fothersite.org")));
+
+ // Separate functions that deal with just a host name on its own.
+ EXPECT_STREQ("site.com/othersite.org", [WebCore::encodeHostName(@"site.com\xEF\xBC\x8Fothersite.org") UTF8String]);
+ EXPECT_STREQ("site.com/othersite.org", [WebCore::decodeHostName(@"site.com\xEF\xBC\x8Fothersite.org") UTF8String]);
+}
+
+TEST(WebCore, URLExtras_Space)
+{
+ // Selected ideographic space, which looks like the ASCII space, which is not allowed unescaped.
+
+ // Code path similar to the one used when typing in a URL.
+ EXPECT_STREQ("http://site.com%20othersite.org", originalDataAsString(WebCore::URLWithUserTypedString(@"http://site.com\xE3\x80\x80othersite.org", nil)));
+ EXPECT_STREQ("http://site.com%20othersite.org", userVisibleString(WebCore::URLWithUserTypedString(@"http://site.com\xE3\x80\x80othersite.org", nil)));
+
+ // Code paths similar to the ones used for URLs found in webpages or HTTP responses.
+ EXPECT_STREQ("http://site.com\xE3\x80\x80othersite.org", originalDataAsString(literalURL("http://site.com\xE3\x80\x80othersite.org")));
+ EXPECT_STREQ("http://site.com%E3%80%80othersite.org", userVisibleString(literalURL("http://site.com\xE3\x80\x80othersite.org")));
+ EXPECT_STREQ("http://site.com%E3%80%80othersite.org", originalDataAsString(literalURL("http://site.com%E3%80%80othersite.org")));
+ EXPECT_STREQ("http://site.com%E3%80%80othersite.org", userVisibleString(literalURL("http://site.com%E3%80%80othersite.org")));
+
+ // Separate functions that deal with just a host name on its own.
+ EXPECT_STREQ("site.com othersite.org", [WebCore::encodeHostName(@"site.com\xE3\x80\x80othersite.org") UTF8String]);
+ EXPECT_STREQ("site.com\xE3\x80\x80othersite.org", [WebCore::decodeHostName(@"site.com\xE3\x80\x80othersite.org") UTF8String]);
+}
+
+TEST(WebCore, URLExtras_ParsingError)
+{
+ // Expect IDN failure.
+ NSURL *url = WebCore::URLWithUserTypedString(@"http://.com", nil);
+ EXPECT_TRUE(url == nil);
+
+ NSString *encodedHostName = WebCore::encodeHostName(@"http://.com");
+ EXPECT_TRUE(encodedHostName == nil);
+}
+
+TEST(WebCore, URLExtras_Nil)
+{
+ NSURL *url1 = WebCore::URLWithUserTypedString(nil, nil);
+ EXPECT_TRUE(url1 == nil);
+
+ NSURL *url2 = WebCore::URLWithUserTypedStringDeprecated(nil, nil);
+ EXPECT_TRUE(url2 == nil);
+}
+
+} // namespace TestWebKitAPI
</ins></span></pre></div>
<a id="trunkToolsTestWebKitAPITestsWebCorecocoaWebCoreNSURLSessionmmfromrev210267trunkToolsTestWebKitAPITestsWebCoreWebCoreNSURLSessionmm"></a>
<div class="copfile"><h4>Copied: trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm (from rev 210267, trunk/Tools/TestWebKitAPI/Tests/WebCore/WebCoreNSURLSession.mm) (0 => 210268)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm         (rev 0)
+++ trunk/Tools/TestWebKitAPI/Tests/WebCore/cocoa/WebCoreNSURLSession.mm        2017-01-04 03:52:03 UTC (rev 210268)
</span><span class="lines">@@ -0,0 +1,173 @@
</span><ins>+/*
+ * Copyright (C) 2016 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+ * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import "config.h"
+
+#if !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 101100
+
+#import "PlatformUtilities.h"
+#import <JavaScriptCore/InitializeThreading.h>
+#import <WebKit/WebView.h>
+#import <WebCore/FrameLoadRequest.h>
+#import <WebCore/MainFrame.h>
+#import <WebCore/Page.h>
+#import <WebCore/PageConfiguration.h>
+#import <WebCore/Document.h>
+#import <WebCore/DocumentLoader.h>
+#import <WebCore/MediaResourceLoader.h>
+#import <WebCore/Settings.h>
+#import <WebCore/SubresourceLoader.h>
+#import <WebCore/WebCoreNSURLSession.h>
+#import <WebCore/ResourceLoader.h>
+#import <wtf/SchedulePair.h>
+
+static bool didLoadMainResource;
+static bool didRecieveResponse;
+static bool didRecieveData;
+static bool didComplete;
+static bool didInvalidate;
+
+static NSURL *documentURL = [[NSBundle mainBundle] URLForResource:@"simple" withExtension:@"html" subdirectory:@"TestWebKitAPI.resources"];
+static NSURL *resourceURL = [[NSBundle mainBundle] URLForResource:@"test" withExtension:@"mp4" subdirectory:@"TestWebKitAPI.resources"];
+
+@interface TestNSURLSessionLoaderDelegate : NSObject<WebFrameLoadDelegate>
+@end
+
+@implementation TestNSURLSessionLoaderDelegate
+- (void)webView:(WebView *)sender didCommitLoadForFrame:(WebFrame *)frame
+{
+ UNUSED_PARAM(sender);
+ UNUSED_PARAM(frame);
+ didLoadMainResource = true;
+}
+@end
+
+@interface TestNSURLSessionDataDelegate : NSObject<NSURLSessionDataDelegate>
+@end
+
+@implementation TestNSURLSessionDataDelegate
+- (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didCompleteWithError:(nullable NSError *)error
+{
+ didComplete = true;
+}
+
+- (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveResponse:(NSURLResponse *)response completionHandler:(void (^)(NSURLSessionResponseDisposition disposition))completionHandler
+{
+ didRecieveResponse = true;
+ completionHandler(NSURLSessionResponseAllow);
+}
+
+- (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveData:(NSData *)data
+{
+ didRecieveData = true;
+
+ NSData* directData = [NSData dataWithContentsOfURL:dataTask.originalRequest.URL];
+ NSData* directSubdata = [directData subdataWithRange:NSMakeRange(dataTask.countOfBytesReceived - data.length, data.length)];
+ ASSERT_TRUE([data isEqualToData:directSubdata]);
+}
+
+- (void)URLSession:(NSURLSession *)session didBecomeInvalidWithError:(nullable NSError *)error
+{
+ didInvalidate = true;
+}
+@end
+
+using namespace WebCore;
+
+@interface WebView (WebViewInternalForTesting)
+- (WebCore::Frame*)_mainCoreFrame;
+@end
+
+namespace TestWebKitAPI {
+
+class WebCoreNSURLSessionTest : public testing::Test {
+public:
+ WebView *view { nil };
+ Frame* frame { nullptr };
+ TestNSURLSessionDataDelegate *delegate { nil };
+ RefPtr<MediaResourceLoader> loader;
+
+ virtual void SetUp()
+ {
+#if PLATFORM(IOS)
+ JSC::initializeThreading();
+#endif
+ view = [[WebView alloc] initWithFrame:NSZeroRect];
+ view.frameLoadDelegate = [[[TestNSURLSessionLoaderDelegate alloc] init] autorelease];
+
+ didLoadMainResource = false;
+ view.mainFrameURL = documentURL.absoluteString;
+ TestWebKitAPI::Util::run(&didLoadMainResource);
+
+ delegate = [[TestNSURLSessionDataDelegate alloc] init];
+ frame = [view _mainCoreFrame];
+ loader = adoptRef(new MediaResourceLoader(*frame->document(), emptyString()));
+ }
+
+ virtual void TearDown()
+ {
+ [view release];
+ [delegate release];
+ loader = nullptr;
+ }
+};
+
+TEST_F(WebCoreNSURLSessionTest, BasicOperation)
+{
+ WebCoreNSURLSession* session = [[WebCoreNSURLSession alloc] initWithResourceLoader:*loader delegate:delegate delegateQueue:[NSOperationQueue mainQueue]];
+ didRecieveResponse = false;
+ didRecieveData = false;
+ didComplete = false;
+
+ NSURLSessionDataTask *task = [session dataTaskWithURL:resourceURL];
+ [task resume];
+
+ TestWebKitAPI::Util::run(&didRecieveResponse);
+ TestWebKitAPI::Util::run(&didRecieveData);
+ TestWebKitAPI::Util::run(&didComplete);
+
+ didInvalidate = false;
+
+ task = [session dataTaskWithURL:resourceURL];
+ [task resume];
+ [session finishTasksAndInvalidate];
+
+ TestWebKitAPI::Util::run(&didInvalidate);
+
+ [session release];
+}
+
+TEST_F(WebCoreNSURLSessionTest, InvalidateEmpty)
+{
+ WebCoreNSURLSession* session = [[WebCoreNSURLSession alloc] initWithResourceLoader:*loader delegate:delegate delegateQueue:[NSOperationQueue mainQueue]];
+ didInvalidate = false;
+ [session finishTasksAndInvalidate];
+ TestWebKitAPI::Util::run(&didInvalidate);
+ [session release];
+}
+
+}
+
+#endif
</ins></span></pre>
</div>
</div>
</body>
</html>