Skip to content

Commit

Permalink
Merge pull request #76 from snrmwg/issue/74-use-local-timezone
Browse files Browse the repository at this point in the history
fix: issue #74 use local timezone
  • Loading branch information
shadowgate15 authored Feb 5, 2021
2 parents eac6acc + a95c5b0 commit 7be21b4
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 3 deletions.
2 changes: 2 additions & 0 deletions src/job-builder.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ const { boolean } = require('boolean');
const later = require('@breejs/later');
const { isSchedule, parseValue } = require('./job-utils');

later.date.localTime();

// eslint-disable-next-line complexity
const buildJob = (job, config) => {
if (isSANB(job)) {
Expand Down
76 changes: 73 additions & 3 deletions test/test.js
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,9 @@ test('fails if jobs is not an array', (t) => {
root: path.join(__dirname, 'noIndexJobs'),
jobs: null,
// hide MODULE_NOT_FOUND error
logger: { error: () => {} }
logger: {
error: () => {}
}
}),
{ message: 'Jobs must be an Array' }
);
Expand Down Expand Up @@ -289,6 +291,72 @@ test('fails if cron pattern is invalid', (t) => {
);
});

test.serial('job created with cron string is using local timezone', (t) => {
t.plan(2);
const bree = new Bree({
root,
jobs: [{ name: 'basic', cron: '0 18 * * *' }]
});

const clock = FakeTimers.install({ now: Date.now() });
bree.start('basic');
bree.on('worker created', () => {
const now = new Date(clock.now);
const offsetOfLocalDates = new Date().getTimezoneOffset();

t.is(now.getTimezoneOffset(), offsetOfLocalDates);
t.is(now.getHours(), 18);
});
clock.next();
clock.uninstall();
});

test.serial(
'add > job created with cron string is using local timezone',
(t) => {
t.plan(2);
const bree = new Bree({
root: false
});

bree.add({
name: 'basic',
cron: '0 18 * * *',
path: path.join(__dirname, 'jobs/basic.js')
});

const clock = FakeTimers.install({ now: Date.now() });
bree.start('basic');
bree.on('worker created', () => {
const now = new Date(clock.now);
const offsetOfLocalDates = new Date().getTimezoneOffset();

t.is(now.getTimezoneOffset(), offsetOfLocalDates);
t.is(now.getHours(), 18);
});
clock.next();
clock.uninstall();
}
);

test.serial('job created with human interval is using local timezone', (t) => {
t.plan(2);
const bree = new Bree({
root,
jobs: [{ name: 'basic', interval: 'at 13:26' }]
});

const clock = FakeTimers.install({ now: Date.now() });
bree.start('basic');
bree.on('worker created', () => {
const now = new Date(clock.now);
t.is(now.getHours(), 13);
t.is(now.getMinutes(), 26);
});
clock.next();
clock.uninstall();
});

test('fails if closeWorkersAfterMs is <= 0 or infinite', (t) => {
t.throws(
() =>
Expand Down Expand Up @@ -444,7 +512,7 @@ test.serial('run > job terminates after set time', async (t) => {
await new Promise((resolve, reject) => {
bree.workers.infinite.on('error', reject);
bree.workers.infinite.on('exit', (code) => {
t.true(code === 1);
t.is(code, 1);
resolve();
});
});
Expand All @@ -467,7 +535,7 @@ test.serial('run > job terminates before set time', async (t) => {
await new Promise((resolve, reject) => {
bree.workers.basic.on('error', reject);
bree.workers.basic.on('exit', (code) => {
t.true(code === 0);
t.is(code, 0);
resolve();
});
});
Expand Down Expand Up @@ -1711,7 +1779,9 @@ test('remove > fails if job does not exist', (t) => {

test('add > successfully adds job object', (t) => {
const bree = new Bree({ root: false });

function noop() {}

bree.add({ name: 'basic', path: noop.toString() });
t.pass();
});
Expand Down

0 comments on commit 7be21b4

Please sign in to comment.