discourse/test/javascripts/acceptance/composer-actions-test.js.es6

170 lines
6.5 KiB
JavaScript

import { acceptance } from 'helpers/qunit-helpers';
acceptance('Composer Actions', {
loggedIn: true,
settings: {
enable_whispers: true
}
});
QUnit.test('replying to post', assert => {
const composerActions = selectKit('.composer-actions');
visit('/t/internationalization-localization/280');
click('article#post_3 button.reply');
composerActions.expand();
andThen(() => {
assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic');
assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message');
assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic');
assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper');
assert.equal(composerActions.rowByIndex(4).value(), undefined);
});
});
QUnit.test('replying to post - reply_as_private_message', assert => {
const composerActions = selectKit('.composer-actions');
visit('/t/internationalization-localization/280');
click('article#post_3 button.reply');
composerActions.expand().selectRowByValue('reply_as_private_message');
andThen(() => {
assert.equal(find('.users-input .item:eq(0)').text(), 'codinghorror');
assert.ok(find('.d-editor-input').val().indexOf('Continuing the discussion') >= 0);
});
});
QUnit.test('replying to post - reply_to_topic', assert => {
const composerActions = selectKit('.composer-actions');
visit('/t/internationalization-localization/280');
click('article#post_3 button.reply');
fillIn('.d-editor-input', 'test replying to topic when initially replied to post');
composerActions.expand().selectRowByValue('reply_to_topic');
andThen(() => {
assert.equal(find('.action-title .topic-link').text().trim(), 'Internationalization / localization');
assert.equal(find('.action-title .topic-link').attr("href"), '/t/internationalization-localization/280');
assert.equal(find('.d-editor-input').val(), 'test replying to topic when initially replied to post');
});
});
QUnit.test('replying to post - toggle_whisper', assert => {
const composerActions = selectKit('.composer-actions');
visit('/t/internationalization-localization/280');
click('article#post_3 button.reply');
fillIn('.d-editor-input', 'test replying as whisper to topic when initially not a whisper');
composerActions.expand().selectRowByValue('toggle_whisper');
andThen(() => {
assert.ok(
find('.composer-fields .whisper').text().indexOf(I18n.t("composer.whisper")) > 0
);
});
});
QUnit.test('replying to post - reply_as_new_topic', assert => {
const composerActions = selectKit('.composer-actions');
const categoryChooser = selectKit('.title-wrapper .category-chooser');
const categoryChooserReplyArea = selectKit('.reply-area .category-chooser');
const quote = 'test replying as new topic when initially replied to post';
visit('/t/internationalization-localization/280');
click('#topic-title .d-icon-pencil');
categoryChooser.expand().selectRowByValue(4);
click('#topic-title .submit-edit');
click('article#post_3 button.reply');
fillIn('.d-editor-input', quote);
composerActions.expand().selectRowByValue('reply_as_new_topic');
andThen(() => {
assert.equal(categoryChooserReplyArea.header().name(), 'faq');
assert.equal(find('.action-title').text().trim(), I18n.t("topic.create_long"));
assert.ok(find('.d-editor-input').val().includes(quote));
});
});
QUnit.test('shared draft', assert => {
let composerActions = selectKit('.composer-actions');
visit("/");
click('#create-topic');
andThen(() => {
composerActions.expand().selectRowByValue('shared_draft');
});
andThen(() => {
assert.equal(
find('#reply-control .btn-primary.create .d-button-label').text(),
I18n.t('composer.create_shared_draft')
);
assert.ok(find('#reply-control.composing-shared-draft').length === 1);
});
});
QUnit.test('interactions', assert => {
const composerActions = selectKit('.composer-actions');
const quote = 'Life is like riding a bicycle.';
visit('/t/internationalization-localization/280');
click('article#post_3 button.reply');
fillIn('.d-editor-input', quote);
composerActions.expand().selectRowByValue('reply_to_topic');
andThen(() => {
assert.equal(find('.action-title').text().trim(), "Internationalization / localization");
assert.equal(find('.d-editor-input').val(), quote);
});
composerActions.expand();
andThen(() => {
assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic');
assert.equal(composerActions.rowByIndex(1).value(), 'reply_to_post');
assert.equal(composerActions.rowByIndex(2).value(), 'reply_as_private_message');
assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper');
assert.equal(composerActions.rowByIndex(4).value(), undefined);
});
composerActions.selectRowByValue('reply_to_post').expand();
andThen(() => {
assert.ok(exists(find('.action-title img.avatar')));
assert.equal(find('.action-title .user-link').text().trim(), "codinghorror");
assert.equal(find('.d-editor-input').val(), quote);
assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic');
assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message');
assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic');
assert.equal(composerActions.rowByIndex(3).value(), 'toggle_whisper');
assert.equal(composerActions.rowByIndex(4).value(), undefined);
});
composerActions.selectRowByValue('reply_as_new_topic').expand();
andThen(() => {
assert.equal(find('.action-title').text().trim(), I18n.t("topic.create_long"));
assert.ok(find('.d-editor-input').val().includes(quote));
assert.equal(composerActions.rowByIndex(0).value(), 'reply_to_post');
assert.equal(composerActions.rowByIndex(1).value(), 'reply_as_private_message');
assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic');
assert.equal(composerActions.rowByIndex(3).value(), 'shared_draft');
});
composerActions.selectRowByValue('reply_as_private_message').expand();
andThen(() => {
assert.equal(find('.action-title').text().trim(), I18n.t("topic.private_message"));
assert.ok(find('.d-editor-input').val().indexOf("Continuing the discussion") === 0);
assert.equal(composerActions.rowByIndex(0).value(), 'reply_as_new_topic');
assert.equal(composerActions.rowByIndex(1).value(), 'reply_to_post');
assert.equal(composerActions.rowByIndex(2).value(), 'reply_to_topic');
assert.equal(composerActions.rowByIndex(3).value(), undefined);
});
});