import { acceptance, count, exists, query, } from "discourse/tests/helpers/qunit-helpers"; import { click, visit } from "@ember/test-helpers"; import { action } from "@ember/object"; import { extraConnectorClass } from "discourse/lib/plugin-connectors"; import { hbs } from "ember-cli-htmlbars"; import { test } from "qunit"; import { registerTemporaryModule } from "discourse/tests/helpers/temporary-module-helper"; const PREFIX = "discourse/plugins/some-plugin/templates/connectors"; acceptance("Plugin Outlet - Connector Class", function (needs) { needs.hooks.beforeEach(() => { extraConnectorClass("user-profile-primary/hello", { actions: { sayHello() { this.set("hello", `${this.hello || ""}hello!`); }, }, }); extraConnectorClass("user-profile-primary/hi", { setupComponent() { this.appEvents.on("hi:sayHi", this, this.say); }, teardownComponent() { this.appEvents.off("hi:sayHi", this, this.say); }, @action say() { this.set("hi", "hi!"); }, @action sayHi() { this.appEvents.trigger("hi:sayHi"); }, }); extraConnectorClass("user-profile-primary/dont-render", { shouldRender(args) { return args.model.get("username") !== "eviltrout"; }, }); registerTemporaryModule( `${PREFIX}/user-profile-primary/hello`, hbs`{{model.username}} {{hello}}` ); registerTemporaryModule( `${PREFIX}/user-profile-primary/hi`, hbs` {{hi}}` ); registerTemporaryModule( `${PREFIX}/user-profile-primary/dont-render`, hbs`I'm not rendered!` ); }); test("Renders a template into the outlet", async function (assert) { await visit("/u/eviltrout"); assert.strictEqual( count(".user-profile-primary-outlet.hello"), 1, "it has class names" ); assert.ok( !exists(".user-profile-primary-outlet.dont-render"), "doesn't render" ); await click(".say-hello"); assert.strictEqual( query(".hello-result").innerText, "hello!", "actions delegate properly" ); await click(".say-hello-using-this"); assert.strictEqual( query(".hello-result").innerText, "hello!hello!", "actions are made available on `this` and are bound correctly" ); await click(".say-hi"); assert.strictEqual( query(".hi-result").innerText, "hi!", "actions delegate properly" ); }); });