Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Bug 825148 - Make UI Tests and Test receivers app work with CSP

  • Loading branch information...
commit c57add9e52a789036667543945e13c8638a2812f 1 parent fbf48d6
@timdream timdream authored
Showing with 420 additions and 491 deletions.
  1. +0 −23 test_apps/test-receiver-1/js/share-receiver.js
  2. +0 −23 test_apps/test-receiver-2/js/share-receiver.js
  3. +4 −70 test_apps/test-receiver-inline/index.html
  4. +72 −0 test_apps/test-receiver-inline/js/inline-receiver.js
  5. +20 −20 test_apps/uitest/index.html
  6. +27 −0 test_apps/uitest/js/alert.js
  7. +21 −0 test_apps/uitest/js/audiotag.js
  8. +15 −0 test_apps/uitest/js/browseractivities.js
  9. +22 −0 test_apps/uitest/js/contextmenu.js
  10. +13 −0 test_apps/uitest/js/empty.js
  11. +15 −0 test_apps/uitest/js/fullscreen.js
  12. +14 −0 test_apps/uitest/js/geolocation.js
  13. +18 −0 test_apps/uitest/js/inlineactivities.js
  14. +7 −0 test_apps/uitest/js/multiactivities.js
  15. +62 −0 test_apps/uitest/js/notification.js
  16. +3 −0  test_apps/uitest/js/popup.js
  17. +13 −0 test_apps/uitest/js/savebookmark.js
  18. +6 −0 test_apps/uitest/js/scrollbar.js
  19. +16 −0 test_apps/uitest/js/select.js
  20. +7 −6 test_apps/uitest/tests/alert.html
  21. +7 −19 test_apps/uitest/tests/audiotag.html
  22. +5 −12 test_apps/uitest/tests/browseractivities.html
  23. +5 −11 test_apps/uitest/tests/contextmenu.html
  24. +17 −0 test_apps/uitest/tests/csp.html
  25. +1 −0  test_apps/uitest/tests/empty.html
  26. +3 −10 test_apps/uitest/tests/fullscreen.html
  27. +4 −19 test_apps/uitest/tests/geolocation.html
  28. +2 −22 test_apps/uitest/tests/inlineactivities.html
  29. +0 −2  test_apps/uitest/tests/inputmode.html
  30. +2 −8 test_apps/uitest/tests/multiactivities.html
  31. +7 −54 test_apps/uitest/tests/notification.html
  32. +0 −2  test_apps/uitest/tests/open.html
  33. +2 −12 test_apps/uitest/tests/popup.html
  34. +5 −100 test_apps/uitest/tests/recording.html
  35. +3 −15 test_apps/uitest/tests/savebookmark.html
  36. +1 −8 test_apps/uitest/tests/scrollbar.html
  37. +1 −21 test_apps/uitest/tests/select.html
  38. +0 −34 test_apps/uitest/tests/setcapture.html
