import { acceptance, exists, query, queryAll, visible, } from "discourse/tests/helpers/qunit-helpers"; import { test } from "qunit"; import { click, currentURL, fillIn, findAll, visit } from "@ember/test-helpers"; import selectKit from "discourse/tests/helpers/select-kit-helper"; import { getAdminTestingWizard, getBusinessAdminWizard, getCreatedWizard, getCustomFields, getSuppliersAuthorized, getWizard, } from "../helpers/admin-wizard"; acceptance("Admin | Custom Wizard Business Subscription", 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/wizard", () => { return helper.response(getWizard); }); server.get("/admin/wizards/custom-fields", () => { return helper.response(getCustomFields); }); server.get("/admin/wizards/subscription", () => { return helper.response(getBusinessAdminWizard); }); server.get("/admin/wizards/api", () => { return helper.response([]); }); server.get("/admin/customize/user_fields", () => { return helper.response({ user_fields: [] }); }); server.get("/admin/wizards/wizard/this_is_testing_wizard", () => { return helper.response(getAdminTestingWizard); }); server.put("/admin/wizards/wizard/new_wizard_for_testing", () => { return helper.response({ success: "OK", wizard_id: "new_wizard_for_testing", }); }); server.get("/admin/wizards/wizard/new_wizard_for_testing", () => { return helper.response(getCreatedWizard); }); server.get("/admin/plugins/subscription-client/suppliers", () => { return helper.response(getSuppliersAuthorized); }); }); test("Displaying all tabs including API", async (assert) => { await visit("/admin/wizards"); const list = queryAll(".admin-controls li"); const count = list.length; assert.equal(count, 6, "There should be 6 admin tabs"); }); test("shows authorized and subscribed", async (assert) => { await visit("/admin/wizards"); assert.notOk( exists(".supplier-authorize .btn-primary:not(.update)"), "the authorize button is shown." ); assert.strictEqual( query("button.wizard-subscription-badge span").innerText.trim(), "Support" ); }); test("creating a new wizard", async (assert) => { await visit("/admin/wizards/wizard"); await click(".admin-wizard-controls button"); assert.ok( query(".message-content").innerText.includes( "You're creating a new wizard" ), "it displays wizard creation message" ); // "Step 1: Inserting a title const wizardTitle = "New wizard for testing"; await fillIn(".wizard-header input", wizardTitle); assert.equal( $(".wizard-header input").val(), wizardTitle, "The title input is inserted" ); const wizardLink = queryAll("div.wizard-url a"); assert.equal(wizardLink.length, 1, "Wizard link was created"); assert.equal( queryAll(".wizard-subscription-container a:contains('Subscribed')") .length, 1, "Wizard subscription features are accesible" ); await click( '.wizard-subscription-container .subscription-settings .setting-value input[type="checkbox"]' ); assert.ok( queryAll( '.wizard-subscription-container .subscription-settings .setting-value input[type="checkbox"]' ).is(":checked"), "subscription feature available" ); // Step 2: Creating a step section await click(".step .link-list button"); const stepOneText = "step_1 (step_1)"; const stepOneBtn = queryAll(`.step button:contains(${stepOneText})`); assert.equal(stepOneBtn.length, 1, "Creating a step"); const stepTitle = "step title"; await fillIn(".wizard-custom-step input[name='title']", stepTitle); const stepButtonText = $.trim( $(".step div[data-id='step_1'] button").text() ); assert.ok( stepButtonText.includes(stepTitle), "The step button changes according to title" ); assert.equal( queryAll(".wizard-subscription-container a:contains('Subscribed')") .length, 2, "Steps subscription features are accesible" ); // Step 3: Creating a field section await click(".field .link-list button"); assert.ok( !visible(".wizard-custom-field button.undo-changes"), "clear button is not rendered" ); const fieldOneText = "step_1_field_1 (step_1_field_1)"; const fieldOneBtn = queryAll(`.field button:contains(${fieldOneText})`); assert.equal(fieldOneBtn.length, 1, "Creating a field"); const fieldTitle = "field title"; await fillIn(".wizard-custom-field input[name='label']", fieldTitle); assert.ok( visible(".wizard-custom-field button.undo-changes"), "clear button is rendered after filling content" ); let fieldButtonText = $.trim( $(".field div[data-id='step_1_field_1'] button").text() ); assert.ok( fieldButtonText.includes(fieldTitle), "The step button changes according to title" ); await click(`.wizard-custom-field button.undo-changes`); fieldButtonText = $(".field div[data-id='step_1_field_1'] button") .text() .trim(); assert.ok( fieldButtonText.includes("step_1_field_1 (step_1_field_1)"), "The field button changes to default title after clear button is clicked" ); const fieldTypeDropdown = selectKit( ".wizard-custom-field .setting-value .select-kit" ); await fieldTypeDropdown.expand(); await fieldTypeDropdown.selectRowByValue("text"); assert.ok( query(".wizard-custom-field .message-content").innerText.includes( "You're editing a field" ), "Text tipe for field correctly selected" ); assert.equal( queryAll(".wizard-subscription-container a:contains('Subscribed')") .length, 3, "Field subscription features are accesible" ); // Step 4: Creating a action section await click(".action .link-list button"); const actionOneText = "action_1 (action_1)"; const actionOneBtn = queryAll(`.action button:contains(${actionOneText})`); assert.equal(actionOneBtn.length, 1, "Creating an action"); assert.ok( query( ".wizard-custom-action .wizard-message .message-content" ).innerText.includes("Select an action type"), "it displays wizard select action message" ); const actionTypeDropdown = selectKit( ".wizard-custom-action .setting-value .select-kit" ); await actionTypeDropdown.expand(); const listEnabled = findAll( ".wizard-custom-action .setting .setting-value ul li:not(.disabled)" ); const listDisabled = findAll( ".wizard-custom-action .setting .setting-value ul li.disabled" ); assert.ok( listDisabled.length === 0, "Disabled items displayed correctly in action dropdown" ); assert.ok( listEnabled.length === 11, "Enabled items displayed correctly in action dropdown" ); await actionTypeDropdown.selectRowByValue("create_topic"); assert.ok( query(".wizard-custom-action .message-content").innerText.includes( "You're editing an action" ), "Create type action correctly selected" ); let listTopicSettings = findAll( ".admin-wizard-container .wizard-custom-action .setting" ); assert.ok( listTopicSettings.length === 12, "Display all settings of create topic" ); await actionTypeDropdown.expand(); await actionTypeDropdown.selectRowByValue("send_to_api"); listTopicSettings = findAll( ".admin-wizard-container .wizard-custom-action .setting" ); assert.ok( listTopicSettings.length === 5, "Display all settings of send to api" ); await actionTypeDropdown.expand(); await actionTypeDropdown.selectRowByValue("create_category"); listTopicSettings = findAll( ".admin-wizard-container .wizard-custom-action .setting" ); assert.ok( listTopicSettings.length === 9, "Display all settings of create categories" ); await actionTypeDropdown.expand(); await actionTypeDropdown.selectRowByValue("create_group"); listTopicSettings = findAll( ".admin-wizard-container .wizard-custom-action .setting" ); assert.ok( listTopicSettings.length === 14, "Display all settings of create group" ); await actionTypeDropdown.expand(); await actionTypeDropdown.selectRowByValue("create_topic"); assert.ok( !visible('.admin-wizard-buttons button:contains("Delete Wizard")'), "delete wizard button not displayed" ); //Step 5: Save wizard await click(".admin-wizard-buttons button"); assert.equal( currentURL(), "/admin/wizards/wizard/new_wizard_for_testing", "clicking the button navigates to the correct URL" ); assert.ok( visible('.admin-wizard-buttons button:contains("Delete Wizard")'), "delete wizard button visible" ); }); });