discourse/test/javascripts/models/category-test.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

333 lines
8.8 KiB
JavaScript
Raw Normal View History

import createStore from "helpers/create-store";
import Category from "discourse/models/category";
2017-06-14 13:57:58 -04:00
QUnit.module("model:category");
2017-06-14 13:57:58 -04:00
QUnit.test("slugFor", (assert) => {
const store = createStore();
const slugFor = function (cat, val, text) {
assert.equal(Category.slugFor(cat), val, text);
};
slugFor(
store.createRecord("category", { slug: "hello" }),
"hello",
"It calculates the proper slug for hello"
);
slugFor(
store.createRecord("category", { id: 123, slug: "" }),
"123-category",
"It returns id-category for empty strings"
);
slugFor(
store.createRecord("category", { id: 456 }),
"456-category",
"It returns id-category for undefined slugs"
);
slugFor(
store.createRecord("category", { slug: "熱帶風暴畫眉" }),
"熱帶風暴畫眉",
"It can be non english characters"
);
2018-06-15 11:03:24 -04:00
const parentCategory = store.createRecord("category", {
id: 345,
slug: "darth",
});
slugFor(
store.createRecord("category", {
slug: "luke",
parentCategory: parentCategory,
}),
2013-10-23 14:40:39 -04:00
"darth/luke",
"it uses the parent slug before the child"
);
2018-06-15 11:03:24 -04:00
slugFor(
store.createRecord("category", { id: 555, parentCategory: parentCategory }),
"darth/555-category",
2013-10-23 14:40:39 -04:00
"it uses the parent slug before the child and then uses id"
);
2018-06-15 11:03:24 -04:00
2013-10-23 14:40:39 -04:00
parentCategory.set("slug", null);
slugFor(
store.createRecord("category", { id: 555, parentCategory: parentCategory }),
"345-category/555-category",
2013-10-23 14:40:39 -04:00
"it uses the parent before the child and uses ids for both"
);
2013-10-23 13:29:20 -04:00
});
2017-06-14 13:57:58 -04:00
QUnit.test("findBySlug", (assert) => {
assert.expect(6);
2015-04-13 10:50:41 -04:00
const store = createStore();
const darth = store.createRecord("category", { id: 1, slug: "darth" }),
luke = store.createRecord("category", {
id: 2,
slug: "luke",
parentCategory: darth,
}),
hurricane = store.createRecord("category", { id: 3, slug: "熱帶風暴畫眉" }),
newsFeed = store.createRecord("category", {
id: 4,
slug: "뉴스피드",
parentCategory: hurricane,
}),
time = store.createRecord("category", {
id: 5,
slug: "时间",
parentCategory: darth,
}),
bah = store.createRecord("category", {
id: 6,
slug: "bah",
parentCategory: hurricane,
}),
2015-04-13 10:50:41 -04:00
categoryList = [darth, luke, hurricane, newsFeed, time, bah];
sandbox.stub(Category, "list").returns(categoryList);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.findBySlug("darth"),
2017-06-14 13:57:58 -04:00
darth,
"we can find a category"
);
assert.deepEqual(
Category.findBySlug("luke", "darth"),
2017-06-14 13:57:58 -04:00
luke,
"we can find the other category with parent category"
);
assert.deepEqual(
Category.findBySlug("熱帶風暴畫眉"),
2017-06-14 13:57:58 -04:00
hurricane,
"we can find a category with CJK slug"
);
assert.deepEqual(
Category.findBySlug("뉴스피드", "熱帶風暴畫眉"),
2017-06-14 13:57:58 -04:00
newsFeed,
"we can find a category with CJK slug whose parent slug is also CJK"
);
assert.deepEqual(
Category.findBySlug("时间", "darth"),
2017-06-14 13:57:58 -04:00
time,
"we can find a category with CJK slug whose parent slug is english"
);
assert.deepEqual(
Category.findBySlug("bah", "熱帶風暴畫眉"),
2017-06-14 13:57:58 -04:00
bah,
"we can find a category with english slug whose parent slug is CJK"
);
sandbox.restore();
2015-04-13 10:50:41 -04:00
});
2017-06-14 13:57:58 -04:00
QUnit.test("findSingleBySlug", (assert) => {
assert.expect(6);
2015-04-13 10:50:41 -04:00
const store = createStore();
const darth = store.createRecord("category", { id: 1, slug: "darth" }),
luke = store.createRecord("category", {
id: 2,
slug: "luke",
parentCategory: darth,
}),
hurricane = store.createRecord("category", { id: 3, slug: "熱帶風暴畫眉" }),
newsFeed = store.createRecord("category", {
id: 4,
slug: "뉴스피드",
parentCategory: hurricane,
}),
time = store.createRecord("category", {
id: 5,
slug: "时间",
parentCategory: darth,
}),
bah = store.createRecord("category", {
id: 6,
slug: "bah",
parentCategory: hurricane,
}),
2015-04-13 10:50:41 -04:00
categoryList = [darth, luke, hurricane, newsFeed, time, bah];
2013-10-23 14:40:39 -04:00
sandbox.stub(Category, "list").returns(categoryList);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.findSingleBySlug("darth"),
2017-06-14 13:57:58 -04:00
darth,
"we can find a category"
);
assert.deepEqual(
Category.findSingleBySlug("darth/luke"),
2017-06-14 13:57:58 -04:00
luke,
"we can find the other category with parent category"
);
assert.deepEqual(
Category.findSingleBySlug("熱帶風暴畫眉"),
2017-06-14 13:57:58 -04:00
hurricane,
"we can find a category with CJK slug"
);
assert.deepEqual(
Category.findSingleBySlug("熱帶風暴畫眉/뉴스피드"),
2017-06-14 13:57:58 -04:00
newsFeed,
"we can find a category with CJK slug whose parent slug is also CJK"
);
assert.deepEqual(
Category.findSingleBySlug("darth/时间"),
2017-06-14 13:57:58 -04:00
time,
"we can find a category with CJK slug whose parent slug is english"
);
assert.deepEqual(
Category.findSingleBySlug("熱帶風暴畫眉/bah"),
2017-06-14 13:57:58 -04:00
bah,
"we can find a category with english slug whose parent slug is CJK"
);
});
QUnit.test("findBySlugPathWithID", (assert) => {
const store = createStore();
const foo = store.createRecord("category", { id: 1, slug: "foo" });
const bar = store.createRecord("category", {
id: 2,
slug: "bar",
parentCategory: foo,
});
const baz = store.createRecord("category", {
id: 3,
slug: "baz",
parentCategory: foo,
});
const categoryList = [foo, bar, baz];
sandbox.stub(Category, "list").returns(categoryList);
assert.deepEqual(Category.findBySlugPathWithID("foo"), foo);
assert.deepEqual(Category.findBySlugPathWithID("foo/bar"), bar);
assert.deepEqual(Category.findBySlugPathWithID("foo/bar/"), bar);
assert.deepEqual(Category.findBySlugPathWithID("foo/baz/3"), baz);
});
2017-06-14 13:57:58 -04:00
QUnit.test("search with category name", (assert) => {
const store = createStore(),
category1 = store.createRecord("category", {
id: 1,
name: "middle term",
slug: "different-slug",
}),
category2 = store.createRecord("category", {
id: 2,
name: "middle term",
slug: "another-different-slug",
});
sandbox.stub(Category, "listByActivity").returns([category1, category2]);
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("term", { limit: 0 }),
[],
"returns an empty array when limit is 0"
);
assert.deepEqual(
Category.search(""),
[category1, category2],
"orders by activity if no term is matched"
);
assert.deepEqual(
Category.search("term"),
[category1, category2],
"orders by activity"
2018-06-15 11:03:24 -04:00
);
category2.set("name", "TeRm start");
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("tErM"),
[category2, category1],
"ignores case of category name and search term"
);
2018-06-15 11:03:24 -04:00
category2.set("name", "term start");
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("term"),
[category2, category1],
"orders matching begin with and then contains"
);
sandbox.restore();
const child_category1 = store.createRecord("category", {
id: 3,
name: "term start",
parent_category_id: category1.get("id"),
}),
read_restricted_category = store.createRecord("category", {
id: 4,
name: "some term",
read_restricted: true,
});
2018-06-15 11:03:24 -04:00
sandbox
.stub(Category, "listByActivity")
.returns([read_restricted_category, category1, child_category1, category2]);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search(""),
[category1, category2, read_restricted_category],
"prioritize non read_restricted and does not include child categories when term is blank"
);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("", { limit: 3 }),
[category1, category2, read_restricted_category],
"prioritize non read_restricted and does not include child categories categories when term is blank with limit"
);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("term"),
[child_category1, category2, category1, read_restricted_category],
"prioritize non read_restricted"
);
2018-06-15 11:03:24 -04:00
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("term", { limit: 3 }),
[child_category1, category2, read_restricted_category],
"prioritize non read_restricted with limit"
);
sandbox.restore();
});
2017-06-14 13:57:58 -04:00
QUnit.test("search with category slug", (assert) => {
const store = createStore(),
category1 = store.createRecord("category", {
id: 1,
name: "middle term",
slug: "different-slug",
}),
category2 = store.createRecord("category", {
id: 2,
name: "middle term",
slug: "another-different-slug",
});
sandbox.stub(Category, "listByActivity").returns([category1, category2]);
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("different-slug"),
[category1, category2],
"returns the right categories"
);
assert.deepEqual(
Category.search("another-different"),
[category2],
"returns the right categories"
2018-06-15 11:03:24 -04:00
);
category2.set("slug", "ANOTher-DIFfereNT");
2017-06-14 13:57:58 -04:00
assert.deepEqual(
Category.search("anOtHer-dIfFeREnt"),
[category2],
"ignores case of category slug and search term"
);
});