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("|"));
|
|
});
|
|
});
|
|
});
|
|
|
|
}); |