RESOLVED FIXED 98153
[GTK] WebKitWebView doesn't emit notify:favicon when it changes in some cases in WebKit2
https://bugs.webkit.org/show_bug.cgi?id=98153
Summary [GTK] WebKitWebView doesn't emit notify:favicon when it changes in some cases...
Carlos Garcia Campos
Reported 2012-10-02 05:44:42 PDT
The main problem is that it relies on icon-ready signal to be emitted by the favicon database, but that signal is only emitted when the icon is loaded from the network or imported from the database, but not when the icon is already in memory.
Attachments
Patch (14.20 KB, patch)
2012-10-02 05:59 PDT, Carlos Garcia Campos
cgarcia: commit-queue-
Updated patch (18.27 KB, patch)
2012-10-02 11:29 PDT, Carlos Garcia Campos
no flags
Updated patch (25.53 KB, patch)
2012-10-03 04:44 PDT, Carlos Garcia Campos
mrobinson: review+
Carlos Garcia Campos
Comment 1 2012-10-02 05:59:19 PDT
WebKit Review Bot
Comment 2 2012-10-02 06:01:45 PDT
Thanks for the patch. If this patch contains new public API please make sure it follows the guidelines for new WebKit2 GTK+ API. See http://trac.webkit.org/wiki/WebKitGTK/AddingNewWebKit2API
WebKit Review Bot
Comment 3 2012-10-02 06:02:04 PDT
Attachment 166680 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'Source/WebKit2/ChangeLog', u'Source/WebKit..." exit_code: 1 Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:1270: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:134: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:142: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Total errors found: 3 in 3 files If any of these errors are false positives, please file a bug against check-webkit-style.
Alberto Garcia
Comment 4 2012-10-02 06:08:57 PDT
(In reply to comment #0) > The main problem is that it relies on icon-ready signal to be > emitted by the favicon database, but that signal is only emitted > when the icon is loaded from the network or imported from the > database, but not when the icon is already in memory. I tested my patch with this and it seems to work fine now.
Mario Sanchez Prada
Comment 5 2012-10-02 06:39:24 PDT
Comment on attachment 166680 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=166680&action=review The patch looks good to me. Only concern I have is whether it would be needed to write / extend a unit test for it. > Source/WebKit2/ChangeLog:23 > + known by the database and it doesn't have a favicon. Good catch > Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:1253 > +static void faviconReadyCallback(GObject* object, GAsyncResult* result, gpointer userData) Nit. I would probably rename this function to better reflect is the async callback for _get_favicon() and not the handler for the icon-ready signal (as it seems to suggest)
Carlos Garcia Campos
Comment 6 2012-10-02 06:55:03 PDT
(In reply to comment #5) > (From update of attachment 166680 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=166680&action=review > > The patch looks good to me. Only concern I have is whether it would be needed to write / extend a unit test for it. Unit tests are currently broken indeed, but I don't know why, I'll look at it. > > Source/WebKit2/ChangeLog:23 > > + known by the database and it doesn't have a favicon. > > Good catch > > > Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:1253 > > +static void faviconReadyCallback(GObject* object, GAsyncResult* result, gpointer userData) > > Nit. I would probably rename this function to better reflect is the async callback for _get_favicon() and not the handler for the icon-ready signal (as it seems to suggest) You are right.
Carlos Garcia Campos
Comment 7 2012-10-02 06:55:35 PDT
Comment on attachment 166680 [details] Patch The patch seems to break the unit tests, but still don't see why, I'm working on it.
Carlos Garcia Campos
Comment 8 2012-10-02 08:30:08 PDT
It seems it was not my patch, test is failing in the bots
Carlos Garcia Campos
Comment 9 2012-10-02 11:29:19 PDT
Created attachment 166719 [details] Updated patch It fixes some issues with the previous patch, removing race conditions in the cancellation code and cancelling the operation in WebView when needed.
WebKit Review Bot
Comment 10 2012-10-02 11:41:49 PDT
Attachment 166719 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'Source/WebKit2/ChangeLog', u'Source/WebKit..." exit_code: 1 Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:1288: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:127: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:135: When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] Total errors found: 3 in 3 files If any of these errors are false positives, please file a bug against check-webkit-style.
Martin Robinson
Comment 11 2012-10-02 12:10:05 PDT
Comment on attachment 166719 [details] Updated patch View in context: https://bugs.webkit.org/attachment.cgi?id=166719&action=review Okay. This looks reasonable. I'd really like Mario to do an informal review before I r+ this though. >> Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:127 >> + _("Unknown favicon for page %s"), pageURL.utf8().data()); > > When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] I know that we have agreed in the past to line up the arguments, but it seems that the style bot now complains about this. We should follow the herd here. Sticking with what we agreed to before will just cause us pain, because the bot will never stop complaining. When does this error case happen? I'm a bit confused by the phrase "Unknown favicon for page..." > Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:270 > +static void webkitWebViewCancelFavicon(WebKitWebView* webView) webkitWebViewCancelFaviconRequest? > Source/WebKit2/UIProcess/API/gtk/WebKitWebView.cpp:288 > static void iconReadyCallback(WebKitFaviconDatabase *database, const char *uri, WebKitWebView *webView) Do you mind also fixing the asterisks here?
Mario Sanchez Prada
Comment 12 2012-10-03 01:00:43 PDT
(In reply to comment #11) > (From update of attachment 166719 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=166719&action=review > > Okay. This looks reasonable. I'd really like Mario to do an informal review before I r+ this though. I have reviewed it and it looks good to me. Only doubt I had was about removing all the code to connect to the cancellable object, but Carlos explained me via jabber that not only it's not needed[*], but that it was also a source of problems due to a race condition that might happen in some cases. So, I think an r+ is in place :) [*] We would not be cancelling anything in the middle of the operation anyway, but just checking if it was cancelled in the _finish() method, and report accordingly.
Carlos Garcia Campos
Comment 13 2012-10-03 04:27:54 PDT
(In reply to comment #11) > (From update of attachment 166719 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=166719&action=review > > Okay. This looks reasonable. I'd really like Mario to do an informal review before I r+ this though. > > >> Source/WebKit2/UIProcess/API/gtk/WebKitFaviconDatabase.cpp:127 > >> + _("Unknown favicon for page %s"), pageURL.utf8().data()); > > > > When wrapping a line, only indent 4 spaces. [whitespace/indent] [3] > > I know that we have agreed in the past to line up the arguments, but it seems that the style bot now complains about this. We should follow the herd here. Sticking with what we agreed to before will just cause us pain, because the bot will never stop complaining. > > When does this error case happen? I'm a bit confused by the phrase "Unknown favicon for page..." > There are some cases where we don't know anything about the favicon, because the page hasn't been loaded or is being loaded and the icon hasn't been asked yet. Maybe we could rename it to unknown page, there might be a record in the database for he page, but not for the icon yet.
Carlos Garcia Campos
Comment 14 2012-10-03 04:44:41 PDT
Created attachment 166855 [details] Updated patch Addressed review comments, workaround style issues, and fix the unit tests. The problem as a special case that happens when you as for an icon when it's being loaded and the database initial import is ongoing, something that it's unlikely to happen in a real app, but always happens in unit tests because things are done too early and fast. In such case the icon-data-ready callback can be called before the favicon has been loaded. With this patch WebKitWebView now does the right thing, so instead of waiting for the icon-ready signal, we can wait for the notify::favicon signal os WebKitWebView that will be emitted when the favicon data is actually ready.
Carlos Garcia Campos
Comment 15 2012-10-03 06:06:26 PDT
Note You need to log in before you can comment on or make changes to this bug.