From 5708e86a054296fa8a24e4232083a664414ae0fa Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Thu, 8 Sep 2016 14:27:10 +0900 Subject: [PATCH] Fix API change of findInPage API --- atom/browser/api/atom_api_web_contents.cc | 18 ++++++---------- spec/webview-spec.js | 26 ++++++++++------------- 2 files changed, 17 insertions(+), 27 deletions(-) diff --git a/atom/browser/api/atom_api_web_contents.cc b/atom/browser/api/atom_api_web_contents.cc index 467131a6a9a7..816fc00b2625 100644 --- a/atom/browser/api/atom_api_web_contents.cc +++ b/atom/browser/api/atom_api_web_contents.cc @@ -532,18 +532,12 @@ void WebContents::FindReply(content::WebContents* web_contents, v8::HandleScope handle_scope(isolate()); mate::Dictionary result = mate::Dictionary::CreateEmpty(isolate()); - if (number_of_matches == -1) { - result.Set("requestId", request_id); - result.Set("selectionArea", selection_rect); - result.Set("finalUpdate", final_update); - result.Set("activeMatchOrdinal", active_match_ordinal); - Emit("found-in-page", result); - } else if (final_update) { - result.Set("requestId", request_id); - result.Set("matches", number_of_matches); - result.Set("finalUpdate", final_update); - Emit("found-in-page", result); - } + result.Set("requestId", request_id); + result.Set("matches", number_of_matches); + result.Set("finalUpdate", final_update); + result.Set("selectionArea", selection_rect); + result.Set("activeMatchOrdinal", active_match_ordinal); + Emit("found-in-page", result); } bool WebContents::CheckMediaAccessPermission( diff --git a/spec/webview-spec.js b/spec/webview-spec.js index 6b36c84fd645..01374baf806a 100644 --- a/spec/webview-spec.js +++ b/spec/webview-spec.js @@ -780,25 +780,21 @@ describe(' tag', function () { describe('found-in-page event', function () { it('emits when a request is made', function (done) { - var requestId = null - var totalMatches = null - var activeMatchOrdinal = [] - var listener = function (e) { + let requestId = null + let activeMatchOrdinal = [] + const listener = function (e) { assert.equal(e.result.requestId, requestId) - if (e.result.finalUpdate) { - assert.equal(e.result.matches, 3) - totalMatches = e.result.matches - listener2() + assert.equal(e.result.matches, 3) + activeMatchOrdinal.push(e.result.activeMatchOrdinal) + if (e.result.activeMatchOrdinal === e.result.matches) { + assert.deepEqual(activeMatchOrdinal, [1, 2, 3]) + webview.stopFindInPage('clearSelection') + done() } else { - activeMatchOrdinal.push(e.result.activeMatchOrdinal) - if (e.result.activeMatchOrdinal === totalMatches) { - assert.deepEqual(activeMatchOrdinal, [1, 2, 3]) - webview.stopFindInPage('clearSelection') - done() - } + listener2() } } - var listener2 = function () { + const listener2 = function () { requestId = webview.findInPage('virtual') } webview.addEventListener('found-in-page', listener)