Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(613)

Unified Diff: chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js

Issue 468813002: Add NotifyOnPermissionLevelChanged implementation of notification (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address comments, deleted test for notifyOnShowSettings since it's not implemented Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js
diff --git a/chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js b/chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js
index 58e524266a1ae0fcb1c4d545cb68bc3ca2d14ce1..5a1f609c5371acaabccc52cac1bc091c8fc67917 100644
--- a/chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js
+++ b/chrome/test/data/extensions/api_test/notification_provider/basic_usage/background.js
@@ -63,33 +63,39 @@ function notifyOnButtonClicked(senderId, notificationId, buttonIndex) {
});
};
-function notifyOnPermissionLevelChanged(senderId, permissionLevel) {
+function notifyOnPermissionLevelChanged(senderId,
+ notifierType,
+ permissionLevel) {
return new Promise(function (resolve, reject) {
notificationProvider.notifyOnPermissionLevelChanged(
senderId,
+ notifierType,
permissionLevel,
- function (notifierExists) {
- if (chrome.runtime.lastError || !notifierExists) {
+ function (wasChanged) {
+ if (chrome.runtime.lastError || !wasChanged) {
reject(new Error("Unable to send onPermissionLevelChanged message"));
return;
}
- resolve(notifierExists);
+ resolve(wasChanged);
return;
});
});
};
-function notifyOnShowSettings(senderId) {
+function allEventsReceived(on_clicked_received,
+ on_button_clicked_received,
+ on_closed_received,
+ on_permission_level_changed_called) {
return new Promise(function (resolve, reject) {
- notificationProvider.notifyOnShowSettings(senderId,
- function (notifierExists) {
- if (chrome.runtime.lastError || !notifierExists) {
- reject(new Error("Unable to send onShowSettings message"));
- return;
- }
- resolve(notifierExists);
+ if (on_clicked_received &&
+ on_button_clicked_received &&
+ on_closed_received &&
+ on_permission_level_changed_called) {
+ resolve();
return;
- });
+ }
+ reject(new Error("Not all events are fired correctly."));
+ return;
});
};
@@ -108,16 +114,42 @@ function testFunctions() {
message: "This is the message."
};
+ var on_clicked_received = false;
+ function listenForOnClicked() {
+ on_clicked_received = true;
+ }
+
+ var on_button_clicked_received = false;
+ function listenForOnButtonClicked() {
+ on_button_clicked_received = true;
+ }
+
+ var on_closed_received = false;
+ function listenForOnClosed() {
+ on_closed_received = true;
+ }
+
+ var on_permission_level_changed_called = false;
+ function listenForOnPermissionLevelChanged() {
+ on_permission_level_changed_called = true;
+ }
+
+ chrome.notifications.onClicked.addListener(listenForOnClicked);
+ chrome.notifications.onButtonClicked.addListener(listenForOnButtonClicked);
+ chrome.notifications.onClosed.addListener(listenForOnClosed);
+ chrome.notifications.onPermissionLevelChanged.addListener(
+ listenForOnPermissionLevelChanged);
+
// Create a notification, so there will be one existing notification
createNotification(id1, content)
.catch(function() { failTest("notifications.create"); })
// Notify the sender that a notificaion was clicked.
.then(function() { return notifyOnClicked(myId, returnId); })
- .catch(function() { failTest("NotifyOnClicked1"); })
+ .catch(function() { failTest("NotifyOnClicked"); })
// Try to notify that an non-existent notification was clicked.
.then(function() { return notifyOnClicked(myId, "doesNotExist"); })
// Fail if it returns true.
- .then(function() { failTest("NotifyOnClicked2"); })
+ .then(function() { failTest("NotifyOnClicked"); })
// Notify the sender that a notificaion button was clicked.
.catch(function() { return notifyOnButtonClicked(myId, returnId, 0); })
.catch(function() { failTest("NotifyOnButtonClicked"); })
@@ -131,10 +163,21 @@ function testFunctions() {
.catch(function() { return notifyOnCleared(myId, returnId); })
.catch(function() { failTest("NotifyOnCleared"); })
.then(function () { return notifyOnPermissionLevelChanged(myId,
+ "application",
"granted"); })
.catch(function() { failTest("NotifyOnPermissionLevelChanged"); })
- .then(function () { return notifyOnShowSettings(myId); })
- .catch(function() { failTest("NotifyOnShowSettings"); })
+ // Try to notify a web type notifier its permissional level is changed
+ .then(function() { return notifyOnPermissionLevelChanged("SomeURL",
+ "web",
+ "granted"); })
+ // Fail if it returns true
+ .then(function() { failTest("NotifyOnPermissionLevelChanged"); })
+ .catch(function() { return allEventsReceived(
dewittj 2014/08/13 21:30:36 This is technically racy; imagine an environment w
liyanhou 2014/08/14 16:15:24 Done.
+ on_clicked_received,
+ on_button_clicked_received,
+ on_closed_received,
+ on_permission_level_changed_called); })
+ .catch(function() { failTest("DidNotReceiveAllEvents"); })
.then(function() { chrome.test.succeed(); });
};

Powered by Google App Engine
This is Rietveld 408576698