diff --git a/.travis.yml b/.travis.yml index 69eaec2..92ca091 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,9 +1,6 @@ language: node_js node_js: - - '4' - - '5' - - '6' - - '7' - '8' + - '9' after_script: - npm run coveralls \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..dded8a2 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,50 @@ +# Changelog + +## [1.2.2] - 2017-11-18 + +### Fixed + +- Fixed Wrong .angleTo() computing [#41](https://github.com/broadsw0rd/vectory/issues/41) + +## [1.2.1] - 2017-09-04 + +### Added + +- Support of es6 [pkg.module](https://github.com/rollup/rollup/wiki/pkg.module) [#38](https://github.com/broadsw0rd/vectory/issues/38) + +## [1.2.0] - 2017-08-29 + +### Added + +- Implemented vector rotation [#34](https://github.com/broadsw0rd/vectory/issues/34) + + - `Vector.rotate(theta, vector)` + - `Vector.prototype.rotate(theta)` + - `Vector.irotate(theta, vector)` + - `Vector.prototype.irotate(theta)` + +- Implemented alias `Vector#clone()` for `Vector#copy()` [#35](https://github.com/broadsw0rd/vectory/issues/35) + +- Implemented filter for benchmark [#29](https://github.com/broadsw0rd/vectory/issues/29) + +``` +npm run behch -- --filter add +``` + +list of available filters: `create`, `add`, `sub`, `mul`, `div`, `lerp`, `norm`, `mag`, `dot`, `dist`, `angle`, `rotate`, `reset`, `copy`, `convert`, `equal`, `swizzling`, `iterator` + +### Fixed + +- Fixed vectors' equality: implemented usage of `Number.EPSILON` [#36](https://github.com/broadsw0rd/vectory/issues/36) + +### Removed + +- Dropped support of Node < 4 + +## [1.1.0] - 2016-07-23 + +### Added + +- Implemented `Vector.prototype.set(x, y)` +- Implemented `Vector.prototype.toArray()` +- Implemented `Symbol.toStringTag` support diff --git a/README.md b/README.md index e4e6339..cb79e1e 100644 --- a/README.md +++ b/README.md @@ -19,6 +19,44 @@

