2020-07-12 00:40:13 +08:00
|
|
|
require("@testing-library/jest-dom");
|
2020-07-12 10:28:28 +08:00
|
|
|
const cssToObject = require("css-to-object");
|
2020-08-02 15:37:26 +08:00
|
|
|
const renderStatsCard = require("../src/cards/stats-card");
|
2020-07-12 00:40:13 +08:00
|
|
|
|
2020-07-16 18:21:21 +08:00
|
|
|
const {
|
|
|
|
getByTestId,
|
|
|
|
queryByTestId,
|
|
|
|
queryAllByTestId,
|
|
|
|
} = require("@testing-library/dom");
|
2020-07-19 23:04:41 +08:00
|
|
|
const themes = require("../themes");
|
2020-07-12 00:40:13 +08:00
|
|
|
|
|
|
|
describe("Test renderStatsCard", () => {
|
|
|
|
const stats = {
|
|
|
|
name: "Anurag Hazra",
|
|
|
|
totalStars: 100,
|
|
|
|
totalCommits: 200,
|
|
|
|
totalIssues: 300,
|
|
|
|
totalPRs: 400,
|
|
|
|
contributedTo: 500,
|
2020-07-14 22:34:36 +08:00
|
|
|
rank: { level: "A+", score: 40 },
|
2020-07-12 00:40:13 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
it("should render correctly", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats);
|
|
|
|
|
|
|
|
expect(document.getElementsByClassName("header")[0].textContent).toBe(
|
2020-09-25 00:08:14 +08:00
|
|
|
"Anurag Hazra's GitHub Stats",
|
2020-07-12 00:40:13 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
expect(
|
2020-09-25 00:08:14 +08:00
|
|
|
document.body.getElementsByTagName("svg")[0].getAttribute("height"),
|
2020-07-12 00:40:13 +08:00
|
|
|
).toBe("195");
|
|
|
|
expect(getByTestId(document.body, "stars").textContent).toBe("100");
|
|
|
|
expect(getByTestId(document.body, "commits").textContent).toBe("200");
|
|
|
|
expect(getByTestId(document.body, "issues").textContent).toBe("300");
|
|
|
|
expect(getByTestId(document.body, "prs").textContent).toBe("400");
|
|
|
|
expect(getByTestId(document.body, "contribs").textContent).toBe("500");
|
2020-07-19 23:04:41 +08:00
|
|
|
expect(queryByTestId(document.body, "card-bg")).toBeInTheDocument();
|
2020-07-13 22:11:47 +08:00
|
|
|
expect(queryByTestId(document.body, "rank-circle")).toBeInTheDocument();
|
2020-07-12 00:40:13 +08:00
|
|
|
});
|
|
|
|
|
2020-07-20 02:32:07 +08:00
|
|
|
it("should have proper name apostrophe", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard({ ...stats, name: "Anil Das" });
|
|
|
|
|
|
|
|
expect(document.getElementsByClassName("header")[0].textContent).toBe(
|
2020-09-25 00:08:14 +08:00
|
|
|
"Anil Das' GitHub Stats",
|
2020-07-20 02:32:07 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
document.body.innerHTML = renderStatsCard({ ...stats, name: "Felix" });
|
|
|
|
|
|
|
|
expect(document.getElementsByClassName("header")[0].textContent).toBe(
|
2020-09-25 00:08:14 +08:00
|
|
|
"Felix' GitHub Stats",
|
2020-07-20 02:32:07 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2020-07-12 00:40:13 +08:00
|
|
|
it("should hide individual stats", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
2020-07-23 23:31:23 +08:00
|
|
|
hide: ["issues", "prs", "contribs"],
|
2020-07-12 00:40:13 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
expect(
|
2020-09-25 00:08:14 +08:00
|
|
|
document.body.getElementsByTagName("svg")[0].getAttribute("height"),
|
2020-07-13 22:11:47 +08:00
|
|
|
).toBe("150"); // height should be 150 because we clamped it.
|
|
|
|
|
2020-07-12 00:40:13 +08:00
|
|
|
expect(queryByTestId(document.body, "stars")).toBeDefined();
|
|
|
|
expect(queryByTestId(document.body, "commits")).toBeDefined();
|
|
|
|
expect(queryByTestId(document.body, "issues")).toBeNull();
|
|
|
|
expect(queryByTestId(document.body, "prs")).toBeNull();
|
|
|
|
expect(queryByTestId(document.body, "contribs")).toBeNull();
|
|
|
|
});
|
|
|
|
|
2020-07-13 22:11:47 +08:00
|
|
|
it("should hide_rank", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, { hide_rank: true });
|
|
|
|
|
|
|
|
expect(queryByTestId(document.body, "rank-circle")).not.toBeInTheDocument();
|
|
|
|
});
|
|
|
|
|
2020-07-12 10:28:28 +08:00
|
|
|
it("should render default colors properly", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats);
|
|
|
|
|
|
|
|
const styleTag = document.querySelector("style");
|
2020-07-14 22:34:36 +08:00
|
|
|
const stylesObject = cssToObject(styleTag.textContent);
|
2020-07-12 10:28:28 +08:00
|
|
|
|
|
|
|
const headerClassStyles = stylesObject[".header"];
|
|
|
|
const statClassStyles = stylesObject[".stat"];
|
|
|
|
const iconClassStyles = stylesObject[".icon"];
|
|
|
|
|
|
|
|
expect(headerClassStyles.fill).toBe("#2f80ed");
|
|
|
|
expect(statClassStyles.fill).toBe("#333");
|
|
|
|
expect(iconClassStyles.fill).toBe("#4c71f2");
|
2020-07-19 23:04:41 +08:00
|
|
|
expect(queryByTestId(document.body, "card-bg")).toHaveAttribute(
|
2020-07-12 15:16:08 +08:00
|
|
|
"fill",
|
2020-09-25 00:08:14 +08:00
|
|
|
"#fffefe",
|
2020-07-12 15:16:08 +08:00
|
|
|
);
|
2020-07-12 10:28:28 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should render custom colors properly", () => {
|
|
|
|
const customColors = {
|
|
|
|
title_color: "5a0",
|
|
|
|
icon_color: "1b998b",
|
|
|
|
text_color: "9991",
|
2020-07-12 15:16:08 +08:00
|
|
|
bg_color: "252525",
|
2020-07-12 10:28:28 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, { ...customColors });
|
|
|
|
|
|
|
|
const styleTag = document.querySelector("style");
|
|
|
|
const stylesObject = cssToObject(styleTag.innerHTML);
|
|
|
|
|
|
|
|
const headerClassStyles = stylesObject[".header"];
|
|
|
|
const statClassStyles = stylesObject[".stat"];
|
|
|
|
const iconClassStyles = stylesObject[".icon"];
|
|
|
|
|
|
|
|
expect(headerClassStyles.fill).toBe(`#${customColors.title_color}`);
|
|
|
|
expect(statClassStyles.fill).toBe(`#${customColors.text_color}`);
|
|
|
|
expect(iconClassStyles.fill).toBe(`#${customColors.icon_color}`);
|
2020-07-19 23:04:41 +08:00
|
|
|
expect(queryByTestId(document.body, "card-bg")).toHaveAttribute(
|
2020-07-12 15:16:08 +08:00
|
|
|
"fill",
|
2020-09-25 00:08:14 +08:00
|
|
|
"#252525",
|
2020-07-12 15:16:08 +08:00
|
|
|
);
|
2020-07-12 10:28:28 +08:00
|
|
|
});
|
2020-07-16 18:21:21 +08:00
|
|
|
|
2020-07-19 23:04:41 +08:00
|
|
|
it("should render custom colors with themes", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
|
|
|
title_color: "5a0",
|
|
|
|
theme: "radical",
|
|
|
|
});
|
|
|
|
|
|
|
|
const styleTag = document.querySelector("style");
|
|
|
|
const stylesObject = cssToObject(styleTag.innerHTML);
|
|
|
|
|
|
|
|
const headerClassStyles = stylesObject[".header"];
|
|
|
|
const statClassStyles = stylesObject[".stat"];
|
|
|
|
const iconClassStyles = stylesObject[".icon"];
|
|
|
|
|
|
|
|
expect(headerClassStyles.fill).toBe("#5a0");
|
|
|
|
expect(statClassStyles.fill).toBe(`#${themes.radical.text_color}`);
|
|
|
|
expect(iconClassStyles.fill).toBe(`#${themes.radical.icon_color}`);
|
|
|
|
expect(queryByTestId(document.body, "card-bg")).toHaveAttribute(
|
|
|
|
"fill",
|
2020-09-25 00:08:14 +08:00
|
|
|
`#${themes.radical.bg_color}`,
|
2020-07-19 23:04:41 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2020-07-21 15:45:53 +08:00
|
|
|
it("should render with all the themes", () => {
|
|
|
|
Object.keys(themes).forEach((name) => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
|
|
|
theme: name,
|
|
|
|
});
|
|
|
|
|
|
|
|
const styleTag = document.querySelector("style");
|
|
|
|
const stylesObject = cssToObject(styleTag.innerHTML);
|
|
|
|
|
|
|
|
const headerClassStyles = stylesObject[".header"];
|
|
|
|
const statClassStyles = stylesObject[".stat"];
|
|
|
|
const iconClassStyles = stylesObject[".icon"];
|
|
|
|
|
|
|
|
expect(headerClassStyles.fill).toBe(`#${themes[name].title_color}`);
|
|
|
|
expect(statClassStyles.fill).toBe(`#${themes[name].text_color}`);
|
|
|
|
expect(iconClassStyles.fill).toBe(`#${themes[name].icon_color}`);
|
|
|
|
expect(queryByTestId(document.body, "card-bg")).toHaveAttribute(
|
|
|
|
"fill",
|
2020-09-25 00:08:14 +08:00
|
|
|
`#${themes[name].bg_color}`,
|
2020-07-21 15:45:53 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-07-19 23:04:41 +08:00
|
|
|
it("should render custom colors with themes and fallback to default colors if invalid", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
|
|
|
title_color: "invalid color",
|
|
|
|
text_color: "invalid color",
|
|
|
|
theme: "radical",
|
|
|
|
});
|
|
|
|
|
|
|
|
const styleTag = document.querySelector("style");
|
|
|
|
const stylesObject = cssToObject(styleTag.innerHTML);
|
|
|
|
|
|
|
|
const headerClassStyles = stylesObject[".header"];
|
|
|
|
const statClassStyles = stylesObject[".stat"];
|
|
|
|
const iconClassStyles = stylesObject[".icon"];
|
|
|
|
|
|
|
|
expect(headerClassStyles.fill).toBe(`#${themes.default.title_color}`);
|
|
|
|
expect(statClassStyles.fill).toBe(`#${themes.default.text_color}`);
|
|
|
|
expect(iconClassStyles.fill).toBe(`#${themes.radical.icon_color}`);
|
|
|
|
expect(queryByTestId(document.body, "card-bg")).toHaveAttribute(
|
|
|
|
"fill",
|
2020-09-25 00:08:14 +08:00
|
|
|
`#${themes.radical.bg_color}`,
|
2020-07-19 23:04:41 +08:00
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2020-07-16 18:21:21 +08:00
|
|
|
it("should render icons correctly", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
2020-07-18 01:31:16 +08:00
|
|
|
show_icons: true,
|
2020-07-16 18:21:21 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
expect(queryAllByTestId(document.body, "icon")[0]).toBeDefined();
|
|
|
|
expect(queryByTestId(document.body, "stars")).toBeDefined();
|
|
|
|
expect(
|
2020-09-25 00:08:14 +08:00
|
|
|
queryByTestId(document.body, "stars").previousElementSibling, // the label
|
2020-07-16 18:21:21 +08:00
|
|
|
).toHaveAttribute("x", "25");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should not have icons if show_icons is false", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, { show_icons: false });
|
|
|
|
|
|
|
|
expect(queryAllByTestId(document.body, "icon")[0]).not.toBeDefined();
|
|
|
|
expect(queryByTestId(document.body, "stars")).toBeDefined();
|
|
|
|
expect(
|
2020-09-25 00:08:14 +08:00
|
|
|
queryByTestId(document.body, "stars").previousElementSibling, // the label
|
2020-07-16 18:21:21 +08:00
|
|
|
).not.toHaveAttribute("x");
|
|
|
|
});
|
2020-10-04 16:05:15 +08:00
|
|
|
|
2020-12-13 22:45:00 +08:00
|
|
|
it("should auto resize if hide_rank is true", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
|
|
|
hide_rank: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(
|
|
|
|
document.body.getElementsByTagName("svg")[0].getAttribute("width"),
|
|
|
|
).toBe("305.81250000000006");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should auto resize if hide_rank is true & custom_title is set", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, {
|
|
|
|
hide_rank: true,
|
|
|
|
custom_title: "Hello world",
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(
|
|
|
|
document.body.getElementsByTagName("svg")[0].getAttribute("width"),
|
|
|
|
).toBe("270");
|
|
|
|
});
|
|
|
|
|
2020-10-04 16:05:15 +08:00
|
|
|
it("should render translations", () => {
|
|
|
|
document.body.innerHTML = renderStatsCard(stats, { locale: "cn" });
|
|
|
|
expect(document.getElementsByClassName("header")[0].textContent).toBe(
|
2020-10-04 22:47:13 +08:00
|
|
|
"Anurag Hazra 的 GitHub 统计",
|
2020-10-04 16:05:15 +08:00
|
|
|
);
|
|
|
|
expect(
|
|
|
|
document.querySelector(
|
|
|
|
'g[transform="translate(0, 0)"]>.stagger>.stat.bold',
|
|
|
|
).textContent,
|
2020-10-04 22:47:13 +08:00
|
|
|
).toBe("总 Star:");
|
2020-10-04 16:05:15 +08:00
|
|
|
expect(
|
|
|
|
document.querySelector(
|
|
|
|
'g[transform="translate(0, 25)"]>.stagger>.stat.bold',
|
|
|
|
).textContent,
|
2021-01-03 16:10:38 +08:00
|
|
|
).toBe(`总提交 (${new Date().getFullYear()}):`);
|
2020-10-04 16:05:15 +08:00
|
|
|
expect(
|
|
|
|
document.querySelector(
|
|
|
|
'g[transform="translate(0, 50)"]>.stagger>.stat.bold',
|
|
|
|
).textContent,
|
2020-10-04 22:47:13 +08:00
|
|
|
).toBe("总 PR:");
|
2020-10-04 16:05:15 +08:00
|
|
|
expect(
|
|
|
|
document.querySelector(
|
|
|
|
'g[transform="translate(0, 75)"]>.stagger>.stat.bold',
|
|
|
|
).textContent,
|
2020-10-04 22:47:13 +08:00
|
|
|
).toBe("总 Issue:");
|
2020-10-04 16:05:15 +08:00
|
|
|
expect(
|
|
|
|
document.querySelector(
|
|
|
|
'g[transform="translate(0, 100)"]>.stagger>.stat.bold',
|
|
|
|
).textContent,
|
2020-10-04 22:47:13 +08:00
|
|
|
).toBe("总贡献:");
|
2020-10-04 16:05:15 +08:00
|
|
|
});
|
2020-07-12 00:40:13 +08:00
|
|
|
});
|