Bug 214880

Summary: http/tests/cookies/document-cookie-multiple-cookies.html is failing on Windows
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: Tools / TestsAssignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: achristensen, darin, ggaren, rackler, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=214222
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch none

Chris Dumez
Reported 2020-07-28 09:47:01 PDT
http/tests/cookies/document-cookie-multiple-cookies.html is failing on Windows: e.g.: https://ews-build.s3-us-west-2.amazonaws.com/Windows-EWS/r405345-31731-clean-tree/results.html -PASS document.cookie is "samesite-unspecified=0" +FAIL document.cookie should be samesite-unspecified=0. Was samesite-lax=1; samesite-strict=2; samesite-unspecified=0.
Attachments
Patch (5.24 KB, patch)
2020-07-28 09:59 PDT, Chris Dumez
no flags
Patch (5.25 KB, patch)
2020-07-28 11:46 PDT, Chris Dumez
no flags
Patch (5.30 KB, patch)
2020-07-28 12:19 PDT, Chris Dumez
no flags
Patch (5.30 KB, patch)
2020-07-28 13:13 PDT, Chris Dumez
no flags
Patch (5.56 KB, patch)
2020-07-28 14:42 PDT, Chris Dumez
no flags
Patch (6.36 KB, patch)
2020-07-28 15:13 PDT, Chris Dumez
no flags
Patch (6.98 KB, patch)
2020-07-28 17:14 PDT, Chris Dumez
no flags
Patch (6.69 KB, patch)
2020-07-28 18:48 PDT, Chris Dumez
no flags
Patch (6.70 KB, patch)
2020-07-28 22:06 PDT, Chris Dumez
no flags
Patch (6.73 KB, patch)
2020-07-29 09:39 PDT, Chris Dumez
no flags
Patch (6.74 KB, patch)
2020-07-29 09:45 PDT, Chris Dumez
no flags
Patch (6.70 KB, patch)
2020-07-29 10:16 PDT, Chris Dumez
no flags
Chris Dumez
Comment 1 2020-07-28 09:59:15 PDT
Chris Dumez
Comment 2 2020-07-28 11:46:49 PDT
Geoffrey Garen
Comment 3 2020-07-28 12:07:11 PDT
Comment on attachment 405384 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=405384&action=review > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:201 > + RetainPtr<CFStringRef> cookieStringCF = cookieString.createCFString(); Could be auto > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:231 > + auto cookies = adoptCF(CFArrayCreate(kCFAllocatorDefault, 0, 0, &kCFTypeArrayCallBacks)); Don't you need CFArrayCreateMutable if you want to append? Seems like a bug. Can we avoid my question about whether append is valid, and the cost of reallocation in append, by passing in { &cookie, 1 } (or syntactically valid equivalent) instead of { 0, 0 } here?
Chris Dumez
Comment 4 2020-07-28 12:19:42 PDT
Geoffrey Garen
Comment 5 2020-07-28 13:05:16 PDT
Comment on attachment 405390 [details] Patch r=me
Chris Dumez
Comment 6 2020-07-28 13:13:28 PDT
Chris Dumez
Comment 7 2020-07-28 14:35:43 PDT
Comment on attachment 405398 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=405398&action=review > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:216 > + return WTFMove(cookie); Windows really does not like this return statement it seems. I tried without WTFMove() first and now with it. It is still failing. Not sure what's going on...
Chris Dumez
Comment 8 2020-07-28 14:42:59 PDT
Chris Dumez
Comment 9 2020-07-28 15:13:55 PDT
Karl Rackler
Comment 10 2020-07-28 17:12:25 PDT
I have marked these tests as failing while this issue is investigated. https://trac.webkit.org/changeset/265021/webkit
Chris Dumez
Comment 11 2020-07-28 17:14:20 PDT
Chris Dumez
Comment 12 2020-07-28 17:15:00 PDT
(In reply to Karl Rackler from comment #10) > I have marked these tests as failing while this issue is investigated. > https://trac.webkit.org/changeset/265021/webkit Thanks, I updated my patch to unskip it.
Chris Dumez
Comment 13 2020-07-28 18:19:40 PDT
NetworkStorageSessionCFNetWin.obj : error LNK2019: unresolved external symbol __imp__CFHTTPCookieCreateWithStringAndPartition referenced in function "class WTF::RetainPtr<struct OpaqueCFHTTPCookie const *> __cdecl WebCore::parseDOMCookie(class WTF::String,struct __CFURL const *)" (?parseDOMCookie@WebCore@@YA?AV?$RetainPtr@PEBUOpaqueCFHTTPCookie@@@WTF@@VString@3@PEBU__CFURL@@@Z) [C:\cygwin\home\buildbot\worker\Windows-EWS\build\WebKitBuild\Release\Tools\TestWebKitAPI\TestWebCoreLib.vcxproj] C:\cygwin\home\buildbot\worker\Windows-EWS\build\WebKitBuild\Release\bin64\TestWebCoreLib.dll : fatal error LNK1120: 1 unresolved externals [C:\cygwin\home\buildbot\worker\Windows-EWS\build\WebKitBuild\Release\Tools\TestWebKitAPI\TestWebCoreLib.vcxproj] Looks like I may not be able to use __CFHTTPCookieCreateWithStringAndPartition() on Windows... I guess I'll keep using the old API but only keep the first cookie..
Chris Dumez
Comment 14 2020-07-28 18:48:29 PDT
Darin Adler
Comment 15 2020-07-28 19:05:04 PDT
Comment on attachment 405433 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=405433&action=review > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:223 > + return cookie; Getting a type mismatch on this line; maybe you need a cast somewhere to CFHTTPCookieRef?
Chris Dumez
Comment 16 2020-07-28 22:06:51 PDT
Chris Dumez
Comment 17 2020-07-29 09:39:02 PDT
Darin Adler
Comment 18 2020-07-29 09:42:01 PDT
Comment on attachment 405465 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=405465&action=review > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:211 > + auto cookie = static_cast<CFHTTPCookieRef>(CFArrayGetValueAtIndex(parsedCookies.get(), 0)); Idle unimportant thought: I wonder if we can use checked_cf_cast instead of static_cast. I think it’s designed for uses like this one.
Chris Dumez
Comment 19 2020-07-29 09:45:46 PDT
Darin Adler
Comment 20 2020-07-29 10:07:57 PDT
Comment on attachment 405467 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=405467&action=review > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:229 > + UNUSED_PARAM(frameID); > + UNUSED_PARAM(pageID); Could use "omit the name" style for unused arguments instead of UNUSED_PARAM style. > Source/WebCore/platform/network/cf/NetworkStorageSessionCFNetWin.cpp:239 > + auto cookies = adoptCF(CFArrayCreateMutable(0, 1, &kCFTypeArrayCallBacks)); > + CFArrayAppendValue(cookies.get(), cookie.get()); Not important to optimize, but this could be done more efficiently with CFArrayCreate. Like we do above for CFDictionaryCreate, although it can be done with less type casting by defining local arrays.
Chris Dumez
Comment 21 2020-07-29 10:16:44 PDT
EWS
Comment 22 2020-07-29 11:30:19 PDT
Committed r265048: <https://trac.webkit.org/changeset/265048> All reviewed patches have been landed. Closing bug and clearing flags on attachment 405471 [details].
Radar WebKit Bug Importer
Comment 23 2020-07-29 11:31:16 PDT
Note You need to log in before you can comment on or make changes to this bug.