mail/static/tests/core/search_highlight_test.js

192 lines
7.6 KiB
JavaScript
Raw Permalink Normal View History

2024-05-03 12:40:35 +03:00
/* @odoo-module */
import { HIGHLIGHT_CLASS, searchHighlight } from "@mail/core/common/message_search_hook";
import { triggerHotkey } from "@web/../tests/helpers/utils";
import { click, contains, insertText } from "@web/../tests/utils";
import { startServer } from "@bus/../tests/helpers/mock_python_environment";
import { start } from "../helpers/test_utils";
import { SIZES, patchUiSize } from "../helpers/patch_ui_size";
QUnit.module("Search highlight test", {});
QUnit.test("Search highlight", async (assert) => {
const testCases = [
{
input: "test odoo",
output: `test <span class="${HIGHLIGHT_CLASS}">odoo</span>`,
searchTerm: "odoo",
},
{
2024-05-28 17:34:57 +03:00
input: '<a href="#">https://www.odoo.com</a>',
output: `<a href="#">https://www.<span class="${HIGHLIGHT_CLASS}">odoo</span>.com</a>`,
2024-05-03 12:40:35 +03:00
searchTerm: "odoo",
},
{
2024-05-28 17:34:57 +03:00
input: '<a href="#">Odoo</a>',
output: `<a href="#"><span class="${HIGHLIGHT_CLASS}">Odoo</span></a>`,
2024-05-03 12:40:35 +03:00
searchTerm: "odoo",
},
{
2024-05-28 17:34:57 +03:00
input: '<a href="#">Odoo</a>Talismanis a free software',
output: `<a href="#"><span class="${HIGHLIGHT_CLASS}">Odoo</span></a> <span class="${HIGHLIGHT_CLASS}">Odoo</span> is a free software`,
2024-05-03 12:40:35 +03:00
searchTerm: "odoo",
},
{
input: "odoo is a free software",
output: `<span class="${HIGHLIGHT_CLASS}">odoo</span> is a free software`,
searchTerm: "odoo",
},
{
input: "software ODOO is a free",
output: `software <span class="${HIGHLIGHT_CLASS}">ODOO</span> is a free`,
searchTerm: "odoo",
},
{
input: `<ul>
<li>Odoo</li>
<li><a href="https://odoo.com">Odoo ERP</a> Best ERP</li>
</ul>`,
output: `<ul>
<li><span class="${HIGHLIGHT_CLASS}">Odoo</span></li>
<li><a href="https://odoo.com"><span class="${HIGHLIGHT_CLASS}">Odoo</span> ERP</a> Best ERP</li>
</ul>`,
searchTerm: "odoo",
},
{
input: "test <strong>Odoo</strong> test",
output: `<span class="${HIGHLIGHT_CLASS}">test</span> <strong><span class="${HIGHLIGHT_CLASS}">Odoo</span></strong> <span class="${HIGHLIGHT_CLASS}">test</span>`,
searchTerm: "odoo test",
},
{
input: "test <br> test",
output: `<span class="${HIGHLIGHT_CLASS}">test</span> <br> <span class="${HIGHLIGHT_CLASS}">test</span>`,
searchTerm: "odoo test",
},
{
input: "<strong>test</strong> test",
output: `<strong><span class="${HIGHLIGHT_CLASS}">test</span></strong> <span class="${HIGHLIGHT_CLASS}">test</span>`,
searchTerm: "test",
},
{
input: "<strong>a</strong> test",
output: `<strong><span class="${HIGHLIGHT_CLASS}">a</span></strong> <span class="${HIGHLIGHT_CLASS}">test</span>`,
searchTerm: "a test",
},
{
input: "&amp;amp;",
output: `<span class="${HIGHLIGHT_CLASS}">&amp;amp;</span>`,
searchTerm: "&amp;",
},
{
input: "&amp;amp;",
output: `<span class="${HIGHLIGHT_CLASS}">&amp;</span>amp;`,
searchTerm: "&",
},
{
input: "<strong>test</strong> hello",
output: `<strong><span class="${HIGHLIGHT_CLASS}">test</span></strong> <span class="${HIGHLIGHT_CLASS}">hello</span>`,
searchTerm: "test hello",
},
{
input: "<p>&lt;strong&gt;test&lt;/strong&gt; hello</p>",
output: `<p>&lt;strong&gt;<span class="${HIGHLIGHT_CLASS}">test</span>&lt;/strong&gt; <span class="${HIGHLIGHT_CLASS}">hello</span></p>`,
searchTerm: "test hello",
},
];
for (const { input, output, searchTerm } of testCases) {
assert.equal(searchHighlight(searchTerm, input), output);
}
});
QUnit.test("Display highligthed search in chatter", async () => {
patchUiSize({ size: SIZES.XXL });
const pyEnv = await startServer();
const partnerId = pyEnv["res.partner"].create({ name: "John Doe" });
pyEnv["mail.message"].create({
body: "not empty",
model: "res.partner",
res_id: partnerId,
});
const { openFormView } = await start();
await openFormView("res.partner", partnerId);
await click("[title='Search Messages']");
await insertText(".o_searchview_input", "empty");
triggerHotkey("Enter");
await contains(`.o-mail-Chatter-search .o-mail-Message span.${HIGHLIGHT_CLASS}`);
});
QUnit.test("Display multiple highligthed search in chatter", async () => {
patchUiSize({ size: SIZES.XXL });
const pyEnv = await startServer();
const partnerId = pyEnv["res.partner"].create({ name: "John Doe" });
pyEnv["mail.message"].create({
body: "not test empty",
model: "res.partner",
res_id: partnerId,
});
const { openFormView } = await start();
await openFormView("res.partner", partnerId);
await click("[title='Search Messages']");
await insertText(".o_searchview_input", "not empty");
triggerHotkey("Enter");
await contains(`.o-mail-Chatter-search .o-mail-Message span.${HIGHLIGHT_CLASS}`, { count: 2 });
});
QUnit.test("Display highligthed search in Discuss", async () => {
const pyEnv = await startServer();
const channelId = pyEnv["discuss.channel"].create({ name: "General" });
pyEnv["mail.message"].create({
author_id: pyEnv.currentPartnerId,
body: "not empty",
attachment_ids: [],
message_type: "comment",
model: "discuss.channel",
res_id: channelId,
});
const { openDiscuss } = await start();
await openDiscuss(channelId);
await click("button[title='Search Messages']");
await insertText(".o_searchview_input", "empty");
triggerHotkey("Enter");
await contains(`.o-mail-SearchMessagesPanel .o-mail-Message span.${HIGHLIGHT_CLASS}`);
});
QUnit.test("Display multiple highligthed search in Discuss", async () => {
const pyEnv = await startServer();
const channelId = pyEnv["discuss.channel"].create({ name: "General" });
pyEnv["mail.message"].create({
author_id: pyEnv.currentPartnerId,
body: "not prout empty",
attachment_ids: [],
message_type: "comment",
model: "discuss.channel",
res_id: channelId,
});
const { openDiscuss } = await start();
await openDiscuss(channelId);
await click("button[title='Search Messages']");
await insertText(".o_searchview_input", "not empty");
triggerHotkey("Enter");
await contains(`.o-mail-SearchMessagesPanel .o-mail-Message span.${HIGHLIGHT_CLASS}`, {
count: 2,
});
});
QUnit.test("Display highligthed with escaped character must ignore them", async () => {
patchUiSize({ size: SIZES.XXL });
const pyEnv = await startServer();
const partnerId = pyEnv["res.partner"].create({ name: "John Doe" });
pyEnv["mail.message"].create({
body: "<p>&lt;strong&gt;test&lt;/strong&gt; hello</p>",
model: "res.partner",
res_id: partnerId,
});
const { openFormView } = await start();
await openFormView("res.partner", partnerId);
await click("[title='Search Messages']");
await insertText(".o_searchview_input", "test hello");
triggerHotkey("Enter");
await contains(`.o-mail-Chatter-search .o-mail-Message span.${HIGHLIGHT_CLASS}`, { count: 2 });
await contains(`.o-mail-Message-body`, { text: "<strong>test</strong> hello" });
});