mirror of
https://github.com/discourse/discourse.git
synced 2024-12-04 15:13:44 +08:00
ac7bf98ad1
Our method of loading a subset of client settings into tests via tests/helpers/site-settings.js can be improved upon. Currently we have a hardcoded subset of the client settings, which may get out of date and not have the correct defaults. As well as this plugins do not get their settings into the tests, so whenever you need a setting from a plugin, even if it has a default, you have to do needs.setting({ ... }) which is inconvenient. This commit introduces an ember CLI build step to take the site_settings.yml and all the plugin settings.yml files, pull out the client settings, and dump them into a variable in a single JS file we can load in our tests, so we have the correct selection of settings and default values in our JS tests. It also fixes many, many tests that were operating under incorrect assumptions or old settings. Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
144 lines
4.1 KiB
JavaScript
144 lines
4.1 KiB
JavaScript
import {
|
||
acceptance,
|
||
query,
|
||
queryAll,
|
||
} from "discourse/tests/helpers/qunit-helpers";
|
||
import { test } from "qunit";
|
||
import { click, fillIn, visit } from "@ember/test-helpers";
|
||
import selectKit from "discourse/tests/helpers/select-kit-helper";
|
||
|
||
acceptance("Local Dates - composer", function (needs) {
|
||
needs.user();
|
||
needs.settings({
|
||
discourse_local_dates_enabled: true,
|
||
discourse_local_dates_default_formats: "LLL|LTS|LL|LLLL",
|
||
});
|
||
|
||
test("composer bbcode", async function (assert) {
|
||
const getAttr = (attr) => {
|
||
return query(
|
||
".d-editor-preview .discourse-local-date.cooked-date"
|
||
).getAttribute(`data-${attr}`);
|
||
};
|
||
|
||
await visit("/");
|
||
await click("#create-topic");
|
||
const categoryChooser = selectKit(".category-chooser");
|
||
await categoryChooser.expand();
|
||
await categoryChooser.selectRowByValue(2);
|
||
|
||
await fillIn(
|
||
".d-editor-input",
|
||
'[date=2017-10-23 time=01:30:00 displayedTimezone="America/Chicago" format="LLLL" calendar="off" recurring="1.weeks" timezone=" Asia/Calcutta" timezones="Europe/Paris|America/Los_Angeles"]'
|
||
);
|
||
|
||
assert.strictEqual(
|
||
getAttr("date"),
|
||
"2017-10-23",
|
||
"it has the correct date"
|
||
);
|
||
assert.strictEqual(getAttr("time"), "01:30:00", "it has the correct time");
|
||
assert.strictEqual(
|
||
getAttr("displayed-timezone"),
|
||
"America/Chicago",
|
||
"it has the correct displayed timezone"
|
||
);
|
||
assert.strictEqual(getAttr("format"), "LLLL", "it has the correct format");
|
||
assert.strictEqual(
|
||
getAttr("timezones"),
|
||
"Europe/Paris|America/Los_Angeles",
|
||
"it has the correct timezones"
|
||
);
|
||
assert.strictEqual(
|
||
getAttr("recurring"),
|
||
"1.weeks",
|
||
"it has the correct recurring"
|
||
);
|
||
assert.strictEqual(
|
||
getAttr("timezone"),
|
||
"Asia/Calcutta",
|
||
"it has the correct timezone"
|
||
);
|
||
|
||
await fillIn(
|
||
".d-editor-input",
|
||
'[date=2017-10-24 format="LL" timezone="Asia/Calcutta" timezones="Europe/Paris|America/Los_Angeles"]'
|
||
);
|
||
|
||
assert.strictEqual(
|
||
getAttr("date"),
|
||
"2017-10-24",
|
||
"it has the correct date"
|
||
);
|
||
assert.notOk(getAttr("time"), "it doesn’t have time");
|
||
});
|
||
|
||
test("date modal", async function (assert) {
|
||
await visit("/");
|
||
await click("#create-topic");
|
||
const categoryChooser = selectKit(".category-chooser");
|
||
await categoryChooser.expand();
|
||
await categoryChooser.selectRowByValue(2);
|
||
await click(".d-editor-button-bar .local-dates");
|
||
|
||
const timezoneChooser = selectKit(".timezone-input");
|
||
await timezoneChooser.expand();
|
||
await timezoneChooser.selectRowByValue("Asia/Macau");
|
||
|
||
assert.ok(
|
||
query(".preview .discourse-local-date").textContent.includes("Macau"),
|
||
"it outputs a preview date in selected timezone"
|
||
);
|
||
});
|
||
|
||
test("date modal - controls", async function (assert) {
|
||
await visit("/");
|
||
await click("#create-topic");
|
||
const categoryChooser = selectKit(".category-chooser");
|
||
await categoryChooser.expand();
|
||
await categoryChooser.selectRowByValue(2);
|
||
await click(".d-editor-button-bar .local-dates");
|
||
|
||
await click('.pika-table td[data-day="5"] > .pika-button');
|
||
|
||
assert.ok(
|
||
query("#from-date-time").textContent.includes("5,"),
|
||
"selected FROM date works"
|
||
);
|
||
|
||
await click(".date-time-control.to .date-time");
|
||
|
||
assert.strictEqual(
|
||
queryAll(".pika-table .is-disabled").length,
|
||
4,
|
||
"date just before selected FROM date is disabled"
|
||
);
|
||
|
||
await click('.pika-table td[data-day="10"] > .pika-button');
|
||
|
||
assert.ok(
|
||
query(".date-time-control.to button").textContent.includes("10,"),
|
||
"selected TO date works"
|
||
);
|
||
|
||
assert.strictEqual(
|
||
query(".pika-table .is-selected").textContent,
|
||
"10",
|
||
"selected date is the 10th"
|
||
);
|
||
|
||
await click(".delete-to-date");
|
||
|
||
assert.notOk(
|
||
query(".pika-table .is-selected"),
|
||
"deleting selected TO date works"
|
||
);
|
||
|
||
await click(".advanced-mode-btn");
|
||
|
||
assert.strictEqual(query("input.format-input").value, "");
|
||
await click("ul.formats a.moment-format");
|
||
assert.strictEqual(query("input.format-input").value, "LLL");
|
||
});
|
||
});
|