+Yet another 2d vector implementation for basic motion + +``` js +this.velocity.iadd(this.acceleration) +this.position.iadd(this.velocity) +this.acceleration.zero() +``` + +with rare methods such as [lerp](https://en.wikipedia.org/wiki/Linear_interpolation) + +``` js +var prev = new Vector(1, 2) +var next = new Vector(3, 4) +prev.lerp(next, 0.5) // Vector(2, 3) +``` + +and [swizzling](https://www.opengl.org/wiki/Data_Type_%28GLSL%29#Swizzling) + +``` js +var vector = new Vector(1 ,2) +vector.yx // Vector(2, 1) +``` + +with some ES6 support + +``` js +var vector = new Vector(0, 0) +var vec3 = [...vector, 0] // [0, 0, 0] +``` + +and FP ability + +``` js +// create vectors from raw data and scale them twice +var data = [[1, 2], [3, 4]/*, ... */] +var vectors = data.map(Vector.from).map(Vector.mul.bind(null, 2)) +``` + ## Table of Contents - [Features](#features) @@ -191,117 +229,118 @@ Follow [this link](https://processing.org/tutorials/pvector/) to read more about ## Benchmark -Intel Core i5-4210U @ 1.7 GHz, DDR3 4 Gb, node v8.2.1 +Intel Core i5-4210U @ 1.7 GHz, DDR3 4 Gb, node v9.2.0 ``` -> vectory@1.2.0 bench d:\Projects\vectory + +> vectory@1.2.2 bench d:\Projects\vectory > node ./bench/index.js ℹ start benchmark, please wait a bit... Cteation - ✔ Vector(x, y) x 46,743,543 ops/sec ±0.51% (95 runs sampled) - ✔ Vector.from([x, y]) x 43,975,387 ops/sec ±0.74% (95 runs sampled) - ✔ Vector.fromAngle(angle, magnitude) x 46,690,953 ops/sec ±0.50% (94 runs sampled) - ✔ Vector.parse(string) x 844,061 ops/sec ±0.71% (91 runs sampled) + ✔ Vector(x, y) x 348,913,616 ops/sec ±1.21% (85 runs sampled) + ✔ Vector.from([x, y]) x 338,169,673 ops/sec ±1.39% (86 runs sampled) + ✔ Vector.fromAngle(angle, magnitude) x 356,315,826 ops/sec ±0.82% (85 runs sampled) + ✔ Vector.parse(string) x 1,524,501 ops/sec ±0.38% (96 runs sampled) Addition - ✔ Vector.add(one, another) x 42,209,927 ops/sec ±0.85% (91 runs sampled) - ✔ Vector#add(vector) x 45,393,805 ops/sec ±0.60% (91 runs sampled) - ✔ Vector.iadd(one, another) x 51,974,197 ops/sec ±0.67% (92 runs sampled) - ✔ Vector#iadd(vector) x 56,314,420 ops/sec ±0.97% (94 runs sampled) + ✔ Vector.add(one, another) x 350,259,731 ops/sec ±0.85% (84 runs sampled) + ✔ Vector#add(vector) x 352,389,076 ops/sec ±0.74% (87 runs sampled) + ✔ Vector.iadd(one, another) x 168,892,112 ops/sec ±0.78% (90 runs sampled) + ✔ Vector#iadd(vector) x 170,948,920 ops/sec ±0.66% (88 runs sampled) Substraction - ✔ Vector.sub(one, another) x 42,524,916 ops/sec ±0.87% (92 runs sampled) - ✔ Vector#sub(vector) x 46,091,266 ops/sec ±0.63% (91 runs sampled) - ✔ Vector.isub(one, another) x 51,595,827 ops/sec ±0.67% (94 runs sampled) - ✔ Vector#isub(vector) x 56,167,879 ops/sec ±1.27% (90 runs sampled) + ✔ Vector.sub(one, another) x 352,975,428 ops/sec ±0.96% (90 runs sampled) + ✔ Vector#sub(vector) x 346,215,470 ops/sec ±1.30% (88 runs sampled) + ✔ Vector.isub(one, another) x 168,818,810 ops/sec ±0.90% (87 runs sampled) + ✔ Vector#isub(vector) x 164,773,894 ops/sec ±1.83% (87 runs sampled) Multiplication - ✔ Vector.mul(scalar, vector) x 42,963,883 ops/sec ±1.10% (89 runs sampled) - ✔ Vector#mul(vector) x 45,479,457 ops/sec ±0.99% (93 runs sampled) - ✔ Vector.imul(scalar, vector) x 53,674,489 ops/sec ±0.89% (93 runs sampled) - ✔ Vector#imul(vector) x 56,131,658 ops/sec ±1.45% (87 runs sampled) + ✔ Vector.mul(scalar, vector) x 352,641,917 ops/sec ±0.72% (92 runs sampled) + ✔ Vector#mul(vector) x 228,131,960 ops/sec ±18.68% (59 runs sampled) + ✔ Vector.imul(scalar, vector) x 60,518,558 ops/sec ±1.63% (80 runs sampled) + ✔ Vector#imul(vector) x 148,143,360 ops/sec ±8.39% (81 runs sampled) - undefined - ✔ Vector.div(scalar, vector) x 41,455,674 ops/sec ±1.00% (92 runs sampled) - ✔ Vector#div(vector) x 43,982,841 ops/sec ±0.94% (92 runs sampled) - ✔ Vector.idiv(scalar, vector) x 50,470,195 ops/sec ±0.99% (92 runs sampled) - ✔ Vector#idiv(vector) x 54,262,823 ops/sec ±1.11% (89 runs sampled) + Division + ✔ Vector.div(scalar, vector) x 61,518,555 ops/sec ±1.58% (85 runs sampled) + ✔ Vector#div(vector) x 163,262,379 ops/sec ±22.63% (44 runs sampled) + ✔ Vector.idiv(scalar, vector) x 49,366,939 ops/sec ±4.25% (76 runs sampled) + ✔ Vector#idiv(vector) x 59,498,001 ops/sec ±1.77% (83 runs sampled) Linear Interpolation - ✔ Vector.lerp(one, another, t) x 37,476,071 ops/sec ±0.67% (93 runs sampled) - ✔ Vector#lerp(vector, t) x 40,018,105 ops/sec ±0.95% (91 runs sampled) + ✔ Vector.lerp(one, another, t) x 110,432,701 ops/sec ±12.50% (33 runs sampled) + ✔ Vector#lerp(vector, t) x 60,057,103 ops/sec ±1.93% (85 runs sampled) Normalization - ✔ Vector.normalized(vector) x 34,610,141 ops/sec ±1.70% (91 runs sampled) - ✔ Vector#normalized() x 33,910,394 ops/sec ±1.02% (91 runs sampled) - ✔ Vector.normalize(vector) x 45,430,996 ops/sec ±0.48% (93 runs sampled) - ✔ Vector#normalize() x 51,779,510 ops/sec ±0.98% (92 runs sampled) + ✔ Vector.normalized(vector) x 51,621,604 ops/sec ±3.21% (60 runs sampled) + ✔ Vector#normalized() x 25,901,696 ops/sec ±3.97% (76 runs sampled) + ✔ Vector.normalize(vector) x 29,906,998 ops/sec ±4.02% (75 runs sampled) + ✔ Vector#normalize() x 29,326,114 ops/sec ±3.41% (80 runs sampled) Magnitude - ✔ Vector.magnitude(vector) x 50,388,862 ops/sec ±1.07% (92 runs sampled) - ✔ Vector#magnitude() x 52,680,430 ops/sec ±0.55% (92 runs sampled) + ✔ Vector.magnitude(vector) x 61,280,362 ops/sec ±3.38% (82 runs sampled) + ✔ Vector#magnitude() x 79,351,707 ops/sec ±2.30% (62 runs sampled) Dot Product - ✔ Vector.dot(one, another) x 49,099,926 ops/sec ±1.11% (92 runs sampled) - ✔ Vector#dot(vector) x 50,984,589 ops/sec ±0.75% (91 runs sampled) + ✔ Vector.dot(one, another) x 65,872,652 ops/sec ±1.83% (83 runs sampled) + ✔ Vector#dot(vector) x 73,566,904 ops/sec ±1.89% (78 runs sampled) Distance - ✔ Vector.distance(one, another) x 45,798,049 ops/sec ±1.19% (91 runs sampled) - ✔ Vector#distance(vector) x 48,614,015 ops/sec ±0.86% (86 runs sampled) + ✔ Vector.distance(one, another) x 63,302,249 ops/sec ±1.41% (85 runs sampled) + ✔ Vector#distance(vector) x 62,915,660 ops/sec ±2.25% (84 runs sampled) Angle computing - ✔ Vector.angleOf(vector) x 19,578,714 ops/sec ±0.71% (94 runs sampled) - ✔ Vector#angleOf() x 15,775,111 ops/sec ±0.71% (93 runs sampled) - ✔ Vector.angleTo(one, another) x 24,279,594 ops/sec ±1.05% (89 runs sampled) - ✔ Vector#angleTo(vector) x 25,635,012 ops/sec ±2.02% (88 runs sampled) + ✔ Vector.angleOf(vector) x 19,971,981 ops/sec ±2.31% (75 runs sampled) + ✔ Vector#angleOf() x 36,392,689 ops/sec ±1.45% (84 runs sampled) + ✔ Vector.angleTo(one, another) x 9,924,167 ops/sec ±0.68% (93 runs sampled) + ✔ Vector#angleTo(vector) x 12,599,284 ops/sec ±2.59% (64 runs sampled) Rotation - ✔ Vector.rotate(theta, vector) x 14,454,664 ops/sec ±0.29% (95 runs sampled) - ✔ Vector#rotate(theta) x 14,748,750 ops/sec ±0.83% (89 runs sampled) - ✔ Vector.irotate(theta, vector) x 15,671,034 ops/sec ±0.99% (92 runs sampled) - ✔ Vector#irotate(theta) x 15,809,098 ops/sec ±0.40% (93 runs sampled) + ✔ Vector.rotate(theta, vector) x 60,097,845 ops/sec ±1.84% (81 runs sampled) + ✔ Vector#rotate(theta) x 61,736,300 ops/sec ±1.72% (86 runs sampled) + ✔ Vector.irotate(theta, vector) x 54,403,112 ops/sec ±2.12% (83 runs sampled) + ✔ Vector#irotate(theta) x 54,691,285 ops/sec ±1.82% (83 runs sampled) Resetting - ✔ Vector.reset(one, another) x 56,820,469 ops/sec ±0.71% (91 runs sampled) - ✔ Vector#reset(vector) x 59,785,743 ops/sec ±1.02% (89 runs sampled) - ✔ Vector.zero(vector) x 61,210,667 ops/sec ±0.95% (90 runs sampled) - ✔ Vector#zero() x 37,152,570 ops/sec ±18.39% (52 runs sampled) - ✔ Vector.set(x, y, vector) x 23,268,702 ops/sec ±4.99% (69 runs sampled) - ✔ Vector#set(vector) x 33,454,572 ops/sec ±4.58% (66 runs sampled) + ✔ Vector.reset(one, another) x 60,446,058 ops/sec ±1.94% (87 runs sampled) + ✔ Vector#reset(vector) x 46,877,562 ops/sec ±15.80% (69 runs sampled) + ✔ Vector.zero(vector) x 12,040,985 ops/sec ±17.99% (61 runs sampled) + ✔ Vector#zero() x 11,444,775 ops/sec ±6.08% (67 runs sampled) + ✔ Vector.set(x, y, vector) x 17,119,965 ops/sec ±9.95% (64 runs sampled) + ✔ Vector#set(vector) x 15,993,806 ops/sec ±2.24% (80 runs sampled) Copy - ✔ Vector.copy(vector) x 25,562,562 ops/sec ±3.15% (66 runs sampled) - ✔ Vector#copy() x 24,956,985 ops/sec ±2.95% (69 runs sampled) + ✔ Vector.copy(vector) x 16,624,837 ops/sec ±10.64% (60 runs sampled) + ✔ Vector#copy() x 22,157,494 ops/sec ±13.33% (68 runs sampled) Convertion - ✔ Vector.toJSON(vector) x 25,875,224 ops/sec ±4.33% (72 runs sampled) - ✔ Vector#toJSON() x 31,665,509 ops/sec ±3.53% (81 runs sampled) - ✔ Vector.toString(vector) x 1,394,192 ops/sec ±2.21% (81 runs sampled) - ✔ Vector#toString() x 1,722,970 ops/sec ±0.89% (89 runs sampled) - ✔ Vector.toArray(vector) x 38,888,744 ops/sec ±2.66% (86 runs sampled) - ✔ Vector#toArray() x 34,146,372 ops/sec ±2.63% (87 runs sampled) + ✔ Vector.toJSON(vector) x 19,314,908 ops/sec ±17.50% (60 runs sampled) + ✔ Vector#toJSON() x 11,781,944 ops/sec ±2.69% (76 runs sampled) + ✔ Vector.toString(vector) x 914,328 ops/sec ±6.69% (59 runs sampled) + ✔ Vector#toString() x 927,311 ops/sec ±5.89% (66 runs sampled) + ✔ Vector.toArray(vector) x 30,829,118 ops/sec ±7.14% (67 runs sampled) + ✔ Vector#toArray() x 35,954,257 ops/sec ±6.06% (70 runs sampled) Equality - ✔ Vector.equals(one, another) x 40,988,367 ops/sec ±2.15% (84 runs sampled) - ✔ Vector#equals(vector) x 41,154,452 ops/sec ±2.89% (78 runs sampled) - ✔ Vector.compare(one, another) x 21,772,261 ops/sec ±1.69% (86 runs sampled) - ✔ Vector#compare(vector) x 26,722,372 ops/sec ±0.38% (94 runs sampled) + ✔ Vector.equals(one, another) x 25,457,189 ops/sec ±4.57% (71 runs sampled) + ✔ Vector#equals(vector) x 23,318,002 ops/sec ±6.88% (66 runs sampled) + ✔ Vector.compare(one, another) x 46,436,815 ops/sec ±3.08% (78 runs sampled) + ✔ Vector#compare(vector) x 32,291,344 ops/sec ±4.25% (69 runs sampled) Swizzling - ✔ Vector#xx get x 49,012,070 ops/sec ±0.91% (92 runs sampled) - ✔ Vector#xx set x 59,257,367 ops/sec ±1.06% (89 runs sampled) - ✔ Vector#xy get x 48,156,050 ops/sec ±0.68% (92 runs sampled) - ✔ Vector#xy set x 59,525,311 ops/sec ±0.98% (92 runs sampled) - ✔ Vector#yx get x 47,543,864 ops/sec ±0.43% (90 runs sampled) - ✔ Vector#yx set x 59,701,618 ops/sec ±0.86% (92 runs sampled) - ✔ Vector#yy get x 49,532,593 ops/sec ±0.62% (92 runs sampled) - ✔ Vector#yy set x 59,408,608 ops/sec ±1.11% (88 runs sampled) + ✔ Vector#xx get x 31,354,935 ops/sec ±4.03% (66 runs sampled) + ✔ Vector#xx set x 33,392,725 ops/sec ±5.28% (69 runs sampled) + ✔ Vector#xy get x 29,551,855 ops/sec ±6.72% (68 runs sampled) + ✔ Vector#xy set x 33,795,883 ops/sec ±5.03% (63 runs sampled) + ✔ Vector#yx get x 28,904,521 ops/sec ±13.83% (68 runs sampled) + ✔ Vector#yx set x 41,581,221 ops/sec ±6.78% (76 runs sampled) + ✔ Vector#yy get x 33,609,933 ops/sec ±6.54% (68 runs sampled) + ✔ Vector#yy set x 35,494,083 ops/sec ±5.73% (66 runs sampled) Iterator - ✔ Spread operator x 3,825,038 ops/sec ±0.56% (92 runs sampled) - ✔ for..of loop x 12,763,966 ops/sec ±1.56% (93 runs sampled) + ✔ Spread operator x 2,642,300 ops/sec ±4.77% (70 runs sampled) + ✔ for..of loop x 8,924,210 ops/sec ±4.14% (61 runs sampled) ``` @@ -312,5 +351,5 @@ Command | Description `npm run check` | Check standard code style by [snazzy](https://www.npmjs.com/package/snazzy) `npm run build` | Wrap source code in [UMD](https://github.com/umdjs/umd) by [rollup](https://github.com/rollup/rollup) `npm run bench` | Run [benchmark](http://benchmarkjs.com/) -`npm run test` | Run tests by [ava](https://github.com/sindresorhus/ava) and compute code coverage by [nyc](https://github.com/bcoe/nyc) +`npm run test` | Run tests by [tape](https://github.com/substack/tape) and compute code coverage by [nyc](https://github.com/bcoe/nyc) `npm run min` | Minify code by [UglifyJS](https://github.com/mishoo/UglifyJS) diff --git a/bench/index.js b/bench/index.js index db0c4c3..77ea141 100644 --- a/bench/index.js +++ b/bench/index.js @@ -28,7 +28,7 @@ var benchmarks = { 'add': require('./benchmarks/addition.bench.js'), 'sub': require('./benchmarks/substraction.bench.js'), 'mul': require('./benchmarks/multiplication.bench.js'), - 'dev': require('./benchmarks/division.bench.js'), + 'div': require('./benchmarks/division.bench.js'), 'lerp': require('./benchmarks/lerp.bench.js'), 'norm': require('./benchmarks/normalization.bench.js'), 'mag': require('./benchmarks/magnitude.bench.js'), diff --git a/dist/vectory.js b/dist/vectory.js index 4c2fac8..87c7f77 100644 --- a/dist/vectory.js +++ b/dist/vectory.js @@ -168,7 +168,7 @@ Vector$1.angleTo = function (one, another) { }; Vector$1.prototype.angleTo = function (vector) { - return Math.acos(this.dot(vector) / this.magnitude() * vector.magnitude()) + return Math.acos(this.dot(vector) / (this.magnitude() * vector.magnitude())) }; function rotate (vector, theta) { diff --git a/dist/vectory.min.js b/dist/vectory.min.js index 0cf9cb3..8496768 100644 --- a/dist/vectory.min.js +++ b/dist/vectory.min.js @@ -1 +1 @@ -!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):t.Vector=n()}(this,function(){"use strict";function t(t,n){this.x=t||0,this.y=n||0}function n(t,n){var i=Math.cos(n),r=Math.sin(n),e=t.x,o=t.y;return t.x=e*i-o*r,t.y=e*r+o*i,t}function i(t){this.vector=t,this.__idx=0}t.displayName="Vector",t.from=function(n){return new t(n[0],n[1])},t.fromAngle=function(n,i){return new t(i*Math.cos(n),i*Math.sin(n))},t.parse=function(n){return t.from(n.trim().replace(","," ").split(/\s+/).map(parseFloat))},t.add=function(t,n){return n.add(t)},t.prototype.add=function(n){return new t(this.x+n.x,this.y+n.y)},t.iadd=function(t,n){return n.iadd(t)},t.prototype.iadd=function(t){return this.x+=t.x,this.y+=t.y,this},t.sub=function(t,n){return n.sub(t)},t.prototype.sub=function(n){return new t(this.x-n.x,this.y-n.y)},t.isub=function(t,n){return n.isub(t)},t.prototype.isub=function(t){return this.x-=t.x,this.y-=t.y,this},t.mul=function(t,n){return n.mul(t)},t.prototype.mul=function(n){return new t(this.x*n,this.y*n)},t.imul=function(t,n){return n.imul(t)},t.prototype.imul=function(t){return this.x*=t,this.y*=t,this},t.div=function(t,n){return n.div(t)},t.prototype.div=function(n){return new t(this.x/n,this.y/n)},t.idiv=function(t,n){return n.idiv(t)},t.prototype.idiv=function(t){return this.x/=t,this.y/=t,this},t.lerp=function(t,n,i){return t.lerp(n,i)},t.prototype.lerp=function(n,i){return new t((1-i)*this.x+i*n.x,(1-i)*this.y+i*n.y)},t.normalized=function(t){return t.normalized()},t.prototype.normalized=function(){var n=this.x,i=this.y,r=Math.sqrt(n*n+i*i);return r>0?new t(n/r,i/r):new t(0,0)},t.normalize=function(t){return t.normalize()},t.prototype.normalize=function(){var t=this.x,n=this.y,i=Math.sqrt(t*t+n*n);return i>0&&(this.x=t/i,this.y=n/i),this},t.magnitude=function(t){return t.magnitude()},t.prototype.magnitude=function(){return Math.sqrt(this.x*this.x+this.y*this.y)},t.dot=function(t,n){return n.dot(t)},t.prototype.dot=function(t){return this.x*t.x+this.y*t.y},t.distance=function(t,n){return n.distance(t)},t.prototype.distance=function(t){var n=this.x-t.x,i=this.y-t.y;return Math.sqrt(n*n+i*i)},t.angleOf=function(t){return t.angleOf()},t.prototype.angleOf=function(){return Math.atan2(this.y,this.x)},t.angleTo=function(t,n){return n.angleTo(t)},t.prototype.angleTo=function(t){return Math.acos(this.dot(t)/this.magnitude()*t.magnitude())},t.rotate=function(t,n){return n.rotate(t)},t.prototype.rotate=function(t){return n(this.copy(),t)},t.irotate=function(t,n){return n.irotate(t)},t.prototype.irotate=function(t){return n(this,t)},t.reset=function(t,n){return n.reset(t)},t.prototype.reset=function(t){return this.x=t.x,this.y=t.y,this},t.zero=function(t){return t.zero()},t.prototype.zero=function(){return this.x=0,this.y=0,this},t.set=function(t,n,i){return i.set(t,n)},t.prototype.set=function(t,n){return this.x=t||0,this.y=n||0,this},t.copy=function(t){return t.copy()},t.prototype.copy=function(){return new t(this.x,this.y)},t.clone=t.copy,t.prototype.clone=t.prototype.copy,t.toJSON=function(t){return t.toJSON()},t.prototype.toJSON=function(){return[this.x,this.y]},t.toString=function(t){return t?t.toString():Function.prototype.toString.call(this)},t.prototype.toString=function(){return this.x.toFixed(3)+" "+this.y.toFixed(3)},"undefined"!=typeof Symbol&&Symbol.toStringTag&&(t.prototype[Symbol.toStringTag]="Vector"),t.toArray=function(t){return t.toArray()},t.prototype.toArray=function(){return[this.x,this.y]};var r="EPSILON"in Number?Number.EPSILON:2.220446049250313e-16;return t.equals=function(t,n){return t.equals(n)},t.prototype.equals=function(t){return Math.abs(this.x-t.x)i)-(i>n)},Object.defineProperties(t.prototype,{xx:{configurable:!0,get:function(){return new t(this.x,this.x)},set:function(t){this.x=t.x,this.y=t.x}},xy:{configurable:!0,get:function(){return new t(this.x,this.y)},set:function(t){this.x=t.x,this.y=t.y}},yx:{configurable:!0,get:function(){return new t(this.y,this.x)},set:function(t){this.x=t.y,this.y=t.x}},yy:{configurable:!0,get:function(){return new t(this.y,this.y)},set:function(t){this.x=t.y,this.y=t.y}}}),i.prototype.next=function(){return 0===this.__idx?(this.__idx++,{done:!1,value:this.vector.x}):1===this.__idx?(this.__idx++,{done:!1,value:this.vector.y}):{done:!0,value:void 0}},"undefined"!=typeof Symbol&&Symbol.iterator&&(t.prototype[Symbol.iterator]=function(){return new i(this)}),t}); +!function(t,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):t.Vector=n()}(this,function(){"use strict";function t(t,n){this.x=t||0,this.y=n||0}function n(t,n){var i=Math.cos(n),r=Math.sin(n),e=t.x,o=t.y;return t.x=e*i-o*r,t.y=e*r+o*i,t}function i(t){this.vector=t,this.__idx=0}t.displayName="Vector",t.from=function(n){return new t(n[0],n[1])},t.fromAngle=function(n,i){return new t(i*Math.cos(n),i*Math.sin(n))},t.parse=function(n){return t.from(n.trim().replace(","," ").split(/\s+/).map(parseFloat))},t.add=function(t,n){return n.add(t)},t.prototype.add=function(n){return new t(this.x+n.x,this.y+n.y)},t.iadd=function(t,n){return n.iadd(t)},t.prototype.iadd=function(t){return this.x+=t.x,this.y+=t.y,this},t.sub=function(t,n){return n.sub(t)},t.prototype.sub=function(n){return new t(this.x-n.x,this.y-n.y)},t.isub=function(t,n){return n.isub(t)},t.prototype.isub=function(t){return this.x-=t.x,this.y-=t.y,this},t.mul=function(t,n){return n.mul(t)},t.prototype.mul=function(n){return new t(this.x*n,this.y*n)},t.imul=function(t,n){return n.imul(t)},t.prototype.imul=function(t){return this.x*=t,this.y*=t,this},t.div=function(t,n){return n.div(t)},t.prototype.div=function(n){return new t(this.x/n,this.y/n)},t.idiv=function(t,n){return n.idiv(t)},t.prototype.idiv=function(t){return this.x/=t,this.y/=t,this},t.lerp=function(t,n,i){return t.lerp(n,i)},t.prototype.lerp=function(n,i){return new t((1-i)*this.x+i*n.x,(1-i)*this.y+i*n.y)},t.normalized=function(t){return t.normalized()},t.prototype.normalized=function(){var n=this.x,i=this.y,r=Math.sqrt(n*n+i*i);return r>0?new t(n/r,i/r):new t(0,0)},t.normalize=function(t){return t.normalize()},t.prototype.normalize=function(){var t=this.x,n=this.y,i=Math.sqrt(t*t+n*n);return i>0&&(this.x=t/i,this.y=n/i),this},t.magnitude=function(t){return t.magnitude()},t.prototype.magnitude=function(){return Math.sqrt(this.x*this.x+this.y*this.y)},t.dot=function(t,n){return n.dot(t)},t.prototype.dot=function(t){return this.x*t.x+this.y*t.y},t.distance=function(t,n){return n.distance(t)},t.prototype.distance=function(t){var n=this.x-t.x,i=this.y-t.y;return Math.sqrt(n*n+i*i)},t.angleOf=function(t){return t.angleOf()},t.prototype.angleOf=function(){return Math.atan2(this.y,this.x)},t.angleTo=function(t,n){return n.angleTo(t)},t.prototype.angleTo=function(t){return Math.acos(this.dot(t)/(this.magnitude()*t.magnitude()))},t.rotate=function(t,n){return n.rotate(t)},t.prototype.rotate=function(t){return n(this.copy(),t)},t.irotate=function(t,n){return n.irotate(t)},t.prototype.irotate=function(t){return n(this,t)},t.reset=function(t,n){return n.reset(t)},t.prototype.reset=function(t){return this.x=t.x,this.y=t.y,this},t.zero=function(t){return t.zero()},t.prototype.zero=function(){return this.x=0,this.y=0,this},t.set=function(t,n,i){return i.set(t,n)},t.prototype.set=function(t,n){return this.x=t||0,this.y=n||0,this},t.copy=function(t){return t.copy()},t.prototype.copy=function(){return new t(this.x,this.y)},t.clone=t.copy,t.prototype.clone=t.prototype.copy,t.toJSON=function(t){return t.toJSON()},t.prototype.toJSON=function(){return[this.x,this.y]},t.toString=function(t){return t?t.toString():Function.prototype.toString.call(this)},t.prototype.toString=function(){return this.x.toFixed(3)+" "+this.y.toFixed(3)},"undefined"!=typeof Symbol&&Symbol.toStringTag&&(t.prototype[Symbol.toStringTag]="Vector"),t.toArray=function(t){return t.toArray()},t.prototype.toArray=function(){return[this.x,this.y]};var r="EPSILON"in Number?Number.EPSILON:2.220446049250313e-16;return t.equals=function(t,n){return t.equals(n)},t.prototype.equals=function(t){return Math.abs(this.x-t.x)i)-(i>n)},Object.defineProperties(t.prototype,{xx:{configurable:!0,get:function(){return new t(this.x,this.x)},set:function(t){this.x=t.x,this.y=t.x}},xy:{configurable:!0,get:function(){return new t(this.x,this.y)},set:function(t){this.x=t.x,this.y=t.y}},yx:{configurable:!0,get:function(){return new t(this.y,this.x)},set:function(t){this.x=t.y,this.y=t.x}},yy:{configurable:!0,get:function(){return new t(this.y,this.y)},set:function(t){this.x=t.y,this.y=t.y}}}),i.prototype.next=function(){return 0===this.__idx?(this.__idx++,{done:!1,value:this.vector.x}):1===this.__idx?(this.__idx++,{done:!1,value:this.vector.y}):{done:!0,value:void 0}},"undefined"!=typeof Symbol&&Symbol.iterator&&(t.prototype[Symbol.iterator]=function(){return new i(this)}),t}); diff --git a/dist/vectory.umd.js b/dist/vectory.umd.js index 35e7929..032374f 100644 --- a/dist/vectory.umd.js +++ b/dist/vectory.umd.js @@ -174,7 +174,7 @@ Vector$1.angleTo = function (one, another) { }; Vector$1.prototype.angleTo = function (vector) { - return Math.acos(this.dot(vector) / this.magnitude() * vector.magnitude()) + return Math.acos(this.dot(vector) / (this.magnitude() * vector.magnitude())) }; function rotate (vector, theta) { diff --git a/package.json b/package.json index a19c554..93ac1f8 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "vectory", - "version": "1.2.1", + "version": "1.2.2", "description": "High performant, DevTools friendly, Crankshaft tolerant 2d vectors", "keywords": [ "math", @@ -28,18 +28,19 @@ "main": "dist/vectory.umd.js", "module": "dist/vectory.js", "devDependencies": { - "ava": "0.22.0", "benchmark": "2.1.4", - "coveralls": "2.13.1", - "log-symbols": "2.0.0", + "coveralls": "3.0.0", + "log-symbols": "2.1.0", "minimist": "1.2.0", - "nyc": "11.1.0", - "rollup": "0.49.2", - "rollup-plugin-commonjs": "8.2.0", + "nyc": "11.3.0", + "rollup": "0.51.7", + "rollup-plugin-commonjs": "8.2.6", "rollup-plugin-node-resolve": "3.0.0", "snazzy": "7.0.0", "standard": "10.0.3", - "uglify-js": "3.0.28" + "tap-diff": "0.1.1", + "tape": "4.8.0", + "uglify-js": "3.1.9" }, "dependencies": { "number-epsilon": "1.0.3" @@ -52,7 +53,7 @@ "scripts": { "check": "standard src/*.js test/*.js bench/*.js bench/**/*.js | snazzy", "build": "rollup -c", - "test": "nyc --reporter=html --reporter=lcov --reporter=text ava", + "test": "nyc --reporter=html --reporter=lcov --reporter=text tape test/index.test.js", "bench": "node ./bench/index.js", "min": "uglifyjs dist/vectory.umd.js -c -m > dist/vectory.min.js", "coveralls": "cat ./coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js" diff --git a/src/angle.js b/src/angle.js index 16ada82..b9bdaab 100644 --- a/src/angle.js +++ b/src/angle.js @@ -13,7 +13,7 @@ Vector.angleTo = function (one, another) { } Vector.prototype.angleTo = function (vector) { - return Math.acos(this.dot(vector) / this.magnitude() * vector.magnitude()) + return Math.acos(this.dot(vector) / (this.magnitude() * vector.magnitude())) } export default Vector diff --git a/test/addition.test.js b/test/addition.test.js index 66e3176..df54041 100644 --- a/test/addition.test.js +++ b/test/addition.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.add(one, another)` should return sum of two vectors', function (t) { var one = new Vector(1, 2) @@ -8,6 +8,7 @@ test('`Vector.add(one, another)` should return sum of two vectors', function (t) t.true(result instanceof Vector) t.is(result.x, 4) t.is(result.y, 6) + t.end() }) test('`Vector#add(vector)` should return sum of two vectors', function (t) { @@ -17,6 +18,7 @@ test('`Vector#add(vector)` should return sum of two vectors', function (t) { t.true(result instanceof Vector) t.is(result.x, 4) t.is(result.y, 6) + t.end() }) test('`Vector.iadd(one, another)` should add one vector to another', function (t) { @@ -25,6 +27,7 @@ test('`Vector.iadd(one, another)` should add one vector to another', function (t Vector.iadd(one, another) t.is(another.x, 4) t.is(another.y, 6) + t.end() }) test('`Vector.iadd(one, another)` should return another vector', function (t) { @@ -32,6 +35,7 @@ test('`Vector.iadd(one, another)` should return another vector', function (t) { var another = new Vector(3, 4) var result = Vector.iadd(one, another) t.is(result, another) + t.end() }) test('`Vector#iadd(vector)` should add vector to self', function (t) { @@ -40,6 +44,7 @@ test('`Vector#iadd(vector)` should add vector to self', function (t) { self.iadd(vector) t.is(self.x, 4) t.is(self.y, 6) + t.end() }) test('`Vector#iadd(vector)` should return self instance', function (t) { @@ -47,4 +52,5 @@ test('`Vector#iadd(vector)` should return self instance', function (t) { var vector = new Vector(3, 4) var result = self.iadd(vector) t.is(result, self) + t.end() }) diff --git a/test/angle.test.js b/test/angle.test.js index e43db81..00d7361 100644 --- a/test/angle.test.js +++ b/test/angle.test.js @@ -1,28 +1,32 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.angleOf(vector)` should return the angle theta of vector', function (t) { var vector = new Vector(0, 1) var result = Vector.angleOf(vector) t.is(result * 180 / Math.PI, 90) + t.end() }) test('`Vector#angleOf()` should return the angle theta of vector', function (t) { var self = new Vector(0, 1) var result = self.angleOf() t.is(result * 180 / Math.PI, 90) + t.end() }) test('`Vector.angleTo(one, another)` should return the angle between vectors', function (t) { - var one = new Vector(0, 1) - var another = new Vector(1, 0) + var one = new Vector(5, 10) + var another = new Vector(10, 15) var result = Vector.angleTo(one, another) - t.is(result * 180 / Math.PI, 90) + t.is(Math.round(result * 180 / Math.PI), 7) + t.end() }) test('`Vector#angleTo(vector)` should return the angle between vectors', function (t) { - var self = new Vector(0, 1) - var vector = new Vector(1, 0) + var self = new Vector(5, 10) + var vector = new Vector(10, 15) var result = self.angleTo(vector) - t.is(result * 180 / Math.PI, 90) + t.is(Math.round(result * 180 / Math.PI), 7) + t.end() }) diff --git a/test/convertion.test.js b/test/convertion.test.js index e710073..348ea0b 100644 --- a/test/convertion.test.js +++ b/test/convertion.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.toJSON(vector)` should convert passed vector to JSON', function (t) { var vector = new Vector(1, 2) @@ -8,6 +8,7 @@ test('`Vector.toJSON(vector)` should convert passed vector to JSON', function (t t.is(result.length, 2) t.is(result[0], 1) t.is(result[1], 2) + t.end() }) test('`Vector#toJSON()` should convert self to JSON', function (t) { @@ -17,22 +18,26 @@ test('`Vector#toJSON()` should convert self to JSON', function (t) { t.is(result.length, 2) t.is(result[0], 1) t.is(result[1], 2) + t.end() }) test('`Vector.toString(vector)` should convert to string passed vector', function (t) { var vector = new Vector(1, 2) var result = Vector.toString(vector) t.is(result, '1.000 2.000') + t.end() }) test('`Vector.toString(vector)` should call base .toString() if passed nothing', function (t) { t.is(Vector.toString(), Function.prototype.toString.call(Vector)) + t.end() }) test('`Vector#toString()` should convert self to JSON', function (t) { var self = new Vector(1, 2) var result = self.toString() t.is(result, '1.000 2.000') + t.end() }) if (typeof Symbol !== 'undefined' && Symbol.toStringTag && Vector.prototype[Symbol.toStringTag]) { @@ -40,9 +45,12 @@ if (typeof Symbol !== 'undefined' && Symbol.toStringTag && Vector.prototype[Symb var vector = new Vector(1, 2) var result = Object.prototype.toString.call(vector) t.is(result, '[object Vector]') + t.end() }) } else { - test.skip('`Vector.prototype[Symbol.toStringTag]` should specified [object ___] stringification', function (t) {}) + test.skip('`Vector.prototype[Symbol.toStringTag]` should specified [object ___] stringification', function (t) { + t.end() + }) } test('`Vector.toArray(vector)` should convert passed vector to array', function (t) { @@ -52,6 +60,7 @@ test('`Vector.toArray(vector)` should convert passed vector to array', function t.is(result.length, 2) t.is(result[0], 1) t.is(result[1], 2) + t.end() }) test('`Vector#toArray()` should convert self to array', function (t) { @@ -61,4 +70,5 @@ test('`Vector#toArray()` should convert self to array', function (t) { t.is(result.length, 2) t.is(result[0], 1) t.is(result[1], 2) + t.end() }) diff --git a/test/copy.test.js b/test/copy.test.js index 5fa3397..f16830e 100644 --- a/test/copy.test.js +++ b/test/copy.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.copy(vector)` should copy passed vector', function (t) { var vector = new Vector(1, 2) @@ -7,6 +7,7 @@ test('`Vector.copy(vector)` should copy passed vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 2) + t.end() }) test('`Vector#copy()` should copy self', function (t) { @@ -15,4 +16,5 @@ test('`Vector#copy()` should copy self', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 2) + t.end() }) diff --git a/test/creation.test.js b/test/creation.test.js index a818fc6..1a2e33c 100644 --- a/test/creation.test.js +++ b/test/creation.test.js @@ -1,11 +1,12 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`new Vector(x, y)` should create vector instance', function (t) { var vector = new Vector(1, 2) t.true(vector instanceof Vector) t.is(vector.x, 1) t.is(vector.y, 2) + t.end() }) test('`new Vector(x, y)` should create zero vector if args not passed', function (t) { @@ -13,6 +14,7 @@ test('`new Vector(x, y)` should create zero vector if args not passed', function t.true(vector instanceof Vector) t.is(vector.x, 0) t.is(vector.y, 0) + t.end() }) test('`Vector.from([x, y])` should return new vector from data', function (t) { @@ -20,6 +22,7 @@ test('`Vector.from([x, y])` should return new vector from data', function (t) { t.true(vector instanceof Vector) t.is(vector.x, 1) t.is(vector.y, 2) + t.end() }) test('`Vector.fromAngle(angle, magnitude)` should return new vector from angle and magnitude', function (t) { @@ -27,6 +30,7 @@ test('`Vector.fromAngle(angle, magnitude)` should return new vector from angle a t.true(vector instanceof Vector) t.is(Math.round(vector.x), 0) t.is(vector.y, 1) + t.end() }) test('`Vector.parse(string)` should return new vector from string', function (t) { @@ -49,4 +53,5 @@ test('`Vector.parse(string)` should return new vector from string', function (t) t.true(vector instanceof Vector) t.is(vector.x, 1.1) t.is(vector.y, 2.2) + t.end() }) diff --git a/test/distance.test.js b/test/distance.test.js index c78f613..6c54aae 100644 --- a/test/distance.test.js +++ b/test/distance.test.js @@ -1,11 +1,12 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.distance(one, another)` should return distance between vectors', function (t) { var one = new Vector(4, 3) var another = new Vector(8, 6) var distance = Vector.distance(one, another) t.is(distance, 5) + t.end() }) test('`Vector#distance(vector)` should return distance between vectors', function (t) { @@ -13,4 +14,5 @@ test('`Vector#distance(vector)` should return distance between vectors', functio var vector = new Vector(4, 3) var distance = self.distance(vector) t.is(distance, 5) + t.end() }) diff --git a/test/division.test.js b/test/division.test.js index 5b85b8e..826e54e 100644 --- a/test/division.test.js +++ b/test/division.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.div(scalar, vector)` should divide vector on scalar', function (t) { var vector = new Vector(4, 6) @@ -8,6 +8,7 @@ test('`Vector.div(scalar, vector)` should divide vector on scalar', function (t) t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 3) + t.end() }) test('`Vector#div(scalar)` should divide self on scalar', function (t) { @@ -17,6 +18,7 @@ test('`Vector#div(scalar)` should divide self on scalar', function (t) { t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 3) + t.end() }) test('`Vector.idiv(scalar, vector)` should divide vector on scalar', function (t) { @@ -25,6 +27,7 @@ test('`Vector.idiv(scalar, vector)` should divide vector on scalar', function (t Vector.idiv(scalar, vector) t.is(vector.x, 2) t.is(vector.y, 3) + t.end() }) test('`Vector.idiv(scalar, vector)` should return vector', function (t) { @@ -32,6 +35,7 @@ test('`Vector.idiv(scalar, vector)` should return vector', function (t) { var scalar = 2 var result = Vector.idiv(scalar, vector) t.is(result, vector) + t.end() }) test('`Vector#idiv(scalar)` should multiply self on scalar', function (t) { @@ -40,6 +44,7 @@ test('`Vector#idiv(scalar)` should multiply self on scalar', function (t) { vector.idiv(scalar) t.is(vector.x, 2) t.is(vector.y, 3) + t.end() }) test('`Vector#idiv(scalar)` should return self instance', function (t) { @@ -47,4 +52,5 @@ test('`Vector#idiv(scalar)` should return self instance', function (t) { var scalar = 2 var result = vector.idiv(scalar) t.is(result, vector) + t.end() }) diff --git a/test/dot-product.test.js b/test/dot-product.test.js index 72c8011..830c9d2 100644 --- a/test/dot-product.test.js +++ b/test/dot-product.test.js @@ -1,11 +1,12 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.dot(one, another)` should return dot product', function (t) { var one = new Vector(2, 3) var another = new Vector(3, 2) var product = Vector.dot(one, another) t.is(product, 12) + t.end() }) test('`Vector#dot(vector)` should return dot product', function (t) { @@ -13,4 +14,5 @@ test('`Vector#dot(vector)` should return dot product', function (t) { var vector = new Vector(3, 2) var product = self.dot(vector) t.is(product, 12) + t.end() }) diff --git a/test/equality.test.js b/test/equality.test.js index a3c8970..3aed0ae 100644 --- a/test/equality.test.js +++ b/test/equality.test.js @@ -1,11 +1,12 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.equals(one, another)` should check vectors equality', function (t) { var one = new Vector(1, 2) var another = new Vector(1, 2) var result = Vector.equals(one, another) t.true(result) + t.end() }) test('`Vector#equals(vector)` should check vectors equality', function (t) { @@ -13,6 +14,7 @@ test('`Vector#equals(vector)` should check vectors equality', function (t) { var vector = new Vector(1, 2) var result = self.equals(vector) t.true(result) + t.end() }) test('`Vector.compare(one, another)` should check vectors equality', function (t) { @@ -20,6 +22,7 @@ test('`Vector.compare(one, another)` should check vectors equality', function (t var another = new Vector(1, 2) var result = Vector.compare(one, another) t.is(result, 1) + t.end() }) test('`Vector#compare(vector)` should check vectors equality', function (t) { @@ -27,4 +30,5 @@ test('`Vector#compare(vector)` should check vectors equality', function (t) { var vector = new Vector(2, 2) var result = self.compare(vector) t.is(result, -1) + t.end() }) diff --git a/test/index.test.js b/test/index.test.js new file mode 100644 index 0000000..abbefcc --- /dev/null +++ b/test/index.test.js @@ -0,0 +1,26 @@ +var test = require('tape') +var tapDiff = require('tap-diff') + +test.createStream() + .pipe(tapDiff()) + .pipe(process.stdout) + +require('./addition.test.js') +require('./angle.test.js') +require('./convertion.test.js') +require('./copy.test.js') +require('./creation.test.js') +require('./distance.test.js') +require('./division.test.js') +require('./dot-product.test.js') +require('./equality.test.js') +require('./index.test.js') +require('./iterator.test.js') +require('./lerp.test.js') +require('./magnitude.test.js') +require('./multiplication.test.js') +require('./normalization.test.js') +require('./resetting.test.js') +require('./rotation.test.js') +require('./substraction.test.js') +require('./swizzling.test.js') diff --git a/test/iterator.test.js b/test/iterator.test.js index 69b556b..67a0405 100644 --- a/test/iterator.test.js +++ b/test/iterator.test.js @@ -1,15 +1,16 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') if (typeof Symbol !== 'undefined' && Symbol.iterator && Vector.prototype[Symbol.iterator]) { test('`Vector.prototype[Symbol.iterator]()` should return an iterator', function (t) { var vector = new Vector(3, 4) var iterator = vector[Symbol.iterator]() - t.truthy(iterator) + t.ok(iterator) t.true(typeof iterator.next === 'function') t.deepEqual(iterator.next(), { done: false, value: 3 }) t.deepEqual(iterator.next(), { done: false, value: 4 }) t.deepEqual(iterator.next(), { done: true, value: void 0 }) + t.end() }) } else { test.skip('`Vector.prototype[Symbol.iterator]()` should return an iterator', function (t) {}) diff --git a/test/lerp.test.js b/test/lerp.test.js index 6b23439..e8b8a80 100644 --- a/test/lerp.test.js +++ b/test/lerp.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.lerp(one, another, t)` should return linear interpolant between the vectors', function (t) { var one = new Vector(2, 2) @@ -9,6 +9,7 @@ test('`Vector.lerp(one, another, t)` should return linear interpolant between th t.true(result instanceof Vector) t.is(result.x, 3) t.is(result.y, 3) + t.end() }) test('`Vector#lerp(vector, t)` should return linear interpolant between the vectors', function (t) { @@ -19,4 +20,5 @@ test('`Vector#lerp(vector, t)` should return linear interpolant between the vect t.true(result instanceof Vector) t.is(result.x, 3) t.is(result.y, 3) + t.end() }) diff --git a/test/magnitude.test.js b/test/magnitude.test.js index 87cb805..b256f39 100644 --- a/test/magnitude.test.js +++ b/test/magnitude.test.js @@ -1,14 +1,16 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.magnitude(vector)` should return vector magnitude', function (t) { var vector = new Vector(3, 4) var magnitude = Vector.magnitude(vector) t.is(magnitude, 5) + t.end() }) test('`Vector#magnitude()` should return vector magnitude', function (t) { var vector = new Vector(3, 4) var magnitude = vector.magnitude() t.is(magnitude, 5) + t.end() }) diff --git a/test/multiplication.test.js b/test/multiplication.test.js index ec67521..0f7f314 100644 --- a/test/multiplication.test.js +++ b/test/multiplication.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.mul(scalar, vector)` should multiply vector on scalar', function (t) { var vector = new Vector(2, 3) @@ -8,6 +8,7 @@ test('`Vector.mul(scalar, vector)` should multiply vector on scalar', function ( t.true(result instanceof Vector) t.is(result.x, 4) t.is(result.y, 6) + t.end() }) test('`Vector#mul(scalar)` should multiply self on scalar', function (t) { @@ -17,6 +18,7 @@ test('`Vector#mul(scalar)` should multiply self on scalar', function (t) { t.true(result instanceof Vector) t.is(result.x, 4) t.is(result.y, 6) + t.end() }) test('`Vector.imul(scalar, vector)` should multiply vector on scalar', function (t) { @@ -25,6 +27,7 @@ test('`Vector.imul(scalar, vector)` should multiply vector on scalar', function Vector.imul(scalar, vector) t.is(vector.x, 4) t.is(vector.y, 6) + t.end() }) test('`Vector.imul(scalar, vector)` should return vector', function (t) { @@ -32,6 +35,7 @@ test('`Vector.imul(scalar, vector)` should return vector', function (t) { var scalar = 2 var result = Vector.imul(scalar, vector) t.is(result, vector) + t.end() }) test('`Vector#imul(scalar)` should multiply self on scalar', function (t) { @@ -40,6 +44,7 @@ test('`Vector#imul(scalar)` should multiply self on scalar', function (t) { vector.imul(scalar) t.is(vector.x, 4) t.is(vector.y, 6) + t.end() }) test('`Vector#imul(scalar)` should return self instance', function (t) { @@ -47,4 +52,5 @@ test('`Vector#imul(scalar)` should return self instance', function (t) { var scalar = 2 var result = vector.imul(scalar) t.is(result, vector) + t.end() }) diff --git a/test/normalization.test.js b/test/normalization.test.js index 85f6bdc..c786de6 100644 --- a/test/normalization.test.js +++ b/test/normalization.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.normalized(vector)` should return unit vector', function (t) { var vector = new Vector(2, 0) @@ -7,6 +7,7 @@ test('`Vector.normalized(vector)` should return unit vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 0) + t.end() }) test('`Vector.normalized(vector)` should return zero vector if zero vector was passed', function (t) { @@ -15,6 +16,7 @@ test('`Vector.normalized(vector)` should return zero vector if zero vector was p t.true(result instanceof Vector) t.is(result.x, 0) t.is(result.y, 0) + t.end() }) test('`Vector#normalized()` should return unit vector', function (t) { @@ -23,6 +25,7 @@ test('`Vector#normalized()` should return unit vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 0) + t.end() }) test('`Vector#normalized()` should return zero vector from zero vector', function (t) { @@ -31,6 +34,7 @@ test('`Vector#normalized()` should return zero vector from zero vector', functio t.true(result instanceof Vector) t.is(result.x, 0) t.is(result.y, 0) + t.end() }) test('`Vector.normalize(vector)` should convert passed vector to unit vector', function (t) { @@ -39,6 +43,7 @@ test('`Vector.normalize(vector)` should convert passed vector to unit vector', f t.is(vector.x, 1) t.is(vector.y, 0) t.is(result, vector) + t.end() }) test('`Vector.normalize(vector)` should do nothing if zero vector was passed', function (t) { @@ -47,6 +52,7 @@ test('`Vector.normalize(vector)` should do nothing if zero vector was passed', f t.is(vector.x, 0) t.is(vector.y, 0) t.is(result, vector) + t.end() }) test('`Vector#normalize()` should convert vector to unit vector', function (t) { @@ -54,10 +60,12 @@ test('`Vector#normalize()` should convert vector to unit vector', function (t) { vector.normalize() t.is(vector.x, 1) t.is(vector.y, 0) + t.end() }) test('`Vector#normalize()` should return self', function (t) { var vector = new Vector(0, 0) var result = vector.normalize() t.is(result, vector) + t.end() }) diff --git a/test/resetting.test.js b/test/resetting.test.js index 7a285eb..a31dab4 100644 --- a/test/resetting.test.js +++ b/test/resetting.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.reset(one, another)` should reset vector values', function (t) { var one = new Vector(1, 2) @@ -7,6 +7,7 @@ test('`Vector.reset(one, another)` should reset vector values', function (t) { Vector.reset(one, another) t.is(another.x, 1) t.is(another.y, 2) + t.end() }) test('`Vector.reset(one, another)` should return another vector', function (t) { @@ -14,6 +15,7 @@ test('`Vector.reset(one, another)` should return another vector', function (t) { var another = new Vector(0, 0) var result = Vector.reset(one, another) t.is(result, another) + t.end() }) test('`Vector#reset(vector)` should reset vector values', function (t) { @@ -22,6 +24,7 @@ test('`Vector#reset(vector)` should reset vector values', function (t) { self.reset(vector) t.is(self.x, 1) t.is(self.y, 2) + t.end() }) test('`Vector#reset(vector)` should return self', function (t) { @@ -29,6 +32,7 @@ test('`Vector#reset(vector)` should return self', function (t) { var vector = new Vector(1, 2) var result = self.reset(vector) t.is(result, self) + t.end() }) test('`Vector.zero(vector)` should reset vector values to zero', function (t) { @@ -36,12 +40,14 @@ test('`Vector.zero(vector)` should reset vector values to zero', function (t) { Vector.zero(vector) t.is(vector.x, 0) t.is(vector.y, 0) + t.end() }) test('`Vector.zero(vector)` should return passed vector', function (t) { var vector = new Vector(1, 2) var result = Vector.zero(vector) t.is(result, vector) + t.end() }) test('`Vector#zero()` should reset vector values to zero', function (t) { @@ -49,12 +55,14 @@ test('`Vector#zero()` should reset vector values to zero', function (t) { self.zero() t.is(self.x, 0) t.is(self.y, 0) + t.end() }) test('`Vector#zero()` should return self', function (t) { var self = new Vector(1, 2) var result = self.zero() t.is(result, self) + t.end() }) test('`Vector.set(x, y, vector)` should set vector values', function (t) { @@ -62,12 +70,14 @@ test('`Vector.set(x, y, vector)` should set vector values', function (t) { Vector.set(1, 2, vector) t.is(vector.x, 1) t.is(vector.y, 2) + t.end() }) test('`Vector.set(one, another)` should return vector', function (t) { var vector = new Vector(0, 0) var result = Vector.set(1, 2, vector) t.is(result, vector) + t.end() }) test('`Vector#set(vector)` should set vector values', function (t) { @@ -75,12 +85,14 @@ test('`Vector#set(vector)` should set vector values', function (t) { vector.set(1, 2) t.is(vector.x, 1) t.is(vector.y, 2) + t.end() }) test('`Vector#set(vector)` should return self', function (t) { var vector = new Vector(0, 0) var result = vector.set(1, 2) t.is(result, vector) + t.end() }) test('`Vector#set(vector)` should set vector values to zero if args not passed', function (t) { @@ -88,4 +100,5 @@ test('`Vector#set(vector)` should set vector values to zero if args not passed', vector.set() t.is(vector.x, 0) t.is(vector.y, 0) + t.end() }) diff --git a/test/rotation.test.js b/test/rotation.test.js index 8273074..7ef4cb8 100644 --- a/test/rotation.test.js +++ b/test/rotation.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.rotate(theta, vector)` should rotate vector on theta angle', function (t) { var vector = new Vector(3, 3) @@ -8,6 +8,7 @@ test('`Vector.rotate(theta, vector)` should rotate vector on theta angle', funct t.true(result instanceof Vector) t.is(result.x, -3) t.is(result.y, 3) + t.end() }) test('`Vector#rotate(theta)` should rotate vector on theta angle', function (t) { @@ -17,6 +18,7 @@ test('`Vector#rotate(theta)` should rotate vector on theta angle', function (t) t.true(result instanceof Vector) t.is(result.x, -3) t.is(result.y, 3) + t.end() }) test('`Vector.irotate(theta, vector)` should rotate vector on theta angle', function (t) { @@ -27,6 +29,7 @@ test('`Vector.irotate(theta, vector)` should rotate vector on theta angle', func t.is(result, vector) t.is(result.x, -3) t.is(result.y, 3) + t.end() }) test('`Vector.irotate(theta, vector)` should return vector', function (t) { @@ -34,6 +37,7 @@ test('`Vector.irotate(theta, vector)` should return vector', function (t) { var theta = Math.PI / 2 var result = Vector.irotate(theta, vector) t.is(result, vector) + t.end() }) test('`Vector#irotate(theta)` should rotate vector on theta angle', function (t) { @@ -44,6 +48,7 @@ test('`Vector#irotate(theta)` should rotate vector on theta angle', function (t) t.is(result, self) t.is(result.x, -3) t.is(result.y, 3) + t.end() }) test('`Vector#irotate(theta)` should return self instance', function (t) { @@ -51,4 +56,5 @@ test('`Vector#irotate(theta)` should return self instance', function (t) { var theta = Math.PI / 2 var result = self.irotate(theta) t.is(result, self) + t.end() }) diff --git a/test/substraction.test.js b/test/substraction.test.js index 9be52db..339f970 100644 --- a/test/substraction.test.js +++ b/test/substraction.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector.sub(one, another)` should return diff of two vectors', function (t) { var one = new Vector(1, 2) @@ -8,6 +8,7 @@ test('`Vector.sub(one, another)` should return diff of two vectors', function (t t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 2) + t.end() }) test('`Vector#sub(vector)` should return diff of two vectors', function (t) { @@ -17,6 +18,7 @@ test('`Vector#sub(vector)` should return diff of two vectors', function (t) { t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 2) + t.end() }) test('`Vector.isub(one, another)` should substract one vector from another', function (t) { @@ -25,6 +27,7 @@ test('`Vector.isub(one, another)` should substract one vector from another', fun Vector.isub(one, another) t.is(another.x, 2) t.is(another.y, 2) + t.end() }) test('`Vector.isub(one, another)` should return another vector', function (t) { @@ -32,6 +35,7 @@ test('`Vector.isub(one, another)` should return another vector', function (t) { var another = new Vector(3, 4) var result = Vector.isub(one, another) t.is(result, another) + t.end() }) test('`Vector#isub(vector)` should substract vector from self', function (t) { @@ -40,6 +44,7 @@ test('`Vector#isub(vector)` should substract vector from self', function (t) { self.isub(vector) t.is(self.x, 2) t.is(self.y, 2) + t.end() }) test('`Vector#isub(vector)` should return self instance', function (t) { @@ -47,4 +52,5 @@ test('`Vector#isub(vector)` should return self instance', function (t) { var vector = new Vector(1, 2) var result = self.isub(vector) t.is(result, self) + t.end() }) diff --git a/test/swizzling.test.js b/test/swizzling.test.js index d1d1a35..28772cc 100644 --- a/test/swizzling.test.js +++ b/test/swizzling.test.js @@ -1,5 +1,5 @@ var Vector = require('../dist/vectory.umd.js') -var test = require('ava') +var test = require('tape') test('`Vector#xx` should be an accessor', function (t) { var descriptor = Object.getOwnPropertyDescriptor(Vector.prototype, 'xx') @@ -7,6 +7,7 @@ test('`Vector#xx` should be an accessor', function (t) { t.is(descriptor.enumerable, false) t.true(typeof descriptor.get === 'function') t.true(typeof descriptor.set === 'function') + t.end() }) test('`Vector#xx` should have getter which return new vector', function (t) { @@ -15,6 +16,7 @@ test('`Vector#xx` should have getter which return new vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 1) + t.end() }) test('`Vector#xx` should have setter which set vector values', function (t) { @@ -23,6 +25,7 @@ test('`Vector#xx` should have setter which set vector values', function (t) { self.xx = vector t.is(self.x, 3) t.is(self.y, 3) + t.end() }) test('`Vector#xy` should be an accessor', function (t) { @@ -31,6 +34,7 @@ test('`Vector#xy` should be an accessor', function (t) { t.is(descriptor.enumerable, false) t.true(typeof descriptor.get === 'function') t.true(typeof descriptor.set === 'function') + t.end() }) test('`Vector#xy` should have getter which return new vector', function (t) { @@ -39,6 +43,7 @@ test('`Vector#xy` should have getter which return new vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 1) t.is(result.y, 2) + t.end() }) test('`Vector#xy` should have setter which set vector values', function (t) { @@ -47,6 +52,7 @@ test('`Vector#xy` should have setter which set vector values', function (t) { self.xy = vector t.is(self.x, 3) t.is(self.y, 4) + t.end() }) test('`Vector#yx` should be an accessor', function (t) { @@ -55,6 +61,7 @@ test('`Vector#yx` should be an accessor', function (t) { t.is(descriptor.enumerable, false) t.true(typeof descriptor.get === 'function') t.true(typeof descriptor.set === 'function') + t.end() }) test('`Vector#yx` should have getter which return new vector', function (t) { var self = new Vector(1, 2) @@ -62,6 +69,7 @@ test('`Vector#yx` should have getter which return new vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 1) + t.end() }) test('`Vector#yx` should have setter which set vector values', function (t) { @@ -70,6 +78,7 @@ test('`Vector#yx` should have setter which set vector values', function (t) { self.yx = vector t.is(self.x, 4) t.is(self.y, 3) + t.end() }) test('`Vector#yy` should be an accessor', function (t) { @@ -78,6 +87,7 @@ test('`Vector#yy` should be an accessor', function (t) { t.is(descriptor.enumerable, false) t.true(typeof descriptor.get === 'function') t.true(typeof descriptor.set === 'function') + t.end() }) test('`Vector#yy` should have getter which return new vector', function (t) { @@ -86,6 +96,7 @@ test('`Vector#yy` should have getter which return new vector', function (t) { t.true(result instanceof Vector) t.is(result.x, 2) t.is(result.y, 2) + t.end() }) test('`Vector#yy` should have setter which set vector values', function (t) { @@ -94,4 +105,5 @@ test('`Vector#yy` should have setter which set vector values', function (t) { self.yy = vector t.is(self.x, 4) t.is(self.y, 4) + t.end() })