FIX: regression preventing to set number of hours before closing

This commit also adds a full test suite for editing topic timer.
This commit is contained in:
Joffrey JAFFEUX 2017-11-24 02:48:45 +01:00 committed by GitHub
parent 82222e8d18
commit 63307c303a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 156 additions and 2 deletions

View File

@ -1,6 +1,6 @@
<form> <form>
<div class="control-group"> <div class="control-group">
{{combo-box allowInitialValueMutation=true content=timerTypes value=selection}} {{combo-box class="timer-type" allowInitialValueMutation=true content=timerTypes value=selection}}
</div> </div>
<div> <div>

View File

@ -114,6 +114,7 @@ export default ComboBoxComponent.extend(DatetimeMixin, {
pluginApiIdentifiers: ["future-date-input-selector"], pluginApiIdentifiers: ["future-date-input-selector"],
classNames: ["future-date-input-selector"], classNames: ["future-date-input-selector"],
isCustom: Ember.computed.equal("value", "pick_date_and_time"), isCustom: Ember.computed.equal("value", "pick_date_and_time"),
isBasedOnLastPost: Ember.computed.equal("value", "set_based_on_last_post"),
clearable: true, clearable: true,
rowComponent: "future-date-input-selector/future-date-input-selector-row", rowComponent: "future-date-input-selector/future-date-input-selector-row",
headerComponent: "future-date-input-selector/future-date-input-selector-header", headerComponent: "future-date-input-selector/future-date-input-selector-header",
@ -154,7 +155,7 @@ export default ComboBoxComponent.extend(DatetimeMixin, {
}, },
mutateValue(value) { mutateValue(value) {
if (this.get("isCustom")) { if (this.get("isCustom") || this.get("isBasedOnLastPost")) {
this.set("value", value); this.set("value", value);
} else { } else {
let input = null; let input = null;

View File

@ -0,0 +1,153 @@
import { acceptance } from 'helpers/qunit-helpers';
acceptance('Topic - Edit timer', { loggedIn: true });
QUnit.test('default', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
andThen(() => {
assert.equal(selectKit('.select-kit.timer-type').header.name(), 'Auto-Close Topic');
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Select a timeframe');
});
click('#private-topic-timer');
andThen(() => {
assert.equal(selectKit('.select-kit.timer-type').header.name(), 'Remind Me');
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Select a timeframe');
});
});
QUnit.test('autoclose - specific time', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('later_today', { selector: '.future-date-input-selector' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Later today');
const regex = /will automatically close in/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
});
QUnit.test('autoclose', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('later_today', { selector: '.future-date-input-selector' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Later today');
const regex = /will automatically close in/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('pick_date_and_time', { selector: '.future-date-input-selector' });
fillIn('.future-date-input .date-picker', '2099-11-24');
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Pick date and time');
const regex = /will automatically close in/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('set_based_on_last_post', { selector: '.future-date-input-selector' });
fillIn('.future-date-input input[type=number]', '2');
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Close based on last post');
const regex = /This topic will close.*after the last reply/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
});
QUnit.test('close temporarily', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
expandSelectKit('.select-kit.timer-type');
selectKitSelectRow('open', { selector: '.select-kit.timer-type' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Select a timeframe');
});
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('tomorrow', { selector: '.future-date-input-selector' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Tomorrow');
const regex = /will automatically open in/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('pick_date_and_time', { selector: '.future-date-input-selector' });
fillIn('.future-date-input .date-picker', '2099-11-24');
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Pick date and time');
const regex = /will automatically open in/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
});
QUnit.test('schedule', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
expandSelectKit('.select-kit.timer-type');
selectKitSelectRow('publish_to_category', { selector: '.select-kit.timer-type' });
andThen(() => {
assert.equal(selectKit('.modal-body .category-chooser').header.name(), 'uncategorized');
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Select a timeframe');
});
expandSelectKit('.modal-body .category-chooser');
selectKitSelectRow('7', { selector: '.modal-body .category-chooser' });
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('next_week', { selector: '.future-date-input-selector' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Next week');
const regex = /will be published to #dev/g;
const text = find('.future-date-input .topic-status-info').text().trim();
assert.ok(regex.test(text));
});
});
QUnit.test('auto delete', assert => {
visit('/t/internationalization-localization');
click('.toggle-admin-menu');
click('.topic-admin-status-update button');
expandSelectKit('.select-kit.timer-type');
selectKitSelectRow('delete', { selector: '.select-kit.timer-type' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Select a timeframe');
});
expandSelectKit('.future-date-input-selector');
selectKitSelectRow('next_month', { selector: '.future-date-input-selector' });
andThen(() => {
assert.equal(selectKit('.future-date-input-selector').header.name(), 'Next month');
const regex = /will be automatically deleted/g;
const html = find('.future-date-input .topic-status-info').html().trim();
assert.ok(regex.test(html));
});
});