forked from sheetjs/sheetjs
		
	
		
			
				
	
	
		
			38 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* vim: set ts=2: */
 | |
| /*jshint loopfunc:true, mocha:true, node:true */
 | |
| /*eslint-env node, mocha */
 | |
| var XLSX = require("xlsx"), SSF = require("../");
 | |
| 
 | |
| describe('rounding', function() {
 | |
| 
 | |
|   it('number', function() {
 | |
|     var wb = XLSX.readFile("./test/rounding.xlsx", {cellNF: true, dense: true});
 | |
|     var data = wb.Sheets.number["!data"];
 | |
|     data.slice(1).forEach(function(r,R) {
 | |
|       var val = data[R+1][0].v;
 | |
|       var raw = parseFloat(data[R+1][1].v);
 | |
|       r.slice(2).forEach(function(cell, C) {
 | |
|         var fmt = data[0][C+2].v;
 | |
|         var w = SSF.format(fmt, val);
 | |
|         if(w != cell.v) throw ([R, C, val, fmt, cell.v, w].join("|"));
 | |
|         var W = SSF.format(fmt, raw);
 | |
|         if(W != cell.v) throw ([R, C, val, fmt, cell.v, W, "!!"].join("|"));
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   it('date', function() {
 | |
|     var wb = XLSX.readFile("./test/rounding.xlsx", {cellNF: true, dense: true});
 | |
|     var data = wb.Sheets.date["!data"];
 | |
|     data.slice(1).forEach(function(r,R) {
 | |
|       var val = data[R+1][0].v;
 | |
|       r.slice(1).forEach(function(cell, C) {
 | |
|         var fmt = data[0][C+1].v;
 | |
|         if(fmt == 'yyyy-mm-dd [hh]:mm:ss') return; // Format broken in excel 2007 - present
 | |
|         var w = SSF.format(fmt, val);
 | |
|         if(w != cell.v) throw([R, C, val, fmt, cell.v, w].join("|"));
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| 
 | |
| }); |