DEV: Fix badge tests (#23442)
`badge.save(["name", "description", "badge_type_id"])` api it was testing isn't a thing anymore. Also: replaces `assert.expect(0)` with more useful assertions
This commit is contained in:
parent
4776983620
commit
02bd709bc3
|
@ -1,4 +1,8 @@
|
||||||
import { module, test } from "qunit";
|
import { module, test } from "qunit";
|
||||||
|
import pretender, {
|
||||||
|
parsePostData,
|
||||||
|
response,
|
||||||
|
} from "discourse/tests/helpers/create-pretender";
|
||||||
import Badge from "discourse/models/badge";
|
import Badge from "discourse/models/badge";
|
||||||
import { setupTest } from "ember-qunit";
|
import { setupTest } from "ember-qunit";
|
||||||
import { getOwner } from "discourse-common/lib/get-owner";
|
import { getOwner } from "discourse-common/lib/get-owner";
|
||||||
|
@ -61,27 +65,48 @@ module("Unit | Model | badge", function (hooks) {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("save", function (assert) {
|
test("save", async function (assert) {
|
||||||
assert.expect(0);
|
|
||||||
const store = getOwner(this).lookup("service:store");
|
const store = getOwner(this).lookup("service:store");
|
||||||
const badge = store.createRecord("badge", {
|
const badge = store.createRecord("badge", {
|
||||||
|
id: 1999,
|
||||||
name: "New Badge",
|
name: "New Badge",
|
||||||
description: "This is a new badge.",
|
description: "This is a new badge.",
|
||||||
badge_type_id: 1,
|
badge_type_id: 1,
|
||||||
});
|
});
|
||||||
badge.save(["name", "description", "badge_type_id"]);
|
|
||||||
|
pretender.put("/admin/badges/1999", (request) => {
|
||||||
|
const params = parsePostData(request.requestBody);
|
||||||
|
assert.deepEqual(params, { description: "A special badge!" });
|
||||||
|
assert.step("called API");
|
||||||
|
return response({});
|
||||||
|
});
|
||||||
|
|
||||||
|
await badge.save({
|
||||||
|
description: "A special badge!",
|
||||||
|
});
|
||||||
|
|
||||||
|
assert.verifySteps(["called API"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("destroy", function (assert) {
|
test("destroy", async function (assert) {
|
||||||
assert.expect(0);
|
|
||||||
const store = getOwner(this).lookup("service:store");
|
const store = getOwner(this).lookup("service:store");
|
||||||
const badge = store.createRecord("badge", {
|
const badge = store.createRecord("badge", {
|
||||||
name: "New Badge",
|
name: "New Badge",
|
||||||
description: "This is a new badge.",
|
description: "This is a new badge.",
|
||||||
badge_type_id: 1,
|
badge_type_id: 1,
|
||||||
});
|
});
|
||||||
badge.destroy();
|
|
||||||
|
pretender.delete("/admin/badges/3", () => {
|
||||||
|
assert.step("called API");
|
||||||
|
return response({});
|
||||||
|
});
|
||||||
|
|
||||||
|
// Doesn't call the API if destroying a new badge
|
||||||
|
await badge.destroy();
|
||||||
|
|
||||||
badge.set("id", 3);
|
badge.set("id", 3);
|
||||||
badge.destroy();
|
await badge.destroy();
|
||||||
|
|
||||||
|
assert.verifySteps(["called API"]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue