mirror of
https://gh.wpcy.net/https://github.com/discourse/discourse.git
synced 2026-06-19 03:43:54 +08:00
Currently, most of the JS test modules follow this
convention:
```
module("Integration | Component | topic-dismiss-buttons"
```
Which is a legacy from when ember components etc were
rendered in templates like this:
```
{{d-button title="foo"}}
```
Instead, this commit updates all of them to follow this
PascalCase convention:
```
module("Integration | Component | TopicDismissButtons", function (hooks) {
```
No linting is added to enforce this, we suspect that it's
mostly a result of cargo culting, and people will add new
tests following PascalCase convention.
Also adds an initial AI skill for writing JS tests.
44 lines
1.4 KiB
Text
Vendored
44 lines
1.4 KiB
Text
Vendored
import { render } from "@ember/test-helpers";
|
|
import { module, test } from "qunit";
|
|
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
|
import GamificationLeaderboardRow from "../discourse/components/gamification-leaderboard-row";
|
|
|
|
module(
|
|
"Discourse Gamification | Component | GamificationLeaderboardRow",
|
|
function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
test("Display name prioritizes name", async function (assert) {
|
|
this.siteSettings.prioritize_username_in_ux = false;
|
|
const rank = { username: "id", name: "bob" };
|
|
|
|
await render(
|
|
<template><GamificationLeaderboardRow @rank={{rank}} /></template>
|
|
);
|
|
|
|
assert.dom(".user__name").hasText("bob");
|
|
});
|
|
|
|
test("Display name prioritizes username", async function (assert) {
|
|
this.siteSettings.prioritize_username_in_ux = true;
|
|
const rank = { username: "id", name: "bob" };
|
|
|
|
await render(
|
|
<template><GamificationLeaderboardRow @rank={{rank}} /></template>
|
|
);
|
|
|
|
assert.dom(".user__name").hasText("id");
|
|
});
|
|
|
|
test("Display name prioritizes username when name is empty", async function (assert) {
|
|
this.siteSettings.prioritize_username_in_ux = false;
|
|
const rank = { username: "id", name: "" };
|
|
|
|
await render(
|
|
<template><GamificationLeaderboardRow @rank={{rank}} /></template>
|
|
);
|
|
|
|
assert.dom(".user__name").hasText("id");
|
|
});
|
|
}
|
|
);
|