35 lines
1.2 KiB
JavaScript
35 lines
1.2 KiB
JavaScript
const assert = require('node:assert/strict');
|
|
const test = require('node:test');
|
|
|
|
const { buildDateFilter, normalizeDateParam } = require('../services/analyticsService');
|
|
|
|
test('normalizeDateParam accepts strict ISO dates', () => {
|
|
assert.equal(normalizeDateParam('2026-05-28'), '2026-05-28');
|
|
});
|
|
|
|
test('normalizeDateParam rejects non-ISO or impossible dates', () => {
|
|
assert.equal(normalizeDateParam('28/05/2026'), null);
|
|
assert.equal(normalizeDateParam('2026-02-31'), null);
|
|
assert.equal(normalizeDateParam(''), null);
|
|
});
|
|
|
|
test('buildDateFilter builds bounded date predicates', () => {
|
|
const filter = buildDateFilter({ start: '2026-05-01', end: '2026-05-28' });
|
|
|
|
assert.deepEqual(filter.params, ['2026-05-01', '2026-05-28']);
|
|
assert.equal(
|
|
filter.whereClause,
|
|
'WHERE data_pedido_date IS NOT NULL AND data_pedido_date >= $1::date AND data_pedido_date <= $2::date'
|
|
);
|
|
});
|
|
|
|
test('buildDateFilter ignores invalid bounds', () => {
|
|
const filter = buildDateFilter({ start: 'invalid', end: '2026-05-28' });
|
|
|
|
assert.deepEqual(filter.params, ['2026-05-28']);
|
|
assert.equal(
|
|
filter.whereClause,
|
|
'WHERE data_pedido_date IS NOT NULL AND data_pedido_date <= $1::date'
|
|
);
|
|
});
|