Skip to content

Commit

Permalink
Use native ESM
Browse files Browse the repository at this point in the history
  • Loading branch information
1000ch committed Dec 17, 2021
1 parent 0849037 commit ca0376d
Show file tree
Hide file tree
Showing 5 changed files with 54 additions and 93 deletions.
77 changes: 19 additions & 58 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
@@ -1,64 +1,25 @@
name: test

on:
push:
branches:
- master
pull_request:
branches:
- master

- push
- pull_request
jobs:
linux:
runs-on: ubuntu-latest

test:
name: Node.js ${{ matrix.node-version }} on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
node-version: [10.x, 12.x, 14.x]

node-version:
- 16
- 14
- 12
os:
- ubuntu-latest
- macos-latest
- windows-latest
steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- run: npm install
- run: npm test
env:
CI: true

macos:
runs-on: macos-latest

strategy:
matrix:
node-version: [10.x, 12.x, 14.x]

steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- run: npm install
- run: npm test
env:
CI: true

windows:
runs-on: windows-latest

strategy:
matrix:
node-version: [10.x, 12.x, 14.x]

steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- run: npm install
- run: npm test
env:
CI: true
- uses: actions/checkout@v2
- uses: actions/setup-node@v2
with:
node-version: ${{ matrix.node-version }}
- run: npm install
- run: npm test
20 changes: 11 additions & 9 deletions index.js
Original file line number Diff line number Diff line change
@@ -1,17 +1,17 @@
'use strict';
const execa = require('execa');
const isJpg = require('is-jpg');
const jpegoptim = require('jpegoptim-bin');
import {Buffer} from 'node:buffer';
import {execa} from 'execa';
import isJpg from 'is-jpg';
import jpegoptim from 'jpegoptim-bin';

module.exports = options => async buffer => {
const imageminJpegoptim = options => async buffer => {
options = {
stripAll: true,
stripCom: true,
stripExif: true,
stripIptc: true,
stripIcc: true,
stripXmp: true,
...options
...options,
};

if (!Buffer.isBuffer(buffer)) {
Expand All @@ -24,7 +24,7 @@ module.exports = options => async buffer => {

const args = [
'--stdin',
'--stdout'
'--stdout',
];

if (options.stripAll) {
Expand Down Expand Up @@ -59,15 +59,17 @@ module.exports = options => async buffer => {
args.push(`--max=${options.max}`);
}

if (options.size) {
if (options.size > 0) {
args.push(`--size=${options.size}`);
}

const {stdout} = await execa(jpegoptim, args, {
encoding: null,
input: buffer,
maxBuffer: Infinity
maxBuffer: Number.POSITIVE_INFINITY,
});

return stdout;
};

export default imageminJpegoptim;
14 changes: 8 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
"description": "Imagemin plugin for jpegoptim",
"license": "MIT",
"repository": "imagemin/imagemin-jpegoptim",
"type": "module",
"exports": "./index.js",
"author": {
"name": "Kevin Mårtensson",
"email": "[email protected]",
Expand All @@ -21,7 +23,7 @@
}
],
"engines": {
"node": ">=10"
"node": "^12.20.0 || ^14.13.1 || >=16.0.0"
},
"scripts": {
"test": "xo && ava"
Expand All @@ -39,13 +41,13 @@
"optimize"
],
"dependencies": {
"execa": "^4.0.0",
"is-jpg": "^2.0.0",
"jpegoptim-bin": "^6.0.0"
"execa": "^6.0.0",
"is-jpg": "^3.0.0",
"jpegoptim-bin": "^7.1.0"
},
"devDependencies": {
"ava": "^3.8.0",
"ava": "^3.15.0",
"is-progressive": "^3.0.0",
"xo": "^0.30.0"
"xo": "^0.47.0"
}
}
4 changes: 2 additions & 2 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ See [`jpegoptim-bin`'s install section](https://github.com/imagemin/jpegoptim-bi
## Usage

```js
const imagemin = require('imagemin');
const imageminJpegoptim = require('imagemin-jpegoptim');
import imagemin from 'imagemin';
import imageminJpegoptim from 'imagemin-jpegoptim';

(async () => {
await imagemin(['images/*.jpg'], {
Expand Down
32 changes: 14 additions & 18 deletions test.js
Original file line number Diff line number Diff line change
@@ -1,42 +1,38 @@
const {promisify} = require('util');
const fs = require('fs');
const path = require('path');
const isJpg = require('is-jpg');
const isProgressive = require('is-progressive');
const test = require('ava');
const m = require('.');

const readFile = promisify(fs.readFile);
import {promises as fs} from 'node:fs';
import isJpg from 'is-jpg';
import isProgressive from 'is-progressive';
import test from 'ava';
import imageminJpegoptim from './index.js';

test('optimize a JPG', async t => {
const buffer = await readFile(path.join(__dirname, 'fixtures/test.jpg'));
const data = await m()(buffer);
const buffer = await fs.readFile(new URL('fixtures/test.jpg', import.meta.url));
const data = await imageminJpegoptim()(buffer);
t.true(data.length < buffer.length);
t.true(isJpg(data));
});

test('throw error when a JPG is corrupt', async t => {
const buffer = await readFile(path.join(__dirname, 'fixtures/test-corrupt.jpg'));
const buffer = await fs.readFile(new URL('fixtures/test-corrupt.jpg', import.meta.url));
await t.throwsAsync(async () => {
await m()(buffer);
await imageminJpegoptim()(buffer);
}, {message: /JFIF/});
});

test('throw error when a large JPG is corrupt', async t => {
const buffer = await readFile(path.join(__dirname, 'fixtures/test-corrupt-large.jpg'));
const buffer = await fs.readFile(new URL('fixtures/test-corrupt-large.jpg', import.meta.url));
await t.throwsAsync(async () => {
await m()(buffer);
await imageminJpegoptim()(buffer);
}, {message: /EPIPE|ERROR/});
});

test('progressive option', async t => {
const buffer = await readFile(path.join(__dirname, 'fixtures/test.jpg'));
const data = await m({progressive: true})(buffer);
const buffer = await fs.readFile(new URL('fixtures/test.jpg', import.meta.url));
const data = await imageminJpegoptim({progressive: true})(buffer);
t.true(isProgressive.buffer(data));
});

test('throw on wrong input', async t => {
await t.throwsAsync(async () => {
await m()('foo');
await imageminJpegoptim()('foo');
}, {message: 'Expected a Buffer, got string'});
});

0 comments on commit ca0376d

Please sign in to comment.