Bug 182557

Summary: REGRESSION(r226396): File paths are inserted when dropping image files
Product: WebKit Reporter: Wenson Hsieh <wenson_hsieh>
Component: HTML EditingAssignee: Wenson Hsieh <wenson_hsieh>
Status: RESOLVED FIXED    
Severity: Normal CC: ap, bdakin, commit-queue, rniwa, thorton, webkit-bug-importer, wenson_hsieh
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Fixes the bug
none
Fixes the bug
none
ChangeLog tweak
none
Test copy/paste as well. none

Wenson Hsieh
Reported 2018-02-06 16:30:33 PST
<https://trac.webkit.org/r226396> unintentionally changed behavior when dropping files when attachment elements are disabled.
Attachments
Fixes the bug (8.34 KB, patch)
2018-02-06 18:06 PST, Wenson Hsieh
no flags
Fixes the bug (8.31 KB, patch)
2018-02-06 18:21 PST, Wenson Hsieh
no flags
ChangeLog tweak (8.32 KB, patch)
2018-02-07 09:09 PST, Wenson Hsieh
no flags
Test copy/paste as well. (11.79 KB, patch)
2018-02-07 11:07 PST, Wenson Hsieh
no flags
Radar WebKit Bug Importer
Comment 1 2018-02-06 16:33:55 PST
Wenson Hsieh
Comment 2 2018-02-06 16:45:50 PST
This function used to be: bool Editor::WebContentReader::readFilenames(const Vector<String>& paths) { if (paths.isEmpty()) return false; if (!frame.document()) return false; Document& document = *frame.document(); fragment = document.createDocumentFragment(); for (auto& text : paths) { #if ENABLE(ATTACHMENT_ELEMENT) auto attachment = HTMLAttachmentElement::create(attachmentTag, document); attachment->setFile(File::create([[NSURL fileURLWithPath:text] path]).ptr()); fragment->appendChild(attachment); #else auto paragraph = createDefaultParagraphElement(document); paragraph->appendChild(document.createTextNode(frame.editor().client()->userVisibleString([NSURL fileURLWithPath:text]))); fragment->appendChild(paragraph); #endif } return true; } ...and it is now: bool WebContentReader::readFilePaths(const Vector<String>& paths) { if (paths.isEmpty() || !frame.document()) return false; auto& document = *frame.document(); bool readAnyFilePath = false; for (auto& path : paths) { #if ENABLE(ATTACHMENT_ELEMENT) if (RuntimeEnabledFeatures::sharedFeatures().attachmentElementEnabled()) { auto attachment = HTMLAttachmentElement::create(HTMLNames::attachmentTag, document); attachment->setFile(File::create(path), HTMLAttachmentElement::UpdateDisplayAttributes::Yes); ensureFragment().appendChild(attachment); readAnyFilePath = true; continue; } #endif #if PLATFORM(MAC) // FIXME: Does (and should) any macOS client depend on inserting file paths as plain text in web content? // If not, we should just remove this. auto paragraph = createDefaultParagraphElement(document); paragraph->appendChild(document.createTextNode(userVisibleString([NSURL fileURLWithPath:path]))); ensureFragment().appendChild(paragraph); readAnyFilePath = true; #endif } return readAnyFilePath; } ...so I had unintentionally resurrected the dead codepath to append the visible URL as a text node. There's also a more subtle difference here, which is that we used to always return true and initialize the document fragment here in this function, but now we only do so if we actually appended anything to the document fragment. A fix here is to (1) just remove the dead codepath, since there's no version of macOS where !ENABLE(ATTACHMENT_ELEMENT), and (2) revert to the old behavior where we always create the document fragment after calling this function.
Wenson Hsieh
Comment 3 2018-02-06 16:48:35 PST
> // FIXME: Does (and should) any macOS client depend on inserting > file paths as plain text in web content? > // If not, we should just remove this. Ironically, I had even considered just removing this code in that same patch, but decided not to so that there'd be less chance of breakage. I failed to see that this was dead code to begin with :/
Wenson Hsieh
Comment 4 2018-02-06 18:06:52 PST
Created attachment 333240 [details] Fixes the bug
Wenson Hsieh
Comment 5 2018-02-06 18:21:00 PST
Created attachment 333247 [details] Fixes the bug
Wenson Hsieh
Comment 6 2018-02-07 09:09:38 PST
Created attachment 333291 [details] ChangeLog tweak
Alexey Proskuryakov
Comment 7 2018-02-07 09:30:39 PST
Given that the original way this was discovered was by pasting, not by dropping, I wonder if both paths need to be tested.
Wenson Hsieh
Comment 8 2018-02-07 09:38:31 PST
(In reply to Alexey Proskuryakov from comment #7) > Given that the original way this was discovered was by pasting, not by > dropping, I wonder if both paths need to be tested. Given that the bug lies in WebContentReader code common to both dropping and pasting, I don't think we need a separate test that uses paste to trigger this bug...
Wenson Hsieh
Comment 9 2018-02-07 11:07:28 PST
Created attachment 333305 [details] Test copy/paste as well.
Wenson Hsieh
Comment 10 2018-02-07 11:08:49 PST
(In reply to Wenson Hsieh from comment #8) > (In reply to Alexey Proskuryakov from comment #7) > > Given that the original way this was discovered was by pasting, not by > > dropping, I wonder if both paths need to be tested. > > Given that the bug lies in WebContentReader code common to both dropping and > pasting, I don't think we need a separate test that uses paste to trigger > this bug... Well, then again, no harm in more test coverage :) We can adjust some existing API tests to exercise copy/paste.
Wenson Hsieh
Comment 11 2018-02-07 13:07:15 PST
Comment on attachment 333305 [details] Test copy/paste as well. Thanks for the review!
WebKit Commit Bot
Comment 12 2018-02-07 13:31:20 PST
Comment on attachment 333305 [details] Test copy/paste as well. Clearing flags on attachment: 333305 Committed r228240: <https://trac.webkit.org/changeset/228240>
WebKit Commit Bot
Comment 13 2018-02-07 13:31:21 PST
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.