mirror of
https://github.com/discourse/discourse.git
synced 2024-11-27 20:13:38 +08:00
69bc552054
The "Show more notifications..." link in the notifications dropdown now links to /my/notifications, which is a historical view of all notifications you have recieved. Notification history is loaded in blocks of 60 at a time. Admins can see others' notification history. (This was requested for 'debugging purposes', though that's what impersonation is for, IMO.)
37 lines
1.6 KiB
JavaScript
37 lines
1.6 KiB
JavaScript
moduleFor("controller:header", "controller:header", {
|
|
needs: ['controller:application']
|
|
});
|
|
|
|
test("showNotifications action", function() {
|
|
var resolveRequestWith;
|
|
var request = new Ember.RSVP.Promise(function(resolve) {
|
|
resolveRequestWith = resolve;
|
|
});
|
|
|
|
var controller = this.subject();
|
|
var viewSpy = {
|
|
showDropdownBySelector: sinon.spy()
|
|
};
|
|
sandbox.stub(Discourse, "ajax").withArgs("/notifications").returns(request);
|
|
sandbox.stub(Discourse.User, "current").returns(Discourse.User.create({
|
|
unread_notifications: 1
|
|
}));
|
|
|
|
Ember.run(function() {
|
|
controller.send("showNotifications", viewSpy);
|
|
});
|
|
|
|
equal(controller.get("notifications"), null, "notifications are null before data has finished loading");
|
|
equal(Discourse.User.current().get("unread_notifications"), 1, "current user's unread notifications count is not zeroed before data has finished loading");
|
|
ok(viewSpy.showDropdownBySelector.calledWith("#user-notifications"), "dropdown with loading glyph is shown before data has finished loading");
|
|
|
|
Ember.run(function() {
|
|
resolveRequestWith(["notification"]);
|
|
});
|
|
|
|
// Can't use deepEquals because controller.get("notifications") is an ArrayProxy, not an Array
|
|
ok(controller.get("notifications").indexOf("notification") !== -1, "notification is in the controller");
|
|
equal(Discourse.User.current().get("unread_notifications"), 0, "current user's unread notifications count is zeroed after data has finished loading");
|
|
ok(viewSpy.showDropdownBySelector.calledWith("#user-notifications"), "dropdown with notifications is shown after data has finished loading");
|
|
});
|