mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-15 20:10:42 +00:00
* fix: Signal and markdown formatting improvements Markdown IR fixes: - Fix list-paragraph spacing (extra newline between list items and following paragraphs) - Fix nested list indentation and newline handling - Fix blockquote_close emitting redundant newline (inner content handles spacing) - Render horizontal rules as visible ─── separator instead of silent drop - Strip inner cell styles in code-mode tables to prevent overlapping with code_block span Signal formatting fixes: - Normalize URLs for dedup comparison (strip protocol, www., trailing slash) - Render headings as bold text (headingStyle: 'bold') - Add '> ' prefix to blockquotes for visual distinction - Re-chunk after link expansion to respect chunk size limits Tests: - 51 new tests for markdown IR (spacing, lists, blockquotes, tables, HR) - 18 new tests for Signal formatting (URL dedup, headings, blockquotes, HR, chunking) - Update Slack nested list test expectation to match corrected IR output * refactor: style-aware Signal text chunker Replace indexOf-based chunk position tracking with deterministic cursor tracking. The new splitSignalFormattedText: - Splits at whitespace/newline boundaries within the limit - Avoids breaking inside parentheses (preserves expanded link URLs) - Slices style ranges at chunk boundaries with correct local offsets - Tracks position via offset arithmetic instead of fragile indexOf Removes dependency on chunkText from auto-reply/chunk. Tests: 19 new tests covering style preservation across chunk boundaries, edge cases (empty text, under limit, exact split points), and integration with link expansion. * fix: correct Signal style offsets with multiple link expansions applyInsertionsToStyles() was using original coordinates for each insertion without tracking cumulative shift from prior insertions. This caused bold/italic/etc styles to drift to wrong text positions when multiple markdown links expanded in a single message. Added cumulative shift tracking and a regression test. * test: clean up test noise and fix ineffective assertions - Remove console.log from ir.list-spacing and ir.hr-spacing tests - Fix ir.nested-lists.test.ts: remove ineffective regex assertion - Fix ir.hr-spacing.test.ts: add actual assertions to edge case test * refactor: split Signal formatting tests (#9781) (thanks @heyhudson) --------- Co-authored-by: Hudson <258693705+hudson-rivera@users.noreply.github.com> Co-authored-by: Peter Steinberger <steipete@gmail.com>
58 lines
2.1 KiB
TypeScript
58 lines
2.1 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import { markdownToSignalText } from "./format.js";
|
|
|
|
describe("markdownToSignalText", () => {
|
|
describe("headings visual distinction", () => {
|
|
it("renders headings as bold text", () => {
|
|
const res = markdownToSignalText("# Heading 1");
|
|
expect(res.text).toBe("Heading 1");
|
|
expect(res.styles).toContainEqual({ start: 0, length: 9, style: "BOLD" });
|
|
});
|
|
|
|
it("renders h2 headings as bold text", () => {
|
|
const res = markdownToSignalText("## Heading 2");
|
|
expect(res.text).toBe("Heading 2");
|
|
expect(res.styles).toContainEqual({ start: 0, length: 9, style: "BOLD" });
|
|
});
|
|
|
|
it("renders h3 headings as bold text", () => {
|
|
const res = markdownToSignalText("### Heading 3");
|
|
expect(res.text).toBe("Heading 3");
|
|
expect(res.styles).toContainEqual({ start: 0, length: 9, style: "BOLD" });
|
|
});
|
|
});
|
|
|
|
describe("blockquote visual distinction", () => {
|
|
it("renders blockquotes with a visible prefix", () => {
|
|
const res = markdownToSignalText("> This is a quote");
|
|
// Should have some kind of prefix to distinguish it
|
|
expect(res.text).toMatch(/^[│>]/);
|
|
expect(res.text).toContain("This is a quote");
|
|
});
|
|
|
|
it("renders multi-line blockquotes with prefix", () => {
|
|
const res = markdownToSignalText("> Line 1\n> Line 2");
|
|
// Should start with the prefix
|
|
expect(res.text).toMatch(/^[│>]/);
|
|
expect(res.text).toContain("Line 1");
|
|
expect(res.text).toContain("Line 2");
|
|
});
|
|
});
|
|
|
|
describe("horizontal rule rendering", () => {
|
|
it("renders horizontal rules as a visible separator", () => {
|
|
const res = markdownToSignalText("Para 1\n\n---\n\nPara 2");
|
|
// Should contain some kind of visual separator like ───
|
|
expect(res.text).toMatch(/[─—-]{3,}/);
|
|
});
|
|
|
|
it("renders horizontal rule between content", () => {
|
|
const res = markdownToSignalText("Above\n\n***\n\nBelow");
|
|
expect(res.text).toContain("Above");
|
|
expect(res.text).toContain("Below");
|
|
// Should have a separator
|
|
expect(res.text).toMatch(/[─—-]{3,}/);
|
|
});
|
|
});
|
|
});
|