2012-02-02 17:11:45 +00:00
# bunyan Changelog
2012-02-23 21:01:12 +00:00
## bunyan 0.6.5
2012-02-20 05:42:58 +00:00
2012-02-23 05:03:03 +00:00
- ANSI coloring output from `bunyan` CLI tool (for the default output mode/style).
Also add the '--color' option to force coloring if the output stream is not
2012-02-23 21:00:53 +00:00
a TTY, e.g. `cat my.log | bunyan --color | less -R` . Use `--no-color` to
disable coloring, e.g. if your terminal doesn't support ANSI codes.
- Add 'level' field to log record before custom fields for that record. This
just means that the raw record JSON will show the 'level' field earlier,
which is a bit nicer for raw reading.
2012-02-22 18:53:12 +00:00
2012-02-20 05:42:58 +00:00
2012-02-20 05:42:47 +00:00
## bunyan 0.6.4
2012-02-20 05:42:23 +00:00
- [issue #5 ] Fix `log.info() -> boolean` to work properly. Previous all were
returning false. Ditto all trace/debug/.../fatal methods.
2012-02-17 00:53:13 +00:00
## bunyan 0.6.3
2012-02-11 05:52:12 +00:00
2012-02-17 00:49:19 +00:00
- Allow an optional `msg` and arguments to the `log.info(<Error> err)` logging
form. For example, before:
log.debug(my_error_instance) // good
log.debug(my_error_instance, "boom!") // wasn't allowed
Now the latter is allowed if you want to expliciting set the log msg. Of course
this applies to all the `log.{trace|debug|info...}()` methods.
2012-02-12 00:34:40 +00:00
- `bunyan` cli output: clarify extra fields with quoting if empty or have
spaces. E.g. 'cmd' and 'stderr' in the following:
[2012-02-12T00:30:43.736Z] INFO: mo-docs/43194 on banana.local: buildDocs results (req_id=185edca2-2886-43dc-911c-fe41c09ec0f5, route=PutDocset, error=null, stderr="", cmd="make docs")
2012-02-11 05:52:12 +00:00
2012-02-11 05:51:59 +00:00
## bunyan 0.6.2
2012-02-10 08:16:59 +00:00
2012-02-11 05:51:38 +00:00
- Fix/guard against unintended inclusion of some files in npm published package
due to < https: / / github . com / isaacs / npm / issues / 2144 >
2012-02-10 08:16:59 +00:00
2012-02-10 08:16:11 +00:00
## bunyan 0.6.1
2012-02-10 05:11:27 +00:00
2012-02-10 08:15:45 +00:00
- Internal: starting jsstyle usage.
- Internal: add .npmignore. Previous packages had reams of bunyan crud in them.
2012-02-10 05:11:27 +00:00
2012-02-10 05:10:26 +00:00
## bunyan 0.6.0
2012-02-10 05:07:01 +00:00
- Add 'pid' automatic log record field.
2012-02-08 23:28:19 +00:00
2012-02-08 23:28:05 +00:00
## bunyan 0.5.3
2012-02-08 18:30:38 +00:00
2012-02-08 23:27:53 +00:00
- Add 'client_req' (HTTP client request) standard formatting in `bunyan` CLI
default output.
2012-02-08 23:18:07 +00:00
- Improve `bunyan` CLI default output to include *all* log record keys. Unknown keys
are either included in the first line parenthetical (if short) or in the indented
subsequent block (if long or multiline).
2012-02-08 18:30:38 +00:00
2012-02-08 18:30:24 +00:00
## bunyan 0.5.2
2012-02-07 05:35:39 +00:00
2012-02-08 18:30:13 +00:00
- [issue #3 ] More type checking of `new Logger(...)` and `log.child(...)`
options.
2012-02-08 18:05:56 +00:00
- Start a test suite.
2012-02-07 05:35:39 +00:00
2012-02-07 05:35:29 +00:00
## bunyan 0.5.1
2012-02-06 23:27:50 +00:00
2012-02-07 05:35:19 +00:00
- [issue #2 ] Add guard on `JSON.stringify` ing of log records before emission.
This will prevent `log.info` et al throwing on record fields that cannot be
represented as JSON. An error will be printed on stderr and a clipped log
record emitted with a 'bunyanMsg' key including error details. E.g.:
2012-02-23 21:00:53 +00:00
2012-02-07 05:34:04 +00:00
bunyan: ERROR: could not stringify log record from /Users/trentm/tm/node-bunyan/examples/unstringifyable.js:12: TypeError: Converting circular structure to JSON
{
"name": "foo",
"hostname": "banana.local",
"bunyanMsg": "bunyan: ERROR: could not stringify log record from /Users/trentm/tm/node-bunyan/examples/unstringifyable.js:12: TypeError: Converting circular structure to JSON",
...
2012-02-23 21:00:53 +00:00
Some timing shows this does effect log speed:
2012-02-07 05:34:04 +00:00
$ node tools/timeguard.js # before
Time try/catch-guard on JSON.stringify:
- log.info: 0.07365ms per iteration
$ node tools/timeguard.js # after
Time try/catch-guard on JSON.stringify:
- log.info: 0.07368ms per iteration
2012-02-07 05:35:19 +00:00
2012-02-06 23:27:50 +00:00
2012-02-06 23:27:42 +00:00
## bunyan 0.5.0
2012-02-06 17:10:11 +00:00
2012-02-06 23:23:51 +00:00
- Use 10/20/... instead of 1/2/... for level constant values. Ostensibly this
allows for intermediary levels from the defined "trace/debug/..." set.
However, that is discouraged. I'd need a strong user argument to add
support for easily using alternative levels. Consider using a separate
JSON field instead.
2012-02-06 23:13:50 +00:00
- s/service/name/ for Logger name field. "service" is unnecessarily tied
to usage for a service. No need to differ from log4j Logger "name".
2012-02-06 23:04:47 +00:00
- Add `log.level(...)` and `log.levels(...)` API for changing logger stream
levels.
- Add `TRACE|DEBUG|INFO|WARN|ERROR|FATAL` level constants to exports.
2012-02-06 17:10:11 +00:00
- Add `log.info(err)` special case for logging an `Error` instance. For
example `log.info(new TypeError("boom")` will produce:
...
"err": {
"message": "boom",
"name": "TypeError",
"stack": "TypeError: boom\n at Object.< anonymous > ..."
},
"msg": "boom",
...
2012-02-06 04:34:40 +00:00
2012-02-06 04:34:08 +00:00
## bunyan 0.4.0
2012-02-06 04:33:57 +00:00
- Add `new Logger({src: true})` config option to have a 'src' attribute be
automatically added to log records with the log call source info. Example:
"src": {
"file": "/Users/trentm/tm/node-bunyan/examples/src.js",
"line": 20,
"func": "Wuzzle.woos"
},
2012-02-05 05:43:06 +00:00
2012-02-05 05:42:55 +00:00
## bunyan 0.3.0
2012-02-04 08:08:37 +00:00
2012-02-05 05:42:47 +00:00
- `log.child(options[, simple])` Added `simple` boolean arg. Set `true` to
assert that options only add fields (no config changes). Results in a 10x
2012-02-23 21:00:53 +00:00
speed increase in child creation. See "tools/timechild.js". On my Mac,
2012-02-05 05:42:47 +00:00
"fast child" creation takes about 0.001ms. IOW, if your app is dishing
10,000 req/s, then creating a log child for each request will take
about 1% of the request time.
2012-02-04 08:08:37 +00:00
- `log.clone` -> `log.child` to better reflect the relationship: streams and
serializers are inherited. Streams can't be removed as part of the child
creation. The child doesn't own the parent's streams (so can't close them).
- Clean up Logger creation. The goal here was to ensure `log.child` usage
is fast. TODO: measure that.
- Add `Logger.stdSerializers.err` serializer which is necessary to get good
Error object logging with node 0.6 (where core Error object properties
are non-enumerable).
2012-02-04 01:05:31 +00:00
2012-02-04 01:05:22 +00:00
## bunyan 0.2.0
2012-02-02 23:16:28 +00:00
2012-02-04 01:05:13 +00:00
- Spec'ing core/recommended log record fields.
- Add `LOG_VERSION` to exports.
- Improvements to request/response serializations.
2012-02-02 23:16:28 +00:00
2012-02-02 22:59:52 +00:00
## bunyan 0.1.0
2012-02-02 17:11:45 +00:00
First release.