discourse/plugins/discourse-gamification/test/javascripts/components/gamification-leaderboard-row-test.gjs
Martin Brennan 79d1c792eb
DEV: Update test module name conventions (#40389)
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.
2026-05-29 15:19:55 +10:00

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");
});
}
);