Compare commits
5 Commits
c7fa02f34e
...
e8f924be64
Author | SHA1 | Date |
---|---|---|
Rahul Padigela | e8f924be64 | |
Rahul Padigela | 081d94ac1e | |
Rahul Padigela | 9eed64874d | |
Rahul Padigela | ba5ca5f6a1 | |
Rahul Padigela | b891f48e30 |
|
@ -6,6 +6,7 @@ const LogLevel = require('./LogLevel.js');
|
||||||
const Utils = require('./Utils.js');
|
const Utils = require('./Utils.js');
|
||||||
const serializeUids = Utils.serializeUids;
|
const serializeUids = Utils.serializeUids;
|
||||||
const generateUid = Utils.generateUid;
|
const generateUid = Utils.generateUid;
|
||||||
|
const objectCopy = Utils.objectCopy;
|
||||||
|
|
||||||
function ensureUidValidity(uid) {
|
function ensureUidValidity(uid) {
|
||||||
if (uid.indexOf(':') !== -1) {
|
if (uid.indexOf(':') !== -1) {
|
||||||
|
@ -26,7 +27,7 @@ class EndLogger {
|
||||||
+ ' once.');
|
+ ' once.');
|
||||||
// We can alter current instance, as it won't be usable after this
|
// We can alter current instance, as it won't be usable after this
|
||||||
// call.
|
// call.
|
||||||
this.fields = Object.assign(this.fields, data || {});
|
this.fields = objectCopy(this.fields, data || {});
|
||||||
return this.logger.log(level, msg, this.fields, true);
|
return this.logger.log(level, msg, this.fields, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,7 +46,7 @@ class EndLogger {
|
||||||
*/
|
*/
|
||||||
addDefaultFields(fields) {
|
addDefaultFields(fields) {
|
||||||
const oldFields = this.fields;
|
const oldFields = this.fields;
|
||||||
this.fields = Object.assign({}, this.fields, fields);
|
this.fields = objectCopy({}, this.fields, fields);
|
||||||
return oldFields;
|
return oldFields;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -248,7 +249,7 @@ class RequestLogger {
|
||||||
*/
|
*/
|
||||||
addDefaultFields(fields) {
|
addDefaultFields(fields) {
|
||||||
const oldFields = this.fields;
|
const oldFields = this.fields;
|
||||||
this.fields = Object.assign({}, this.fields, fields);
|
this.fields = objectCopy({}, this.fields, fields);
|
||||||
return oldFields;
|
return oldFields;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -433,17 +434,16 @@ class RequestLogger {
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const fields = Object.assign({}, logFields || {});
|
const fields = objectCopy({}, logFields || {});
|
||||||
const endFlag = isEnd || false;
|
const endFlag = isEnd || false;
|
||||||
const hr = process.hrtime();
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Here, Stringify hrtime for it to stay within a one-liner when piping
|
* Even though this is added automatically by bunyan, it uses an
|
||||||
* the output through bunyan's cli tool.
|
* expensive regex to figure out the native Date function. By adding
|
||||||
* Then prepend the fields to the argument Array we're preparing for
|
* timestamp here avoids that expensive call.
|
||||||
* bunyan
|
*/
|
||||||
*/
|
if (fields.time === undefined) {
|
||||||
fields.hrtime = JSON.stringify(hr);
|
fields.time = new Date();
|
||||||
|
}
|
||||||
fields.req_id = serializeUids(this.uids);
|
fields.req_id = serializeUids(this.uids);
|
||||||
if (endFlag) {
|
if (endFlag) {
|
||||||
this.elapsedTime = process.hrtime(this.startTime);
|
this.elapsedTime = process.hrtime(this.startTime);
|
||||||
|
@ -483,7 +483,7 @@ class RequestLogger {
|
||||||
* @returns {undefined}
|
* @returns {undefined}
|
||||||
*/
|
*/
|
||||||
doLogIO(logEntry) {
|
doLogIO(logEntry) {
|
||||||
const fields = Object.assign({}, this.fields, logEntry.fields);
|
const fields = objectCopy({}, this.fields, logEntry.fields);
|
||||||
|
|
||||||
switch (logEntry.level) {
|
switch (logEntry.level) {
|
||||||
case 'trace':
|
case 'trace':
|
||||||
|
|
26
lib/Utils.js
26
lib/Utils.js
|
@ -40,8 +40,34 @@ function unserializeUids(stringdata) {
|
||||||
return stringdata.split(':');
|
return stringdata.split(':');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function copies the properties from the source object to the target object
|
||||||
|
* @param {...object} target - object to be copied to
|
||||||
|
* @returns {object} - target object
|
||||||
|
*/
|
||||||
|
function objectCopy(target, source1, source2) {
|
||||||
|
const result = target;
|
||||||
|
if (source1) {
|
||||||
|
Object.keys(source1).forEach( f => result[f] = source1[f]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (source2) {
|
||||||
|
Object.keys(source2).forEach( f => result[f] = source2[f]);
|
||||||
|
}
|
||||||
|
// let source;
|
||||||
|
// function copy(f) {
|
||||||
|
// result[f] = source[f];
|
||||||
|
// }
|
||||||
|
// for (let i = 1; i < arguments.length; i++) {
|
||||||
|
// source = arguments[i];
|
||||||
|
// Object.keys(source).forEach(copy);
|
||||||
|
// }
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
generateUid,
|
generateUid,
|
||||||
serializeUids,
|
serializeUids,
|
||||||
unserializeUids,
|
unserializeUids,
|
||||||
|
objectCopy,
|
||||||
};
|
};
|
||||||
|
|
|
@ -5,6 +5,7 @@ const Utils = require('../../lib/Utils.js');
|
||||||
const generateUid = Utils.generateUid;
|
const generateUid = Utils.generateUid;
|
||||||
const serializeUids = Utils.serializeUids;
|
const serializeUids = Utils.serializeUids;
|
||||||
const unserializeUids = Utils.unserializeUids;
|
const unserializeUids = Utils.unserializeUids;
|
||||||
|
const objectCopy = Utils.objectCopy;
|
||||||
|
|
||||||
describe('Utils: generateUid', () => {
|
describe('Utils: generateUid', () => {
|
||||||
it('generates a string-typed ID', (done) => {
|
it('generates a string-typed ID', (done) => {
|
||||||
|
@ -42,3 +43,25 @@ describe('Utils: serializeUids', () => {
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('Utils: objectCopy', () => {
|
||||||
|
it('copies all the properties from source to target object', (done) => {
|
||||||
|
const target = { foo: 'bar' };
|
||||||
|
const source = { id: 1, name: 'demo', value: { a: 1, b: 2, c: 3 } };
|
||||||
|
const result = { foo: 'bar', id: 1, name: 'demo', value: { a: 1, b: 2, c: 3 } };
|
||||||
|
objectCopy(target, source);
|
||||||
|
assert.deepStrictEqual(target, result, 'target should have the same properties as source');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('copies all the properties from multiple sources to target object', (done) => {
|
||||||
|
const target = { foo: 'bar' };
|
||||||
|
const source1 = { id: 1, name: 'demo1', value: { a: 1, b: 2, c: 3 } };
|
||||||
|
const source2 = { req_id: 2, method: 'test', err: { code: 'error', msg: 'test' } };
|
||||||
|
const result = { foo: 'bar', id: 1, name: 'demo1', value: { a: 1, b: 2, c: 3 },
|
||||||
|
req_id: 2, method: 'test', err: { code: 'error', msg: 'test' }};
|
||||||
|
objectCopy(target, source1, source2);
|
||||||
|
assert.deepStrictEqual(target, result, 'target should have the same properties as source');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue