aboutsummaryrefslogtreecommitdiffstats
path: root/vnfmarket/src/main/webapp/vnfmarket/node_modules/log4js/test/categoryFilter-test.js
blob: 15a7b9068060c210f9198716f00f3ae36c5f1b8d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
'use strict';

var vows = require('vows')
, fs = require('fs')
, assert = require('assert')
, EOL = require('os').EOL || '\n';

function remove(filename) {
  try {
    fs.unlinkSync(filename);
  } catch (e) {
    //doesn't really matter if it failed
  }
}

vows.describe('log4js categoryFilter').addBatch({
  'appender': {
    topic: function() {

      var log4js = require('../lib/log4js'), logEvents = [], webLogger, appLogger;
      log4js.clearAppenders();
      var appender = require('../lib/appenders/categoryFilter')
        .appender(
          ['app'],
          function(evt) { logEvents.push(evt); }
        );
      log4js.addAppender(appender, ["app","web"]);

      webLogger = log4js.getLogger("web");
      appLogger = log4js.getLogger("app");

      webLogger.debug('This should get logged');
      appLogger.debug('This should not');
      webLogger.debug('Hello again');
      log4js.getLogger('db').debug('This shouldn\'t be included by the appender anyway');

      return logEvents;
    },
    'should only pass matching category' : function(logEvents) {
      assert.equal(logEvents.length, 2);
      assert.equal(logEvents[0].data[0], 'This should get logged');
      assert.equal(logEvents[1].data[0], 'Hello again');
    }
  },

  'configure': {
    topic: function() {
      var log4js = require('../lib/log4js')
      , logger, weblogger;

      remove(__dirname + '/categoryFilter-web.log');
      remove(__dirname + '/categoryFilter-noweb.log');

      log4js.configure('test/with-categoryFilter.json');
      logger = log4js.getLogger("app");
      weblogger = log4js.getLogger("web");

      logger.info('Loading app');
      logger.debug('Initialising indexes');
      weblogger.info('00:00:00 GET / 200');
      weblogger.warn('00:00:00 GET / 500');
      //wait for the file system to catch up
      setTimeout(this.callback, 500);
    },
    'tmp-tests.log': {
      topic: function() {
        fs.readFile(__dirname + '/categoryFilter-noweb.log', 'utf8', this.callback);
      },
      'should contain all log messages': function(contents) {
        var messages = contents.trim().split(EOL);
        assert.deepEqual(messages, ['Loading app','Initialising indexes']);
      }
    },
    'tmp-tests-web.log': {
      topic: function() {
        fs.readFile(__dirname + '/categoryFilter-web.log','utf8',this.callback);
      },
      'should contain only error and warning log messages': function(contents) {
        var messages = contents.trim().split(EOL);
        assert.deepEqual(messages, ['00:00:00 GET / 200','00:00:00 GET / 500']);
      }
    }
  }
}).export(module);