45 lines
1.6 KiB
JavaScript
45 lines
1.6 KiB
JavaScript
module("Discourse.HeaderController", {
|
|
setup: function() {
|
|
sinon.stub(Discourse, "ajax");
|
|
},
|
|
|
|
teardown: function() {
|
|
Discourse.ajax.restore();
|
|
}
|
|
});
|
|
|
|
test("showNotifications action", function() {
|
|
var resolveRequestWith;
|
|
var request = new Ember.RSVP.Promise(function(resolve) {
|
|
resolveRequestWith = resolve;
|
|
});
|
|
|
|
|
|
var controller = Discourse.HeaderController.create();
|
|
var viewSpy = {
|
|
showDropdownBySelector: sinon.spy()
|
|
};
|
|
Discourse.User.current().set("unread_notifications", 1);
|
|
Ember.run(function() {
|
|
Discourse.ajax.withArgs("/notifications").returns(request);
|
|
});
|
|
|
|
|
|
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.notCalled, "dropdown with notifications is not shown before data has finished loading");
|
|
|
|
|
|
Ember.run(function() {
|
|
resolveRequestWith(["notification"]);
|
|
});
|
|
|
|
deepEqual(controller.get("notifications"), ["notification"], "notifications are set correctly after data has finished loading");
|
|
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");
|
|
});
|