View
23 test_apps/test-receiver-1/js/share-receiver.js
@@ -1,23 +0,0 @@
-window.onload = function() {
- navigator.mozSetMessageHandler('activity', function(activityRequest) {
- if (activityRequest.source.name === 'share-filenames') {
- addImages(activityRequest.source.data.filenames);
- }
- });
-};
-
-function addImages(filenames) {
- console.log('Receiving', filenames.length, 'files');
- var storage = navigator.getDeviceStorage('pictures');
- filenames.forEach(function(filename) {
- storage.get(filename).onsuccess = function(e) {
- var blob = e.target.result;
- var url = URL.createObjectURL(blob);
- var img = document.createElement('img');
- img.style.width = '100px';
- img.src = url;
- img.onload = function() { URL.revokeObjectURL(this.src); };
- document.body.appendChild(img);
- };
- });
-}
View
23 test_apps/test-receiver-2/js/share-receiver.js
@@ -1,23 +0,0 @@
-window.onload = function() {
- navigator.mozSetMessageHandler('activity', function(activityRequest) {
- if (activityRequest.source.name === 'share-filenames') {
- addImages(activityRequest.source.data.filenames);
- }
- });
-};
-
-function addImages(filenames) {
- console.log('Receiving', filenames.length, 'files');
- var storage = navigator.getDeviceStorage('pictures');
- filenames.forEach(function(filename) {
- storage.get(filename).onsuccess = function(e) {
- var blob = e.target.result;
- var url = URL.createObjectURL(blob);
- var img = document.createElement('img');
- img.style.width = '100px';
- img.src = url;
- img.onload = function() { URL.revokeObjectURL(this.src); };
- document.body.appendChild(img);
- };
- });
-}
View
74 test_apps/test-receiver-inline/index.html
@@ -4,6 +4,7 @@
<meta charset="utf-8">
<meta http-equiv="pragma" content="no-cache">
<title>Test Receiver</title>
+ <script src="js/inline-receiver.js" defer></script>
<style>
button {
font-size: 30px;
@@ -17,80 +18,13 @@
background-color: #e0e0e0;
}
</style>
- <script>
- var activityRequest;
-
- var webActivityHandler = function (request) {
- activityRequest = request;
-
- document.getElementById('button').disabled = '';
- document.getElementById('cancelButton').disabled = '';
- document.getElementById('number').focus();
-
- };
-
- window.onload = function () {
- // If the app is being loaded because a inline disposition web activity,
- // it will came with a pending system message.
- if (!navigator.mozHasPendingMessage('activity')) {
- alert('This application is not intend to launch directly.');
- } else {
- // Register for activity system message handling.
- // Do NOT register for message handling on the main app frame.
- navigator.mozSetMessageHandler('activity', webActivityHandler);
- }
- };
-
- var go = function go() {
- if (!activityRequest) {
- alert('There are no any pending activity request.');
- return;
- }
-
- // Return the request
- activityRequest.postResult({
- type: 'inline',
- text: 'Hello back!'
- });
- activityRequest = null;
-
- // close app, currently useless,
- // see https://bugzilla.mozilla.org/show_bug.cgi?id=789392
- window.close();
- };
-
- var cancel = function cancel() {
- if (!activityRequest) {
- alert('There are no any pending activity request.');
- return;
- }
-
- activityRequest.postError('canceled');
- activityRequest = null;
-
- // close app, currently useless,
- // see https://bugzilla.mozilla.org/show_bug.cgi?id=789392
- window.close();
- };
-
- // When the app is being closed or killed, we will cancel the pending
- // request.
- document.addEventListener('mozvisibilitychange', function visibility(e) {
- if (!document.mozHidden || !activityRequest)
- return;
-
- activityRequest.postError('canceled');
- activityRequest = null;
- });
-
- </script>
</head>
<body>
<h1>Inline Web Activities receiver</h1>
- <p><button onclick="go()" disabled id="button">Send "Hello Back!"</button></p>
+ <p><button disabled id="button">Send "Hello Back!"</button></p>
<!-- add an input field to test keyboard work well -->
<p><input type="number" id="number" size="4" /></p>
- <p><button onclick="cancel()" disabled id="cancelButton">Cancel</button></p>
- <p><button onclick="prompt('inline-activty prompt!');">Prompt</button></p>
+ <p><button disabled id="cancelButton">Cancel</button></p>
+ <p><button id="promptButton">Prompt</button></p>
</body>
</html>
View
72 test_apps/test-receiver-inline/js/inline-receiver.js
@@ -0,0 +1,72 @@
+var activityRequest;
+
+var webActivityHandler = function (request) {
+ activityRequest = request;
+
+ document.getElementById('button').disabled = '';
+ document.getElementById('cancelButton').disabled = '';
+ document.getElementById('number').focus();
+
+};
+
+window.onload = function () {
+ document.getElementById('button').onclick = go;
+ document.getElementById('cancelButton').onclick = cancel;
+ document.getElementById('promptButton').onclick = promptButton;
+
+ // If the app is being loaded because a inline disposition web activity,
+ // it will came with a pending system message.
+ if (!navigator.mozHasPendingMessage('activity')) {
+ alert('This application is not intend to launch directly.');
+ } else {
+ // Register for activity system message handling.
+ // Do NOT register for message handling on the main app frame.
+ navigator.mozSetMessageHandler('activity', webActivityHandler);
+ }
+};
+
+var go = function go() {
+ if (!activityRequest) {
+ alert('There are no any pending activity request.');
+ return;
+ }
+
+ // Return the request
+ activityRequest.postResult({
+ type: 'inline',
+ text: 'Hello back!'
+ });
+ activityRequest = null;
+
+ // close app, currently useless,
+ // see https://bugzilla.mozilla.org/show_bug.cgi?id=789392
+ window.close();
+};
+
+var cancel = function cancel() {
+ if (!activityRequest) {
+ alert('There are no any pending activity request.');
+ return;
+ }
+
+ activityRequest.postError('canceled');
+ activityRequest = null;
+
+ // close app, currently useless,
+ // see https://bugzilla.mozilla.org/show_bug.cgi?id=789392
+ window.close();
+};
+
+var promptButton = function promptButton() {
+ prompt('inline-activty prompt!');
+};
+
+// When the app is being closed or killed, we will cancel the pending
+// request.
+document.addEventListener('mozvisibilitychange', function visibility(e) {
+ if (!document.mozHidden || !activityRequest)
+ return;
+
+ activityRequest.postError('canceled');
+ activityRequest = null;
+});
View
40 test_apps/uitest/index.html
@@ -13,21 +13,20 @@
<p class="toolbar-title">UI Tests</p>
</div>
<ul class="list" id="test-list">
- <li><a href="#test=empty">Empty test</a></li>
- <li><a href="#test=keyboard">Keyboard test</a></li>
- <li><a href="#test=geolocation">Geolocation test</a></li>
- <li><a href="#test=contextmenu">Contextmenu test</a></li>
- <li><a href="#test=recording">Recording test</a></li>
- <li><a href="#test=select">Select test</a></li>
- <li><a href="#test=contacts">Contacts tests</a></li>
- <li><a href="#test=alert">Alert/Prompt tests</a></li>
- <li><a href="#test=open">window.open tests</a></li>
- <li><a href="#test=notification">mozNotification tests</a></li>
- <li><a href="#test=scrollbar">Scroll bar tests</a></li>
- <li><a href="#test=setcapture">setCapture test</a></li>
- <li><a href="#test=inlineactivities">Inline Activities test</a></li>
- <li><a href="#test=multiactivities">Multi Activities test</a></li>
- <li><a href="#test=browseractivities">Browser Web Activities test</a></li>
+ <li><a href="#test=empty">Empty</a></li>
+ <li><a href="#test=keyboard">Keyboard</a></li>
+ <li><a href="#test=geolocation">Geolocation</a></li>
+ <li><a href="#test=contextmenu">Contextmenu</a></li>
+ <li><a href="#test=recording">Recording</a></li>
+ <li><a href="#test=select">Select</a></li>
+ <li><a href="#test=contacts">Contacts</a></li>
+ <li><a href="#test=alert">Alert/Prompt</a></li>
+ <li><a href="#test=open">window.open</a></li>
+ <li><a href="#test=notification">mozNotification</a></li>
+ <li><a href="#test=scrollbar">Scroll bar</a></li>
+ <li><a href="#test=inlineactivities">Inline Activities</a></li>
+ <li><a href="#test=multiactivities">Multi Activities</a></li>
+ <li><a href="#test=browseractivities">Browser Activities</a></li>
<li><a href="#test=savebookmark">Save bookmark</a></li>
<li><a href="#test=fullscreen">mozRequestFullScreen</a></li>
<li><a href="#test=httpauthentication">HTTP Authentication</a></li>
@@ -35,13 +34,14 @@
<li><a href="#test=viewphoto">View Photo</a></li>
<li><a href="#test=openvideo">Open Video</a></li>
<li><a href="#test=openaudio">Open Audio</a></li>
- <li><a href="#test=pay">navigator.mozPay tests</a></li>
- <li><a href="#test=inputmode">text inputmode tests</a></li>
- <li><a href="#test=audiotag">audio tag tests</a></li>
- <li><a href="#test=identity">navigator.mozId tests</a></li>
+ <li><a href="#test=pay">navigator.mozPay</a></li>
+ <li><a href="#test=inputmode">text inputmode</a></li>
+ <li><a href="#test=audiotag">audio tag</a></li>
+ <li><a href="#test=identity">navigator.mozId</a></li>
<li><a href="#test=identity-get">navigator.mozId.get</a></li>
<li><a href="#test=fullscreen_controls">Fullscreen Controls</a></li>
- <li><a href="#test=canvas">Canvas Tag test</a></li>
+ <li><a href="#test=canvas">Canvas Tag</a></li>
+ <li><a href="#test=csp">CSP Warning</a></li>
</ul>
</div>
<div id="test-panel" class="panel">
View
27 test_apps/uitest/js/alert.js
@@ -0,0 +1,27 @@
+'use strict';
+
+var clickHandlers = {
+ 'button1': function () {
+ window.parent.alert('Hello world!');
+ },
+ 'button2': function () {
+ window.parent.alert(window.parent.confirm('Hello world?'));
+ },
+ 'button3': function () {
+ window.parent.alert(window.parent.prompt('Hello world:', 'initial value'));
+ },
+ 'button21': function () {
+ alert('Hello world!');
+ },
+ 'button22': function () {
+ alert(confirm('Hello world?'));
+ },
+ 'button23': function () {
+ alert(prompt('Hello world:', 'initial value'));
+ }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id])
+ clickHandlers[evt.target.id].call(this, evt);
+});
View
21 test_apps/uitest/js/audiotag.js
@@ -0,0 +1,21 @@
+'use strict';
+
+var clickHandlers = {
+ 'play': function play() {
+ var src = this.dataset.src;
+
+ var ringtonePlayer = new Audio();
+ ringtonePlayer.loop = true;
+ var selectedSound = '../style/ringtones/' + src;
+ ringtonePlayer.src = selectedSound;
+ ringtonePlayer.play();
+ window.setTimeout(function _pauseRingtone() {
+ ringtonePlayer.pause();
+ }, 20000);
+ }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
View
15 test_apps/uitest/js/browseractivities.js
@@ -0,0 +1,15 @@
+'use strict';
+
+var clickHandlers = {
+ 'go': function _go() {
+ var URL = document.getElementById('URL').value;
+ var a = new MozActivity({ name: 'view', data: {type: 'url', url: URL }});
+ a.onsuccess = function() { alert('Success!'); };
+ a.onerror = function() { alert('Failure going to URL'); };
+ }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
View
22 test_apps/uitest/js/contextmenu.js
@@ -0,0 +1,22 @@
+'use strict';
+
+var clickHandlers = {
+ 'reload': function () {
+ window.location.reload();
+ },
+ 'comments': function () {
+ window.location='#comments';
+ alert(window.location.href);
+ },
+ 'twitter': function () {
+ window.open('http://twitter.com/intent/tweet?text=' + document.title + ': ' + window.location.href, "shareWindow");
+ },
+ 'facebook': function () {
+ window.open('http://facebook.com/sharer/sharer.php?u=' + window.location.href, "shareWindow");
+ }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
View
13 test_apps/uitest/js/empty.js
@@ -0,0 +1,13 @@
+'use strict';
+
+var clickHandlers = {
+/*
+ 'id': function () {
+ alert('event triggered!');
+ }, */
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
View
15 test_apps/uitest/js/fullscreen.js
@@ -0,0 +1,15 @@
+'use strict';
+
+var clickHandlers = {
+ 'fullscreen': function fullscreen() {
+ document.getElementById('fullscreen-div').mozRequestFullScreen();
+ },
+ 'fullscreenFrame': function fullscreenFrame() {
+ window.parent.document.getElementById('test-iframe').mozRequestFullScreen();
+ }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
View
14 test_apps/uitest/js/geolocation.js
@@ -0,0 +1,14 @@
+function Location(position)//location function is defining with parameter
+{
+ var latitude = position.coords.latitude; //Specifies the longitude estimate in decimal degrees. The value range is [-180.00, +180.00].
+ var longitude = position.coords.longitude;
+ document.getElementById("lati").innerHTML = latitude; //latitude value is defining in label element where id is lati
+ document.getElementById("longi").innerHTML = longitude;
+}
+
+document.getElementById("submit").addEventListener('click', function findLocation() {
+ if (navigator.geolocation)//checking browser compatibility
+ {
+ navigator.geolocation.getCurrentPosition(Location);//getCurrentPosition method retrieve the current geographic location of the user
+ }
+});
View
18 test_apps/uitest/js/inlineactivities.js
@@ -0,0 +1,18 @@
+document.getElementById('go').onclick = function _go() {
+ var a = new MozActivity(
+ {
+ name: 'test',
+ data: {
+ type: 'inline'
+ }
+ }
+ );
+
+ a.onsuccess = function () {
+ document.getElementById('result').textContent = this.result.text;
+ };
+
+ a.onerror = function() {
+ document.getElementById('result').textContent = '(canceled)';
+ };
+};
View
7 test_apps/uitest/js/multiactivities.js
@@ -0,0 +1,7 @@
+document.getElementById('go').onclick = function _go() {
+ var go = function _go() {
+ var a = new MozActivity({ name: 'test', data: {type: 'text'}});
+ a.onsuccess = function() { alert('Success!'); };
+ a.onerror = function() { alert('Failure.'); };
+ };
+};
View
62 test_apps/uitest/js/notification.js
@@ -0,0 +1,62 @@
+var imageData = '';
+
+function noti(win) {
+ var mozNotification;
+ if (!win) {
+ mozNotification = window.navigator.mozNotification;
+ } else {
+ mozNotification = win.navigator.mozNotification;
+ }
+
+ var notification = mozNotification.createNotification('UI Tests mozNotification',
+ 'Hello world!',
+ imageData);
+ notification.show();
+ notification.onclick = function () {
+ window.parent.alert('Notification clicked');
+ };
+ notification.onclose = function () {
+ window.parent.alert('Notification closed');
+ };
+}
+
+function parentFrameNoti() {
+ noti(window.parent);
+}
+
+function noti5() {
+ noti();
+ noti();
+ noti();
+ noti();
+ noti();
+}
+
+function parentFrameNoti5() {
+ noti(window.parent);
+ noti(window.parent);
+ noti(window.parent);
+ noti(window.parent);
+ noti(window.parent);
+}
+
+function delay(callback) {
+ window.parent.alert('Start');
+ setTimeout(callback, 10000);
+}
+
+var clickHandlers = {
+ 'button1': parentFrameNoti,
+ 'button2': function () { delay(parentFrameNoti) },
+ 'button3': function () { delay(parentFrameNoti5) },
+
+ 'button4': noti,
+ 'button5': function () { delay(noti) },
+ 'button6': function () { delay(noti5) }
+};
+
+document.body.addEventListener('click', function (evt) {
+ if (clickHandlers[evt.target.id || evt.target.dataset.fn])
+ clickHandlers[evt.target.id || evt.target.dataset.fn].call(this, evt);
+});
+
View
3  test_apps/uitest/js/popup.js
@@ -0,0 +1,3 @@
+document.getElementById('close').onclick = function () {
+ window.close();
+};
View
13 test_apps/uitest/js/savebookmark.js
@@ -0,0 +1,13 @@
+function save() {
+ new MozActivity({
+ name: 'save-bookmark',
+ data: {
+ type: 'url',
+ url: 'http://www.google.com/',
+ name: 'Google',
+ icon: ''
+ }
+ });
+}
+
+document.getElementById('save').onclick = save;
View
6 test_apps/uitest/js/scrollbar.js
@@ -0,0 +1,6 @@
+window.onload = function () {
+ var p = document.getElementById('probe');
+ document.getElementById('report').textContent =
+ 'Scroll bar width calculated from Javascript: ' +
+ (p.offsetWidth - p.scrollWidth - 2) + 'px' // 2 = border width * 2
+};
View
16 test_apps/uitest/js/select.js
@@ -0,0 +1,16 @@
+function changeTest(evt) {
+ console.log('++select++ onchange: ' + this.selectedIndex);
+}
+
+function blurTest(evt) {
+ console.log('++select++ onblur: ' + this.id);
+}
+
+window.onload = function onload() {
+ var elementList = ['singleSel', 'multiSel', 'sizeSel'];
+ elementList.forEach(function(elementId) {
+ console.log('elementId: ' + elementId);
+ document.getElementById(elementId).onchange = changeTest;
+ document.getElementById(elementId).addEventListener('blur', blurTest);
+ });
+}
View
13 test_apps/uitest/tests/alert.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>Alert/prompt test</title>
+ <script defer src="../js/alert.js"></script>
<style>
button {
font-size: 40px;
@@ -13,14 +14,14 @@
<h1>Alert/Prompt/Confirm</h1>
<h2>Call on mozbrowser frame:</h2>
- <p><button onclick="window.parent.alert('Hello world!')">Alert</button></p>
- <p><button onclick="window.parent.alert(window.parent.confirm('Hello world?'))">Confirm</button></p>
- <p><button onclick="window.parent.alert(window.parent.prompt('Hello world:', 'initial value'))">Prompt</button></p>
+ <p><button id="button1">Alert</button></p>
+ <p><button id="button2">Confirm</button></p>
+ <p><button id="button3">Prompt</button></p>
<h2>Call on this iframe within mozbrowser:</h2>
- <p><button onclick="alert('Hello world!')">Alert</button></p>
- <p><button onclick="alert(confirm('Hello world?'))">Confirm</button></p>
- <p><button onclick="alert(prompt('Hello world:', 'initial value'))">Prompt</button></p>
+ <p><button id="button21">Alert</button></p>
+ <p><button id="button22">Confirm</button></p>
+ <p><button id="button23">Prompt</button></p>
<p>Press back button to go back.</p>
</body>
View
26 test_apps/uitest/tests/audiotag.html
@@ -3,38 +3,26 @@
<head>
<meta charset="utf-8">
<title>Audio Tag test</title>
+ <script defer src="../js/audiotag.js"></script>
<style>
button {
font-size: 40px;
}
</style>
- <script>
- var play = function _play(src) {
- var ringtonePlayer = new Audio();
- ringtonePlayer.loop = true;
- var selectedSound = '../style/ringtones/' + src;
- ringtonePlayer.src = selectedSound;
- ringtonePlayer.play();
- window.setTimeout(function _pauseRingtone() {
- ringtonePlayer.pause();
- }, 20000);
- }
-
- </script>
</head>
<body>
<h1>Audio Tag Test</h1>
<h2>classic.ogg</h2>
- <button onclick="play('classic.ogg')">Play</button></p>
+ <button data-fn="play" data-src"classic.ogg">Play</button></p>
<h2>AC_prgrssv__Retro_Alarm_Clock_v02_SOFT.ogg</h2>
- <button onclick="play('AC_prgrssv__Retro_Alarm_Clock_v02_SOFT.ogg')">Play</button></p>
+ <button data-fn="play" data-src="AC_prgrssv__Retro_Alarm_Clock_v02_SOFT.ogg">Play</button></p>
<h2>AC_progressive_dapple10.ogg</h2>
- <button onclick="play('AC_progressive_dapple10.ogg')">Play</button></p>
+ <button data-fn="play" data-src="AC_progressive_dapple10.ogg">Play</button></p>
<h2>AC_progressive_shimmer07.ogg</h2>
- <button onclick="play('AC_progressive_shimmer07.ogg')">Play</button></p>
+ <button data-fn="play" data-src="AC_progressive_shimmer07.ogg">Play</button></p>
<h2>ALARM_progressive_dapple.mp3</h2>
- <button onclick="play('ALARM_progressive_dapple.mp3')">Play</button></p>
+ <button data-fn="play" data-src="ALARM_progressive_dapple.mp3">Play</button></p>
<h2>ALARM_progressive2_dapple.mp3</h2>
- <button onclick="play('ALARM_progressive2_dapple.mp3')">Play</button></p>
+ <button data-fn="play" data-src="ALARM_progressive2_dapple.mp3">Play</button></p>
</body>
</html>
View
17 test_apps/uitest/tests/browseractivities.html
@@ -2,26 +2,19 @@
<html>
<head>
<meta charset="utf-8">
- <title>Alert/prompt test</title>
+ <title>Browser Web Activities Test</title>
+ <script defer src="../js/browseractivities.js"></script>
<style>
- button {
+ button, input {
font-size: 40px;
}
</style>
- <script>
- var go = function _go() {
- var URL = document.getElementById('URL').value;
- var a = new MozActivity({ name: 'view', data: {type: 'url', url: URL }});
- a.onsuccess = function() { alert('Success!'); };
- a.onerror = function() { alert('Failure going to URL'); };
- };
- </script>
</head>
<body>
<h1>Browser Web Activities Test</h1>
<h2>Go to:</h2>
- <p>URL: <input type="text" id="URL" />
- <button onclick="go()">Go</button></p>
+ <p>URL: <input type="url" id="URL" value="http://" />
+ <button id="go">Go</button></p>
<p>Press back button to go back.</p>
</body>
</html>
View
16 test_apps/uitest/tests/contextmenu.html
@@ -3,27 +3,21 @@
<head>
<meta charset="utf-8">
<title>New fonts test</title>
+ <script defer src="../js/contextmenu.js"></script>
<style>
</style>
- <script type="text/javascript">
-
- </script>
</head>
<body>
<h1>Context menu test</h1>
<section style="background: #eee; border: 1px solid #ccc; padding: 10px;" contextmenu="mymenu">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse et ipsum in nisl euismod venenatis eget sit amet lectus. Nam magna massa, mollis a fringilla eu, lobortis at metus. Maecenas et mi est. Donec arcu nunc, scelerisque id dapibus non, commodo et diam. Suspendisse et nisl vel dui tempus semper. Aenean placerat lectus et lectus iaculis posuere. Pellentesque scelerisque, nisi vel ornare adipiscing, massa tellus sodales nulla, quis porttitor purus lorem nec elit. Curabitur aliquam turpis non erat volutpat gravida. Pellentesque in neque odio, a placerat tellus. Proin a quam magna, at vestibulum sem. Integer a ipsum sapien, quis tempor est. Duis quis varius lectus.</p>
- <!-- actions -->
- <script>
- function goTo(url) { window.open(url, "shareWindow"); }
- </script>
<!-- create the menu -->
<menu type="context" id="mymenu">
- <menuitem label="Refresh Post" onclick="window.location.reload();" icon="http://davidwalsh.name/dw-content/refresh-icon.png"></menuitem>
- <menuitem label="Skip to Comments" onclick="window.location='#comments';" icon="http://davidwalsh.name/dw-content/comment_icon.gif"></menuitem>
+ <menuitem label="Refresh Post" id="reload" icon="http://davidwalsh.name/dw-content/refresh-icon.png"></menuitem>
+ <menuitem label="Skip to Comments" id="comments" icon="http://davidwalsh.name/dw-content/comment_icon.gif"></menuitem>
<menu label="Share on..." icon="http://davidwalsh.name/dw-content/share_icon.gif">
- <menuitem label="Twitter" icon="http://davidwalsh.name/dw-content/twitter_icon.gif" onclick="goTo('//twitter.com/intent/tweet?text=' + document.title + ': ' + window.location.href);"></menuitem>
- <menuitem label="Facebook" icon="http://davidwalsh.name/dw-content/facebook_icon16x16.gif" onclick="goTo('//facebook.com/sharer/sharer.php?u=' + window.location.href);"></menuitem>
+ <menuitem label="Twitter" icon="http://davidwalsh.name/dw-content/twitter_icon.gif" id="twitter"></menuitem>
+ <menuitem label="Facebook" icon="http://davidwalsh.name/dw-content/facebook_icon16x16.gif" id="facebook"></menuitem>
</menu>
</menu>
</section>
View
17 test_apps/uitest/tests/csp.html
@@ -0,0 +1,17 @@
+<!DOCTYPE html>
+<html>
+ <head>
+ <meta charset="utf-8">
+ <title>CSP Warning</title>
+ </head>
+ <body>
+ <h1>CSP Warning test</h1>
+ <p id="text">This line should not be removed by Javascript.</p>
+ <script>
+ window.onload = function () {
+ document.getElementById('text').textContent =
+ 'Error! CSP violation is executed!';
+ };
+ </script>
+ </body>
+</html>
View
1  test_apps/uitest/tests/empty.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>Empty test</title>
+ <script defer src="../js/empty.js"></script>
</head>
<body>
<h1>Hello world!</h1>
View
13 test_apps/uitest/tests/fullscreen.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>mozRequestFullScreen test</title>
+ <script defer src="../js/fullscreen.js"></script>
<style>
button {
font-size: 40px;
@@ -12,14 +13,6 @@
background-color: #ccf;
}
</style>
- <script>
- function fullscreen() {
- document.getElementById('fullscreen-div').mozRequestFullScreen();
- }
- function fullscreenFrame() {
- window.parent.document.getElementById('test-iframe').mozRequestFullScreen();
- }
- </script>
</head>
<body>
<h1>mozRequestFullScreen test</h1>
@@ -30,9 +23,9 @@
<div id="fullscreen-div">
<p>Am I full screen?</p>
</div>
- <p><button onclick="fullscreen()">Test</button></p>
+ <p><button id="fullscreen">Test</button></p>
<h2>Test on this iframe, an element within the mozbrowser</h2>
- <p><button onclick="fullscreenFrame()">Test</button></p>
+ <p><button id="fullscreenFrame">Test</button></p>
</body>
</html>
View
23 test_apps/uitest/tests/geolocation.html
@@ -3,31 +3,16 @@
<head>
<meta charset="utf-8">
<title>Geolocation test</title>
+ <script defer src="../js/geolocation.js"></script>
<style>
- button, select {
- font-size: 25px;
+ button, select, input {
+ font-size: 50px;
}
</style>
- <script type="text/javascript">
- function Location(position)//location function is defining with parameter
- {
- var latitude = position.coords.latitude; //Specifies the longitude estimate in decimal degrees. The value range is [-180.00, +180.00].
- var longitude = position.coords.longitude;
- document.getElementById("lati").innerHTML = latitude; //latitude value is defining in label element where id is lati
- document.getElementById("longi").innerHTML = longitude;
- }
- function findLocation()
- {
- if (navigator.geolocation)//checking browser compatibility
- {
- navigator.geolocation.getCurrentPosition(Location);//getCurrentPosition method retrieve the current geographic location of the user
- }
- }
- </script>
</head>
<body>
Latitude:<label id="lati"></label><br /><br />
Longitude:<label id="longi"></label><br /><br />
- <input type="submit" onclick="findLocation();" value="Find Location" />
+ <input type="button" id="submit" value="Find Location" />
</body>
</html>
View
24 test_apps/uitest/tests/inlineactivities.html
@@ -3,37 +3,17 @@
<head>
<meta charset="utf-8">
<title>Inline Activities Test</title>
+ <script defer src="../js/inlineactivities.js"></script>
<style>
button {
font-size: 40px;
}
</style>
- <script>
-
- var go = function _go() {
- var a = new MozActivity(
- {
- name: 'test',
- data: {
- type: 'inline'
- }
- }
- );
-
- a.onsuccess = function () {
- document.getElementById('result').textContent = this.result.text;
- };
-
- a.onerror = function() {
- document.getElementById('result').textContent = '(canceled)';
- };
- };
- </script>
</head>
<body>
<h1>Inline Activities Test</h1>
- <p><button onclick="go()">Go Test</button></p>
+ <p><button id="go">Go Test</button></p>
<p><strong>Received: </strong><span id="result"></span></p>
</body>
</html>
View
2  test_apps/uitest/tests/inputmode.html
@@ -8,8 +8,6 @@
input { width: 150px; }
textarea { width: 150px; height: 30px; }
</style>
- <script>
- </script>
</head>
<body>
View
10 test_apps/uitest/tests/multiactivities.html
@@ -3,22 +3,16 @@
<head>
<meta charset="utf-8">
<title>Multi Activities test</title>
+ <script defer src="../js/multiactivities.js"></script>
<style>
button {
font-size: 40px;
}
</style>
- <script>
- var go = function _go() {
- var a = new MozActivity({ name: 'test', data: {type: 'text'}});
- a.onsuccess = function() { alert('Success!'); };
- a.onerror = function() { alert('Failure going to URL'); };
- };
- </script>
</head>
<body>
<h1>Multi Activities Test</h1>
- <button onclick="go()">Go Test</button></p>
+ <button id="go">Go Test</button></p>
<p>Press back button to go back.</p>
</body>
</html>
View
61 test_apps/uitest/tests/notification.html
@@ -3,72 +3,25 @@
<head>
<meta charset="utf-8">
<title>mozNotification test</title>
+ <script defer src="../js/notification.js"></script>
<style>
button {
font-size: 40px;
}
</style>
- <script>
- var imageData = '';
-
- function noti(win) {
- var mozNotification;
- if (!win) {
- mozNotification = window.navigator.mozNotification;
- } else {
- mozNotification = win.navigator.mozNotification;
- }
-
- var notification = mozNotification.createNotification('UI Tests mozNotification',
- 'Hello world!',
- imageData);
- notification.show();
- notification.onclick = function () {
- window.parent.alert('Notification clicked');
- };
- notification.onclose = function () {
- window.parent.alert('Notification closed');
- };
- }
-
- function parentFrameNoti() {
- noti(window.parent);
- }
-
- function noti5() {
- noti();
- noti();
- noti();
- noti();
- noti();
- }
-
- function parentFrameNoti5() {
- noti(window.parent);
- noti(window.parent);
- noti(window.parent);
- noti(window.parent);
- noti(window.parent);
- }
-
- function delay(callback) {
- window.parent.alert('Start');
- setTimeout(callback, 10000);
- }
- </script>
</head>
<body>
<h1>mozNotification</h1>
<h2>Call on mozbrowser frame:</h2>
- <p><button onclick="parentFrameNoti()">Notification</button></p>
- <p><button onclick="delay(parentFrameNoti)">Notification (10 sec delay)</button></p>
- <p><button onclick="delay(parentFrameNoti5)">5 Notifications (10 sec delay)</button></p>
+ <p><button id="button1">Notification</button></p>
+ <p><button id="button2">Notification (10 sec delay)</button></p>
+ <p><button id="button3">5 Notifications (10 sec delay)</button></p>
<h2>Call on this iframe within mozbrowser:</h2>
- <p><button onclick="noti()">Notification</button></p>
- <p><button onclick="delay(noti)">Notification (10 sec delay)</button></p>
- <p><button onclick="delay(noti5)">5 Notifications (10 sec delay)</button></p>
+ <p><button id="button4">Notification</button></p>
+ <p><button id="button5">Notification (10 sec delay)</button></p>
+ <p><button id="button6">5 Notifications (10 sec delay)</button></p>
<p>Press back button to go back.</p>
</body>
View
2  test_apps/uitest/tests/open.html
@@ -21,13 +21,11 @@
<h2>Call on mozbrowser frame:</h2>
<p><button class="mozbrowser" data-action="open" data-url="./popup.html">window.open</button></p>
<p><button class="mozbrowser" data-action="open" data-url="./popup.html#attention">window.open(url, name, 'attention')</button></p>
- <p><button class="mozbrowser" data-action="open" data-url="./popup.html#background">window.open(url, name, 'background')</button></p>
<p><button class="mozbrowser" data-action="close" >window.close()</button></p>
<h2>Call on this iframe within mozbrowser:</h2>
<p><button data-action="open" data-url="./popup.html">window.open</button></p>
<p><button data-action="open" data-url="./popup.html#attention">window.open(url, name, 'attention')</button></p>
- <p><button data-action="open" data-url="./popup.html#background">window.open(url, name, 'background')</button></p>
<p><button data-action="open" data-url="https://google.com">Open External URL</button></p>
View
14 test_apps/uitest/tests/popup.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>Popup</title>
+ <script defer src="../js/popup.js"></script>
<style>
body {
background-color: #fff;
@@ -11,22 +12,11 @@
font-size: 40px;
}
</style>
- <script>
- if (window.location.hash == '#background') {
- setTimeout(function hello() {
- alert('Hello World from Background Popup!');
- setTimeout(function self_close() {
- alert('Background Popup is closing!');
- window.close();
- }, 5*1E3);
- }, 2000);
- }
- </script>
</head>
<body>
<h1>Hello world!</h1>
<p>I am a popup created from window.open.</p>
<input type="text" value="focus me!" />
- <p><button onclick="window.close()">Close</button></p>
+ <p><button id="close">Close</button></p>
</body>
</html>
View
105 test_apps/uitest/tests/recording.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>Recording test</title>
+ <script defer src="../js/recording.js"></script>
<style>
#main {
display: block;
@@ -47,113 +48,17 @@
<body>
<div id="main">
<div id="startbuttons">
- <input type="button" value="Video" onClick="startVideo();"/>
- <input type="button" value="Audio" onClick="startAudio();"/>
- <input type="button" value="Picture" onClick="startPicture();"/>
+ <input type="button" value="Video" id="startVideo"/>
+ <input type="button" value="Audio" id="startAudio"/>
+ <input type="button" value="Picture" id="startPicture"/>
</div>
<div id="content"></div>
<div id="message"></div>
<div id="stopbuttons">
- <input type="button" value="Stop" onClick="stopMedia();"/>
+ <input type="button" value="Stop" id="stopMedia"/>
</div>
</div>
</body>
-
- <script type="application/javascript">
- var videoStatus = false;
- var video = document.createElement("video");
- video.setAttribute("width", 800);
- video.setAttribute("height", 600);
-
- var audioStatus = false;
- var audio = document.createElement("audio");
- audio.setAttribute("controls", true);
-
- var pictureStatus = false;
- var picture = document.createElement("img");
-
- var start = document.getElementById("startbuttons");
- var stop = document.getElementById("stopbuttons");
-
- var message = document.getElementById("message");
- var content = document.getElementById("content");
-
- var reader = new FileReader();
-
- function startVideo() {
- videoStatus = true;
- content.appendChild(video);
- startMedia({video:true});
- }
-
- function startAudio() {
- audioStatus = true;
- content.appendChild(audio);
- startMedia({audio:true});
- }
-
- function startPicture() {
- pictureStatus = true;
- content.appendChild(picture);
- startMedia({picture:true});
- }
-
- function stopMedia() {
- if (videoStatus) {
- video.pause();
- video.src = null;
- content.removeChild(video);
- videoStatus = false;
- }
-
- if (audioStatus) {
- audio.pause();
- audio.src = null;
- content.removeChild(audio);
- audioStatus = false;
- }
-
- if (pictureStatus) {
- picture.src = null;
- content.removeChild(picture);
- pictureStatus = false;
- }
- stop.style.display = "none";
- start.style.display = "block";
- }
-
- function startMedia(param) {
- stop.style.display = "block";
- start.style.display = "none";
- try {
- window.navigator.mozGetUserMedia(param, function(stream) {
- message.innerHTML = "<p>Success!</p>";
- if (videoStatus) {
- video.src = stream;
- video.play();
- }
-
- if (audioStatus) {
- audio.src = stream;
- audio.play();
- }
-
- if (pictureStatus) {
- picture.src = window.URL.createObjectURL(stream);
- picture.onload = function(e) {
- window.URL.revokeObjectURL(this.src);
- }
- }
- }, function(err) {
- message.innerHTML = "<p class='error'>" + err + "</p>";
- stopMedia();
- });
- } catch(e) {
- message.innerHTML = "<p class='error'>" + e + "</p>";
- stopMedia();
- }
- }
- </script>
</html>
View
18 test_apps/uitest/tests/savebookmark.html
@@ -2,7 +2,8 @@
<html>
<head>
<meta charset="utf-8">
- <title>Popup</title>
+ <title>Save bookmark</title>
+ <script src="../js/savebookmark.js" defer></script>
<style>
body {
background-color: #fff;
@@ -11,22 +12,9 @@
font-size: 40px;
}
</style>
- <script>
- function save() {
- new MozActivity({
- name: 'save-bookmark',
- data: {
- type: 'url',
- url: 'http://www.google.es',
- name: 'Google',
- icon: ''
- }
- });
- }
- </script>
</head>
<body>
<h1>Save bookmark google</h1>
- <p><button onclick="save()">Save</button></p>
+ <p><button id="save">Save</button></p>
</body>
</html>
View
9 test_apps/uitest/tests/scrollbar.html
@@ -3,6 +3,7 @@
<head>
<meta charset="utf-8">
<title>Scroll Bars!</title>
+ <script defer src="../js/scrollbar.js"></script>
<style>
.box {
width: 200px;
@@ -22,14 +23,6 @@
background-color: #fff;
}
</style>
- <script>
- window.onload = function () {
- var p = document.getElementById('probe');
- document.getElementById('report').textContent =
- 'Scroll bar width calculated from Javascript: ' +
- (p.offsetWidth - p.scrollWidth - 2) + 'px' // 2 = border width * 2
- };
- </script>
</head>
<body>
<p>Each box is 200px width/height, small boxes are 20px.</p>
View
22 test_apps/uitest/tests/select.html
@@ -3,32 +3,12 @@
<head>
<meta charset="utf-8">
<title>Select test</title>
+ <script defer src="../js/select.js"></script>
<style>
body, input, select {
font-size: 1.5em;
}
</style>
-
- <script>
- function changeTest(evt) {
- console.log('++select++ onchange: ' + this.selectedIndex);
- }
-
- function blurTest(evt) {
- console.log('++select++ onblur: ' + this.id);
- }
-
- window.onload = function onload() {
- var elementList = ['singleSel', 'multiSel', 'sizeSel'];
- elementList.forEach(function(elementId) {
- console.log('elementId: ' + elementId);
- document.getElementById(elementId).onchange = changeTest;
- document.getElementById(elementId).addEventListener('blur', blurTest);
- });
- }
-
-
- </script>
</head>
<body>
<ul>
View
34 test_apps/uitest/tests/setcapture.html
@@ -1,34 +0,0 @@
-<!DOCTYPE html>
-<html>
- <head>
- <meta charset="utf-8">
- <title>setCapture test</title>
- <style>
- #target {
- width: 100px;
- height: 100px;
- background-color: #f00;
- }
- </style>
- <script>
-window.onload = function () {
- var target = document.getElementById('target');
-
- target.addEventListener('mousedown', function () {
- target.setCapture(true);
- });
-
- target.addEventListener('mouseup', function () {
- document.releaseCapture();
- alert('mouseup fired from target.');
- });
-}
- </script>
- </head>
- <body>
- <h1>setCapture test</h1>
- <p>Press the red box, move your finger out of it and lift the finger. You should see an alert() if setCapture works.</p>
- <div id="target">
- </div>
- </body>
-</html>
Please sign in to comment.
Something went wrong with that request. Please try again.