mathjs/test/unit-tests/utils/customs.test.js
Jos de Jong 6f00715754
Specify import require paths (continuation of #1941) (#1962)
* Add `.js` extension to source file imports

* Specify package `exports` in `package.json`

Specify package type as `commonjs` (It's good to be specific)

* Move all compiled scripts into `lib` directory

Remove ./number.js (You can use the compiled ones in `./lib/*`)

Tell node that the `esm` directory is type `module` and enable tree shaking.

Remove unused files from packages `files` property

* Allow importing of package.json

* Make library ESM first

* - Fix merge conflicts
- Refactor `bundleAny` into `defaultInstance.js` and `browserBundle.cjs`
- Refactor unit tests to be able to run with plain nodejs (no transpiling)
- Fix browser examples

* Fix browser and browserstack tests

* Fix running unit tests on Node 10 (which has no support for modules)

* Fix node.js examples (those are still commonjs)

* Remove the need for `browserBundle.cjs`

* Generate minified bundle only

* [Security] Bump node-fetch from 2.6.0 to 2.6.1 (#1963)

Bumps [node-fetch](https://github.com/bitinn/node-fetch) from 2.6.0 to 2.6.1. **This update includes a security fix.**
- [Release notes](https://github.com/bitinn/node-fetch/releases)
- [Changelog](https://github.com/node-fetch/node-fetch/blob/master/docs/CHANGELOG.md)
- [Commits](https://github.com/bitinn/node-fetch/compare/v2.6.0...v2.6.1)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>

Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>

* Cleanup console.log

* Add integration tests to test the entry points (commonjs/esm, full/number only)

* Create backward compatibility error messages in the files moved/removed since v8

* Describe breaking changes in HISTORY.md

* Bump karma from 5.2.1 to 5.2.2 (#1965)

Bumps [karma](https://github.com/karma-runner/karma) from 5.2.1 to 5.2.2.
- [Release notes](https://github.com/karma-runner/karma/releases)
- [Changelog](https://github.com/karma-runner/karma/blob/master/CHANGELOG.md)
- [Commits](https://github.com/karma-runner/karma/compare/v5.2.1...v5.2.2)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>

Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>

Co-authored-by: Lee Langley-Rees <lee@greenimp.co.uk>
Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>
2020-09-20 18:01:29 +02:00

176 lines
7.1 KiB
JavaScript

// test boolean utils
import assert from 'assert'
import { isPlainObject, isSafeMethod, isSafeProperty } from '../../../src/utils/customs.js'
import math from '../../../src/defaultInstance.js'
describe('customs', function () {
describe('isSafeMethod', function () {
it('plain objects', function () {
const object = {
fn: function () {}
}
assert.strictEqual(isSafeMethod(object, 'fn'), true)
assert.strictEqual(isSafeMethod(object, 'toString'), true)
assert.strictEqual(isSafeMethod(object, 'toLocaleString'), true)
assert.strictEqual(isSafeMethod(object, 'valueOf'), true)
assert.strictEqual(isSafeMethod(object, 'constructor'), false)
assert.strictEqual(isSafeMethod(object, 'hasOwnProperty'), false)
assert.strictEqual(isSafeMethod(object, 'isPrototypeOf'), false)
assert.strictEqual(isSafeMethod(object, 'propertyIsEnumerable'), false)
assert.strictEqual(isSafeMethod(object, '__defineGetter__'), false)
assert.strictEqual(isSafeMethod(object, '__defineSetter__'), false)
assert.strictEqual(isSafeMethod(object, '__lookupGetter__'), false)
assert.strictEqual(isSafeMethod(object, '__lookupSetter__'), false)
// non existing method
assert.strictEqual(isSafeMethod(object, 'foo'), false)
// custom inherited method
const object1 = {
foo: function () {}
}
const object2 = Object.create(object1)
assert.strictEqual(isSafeMethod(object2, 'foo'), true)
// ghosted native method
const object3 = {}
object3.toString = function () {}
assert.strictEqual(isSafeMethod(object3, 'toString'), false)
})
it('functions', function () {
const f = function () {}
assert.strictEqual(isSafeMethod(f, 'call'), false)
assert.strictEqual(isSafeMethod(f, 'bind'), false)
assert.strictEqual(isSafeMethod(f, 'constructor'), false)
})
it('classes', function () {
const matrix = math.matrix()
assert.strictEqual(isSafeMethod(matrix, 'get'), true)
assert.strictEqual(isSafeMethod(matrix, 'toString'), true)
const complex = math.complex()
assert.strictEqual(isSafeMethod(complex, 'sqrt'), true)
assert.strictEqual(isSafeMethod(complex, 'toString'), true)
const unit = math.unit('5cm')
assert.strictEqual(isSafeMethod(unit, 'toNumeric'), true)
assert.strictEqual(isSafeMethod(unit, 'toString'), true)
// extend the class instance with a custom method
const object = math.matrix()
object.foo = function () {}
assert.strictEqual(isSafeMethod(object, 'foo'), true)
// extend the class instance with a ghosted method
const object2 = math.matrix()
object2.toJSON = function () {}
assert.strictEqual(isSafeMethod(object2, 'toJSON'), false)
// unsafe native methods
assert.strictEqual(isSafeMethod(matrix, 'constructor'), false)
assert.strictEqual(isSafeMethod(matrix, 'hasOwnProperty'), false)
assert.strictEqual(isSafeMethod(matrix, 'isPrototypeOf'), false)
assert.strictEqual(isSafeMethod(matrix, 'propertyIsEnumerable'), false)
assert.strictEqual(isSafeMethod(matrix, '__defineGetter__'), false)
assert.strictEqual(isSafeMethod(matrix, '__defineSetter__'), false)
assert.strictEqual(isSafeMethod(matrix, '__lookupGetter__'), false)
assert.strictEqual(isSafeMethod(matrix, '__lookupSetter__'), false)
// non existing method
assert.strictEqual(isSafeMethod(matrix, 'nonExistingMethod'), false)
// method with unicode chars
assert.strictEqual(isSafeMethod(matrix, 'co\u006Estructor'), false)
})
it('strings', function () {
assert.strictEqual(isSafeMethod('abc', 'toUpperCase'), true)
assert.strictEqual(isSafeMethod('', 'toUpperCase'), true)
assert.strictEqual(isSafeMethod('abc', 'constructor'), false)
assert.strictEqual(isSafeMethod('abc', '__proto__'), false)
})
it('numbers', function () {
assert.strictEqual(isSafeMethod(3.14, 'toFixed'), true)
assert.strictEqual(isSafeMethod(0, 'toFixed'), true)
assert.strictEqual(isSafeMethod(3.14, 'constructor'), false)
assert.strictEqual(isSafeMethod(3.14, '__proto__'), false)
})
it('dates', function () {
assert.strictEqual(isSafeMethod(new Date(), 'getTime'), true)
assert.strictEqual(isSafeMethod(new Date(0), 'getTime'), true)
assert.strictEqual(isSafeMethod(new Date(), 'constructor'), false)
assert.strictEqual(isSafeMethod(new Date(), '__proto__'), false)
})
})
describe('isSafeProperty', function () {
it('should test properties on plain objects', function () {
const object = {}
/* From Object.prototype:
Object.getOwnPropertyNames(Object.prototype).forEach(
key => typeof ({})[key] !== 'function' && console.log(key))
*/
assert.strictEqual(isSafeProperty(object, '__proto__'), false)
assert.strictEqual(isSafeProperty(object, 'constructor'), false)
/* From Function.prototype:
Object.getOwnPropertyNames(Function.prototype).forEach(
key => typeof (function () {})[key] !== 'function' && console.log(key))
*/
assert.strictEqual(isSafeProperty(object, 'length'), true)
assert.strictEqual(isSafeProperty(object, 'name'), true)
assert.strictEqual(isSafeProperty(object, 'arguments'), false)
assert.strictEqual(isSafeProperty(object, 'caller'), false)
// non existing property
assert.strictEqual(isSafeProperty(object, 'bar'), true)
// property with unicode chars
assert.strictEqual(isSafeProperty(object, 'co\u006Estructor'), false)
})
it('should test inherited properties on plain objects ', function () {
const object1 = {}
const object2 = Object.create(object1)
object1.foo = true
object2.bar = true
assert.strictEqual(isSafeProperty(object2, 'foo'), true)
assert.strictEqual(isSafeProperty(object2, 'bar'), true)
assert.strictEqual(isSafeProperty(object2, '__proto__'), false)
assert.strictEqual(isSafeProperty(object2, 'constructor'), false)
object2.foo = true // override "foo" of object1
assert.strictEqual(isSafeProperty(object2, 'foo'), true)
assert.strictEqual(isSafeProperty(object2, 'constructor'), false)
})
it('should test for ghosted native property', function () {
const array1 = []
const array2 = Object.create(array1)
array2.length = Infinity
assert.strictEqual(isSafeProperty(array2, 'length'), true)
})
})
it('should distinguish plain objects', function () {
const a = {}
const b = Object.create(a)
assert.strictEqual(isPlainObject(a), true)
assert.strictEqual(isPlainObject(b), true)
assert.strictEqual(isPlainObject(math.unit('5cm')), false)
assert.strictEqual(isPlainObject(math.unit('5cm')), false)
assert.strictEqual(isPlainObject([]), false)
// assert.strictEqual(isPlainObject (math.complex()), false); // FIXME: shouldn't treat Complex as a plain object (it is a plain object which has __proto__ overridden)
assert.strictEqual(isPlainObject(math.matrix()), false)
})
})