包详细信息

unassertify

unassert-js69.4kMIT3.0.1

Browserify transform for unassert: Encourages programming with assertions by providing tools to compile them away

DbC, unassert, assert, assertion

自述文件

unassertify

Browserify transform for unassert: Encourages programming with assertions) by providing tools to compile them away.

unassert

Build Status NPM version Code Style License

RELATED MODULES

INSTALL

$ npm install --save-dev unassertify

HOW TO USE

via CLI

$ $(npm bin)/browserify -t unassertify /path/to/src/target.js > /path/to/build/target.js

via API

const source = require('vinyl-source-stream');
const browserify = require('browserify');
const glob = require('glob'),

gulp.task('production_build', function() {
    const files = glob.sync('./src/*.js');
    const b = browserify({entries: files});
    b.transform('unassertify');
    return b.bundle()
        .pipe(source('bundle.js'))
        .pipe(gulp.dest('./dist'));
});

EXAMPLE

For given math.js below,

'use strict';

const assert = require('node:assert');

function add (a, b) {
    console.assert(typeof a === 'number');
    assert(!isNaN(a));
    assert.equal(typeof b, 'number');
    assert.ok(!isNaN(b));
    return a + b;
}

Run browserify with -t unassertify to transform file.

$ $(npm bin)/browserify -t unassertify /path/to/demo/math.js > /path/to/build/math.js

You will see assert calls disappear.

'use strict';
function add(a, b) {
    return a + b;
}

SUPPORTED PATTERNS

Assertion expressions are removed when they match patterns below. In other words, unassertify removes assertion calls that are compatible with Node.js standard assert API (and console.assert).

  • assert(value, [message])
  • assert.ok(value, [message])
  • assert.equal(actual, expected, [message])
  • assert.notEqual(actual, expected, [message])
  • assert.strictEqual(actual, expected, [message])
  • assert.notStrictEqual(actual, expected, [message])
  • assert.deepEqual(actual, expected, [message])
  • assert.notDeepEqual(actual, expected, [message])
  • assert.deepStrictEqual(actual, expected, [message])
  • assert.notDeepStrictEqual(actual, expected, [message])
  • assert.match(string, regexp[, message])
  • assert.doesNotMatch(string, regexp[, message])
  • assert.throws(block, [error], [message])
  • assert.doesNotThrow(block, [message])
  • await assert.rejects(asyncFn, [error], [message])
  • await assert.doesNotReject(asyncFn, [error], [message])
  • assert.fail([message])
  • assert.fail(actual, expected, message, operator)
  • assert.ifError(value)
  • console.assert(value, [message])

unassertify also removes assert variable declarations,

  • import assert from "assert"
  • import assert from "assert/strict"
  • import assert from "node:assert"
  • import assert from "node:assert/strict"
  • import * as assert from "assert"
  • import * as assert from "node:assert"
  • import * as assert from "assert/strict"
  • import * as assert from "node:assert/strict"
  • import { strict as assert } from "assert"
  • import { strict as assert } from "node:assert"
  • import { default as assert } from "assert"
  • import { default as assert } from "node:assert"
  • const assert = require("assert")
  • const assert = require("node:assert")
  • const assert = require("assert/strict")
  • const assert = require("node:assert/strict")
  • const assert = require("assert").strict
  • const assert = require("node:assert").strict
  • const { strict: assert } = require("assert")
  • const { strict: assert } = require("node:assert")

and assignments.

  • assert = require("assert")
  • assert = require("node:assert")
  • assert = require("assert/strict")
  • assert = require("node:assert/strict")
  • assert = require("assert").strict
  • assert = require("node:assert").strict

Auto Variable Tracking

unassert automatically removes assertion calls based on their imported variable names.

So if import declaration is as follows,

  • import strictAssert, { ok, equal as eq } from 'node:assert/strict';

unassert removes all strictAssert, ok, eq calls.

AUTHOR

CONTRIBUTORS

OUR SUPPORT POLICY

We support Node under maintenance. In other words, we stop supporting old Node version when their maintenance ends.

This means that any other environment is not supported.

NOTE: If unassertify works in any of the unsupported environments, it is purely coincidental and has no bearing on future compatibility. Use at your own risk.

LICENSE

Licensed under the MIT license.

更新日志

3.0.1 (2022-08-07)

Bug Fixes

  • put .cjs back to .js since browserify ecosystem doesn't yet understand .cjs (5419034a)

3.0.0 (2022-08-07)

Features

Breaking Changes

This release will not affect most users. This is a major release of "just in case" for unassert-v2 which is completely rewritten.

2.1.1 (2018-04-19)

Performance Improvements

2.1.0 (2017-10-23)

Features

2.0.5 (2017-10-17)

Bug Fixes

2.0.4 (2016-12-28)

Chore

  • transfer to unassert-js organization (72ea9da)
  • switch to acorn (c3f1785)

2.0.3 (2015-12-16)

Bug Fixes

  • copy sourceRoot even if it is an empty string (d687a4bc)

2.0.2 (2015-09-27)

Bug Fixes

  • should not transform JSON file (6653d38c)

2.0.1 (2015-09-27)

2.0.0 (2015-09-25)

Features

Breaking Changes

  • Since this release, assertions are always removed even if debug option is on. If you don't want to remove assertions when debug is on, simply do not add unassertify on that build configuration.

1.0.2 (2015-05-27)

1.0.1 (2015-05-27)

  • skip traversing node to be deleted (f936b632)

1.0.0 (2015-05-27)

  • The first release.