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.
		
		
		
		
		
			
		
			
				
					
					
						
							82 lines
						
					
					
						
							2.5 KiB
						
					
					
				
			
		
		
	
	
							82 lines
						
					
					
						
							2.5 KiB
						
					
					
				chai = require 'chai' | 
						|
ParsedError = require '../src/ParsedError' | 
						|
 | 
						|
chai.should() | 
						|
 | 
						|
error = (what) -> | 
						|
  if typeof what is 'string' | 
						|
    return error -> throw Error what | 
						|
 | 
						|
  else if what instanceof Function | 
						|
    try | 
						|
      do what | 
						|
      return null | 
						|
    catch e | 
						|
      return e | 
						|
 | 
						|
  else | 
						|
    throw Error "bad argument for error" | 
						|
 | 
						|
describe "ParsedError", -> | 
						|
  describe "constructor()", -> | 
						|
    it "should accept Error() instances", -> | 
						|
      (-> new ParsedError error -> throw Error "some message").should.not.throw() | 
						|
 | 
						|
    it "should accept ReferenceError() and other derivatives of Error()", -> | 
						|
      (-> new ParsedError error -> throw ReferenceError "some message").should.not.throw() | 
						|
 | 
						|
    it "should accept non errors", -> | 
						|
      (-> e = new ParsedError 'some string').should.not.throw() | 
						|
 | 
						|
  describe "message", -> | 
						|
    it "should return the original error message", -> | 
						|
      e = new ParsedError error 'a' | 
						|
      e.message.should.equal 'a' | 
						|
 | 
						|
  describe "kind", -> | 
						|
    it "should return 'Error' for normal error", -> | 
						|
      e = new ParsedError error 'a' | 
						|
      e.kind.should.equal 'Error' | 
						|
 | 
						|
    it "should recognize 'ReferenceError'", -> | 
						|
      e = new ParsedError error -> a.b = c | 
						|
      e.kind.should.equal 'ReferenceError' | 
						|
 | 
						|
  describe "type", -> | 
						|
    it.skip "should return original error type", -> | 
						|
      e = new ParsedError error -> a.b = c | 
						|
      e.type.should.be.equal 'not_defined' | 
						|
 | 
						|
  describe "arguments", -> | 
						|
    it.skip "should return original error arguments", -> | 
						|
      e = new ParsedError error -> a.b = c | 
						|
      e.arguments.should.be.eql ['a'] | 
						|
 | 
						|
  describe "stack", -> | 
						|
    it "should return original error stack", -> | 
						|
      e = new ParsedError error -> a.b = c | 
						|
      e.stack.should.be.equal e.error.stack | 
						|
 | 
						|
  describe "trace", -> | 
						|
    it "should include correct information about each trace item", -> | 
						|
      e = new ParsedError error -> a.b = c | 
						|
      e.trace.should.have.length.above 2 | 
						|
 | 
						|
      item = e.trace[0] | 
						|
      item.should.include.keys 'original', | 
						|
        'what', 'path', 'addr', | 
						|
        'file', 'dir', 'col', | 
						|
        'line', 'jsCol', 'jsLine' | 
						|
        'packageName', 'shortenedPath', 'shortenedAddr' | 
						|
 | 
						|
      item.path.should.equal module.filename.replace(/[\\]+/g, '/') | 
						|
 | 
						|
      item.line.should.be.a 'number' | 
						|
      item.col.should.be.a 'number' | 
						|
 | 
						|
  describe "_rectifyPath()", -> | 
						|
    it "should work", -> | 
						|
      ParsedError::_rectifyPath('F:/a/node_modules/b/node_modules/d/node_modules/e/f.js').path.should.equal '[a]/[b]/[d]/[e]/f.js' | 
						|
 | 
						|
    it "should return path when `node_modules` is not present", -> | 
						|
      ParsedError::_rectifyPath('a/b/c').path.should.equal 'a/b/c'
 | 
						|
 |