diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/Makefile.am | 20 | ||||
-rw-r--r-- | test/smoke-tests/webview/first_page.html | 54 | ||||
-rw-r--r-- | test/tools/eos-run-test/sanitycheck.js | 3 | ||||
-rw-r--r-- | test/webhelper/smoke-tests/webview.js (renamed from test/smoke-tests/webview.js) | 63 | ||||
-rw-r--r-- | test/webhelper/testTranslate.js | 72 | ||||
-rw-r--r-- | test/webhelper/testWebActions.js | 140 |
6 files changed, 290 insertions, 62 deletions
diff --git a/test/Makefile.am b/test/Makefile.am index b4217c1..4124c52 100644 --- a/test/Makefile.am +++ b/test/Makefile.am @@ -24,3 +24,23 @@ test_run_tests_LDADD = $(TEST_LIBS) test_smoke_tests_hello_SOURCES = test/smoke-tests/hello.c test_smoke_tests_hello_CPPFLAGS = $(TEST_FLAGS) test_smoke_tests_hello_LDADD = $(TEST_LIBS) + +javascript_tests = \ + test/tools/eos-run-test/sanitycheck.js \ + test/webhelper/testTranslate.js \ + test/webhelper/testWebActions.js \ + $(NULL) +EXTRA_DIST += $(javascript_tests) + +# Run tests when running 'make check' +TESTS = \ + test/run-tests \ + $(javascript_tests) \ + $(NULL) +TEST_EXTENSIONS = .js +JS_LOG_COMPILER = tools/eos-run-test +AM_JS_LOG_FLAGS = \ + --include-path=$(top_srcdir)/webhelper \ + $(NULL) +LOG_COMPILER = gtester +AM_LOG_FLAGS = -k --verbose diff --git a/test/smoke-tests/webview/first_page.html b/test/smoke-tests/webview/first_page.html deleted file mode 100644 index 33a6a8f..0000000 --- a/test/smoke-tests/webview/first_page.html +++ /dev/null @@ -1,54 +0,0 @@ -<html> - -<head> -<title>First page</title> - -<style> -p, form { - width: 50%; - padding: 1em; - background: #FFFFFF; -} - -body { - background: #EEEEEE; -} -</style> -</head> - -<body> - -<h1>First page</h1> - -<p> -<a href="endless://moveToPage?name=page2">Move to page 2</a> -</p> - -<p> -<a href="endless://showMessageFromParameter?msg=This%20is%20a%20message%20from%20the%20URL%20parameter">Show message from parameter in this URL</a> -</p> - -<form action="endless://showMessageFromParameter"> -<input name="msg" value="I am in a form!"/> -<input type="submit" value="Show message using a form"/> -</form> - -<p> -<input id="inputformessage" value="my ID is inputformessage"/> -<a href="endless://showMessageFromInputField?id=inputformessage">Show message using the <input>'s ID</a> -</p> - -<p> -<a href="http://wikipedia.org">Regular link to a Web site</a> -</p> - -<p> -<a href="endless://addStars?id=starspan">I want stars!</a> <span id="starspan" /> -</p> - -<p> -This is text that will be translated: <span name="translatable">Hello, world!</span> -</p> - -</body> -</html>
\ No newline at end of file diff --git a/test/tools/eos-run-test/sanitycheck.js b/test/tools/eos-run-test/sanitycheck.js new file mode 100644 index 0000000..4bb3a80 --- /dev/null +++ b/test/tools/eos-run-test/sanitycheck.js @@ -0,0 +1,3 @@ +function testNothing() { + assertEquals(2, 2); +}
\ No newline at end of file diff --git a/test/smoke-tests/webview.js b/test/webhelper/smoke-tests/webview.js index 98226f3..fe2a655 100644 --- a/test/smoke-tests/webview.js +++ b/test/webhelper/smoke-tests/webview.js @@ -11,10 +11,61 @@ const WebHelper = imports.webhelper; const TEST_APPLICATION_ID = 'com.endlessm.example.test-webview'; +const TEST_HTML = '\ +<html> \ +<head> \ +<title>First page</title> \ +<style> \ +p, form { \ + width: 50%; \ + padding: 1em; \ + background: #FFFFFF; \ +} \ +body { \ + background: #EEEEEE; \ +} \ +</style> \ +</head> \ +\ +<body> \ +<h1>First page</h1> \ +\ +<p><a href="endless://moveToPage?name=page2">Move to page 2</a></p> \ +\ +<p><a \ +href="endless://showMessageFromParameter?msg=This%20is%20a%20message%20from%20the%20URL%20parameter">Show \ +message from parameter in this URL</a></p> \ +\ +<form action="endless://showMessageFromParameter"> \ +<input name="msg" value="I am in a form!"/> \ +<input type="submit" value="Show message using a form"/> \ +</form> \ +\ +<p> \ +<input id="inputformessage" value="my ID is inputformessage"/> \ +<a href="endless://showMessageFromInputField?id=inputformessage">Show message \ +using the <input>\'s ID</a> \ +</p> \ +\ +<p><a href="http://wikipedia.org">Regular link to a Web site</a></p> \ +\ +<p><a href="endless://addStars?id=starspan">I want \ +stars!</a> <span id="starspan"/></p> \ +\ +<p>This is text that will be italicized: <span name="translatable">Hello, \ +world!</span></p> \ +\ +</body> \ +</html>'; + const TestApplication = new Lang.Class({ Name: 'TestApplication', Extends: WebHelper.Application, + _translationFunction: function(string) { + return string.italics(); + }, + /* *** ACTIONS AVAILABLE FROM THE WEB VIEW *** */ _webActions: { @@ -64,21 +115,17 @@ const TestApplication = new Lang.Class({ this.parent(); this._webview = new WebKit.WebView(); - - let cwd = GLib.get_current_dir(); - let target = cwd + '/test/smoke-tests/webview/first_page.html'; - this._webview.load_uri(GLib.filename_to_uri(target, null)); - - this._webview.connect('notify::load-status', + this._webview.load_string(TEST_HTML, 'text/html', 'UTF-8', 'file://'); + this._webview.connect('notify::load-status', Lang.bind(this, function (web_view, status) { if (web_view.load_status == WebKit.LoadStatus.FINISHED) { // now we translate to Brazilian Portuguese - this._translateHTML (web_view, 'pt_BR'); + this.translate_html(web_view); } })); this._webview.connect('navigation-policy-decision-requested', - Lang.bind(this, this._onNavigationRequested)); + Lang.bind(this, this.web_actions_handler)); this._page1 = new Gtk.ScrolledWindow(); this._page1.add(this._webview); diff --git a/test/webhelper/testTranslate.js b/test/webhelper/testTranslate.js new file mode 100644 index 0000000..10e389c --- /dev/null +++ b/test/webhelper/testTranslate.js @@ -0,0 +1,72 @@ +const Endless = imports.gi.Endless; +const GLib = imports.gi.GLib; +const Gtk = imports.gi.Gtk; +const Lang = imports.lang; +const WebHelper = imports.webhelper; +const WebKit = imports.gi.WebKit; + +const TestClass = new Lang.Class({ + Name: 'testclass', + Extends: WebHelper.Application, + + vfunc_startup: function() { + this.parent(); + this.webview = new WebKit.WebView(); + let string = '<html><body><p name="translatable">Translate Me</p></body></html>'; + this.webview.load_string(string, 'text/html', 'UTF-8', 'file://'); + this.win = new Endless.Window({ + application: this + }); + this.scrolled = new Gtk.ScrolledWindow(); + this.scrolled.add(this.webview); + this.win.page_manager.add(this.scrolled); + + this.webview.connect('notify::load-status', Lang.bind(this, function() { + if(this.webview.load_status === WebKit.LoadStatus.FINISHED) { + this.translate_html(this.webview); + this.quit(); + } + })); + + // Add an upper bound on how long the app runs, in case app.quit() does + // not get called + GLib.timeout_add_seconds(GLib.PRIORITY_HIGH, 5, Lang.bind(this, function() { + this.quit(); + })); + } +}); + +let app; + +function setUp() { + // Generate a unique ID for each app instance that we test + let id_string = 'com.endlessm.webhelper.test' + GLib.get_real_time(); + app = new TestClass({ + application_id: id_string + }); +} + +function testStringIsTranslated() { + let translationFunctionWasCalled = false; + let translationFunctionCalledWithString; + app._translationFunction = function(s) { + translationFunctionWasCalled = true; + translationFunctionCalledWithString = s; + return s; + }; + app.run([]); + assertTrue(translationFunctionWasCalled); + assertEquals('Translate Me', translationFunctionCalledWithString); +} + +// The following two tests are commented out because GJS cannot catch exceptions +// across FFI interfaces (e.g. in GObject callbacks.) + +// function testMissingTranslationFunctionIsHandled() { +// assertRaises(app.run([])); +// } + +// function testBadTranslationFunctionIsHandled() { +// app._translationFunction = "I am not a function"; +// assertRaises(app.run([])); +// }
\ No newline at end of file diff --git a/test/webhelper/testWebActions.js b/test/webhelper/testWebActions.js new file mode 100644 index 0000000..585ab00 --- /dev/null +++ b/test/webhelper/testWebActions.js @@ -0,0 +1,140 @@ +const Endless = imports.gi.Endless; +const Gio = imports.gi.Gio; +const GLib = imports.gi.GLib; +const Gtk = imports.gi.Gtk; +const Lang = imports.lang; +const WebHelper = imports.webhelper; +const WebKit = imports.gi.WebKit; + +const TestClass = new Lang.Class({ + Name: 'testclass', + Extends: WebHelper.Application, + + vfunc_startup: function() { + this.parent(); + this.webview = new WebKit.WebView(); + this.webview.connect('navigation-policy-decision-requested', + Lang.bind(this, this.web_actions_handler)); + let string = ('<html><head><meta http-equiv="refresh" content="0;url=' + + this.webActionToTest + '"></head><body></body></html>'); + this.webview.load_string(string, 'text/html', 'UTF-8', 'file://'); + this.win = new Endless.Window({ + application: this + }); + this.scrolled = new Gtk.ScrolledWindow(); + this.scrolled.add(this.webview); + this.win.page_manager.add(this.scrolled); + + // Add an upper bound on how long the app runs, in case app.quit() does + // not get called + GLib.timeout_add_seconds(GLib.PRIORITY_HIGH, 5, Lang.bind(this, function() { + this.quit(); + })); + } +}); + +let app; + +function setUp() { + // Generate a unique ID for each app instance that we test + let id_string = 'com.endlessm.webhelper.test' + GLib.get_real_time(); + app = new TestClass({ + application_id: id_string + }); +} + +function testWebActionIsCalled() { + let actionWasCalled = false; + app._webActions = { + quitApplication: function() { + actionWasCalled = true; + app.quit(); + } + }; + app.webActionToTest = 'endless://quitApplication'; + app.run([]); + assertTrue(actionWasCalled); +} + +function testWebActionIsCalledWithParameter() { + let actionParameter; + app._webActions = { + getParameterAndQuit: function(dict) { + actionParameter = dict['param']; + app.quit(); + } + }; + app.webActionToTest = 'endless://getParameterAndQuit?param=value'; + app.run([]); + assertEquals('value', actionParameter); +} + +function testWebActionIsCalledWithManyParameters() { + let firstParameter, secondParameter, thirdParameter; + app._webActions = { + getParametersAndQuit: function(dict) { + firstParameter = dict['first']; + secondParameter = dict['second']; + thirdParameter = dict['third']; + app.quit(); + } + }; + app.webActionToTest = 'endless://getParametersAndQuit?first=thefirst&second=thesecond&third=thethird'; + app.run([]); + assertEquals('thefirst', firstParameter); + assertEquals('thesecond', secondParameter); + assertEquals('thethird', thirdParameter); +} + +function testParameterNameIsUriDecoded() { + let expectedParameter = 'päräm💩'; + let parameterWasFound = false; + app._webActions = { + getUriDecodedParameterAndQuit: function(dict) { + parameterWasFound = (expectedParameter in dict); + app.quit(); + } + }; + app.webActionToTest = 'endless://getUriDecodedParameterAndQuit?p%C3%A4r%C3%A4m%F0%9F%92%A9=value'; + app.run([]); + assertTrue(parameterWasFound); +} + +function testParameterValueIsUriDecoded() { + let expectedValue = 'válué💩'; + let actualValue; + app._webActions = { + getUriDecodedValueAndQuit: function(dict) { + actualValue = dict['param']; + app.quit(); + } + }; + app.webActionToTest = 'endless://getUriDecodedValueAndQuit?param=v%C3%A1lu%C3%A9%F0%9F%92%A9'; + app.run([]); + assertEquals(expectedValue, actualValue); +} + +// This is commented out because GJS cannot catch exceptions across FFI +// interfaces (e.g. in GObject callbacks.) +// function testBadActionIsNotCalled() { +// app.webActionToTest = 'endless://nonexistentAction?param=value'; +// assertRaises(function() { app.run([]); }); +// } + +function testWebActionIsCalledWithBlankParameter() { + let parameterWasFound = false; + let parameterValue; + app._webActions = { + getBlankValueAndQuit: function(dict) { + parameterWasFound = ('param' in dict); + if(parameterWasFound) + parameterValue = dict['param']; + app.quit(); + } + }; + app.webActionToTest = 'endless://getBlankValueAndQuit?param='; + app.run([]); + assertTrue(parameterWasFound); + assertNotUndefined(parameterValue); + assertEquals('', parameterValue); +} |