From 33a82cc8e8cd911d889da0f3e6a02b7bfde8dcae Mon Sep 17 00:00:00 2001 From: lilia Date: Thu, 18 May 2017 12:34:09 -0700 Subject: [PATCH] Add spellcheck smoke test Exposes the spellcheck provider as window.spellChecker, which allows it to be called from tests. --- preload.js | 24 ++++++++++++++---------- test/index.html | 1 + test/spellcheck_test.js | 10 ++++++++++ 3 files changed, 25 insertions(+), 10 deletions(-) create mode 100644 test/spellcheck_test.js diff --git a/preload.js b/preload.js index 91feecb34..8d9fde4c1 100644 --- a/preload.js +++ b/preload.js @@ -46,26 +46,30 @@ } resetSelection(); + window.spellChecker = new SpellCheckProvider(window.config.locale).on('misspelling', function(suggestions) { + // Prime the context menu with spelling suggestions _if_ the user has selected text. Electron + // may sometimes re-run the spell-check provider for an outdated selection e.g. if the user + // right-clicks some misspelled text and then an image. + if (window.getSelection().toString()) { + selection.isMisspelled = true; + // Take the first three suggestions if any. + selection.spellingSuggestions = suggestions.slice(0, 3); + } + }); + // Reset the selection when clicking around, before the spell-checker runs and the context menu shows. window.addEventListener('mousedown', resetSelection); // The spell-checker runs when the user clicks on text and before the 'contextmenu' event fires. // Thus, we may retrieve spell-checking suggestions to put in the menu just before it shows. + webFrame.setSpellCheckProvider( 'en-US', // Not sure what this parameter (`autoCorrectWord`) does: https://github.com/atom/electron/issues/4371 // The documentation for `webFrame.setSpellCheckProvider` passes `true` so we do too. true, - new SpellCheckProvider('en-US').on('misspelling', function(suggestions) { - // Prime the context menu with spelling suggestions _if_ the user has selected text. Electron - // may sometimes re-run the spell-check provider for an outdated selection e.g. if the user - // right-clicks some misspelled text and then an image. - if (window.getSelection().toString()) { - selection.isMisspelled = true; - // Take the first three suggestions if any. - selection.spellingSuggestions = suggestions.slice(0, 3); - } - })); + spellChecker + ); window.addEventListener('contextmenu', function(e) { // Only show the context menu in text editors. diff --git a/test/index.html b/test/index.html index 7cc4b65f9..346d37601 100644 --- a/test/index.html +++ b/test/index.html @@ -654,6 +654,7 @@ + diff --git a/test/spellcheck_test.js b/test/spellcheck_test.js new file mode 100644 index 000000000..3a52e4472 --- /dev/null +++ b/test/spellcheck_test.js @@ -0,0 +1,10 @@ +/* + * vim: ts=4:sw=4:expandtab + */ + +describe('spellChecker', function() { + it('should work', function() { + assert(window.spellChecker.spellCheck('correct')); + assert(!window.spellChecker.spellCheck('fhqwgads')); + }); +});