Skip to content

Commit e2ad0bb

Browse files
committed
Prevent embedding images with empty src attribute
1 parent 1a31d9a commit e2ad0bb

File tree

7 files changed

+55
-1
lines changed

7 files changed

+55
-1
lines changed

src/embed-images.ts

+11
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,17 @@ async function embedImageNode<T extends HTMLElement | SVGImageElement>(
4040
) {
4141
const isImageElement = isInstanceOfElement(clonedNode, HTMLImageElement)
4242

43+
// Skip images with empty sources. Note that reading the src property of an HTMLImageElement (or href of SVGImageElement)
44+
// which has an empty value will return the current URL.
45+
// This is a workaround to prevent the loading of current page URL as an image when there are empty images in the DOM.
46+
if (
47+
(isImageElement && clonedNode.getAttribute('src') === '') ||
48+
(isInstanceOfElement(clonedNode, SVGImageElement) &&
49+
clonedNode.getAttribute('href') === '')
50+
) {
51+
return
52+
}
53+
4354
if (
4455
!(isImageElement && !isDataUrl(clonedNode.src)) &&
4556
!(

test/resources/images/node-empty-png

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+


test/resources/images/node-empty.html

+2
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
<img src="" />
2+
<img src="/base/test/resources/images/image.png" />
+17
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
<svg
2+
width="200"
3+
height="200"
4+
viewBox="0 0 200 200"
5+
xmlns="http://www.w3.org/2000/svg"
6+
>
7+
<image
8+
height="200"
9+
width="200"
10+
href="/base/test/resources/svg-image/svg-image.png"
11+
/>
12+
<image
13+
height="200"
14+
width="200"
15+
href=""
16+
/>
17+
</svg>

test/spec/basic.spec.ts

+12
Original file line numberDiff line numberDiff line change
@@ -183,6 +183,18 @@ describe('basic usage', () => {
183183
.catch(done)
184184
})
185185

186+
it('should not fail on empty images', (done) => {
187+
bootstrap(
188+
'images/node-empty.html',
189+
'images/style.css',
190+
'images/node-empty-png',
191+
)
192+
.then(delay(500))
193+
.then(assertTextRendered(['PNG']))
194+
.then(done)
195+
.catch(done)
196+
})
197+
186198
it('should render webp images', (done) => {
187199
bootstrap('webp/node.html', 'webp/style.css')
188200
.then(delay(500))

test/spec/helper.ts

+1-1
Original file line numberDiff line numberDiff line change
@@ -164,7 +164,7 @@ export async function getSvgDocument(dataUrl: string): Promise<XMLDocument> {
164164
.then((str) => new window.DOMParser().parseFromString(str, 'text/xml'))
165165
}
166166

167-
const PASS_TEXT_MATCH = true
167+
const PASS_TEXT_MATCH = false
168168

169169
export function assertTextRendered(lines: string[], options?: Options) {
170170
return (node: HTMLDivElement = getCaptureNode()) =>

test/spec/svg.spec.ts

+11
Original file line numberDiff line numberDiff line change
@@ -47,6 +47,17 @@ describe('work with svg element', () => {
4747
.catch(done)
4848
})
4949

50+
it('should not fail on empty href in svg `<image>`', (done) => {
51+
bootstrap(
52+
'svg-image/node-empty.html',
53+
'svg-image/style.css',
54+
'svg-image/image',
55+
)
56+
.then(renderAndCheck)
57+
.then(done)
58+
.catch(done)
59+
})
60+
5061
it('should render SVG use tags', function (done) {
5162
bootstrap(
5263
'svg-use-tag/node.html',

0 commit comments

Comments
 (0)