summaryrefslogtreecommitdiff
path: root/packages/integrations/image/test/sharp.test.js
blob: 8e2d1d3afd3d7d5fd3af3253e1d31e2b2b179ebe (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import { expect } from 'chai';
import sharp from '../dist/loaders/sharp.js';

describe('Sharp service', () => {
	describe('serializeTransform', () => {
		const src = '/assets/image.png';

		[
			['only requires src', { src }],
			['quality', { src, quality: 80 }],
			['format', { src, format: 'jpeg' }],
			['width', { src, width: 1280 }],
			['height', { src, height: 414 }],
			['width & height', { src, height: 400, width: 200 }],
			['aspect ratio string', { src, aspectRatio: '16:9' }],
			['aspect ratio float', { src, aspectRatio: 1.7 }],
			['background color', { src, format: 'jpeg', background: '#333333' }],
			['crop fit', { src, fit: 'cover' }],
			['crop position', { src, position: 'center' }],
		].forEach(([description, props]) => {
			it(description, async () => {
				const { searchParams } = await sharp.serializeTransform(props);

				function verifyProp(expected, search) {
					if (expected) {
						expect(searchParams.get(search)).to.equal(expected.toString());
					} else {
						expect(searchParams.has(search)).to.be.false;
					}
				}

				verifyProp(props.quality, 'q');
				verifyProp(props.format, 'f');
				verifyProp(props.width, 'w');
				verifyProp(props.height, 'h');
				verifyProp(props.aspectRatio, 'ar');
				verifyProp(props.fit, 'fit');
				verifyProp(props.position, 'p');
				verifyProp(props.background, 'bg');
			});
		});
	});

	describe('parseTransform', async () => {
		const src = '/assets/image.png';
		const href = encodeURIComponent(src);

		[
			['only requires src', `href=${href}`, { src }],
			['quality', `q=80&href=${href}`, { src, quality: 80 }],
			['format', `f=jpeg&href=${href}`, { src, format: 'jpeg' }],
			['width', `w=1280&href=${href}`, { src, width: 1280 }],
			['height', `h=414&href=${href}`, { src, height: 414 }],
			['width & height', `w=200&h=400&href=${href}`, { src, height: 400, width: 200 }],
			['aspect ratio string', `ar=16:9&href=${href}`, { src, aspectRatio: '16:9' }],
			['aspect ratio float', `ar=1.7&href=${href}`, { src, aspectRatio: 1.7 }],
			[
				'background color',
				`f=jpeg&bg=%23333333&href=${href}`,
				{ src, format: 'jpeg', background: '#333333' },
			],
			['crop fit', `fit=contain&href=${href}`, { src, fit: 'contain' }],
			['crop position', `p=right%20top&href=${href}`, { src, position: 'right top' }],
		].forEach(([description, params, expected]) => {
			it(description, async () => {
				const searchParams = new URLSearchParams(params);
				const props = sharp.parseTransform(searchParams);

				expect(props).to.deep.equal(expected);
			});
		});
	});
});