mirror of
https://github.com/lovell/sharp.git
synced 2025-07-09 10:30:15 +02:00
160 lines
5.5 KiB
JavaScript
160 lines
5.5 KiB
JavaScript
'use strict';
|
|
|
|
const fs = require('fs');
|
|
const assert = require('assert');
|
|
|
|
const sharp = require('../../');
|
|
const fixtures = require('../fixtures');
|
|
|
|
describe('SVG input', function () {
|
|
it('Convert SVG to PNG at default 72DPI', function (done) {
|
|
sharp(fixtures.inputSvg)
|
|
.resize(1024)
|
|
.extract({ left: 290, top: 760, width: 40, height: 40 })
|
|
.toFormat('png')
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(40, info.width);
|
|
assert.strictEqual(40, info.height);
|
|
fixtures.assertSimilar(fixtures.expected('svg72.png'), data, function (err) {
|
|
if (err) throw err;
|
|
sharp(data).metadata(function (err, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual(72, info.density);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
it('Convert SVG to PNG at 1200DPI', function (done) {
|
|
sharp(fixtures.inputSvg, { density: 1200 })
|
|
.resize(1024)
|
|
.extract({ left: 290, top: 760, width: 40, height: 40 })
|
|
.toFormat('png')
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(40, info.width);
|
|
assert.strictEqual(40, info.height);
|
|
fixtures.assertSimilar(fixtures.expected('svg1200.png'), data, function (err) {
|
|
if (err) throw err;
|
|
sharp(data).metadata(function (err, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual(1200, info.density);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
it('Convert SVG to PNG at DPI larger than 2400', function (done) {
|
|
const size = 1024;
|
|
sharp(fixtures.inputSvgSmallViewBox).metadata(function (err, metadata) {
|
|
if (err) throw err;
|
|
const density = (size / Math.max(metadata.width, metadata.height)) * metadata.density;
|
|
sharp(fixtures.inputSvgSmallViewBox, { density })
|
|
.resize(size)
|
|
.toFormat('png')
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(size, info.width);
|
|
assert.strictEqual(size, info.height);
|
|
fixtures.assertSimilar(fixtures.expected('circle.png'), data, function (err) {
|
|
if (err) throw err;
|
|
sharp(data).metadata(function (err, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual(9216, info.density);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
it('Convert SVG to PNG utilizing scale-on-load', function (done) {
|
|
const size = 1024;
|
|
sharp(fixtures.inputSvgSmallViewBox)
|
|
.resize(size)
|
|
.toFormat('png')
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(size, info.width);
|
|
assert.strictEqual(size, info.height);
|
|
fixtures.assertSimilar(fixtures.expected('circle.png'), data, function (err) {
|
|
if (err) throw err;
|
|
sharp(data).metadata(function (err, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual(72, info.density);
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
it('Convert SVG to PNG at 14.4DPI', function (done) {
|
|
sharp(fixtures.inputSvg, { density: 14.4 })
|
|
.toFormat('png')
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(20, info.width);
|
|
assert.strictEqual(20, info.height);
|
|
fixtures.assertSimilar(fixtures.expected('svg14.4.png'), data, function (err) {
|
|
if (err) throw err;
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
it('Convert SVG with embedded images to PNG, respecting dimensions, autoconvert to PNG', function (done) {
|
|
sharp(fixtures.inputSvgWithEmbeddedImages)
|
|
.toBuffer(function (err, data, info) {
|
|
if (err) throw err;
|
|
assert.strictEqual('png', info.format);
|
|
assert.strictEqual(480, info.width);
|
|
assert.strictEqual(360, info.height);
|
|
assert.strictEqual(4, info.channels);
|
|
fixtures.assertSimilar(fixtures.expected('svg-embedded.png'), data, done);
|
|
});
|
|
});
|
|
|
|
it('Converts SVG with truncated embedded PNG', async () => {
|
|
const truncatedPng = fs.readFileSync(fixtures.inputPngTruncated).toString('base64');
|
|
const svg = `<?xml version="1.0" encoding="UTF-8"?>
|
|
<svg width="294" height="240" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
|
<image width="294" height="240" xlink:href="data:image/png;base64,${truncatedPng}"/>
|
|
</svg>`;
|
|
|
|
const { info } = await sharp(Buffer.from(svg)).toBuffer({ resolveWithObject: true });
|
|
assert.strictEqual(info.format, 'png');
|
|
assert.strictEqual(info.width, 294);
|
|
assert.strictEqual(info.height, 240);
|
|
assert.strictEqual(info.channels, 4);
|
|
});
|
|
|
|
it('Fails to render SVG larger than 32767x32767', () =>
|
|
assert.rejects(
|
|
() => sharp(Buffer.from('<svg width="32768" height="1" />')).toBuffer(),
|
|
/Input SVG image exceeds 32767x32767 pixel limit/
|
|
)
|
|
);
|
|
|
|
it('Fails to render scaled SVG larger than 32767x32767', () =>
|
|
assert.rejects(
|
|
() => sharp(Buffer.from('<svg width="32767" height="1" />')).resize(32768).toBuffer(),
|
|
/Input SVG image will exceed 32767x32767 pixel limit when scaled/
|
|
)
|
|
);
|
|
|
|
it('Detects SVG passed as a string', () =>
|
|
assert.rejects(
|
|
() => sharp('<svg></svg>').toBuffer(),
|
|
/Input file is missing, did you mean/
|
|
)
|
|
);
|
|
});
|