diff --git a/src/compiler/compile/render_ssr/handlers/Comment.ts b/src/compiler/compile/render_ssr/handlers/Comment.ts index 4595274bc0f4..2460f8b06433 100644 --- a/src/compiler/compile/render_ssr/handlers/Comment.ts +++ b/src/compiler/compile/render_ssr/handlers/Comment.ts @@ -1,10 +1,8 @@ import Renderer, { RenderOptions } from '../Renderer'; import Comment from '../../nodes/Comment'; -export default function(_node: Comment, _renderer: Renderer, _options: RenderOptions) { - // TODO preserve comments - - // if (options.preserveComments) { - // renderer.append(``); - // } +export default function(node: Comment, renderer: Renderer, options: RenderOptions) { + if (options.preserveComments) { + renderer.add_string(``); + } } diff --git a/test/helpers.ts b/test/helpers.ts index 4de53e6cf91a..101490d4dc2c 100644 --- a/test/helpers.ts +++ b/test/helpers.ts @@ -4,7 +4,7 @@ import glob from 'tiny-glob/sync'; import * as path from 'path'; import * as fs from 'fs'; import * as colors from 'kleur'; -export const assert = (assert$1 as unknown) as typeof assert$1 & { htmlEqual: (actual, expected, message?) => void }; +export const assert = (assert$1 as unknown) as typeof assert$1 & { htmlEqual: (actual, expected, message?) => void, htmlEqualWithComments: (actual, expected, message?) => void }; // for coverage purposes, we need to test source files, // but for sanity purposes, we need to test dist files @@ -118,6 +118,9 @@ function cleanChildren(node) { node.removeChild(child); child = previous; } + } else if (child.nodeType === 8) { + // comment + // do nothing } else { cleanChildren(child); } @@ -137,11 +140,11 @@ function cleanChildren(node) { } } -export function normalizeHtml(window, html) { +export function normalizeHtml(window, html, preserveComments = false) { try { const node = window.document.createElement('div'); node.innerHTML = html - .replace(//g, '') + .replace(/()/g, preserveComments ? '$1' : '') .replace(/>[\s\r\n]+<') .trim(); cleanChildren(node); @@ -162,6 +165,14 @@ export function setupHtmlEqual() { message ); }; + // eslint-disable-next-line no-import-assign + assert.htmlEqualWithComments = (actual, expected, message) => { + assert.deepEqual( + normalizeHtml(window, actual, true), + normalizeHtml(window, expected, true), + message + ); + }; } export function loadConfig(file) { diff --git a/test/js/samples/ssr-preserve-comments/expected.js b/test/js/samples/ssr-preserve-comments/expected.js index de9fa7582ed9..4f3326cec569 100644 --- a/test/js/samples/ssr-preserve-comments/expected.js +++ b/test/js/samples/ssr-preserve-comments/expected.js @@ -3,8 +3,8 @@ import { create_ssr_component } from "svelte/internal"; const Component = create_ssr_component(($$result, $$props, $$bindings, slots) => { return `
before
+ +after
diff --git a/test/server-side-rendering/samples/comment-preserve/main.svelte b/test/server-side-rendering/samples/comment-preserve/main.svelte new file mode 100644 index 000000000000..8ecd344816d1 --- /dev/null +++ b/test/server-side-rendering/samples/comment-preserve/main.svelte @@ -0,0 +1,3 @@ +before
+ +after