2017-09-11 13:14:22 -04:00
|
|
|
import componentTest from 'helpers/component-test';
|
|
|
|
import Topic from 'discourse/models/topic';
|
|
|
|
|
|
|
|
const buildTopic = function() {
|
|
|
|
return Topic.create({
|
|
|
|
id: 1234,
|
|
|
|
title: "Qunit Test Topic",
|
|
|
|
deleted: false,
|
|
|
|
pinned: true
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
moduleForComponent('pinned-button', { integration: true });
|
|
|
|
|
|
|
|
componentTest('updating the content refreshes the list', {
|
|
|
|
template: '{{pinned-button topic=topic}}',
|
|
|
|
|
|
|
|
beforeEach() {
|
|
|
|
this.siteSettings.automatically_unpin_topics = false;
|
|
|
|
this.set("topic", buildTopic());
|
|
|
|
},
|
|
|
|
|
|
|
|
test(assert) {
|
2017-09-14 13:50:32 -04:00
|
|
|
andThen(() => assert.notOk(selectBox().isHidden) );
|
2017-09-11 13:14:22 -04:00
|
|
|
|
2017-09-14 13:50:32 -04:00
|
|
|
expandSelectBox();
|
2017-09-11 13:14:22 -04:00
|
|
|
|
2017-09-14 13:50:32 -04:00
|
|
|
andThen(() => assert.equal(selectBox().selectedRow.el().find(".title").text(), "Pinned") );
|
2017-09-11 13:14:22 -04:00
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
this.set("topic.pinned", false);
|
2017-09-14 13:50:32 -04:00
|
|
|
assert.equal(selectBox().selectedRow.el().find(".title").text(), "Unpinned");
|
2017-09-11 13:14:22 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
this.set("topic.deleted", true);
|
2017-09-14 13:50:32 -04:00
|
|
|
assert.ok(find(".pinned-button").hasClass("is-hidden"), "it hides the button when topic is deleted");
|
2017-09-11 13:14:22 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|