This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
333 lines
14 KiB
333 lines
14 KiB
var expect = require('expect.js'), |
|
|
|
StackTraceParser = require('../lib/stacktrace-parser'); |
|
|
|
describe('StackTraceParser', function() { |
|
var data = { |
|
'Chrome & Chrome Mobile & Opera': [ |
|
{ |
|
from: "Error: with timeout\n at http://errwischt.com/stack_traces/test:76:15\n at wrapped (http://errwischt.com/bandage.js:51:25)", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 76, |
|
column: 15 }, |
|
{ file: 'http://errwischt.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 25 } |
|
] |
|
}, |
|
{ |
|
from: "Error: with timeout and named func\n at timeoutWithName (http://errwischt.com/stack_traces/test:83:15)\n at wrapped (http://errwischt.com/bandage.js:51:25)", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: 15 }, |
|
{ file: 'http://errwischt.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 25 } |
|
] |
|
}, |
|
{ |
|
from: "TypeError: Object # has no method 'objectBreakDown'\n at HTMLDocument. (http://errwischt.com/stack_traces/test:91:19)\n at l (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:24882)\n at Object.c.fireWith [as resolveWith] (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:25702)\n at Function.x.extend.ready (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:2900)\n at HTMLDocument.S (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:553)", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: 'HTMLDocument.', |
|
lineNumber: 91, |
|
column: 19 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'l', |
|
lineNumber: 4, |
|
column: 24882 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'Object.c.fireWith [as resolveWith]', |
|
lineNumber: 4, |
|
column: 25702 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'Function.x.extend.ready', |
|
lineNumber: 4, |
|
column: 2900 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'HTMLDocument.S', |
|
lineNumber: 4, |
|
column: 553 } |
|
] |
|
} |
|
], |
|
'Firefox': [ |
|
{ |
|
from: "timeoutWithName@http://errwischt.com/stack_traces/test:83\nwrapped@http://errwischt.com/bandage.js:51", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: null }, |
|
{ file: 'http://errwischt.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: null } |
|
] |
|
}, |
|
{ |
|
from: "@http://errwischt.com/stack_traces/test:76\nwrapped@http://errwischt.com/bandage.js:51", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 76, |
|
column: null }, |
|
{ file: 'http://errwischt.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: null } |
|
] |
|
}, |
|
{ |
|
from: "@http://errwischt.com/stack_traces/test:97\nx.Callbacks/l@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4\nx.Callbacks/c.fireWith@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4\n.ready@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4\nS@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4", |
|
to: [ |
|
{ file: 'http://errwischt.com/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 97, |
|
column: null }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'x.Callbacks/l', |
|
lineNumber: 4, |
|
column: null }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'x.Callbacks/c.fireWith', |
|
lineNumber: 4, |
|
column: null }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: '.ready', |
|
lineNumber: 4, |
|
column: null }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'S', |
|
lineNumber: 4, |
|
column: null } |
|
] |
|
} |
|
], |
|
'Safari': [ |
|
{ |
|
from: "timeoutWithName@http://bandage.local:8181/stack_traces/test:83:55\nwrapped@http://bandage.local:8181/bandage.js:51:30", |
|
to: [ { file: 'http://bandage.local:8181/stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: 55 }, |
|
{ file: 'http://bandage.local:8181/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 30 } ] |
|
}, |
|
{ |
|
from: "http://bandage.local:8181/stack_traces/test:76:40\nwrapped@http://bandage.local:8181/bandage.js:51:30", |
|
to: [ { file: 'http://bandage.local:8181/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 76, |
|
column: 40 }, |
|
{ file: 'http://bandage.local:8181/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 30 } ] |
|
}, |
|
{ |
|
from: "http://bandage.local:8181/stack_traces/test:97:28\nl@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:24909\nfireWith@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:50440\nready@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:2933\nS@http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:580", |
|
to: [ { file: 'http://bandage.local:8181/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 97, |
|
column: 28 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'l', |
|
lineNumber: 4, |
|
column: 24909 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'fireWith', |
|
lineNumber: 4, |
|
column: 50440 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'ready', |
|
lineNumber: 4, |
|
column: 2933 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'S', |
|
lineNumber: 4, |
|
column: 580 } ] |
|
} |
|
], |
|
'JavaScriptCore': [ |
|
{ |
|
from: "timeoutWithName@stack_traces/test:83:55\nwrapped@bandage.js:51:30", |
|
to: [ { file: 'stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: 55 }, |
|
{ file: 'bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 30 } ] |
|
}, |
|
{ |
|
from: "timeoutWithName@stack_traces/test:83:55\nwrapped@42start-with-number.js:51:30", |
|
to: [ { file: 'stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: 55 }, |
|
{ file: '42start-with-number.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 30 } ] |
|
}, |
|
{ |
|
from: "global code@stack_traces/test:83:55", |
|
to: [ { file: 'stack_traces/test', |
|
methodName: 'global code', |
|
lineNumber: 83, |
|
column: 55 } ] |
|
} |
|
], |
|
'Internet Explorer': [ |
|
{ |
|
from: "Error: with timeout and named func\n at timeoutWithName (http://bandage.jaz-lounge.com/stack_traces/test:83:9)\n at wrapped (http://bandage.jaz-lounge.com/bandage.js:51:13)", |
|
to: [ { file: 'http://bandage.jaz-lounge.com/stack_traces/test', |
|
methodName: 'timeoutWithName', |
|
lineNumber: 83, |
|
column: 9 }, |
|
{ file: 'http://bandage.jaz-lounge.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 13 } ] |
|
}, |
|
{ |
|
from: "Error: with timeout\n at Anonymous function (http://bandage.jaz-lounge.com/stack_traces/test:76:9)\n at wrapped (http://bandage.jaz-lounge.com/bandage.js:51:13)", |
|
to: [ { file: 'http://bandage.jaz-lounge.com/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 76, |
|
column: 9 }, |
|
{ file: 'http://bandage.jaz-lounge.com/bandage.js', |
|
methodName: 'wrapped', |
|
lineNumber: 51, |
|
column: 13 } ] |
|
}, |
|
{ |
|
from: "TypeError: Object doesn't support property or method 'objectBreakDown'\n at Anonymous function (http://bandage.jaz-lounge.com/stack_traces/test:91:7)\n at l (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:24874)\n at fireWith (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:25638)\n at ready (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:2898)\n at S (http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js:4:551)", |
|
to: [ { file: 'http://bandage.jaz-lounge.com/stack_traces/test', |
|
methodName: '<unknown>', |
|
lineNumber: 91, |
|
column: 7 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'l', |
|
lineNumber: 4, |
|
column: 24874 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'fireWith', |
|
lineNumber: 4, |
|
column: 25638 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'ready', |
|
lineNumber: 4, |
|
column: 2898 }, |
|
{ file: 'http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js', |
|
methodName: 'S', |
|
lineNumber: 4, |
|
column: 551 } ] |
|
} |
|
], |
|
'Node.js': [ |
|
{ |
|
from: "ReferenceError: test is not defined\n at repl:1:2\n at REPLServer.self.eval (repl.js:110:21)\n at Interface.<anonymous> (repl.js:239:12)\n at Interface.EventEmitter.emit (events.js:95:17)\n at emitKey (readline.js:1095:12)", |
|
to: [ { file: 'repl', |
|
methodName: '<unknown>', |
|
lineNumber: 1, |
|
column: 2 }, |
|
{ file: 'repl.js', |
|
methodName: 'REPLServer.self.eval', |
|
lineNumber: 110, |
|
column: 21 }, |
|
{ file: 'repl.js', |
|
methodName: 'Interface.<anonymous>', |
|
lineNumber: 239, |
|
column: 12 }, |
|
{ file: 'events.js', |
|
methodName: 'Interface.EventEmitter.emit', |
|
lineNumber: 95, |
|
column: 17 }, |
|
{ file: 'readline.js', |
|
methodName: 'emitKey', |
|
lineNumber: 1095, |
|
column: 12 } ] |
|
}, |
|
{ |
|
from: "ReferenceError: breakDown is not defined\n at null._onTimeout (repl:1:25)\n at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)", |
|
to: [ { file: 'repl', |
|
methodName: 'null._onTimeout', |
|
lineNumber: 1, |
|
column: 25 }, |
|
{ file: 'timers.js', |
|
methodName: 'Timer.listOnTimeout [as ontimeout]', |
|
lineNumber: 110, |
|
column: 15 } ] |
|
}, |
|
], |
|
'io.js': [ |
|
// io.js 2.4.0 |
|
{ |
|
from: "ReferenceError: test is not defined\n at repl:1:1\n at REPLServer.defaultEval (repl.js:154:27)\n at bound (domain.js:254:14)\n at REPLServer.runBound [as eval] (domain.js:267:12)\n at REPLServer.<anonymous> (repl.js:308:12)\n at emitOne (events.js:77:13)\n at REPLServer.emit (events.js:169:7)\n at REPLServer.Interface._onLine (readline.js:210:10)\n at REPLServer.Interface._line (readline.js:549:8)\n at REPLServer.Interface._ttyWrite (readline.js:826:14)", |
|
to: [ { file: 'repl', |
|
methodName: '<unknown>', |
|
lineNumber: 1, |
|
column: 1 }, |
|
{ file: 'repl.js', |
|
methodName: 'REPLServer.defaultEval', |
|
lineNumber: 154, |
|
column: 27 }, |
|
{ file: 'domain.js', |
|
methodName: 'bound', |
|
lineNumber: 254, |
|
column: 14 }, |
|
{ file: 'domain.js', |
|
methodName: 'REPLServer.runBound [as eval]', |
|
lineNumber: 267, |
|
column: 12 }, |
|
{ file: 'repl.js', |
|
methodName: 'REPLServer.<anonymous>', |
|
lineNumber: 308, |
|
column: 12 }, |
|
{ file: 'events.js', |
|
methodName: 'emitOne', |
|
lineNumber: 77, |
|
column: 13 }, |
|
{ file: 'events.js', |
|
methodName: 'REPLServer.emit', |
|
lineNumber: 169, |
|
column: 7 }, |
|
{ file: 'readline.js', |
|
methodName: 'REPLServer.Interface._onLine', |
|
lineNumber: 210, |
|
column: 10 }, |
|
{ file: 'readline.js', |
|
methodName: 'REPLServer.Interface._line', |
|
lineNumber: 549, |
|
column: 8 }, |
|
{ file: 'readline.js', |
|
methodName: 'REPLServer.Interface._ttyWrite', |
|
lineNumber: 826, |
|
column: 14 } ] |
|
}, |
|
] |
|
}; |
|
|
|
Object.keys(data).forEach(function(browser) { |
|
describe('can parse stack trace of ' + browser, function() { |
|
data[browser].forEach(function(browserData) { |
|
it(browserData.from, function() { |
|
var result = StackTraceParser.parse(browserData.from); |
|
expect(result.length).to.equal(browserData.to.length); |
|
expect(result).to.eql(browserData.to); |
|
}); |
|
}); |
|
}); |
|
}); |
|
});
|
|
|