DEV: Add admin logs acceptance test
Dieser Commit ist enthalten in:
Ursprung
0f9fa5fe94
Commit
71b6a184ca
1 geänderte Dateien mit 350 neuen und 0 gelöschten Zeilen
350
test/javascripts/acceptance/admin-logs-test.js
Normale Datei
350
test/javascripts/acceptance/admin-logs-test.js
Normale Datei
|
@ -0,0 +1,350 @@
|
||||||
|
import { acceptance, query } from "discourse/tests/helpers/qunit-helpers";
|
||||||
|
import { test } from "qunit";
|
||||||
|
import { findAll, visit } from "@ember/test-helpers";
|
||||||
|
import selectKit from "discourse/tests/helpers/select-kit-helper";
|
||||||
|
|
||||||
|
acceptance("Admin | Logs", function (needs) {
|
||||||
|
needs.user();
|
||||||
|
needs.settings({
|
||||||
|
custom_wizard_enabled: true,
|
||||||
|
available_locales: JSON.stringify([{ name: "English", value: "en" }]),
|
||||||
|
});
|
||||||
|
needs.pretender((server, helper) => {
|
||||||
|
server.get("admin/wizards/logs", () => {
|
||||||
|
return helper.response([
|
||||||
|
{ id: "this_is_testing_wizard", name: "This is testing wizard" },
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
server.get("admin/wizards/logs/this_is_testing_wizard", () => {
|
||||||
|
return helper.response({
|
||||||
|
wizard: {
|
||||||
|
id: "this_is_testing_wizard",
|
||||||
|
name: "This is testing wizard",
|
||||||
|
},
|
||||||
|
logs: [
|
||||||
|
{
|
||||||
|
date: "2022-12-12T09:41:57.888-04:00",
|
||||||
|
action: "create_topic",
|
||||||
|
username: "someuser",
|
||||||
|
message:
|
||||||
|
"error: invalid topic params - title: ; post: creating a text for this text area that is being displayed here.",
|
||||||
|
user: {
|
||||||
|
id: 1,
|
||||||
|
username: "someuser",
|
||||||
|
name: null,
|
||||||
|
avatar_template: "",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
total: 1,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
server.get("admin/wizards/logs/this_is_testing_wizard?page=0", () => {
|
||||||
|
return helper.response({
|
||||||
|
wizard: {
|
||||||
|
id: "this_is_testing_wizard",
|
||||||
|
name: "This is testing wizard",
|
||||||
|
},
|
||||||
|
logs: [
|
||||||
|
{
|
||||||
|
date: "2022-12-13T05:32:38.906-04:00",
|
||||||
|
action: "create_topic",
|
||||||
|
username: "christin",
|
||||||
|
message: "success: created topic - id: 119",
|
||||||
|
user: {
|
||||||
|
id: 55,
|
||||||
|
username: "christin",
|
||||||
|
name: "Sybil Ratke",
|
||||||
|
avatar_template: "",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
date: "2022-12-12T09:41:57.888-04:00",
|
||||||
|
action: "create_topic",
|
||||||
|
username: "someuser",
|
||||||
|
message:
|
||||||
|
"error: invalid topic params - title: ; post: creating a text for this text area that is being displayed here.",
|
||||||
|
user: {
|
||||||
|
id: 1,
|
||||||
|
username: "someuser",
|
||||||
|
name: null,
|
||||||
|
avatar_template: "",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
total: 2,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
server.get("/admin/wizards", () => {
|
||||||
|
return helper.response({
|
||||||
|
subscribed: false,
|
||||||
|
subscription_type: "none",
|
||||||
|
subscription_attributes: {
|
||||||
|
wizard: {
|
||||||
|
required: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
permitted: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
restart_on_revisit: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
step: {
|
||||||
|
condition: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
required_data: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
permitted_params: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
field: {
|
||||||
|
condition: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
type: {
|
||||||
|
none: [
|
||||||
|
"text",
|
||||||
|
"textarea",
|
||||||
|
"text_only",
|
||||||
|
"date",
|
||||||
|
"time",
|
||||||
|
"date_time",
|
||||||
|
"number",
|
||||||
|
"checkbox",
|
||||||
|
"dropdown",
|
||||||
|
"upload",
|
||||||
|
],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
realtime_validations: {
|
||||||
|
none: [],
|
||||||
|
standard: ["*"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
action: {
|
||||||
|
type: {
|
||||||
|
none: [
|
||||||
|
"create_topic",
|
||||||
|
"update_profile",
|
||||||
|
"open_composer",
|
||||||
|
"route_to",
|
||||||
|
],
|
||||||
|
standard: [
|
||||||
|
"create_topic",
|
||||||
|
"update_profile",
|
||||||
|
"open_composer",
|
||||||
|
"route_to",
|
||||||
|
"send_message",
|
||||||
|
"watch_categories",
|
||||||
|
"add_to_group",
|
||||||
|
],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
custom_field: {
|
||||||
|
klass: {
|
||||||
|
none: ["topic", "post"],
|
||||||
|
standard: ["topic", "post"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
type: {
|
||||||
|
none: ["string", "boolean", "integer"],
|
||||||
|
standard: ["string", "boolean", "integer"],
|
||||||
|
business: ["*"],
|
||||||
|
community: ["*"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
api: {
|
||||||
|
all: { none: [], standard: [], business: ["*"], community: ["*"] },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
subscription_client_installed: false,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
server.get("admin/wizards/wizard", () => {
|
||||||
|
return helper.response({
|
||||||
|
wizard_list: [
|
||||||
|
{ id: "this_is_testing_wizard", name: "This is testing wizard" },
|
||||||
|
],
|
||||||
|
field_types: {
|
||||||
|
text: {
|
||||||
|
min_length: null,
|
||||||
|
max_length: null,
|
||||||
|
prefill: null,
|
||||||
|
char_counter: null,
|
||||||
|
validations: null,
|
||||||
|
placeholder: null,
|
||||||
|
},
|
||||||
|
textarea: {
|
||||||
|
min_length: null,
|
||||||
|
max_length: null,
|
||||||
|
prefill: null,
|
||||||
|
char_counter: null,
|
||||||
|
placeholder: null,
|
||||||
|
},
|
||||||
|
composer: {
|
||||||
|
min_length: null,
|
||||||
|
max_length: null,
|
||||||
|
char_counter: null,
|
||||||
|
placeholder: null,
|
||||||
|
},
|
||||||
|
text_only: {},
|
||||||
|
composer_preview: { preview_template: null },
|
||||||
|
date: { format: "YYYY-MM-DD" },
|
||||||
|
time: { format: "HH:mm" },
|
||||||
|
date_time: { format: "" },
|
||||||
|
number: {},
|
||||||
|
checkbox: {},
|
||||||
|
url: { min_length: null },
|
||||||
|
upload: { file_types: ".jpg,.jpeg,.png" },
|
||||||
|
dropdown: { prefill: null, content: null },
|
||||||
|
tag: { limit: null, prefill: null, content: null, tag_groups: null },
|
||||||
|
category: { limit: 1, property: "id", prefill: null, content: null },
|
||||||
|
group: { prefill: null, content: null },
|
||||||
|
user_selector: {},
|
||||||
|
},
|
||||||
|
realtime_validations: {
|
||||||
|
similar_topics: {
|
||||||
|
types: ["text"],
|
||||||
|
component: "similar-topics-validator",
|
||||||
|
backend: true,
|
||||||
|
required_params: [],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
custom_fields: [
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "category",
|
||||||
|
name: "require_topic_approval",
|
||||||
|
type: "boolean",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "category",
|
||||||
|
name: "require_reply_approval",
|
||||||
|
type: "boolean",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "category",
|
||||||
|
name: "num_auto_bump_daily",
|
||||||
|
type: "integer",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "category",
|
||||||
|
name: "has_chat_enabled",
|
||||||
|
type: "boolean",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "post",
|
||||||
|
name: "missing uploads",
|
||||||
|
type: "json",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "post",
|
||||||
|
name: "missing uploads ignored",
|
||||||
|
type: "boolean",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "post",
|
||||||
|
name: "notice",
|
||||||
|
type: "json",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "post",
|
||||||
|
name: "local_dates",
|
||||||
|
type: "json",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "external",
|
||||||
|
klass: "post",
|
||||||
|
name: "has_polls",
|
||||||
|
type: "boolean",
|
||||||
|
serializers: null,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
test("viewing logs fields tab", async (assert) => {
|
||||||
|
await visit("/admin/wizards/logs");
|
||||||
|
const wizards = selectKit(".select-kit");
|
||||||
|
assert.ok(
|
||||||
|
query(".message-content").innerText.includes(
|
||||||
|
"Select a wizard to see its logs"
|
||||||
|
),
|
||||||
|
"it displays logs message"
|
||||||
|
);
|
||||||
|
assert.ok(
|
||||||
|
query(".message-content").innerText.includes("Select a wizard"),
|
||||||
|
"it displays list of logs"
|
||||||
|
);
|
||||||
|
await wizards.expand();
|
||||||
|
await wizards.selectRowByValue("this_is_testing_wizard");
|
||||||
|
assert.ok(
|
||||||
|
query(".message-content").innerText.includes(
|
||||||
|
"View recent logs for wizards on the forum"
|
||||||
|
),
|
||||||
|
"it displays logs for a selected wizard"
|
||||||
|
);
|
||||||
|
assert.ok(find("table"));
|
||||||
|
assert.ok(findAll("table tbody tr").length === 1, "Displays logs list");
|
||||||
|
// TODO: FIX updating list by refreshing button
|
||||||
|
const refreshButton = find(".refresh.btn");
|
||||||
|
await click(refreshButton);
|
||||||
|
assert.ok(
|
||||||
|
findAll("table tbody tr").length === 2,
|
||||||
|
"Displays refreshed logs list"
|
||||||
|
);
|
||||||
|
await wizards.expand();
|
||||||
|
const li = find('[data-name="Select a wizard"]');
|
||||||
|
await click(li);
|
||||||
|
const wizardContainerDiv = find(".admin-wizard-container");
|
||||||
|
assert.ok(wizardContainerDiv.children().length === 0, "the div is empty");
|
||||||
|
});
|
||||||
|
});
|
Laden …
In neuem Issue referenzieren