52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| // Tests for util-related things
 | |
| describe('PathKit\'s CubicMap Behavior', function() {
 | |
|     it('computes YFromX correctly', function(done) {
 | |
|         LoadPathKit.then(catchException(done, () => {
 | |
|             // Spot check a few points
 | |
|             const testcases = [
 | |
|                 // input x, expected y
 | |
|                 [0.025391,  0.117627],
 | |
|                 [0.333984,  0.276221],
 | |
|                 [0.662109,  0.366052],
 | |
|                 [0.939453,  0.643296],
 | |
|             ];
 | |
|             for (tc of testcases) {
 | |
|                 expect(PathKit.cubicYFromX(0, 0.5, 1.0, 0, tc[0])).toBeCloseTo(tc[1], 5);
 | |
|             }
 | |
|             done();
 | |
|         }));
 | |
|     });
 | |
|     it('computes a point from T correctly', function(done) {
 | |
|         LoadPathKit.then(catchException(done, () => {
 | |
|             // Spot check a few points
 | |
|             const testcases = [
 | |
|                 // input t, expected x, expected y
 | |
|                 [0.25, [0.128125, 0.240625]],
 | |
|                 [0.5,  [0.35, 0.35]],
 | |
|                 [0.75, [0.646875, 0.534375]],
 | |
|                 [1.0, [1.0, 1.0]],
 | |
|             ];
 | |
|             for (tc of testcases) {
 | |
|                 let ans = PathKit.cubicPtFromT(0.1, 0.5, 0.5, 0.1, tc[0]);
 | |
|                 expect(ans).toBeTruthy();
 | |
|                 expect(ans.length).toBe(2);
 | |
|                 expect(ans[0]).toBeCloseTo(tc[1][0]);
 | |
|                 expect(ans[1]).toBeCloseTo(tc[1][1]);
 | |
|             }
 | |
|             done();
 | |
|         }));
 | |
|     });
 | |
| 
 | |
|     it('does not leak, with or without cache', function(done) {
 | |
|         LoadPathKit.then(catchException(done, () => {
 | |
|             // Run it a lot to make sure we don't leak.
 | |
|             for (let i = 0; i < 300000; i++) {
 | |
|                 PathKit.cubicYFromX(0.1, 0.5, 0.5, 0.1, 0.1);
 | |
|                 PathKit.cubicPtFromT(0.1, 0.5, 0.5, 0.1, 0.1);
 | |
|             }
 | |
|             done();
 | |
|         }));
 | |
|     });
 | |
| 
 | |
| });
 |