1 | // Copyright (c) 2015 Uber Technologies, Inc.
|
2 | //
|
3 | // Permission is hereby granted, free of charge, to any person obtaining a copy
|
4 | // of this software and associated documentation files (the "Software"), to deal
|
5 | // in the Software without restriction, including without limitation the rights
|
6 | // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
7 | // copies of the Software, and to permit persons to whom the Software is
|
8 | // furnished to do so, subject to the following conditions:
|
9 | //
|
10 | // The above copyright notice and this permission notice shall be included in
|
11 | // all copies or substantial portions of the Software.
|
12 | //
|
13 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
14 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
15 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
16 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
17 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
18 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
19 | // THE SOFTWARE.
|
20 |
|
21 | var test = require('tape');
|
22 |
|
23 | var Logger = require('../logger.js');
|
24 |
|
25 | test('Logger() throws', function (assert) {
|
26 | var error = tryCatch(function () {
|
27 | Logger();
|
28 | });
|
29 |
|
30 | assert.ok(error);
|
31 | assert.equal(error.type, 'rt-logger.options.required');
|
32 |
|
33 | assert.end();
|
34 | });
|
35 |
|
36 | test('Logger({ meta: null }) throws', function (assert) {
|
37 | var error = tryCatch(function () {
|
38 | Logger({ meta: null });
|
39 | });
|
40 |
|
41 | assert.ok(error);
|
42 | assert.equal(error.type, 'rt-logger.options.meta.required');
|
43 |
|
44 | assert.end();
|
45 | });
|
46 |
|
47 | test('Logger({ meta: {}, backends: null }) throws', function (assert) {
|
48 | var error = tryCatch(function () {
|
49 | Logger({ meta: {}, backends: null });
|
50 | });
|
51 |
|
52 | assert.ok(error);
|
53 | assert.equal(error.type,
|
54 | 'rt-logger.options.backends.required');
|
55 |
|
56 | assert.end();
|
57 | });
|
58 |
|
59 | function tryCatch(fn) {
|
60 | try {
|
61 | fn();
|
62 | return null;
|
63 | } catch (err) {
|
64 | return err;
|
65 | }
|
66 | }
|