3.1.1 • Published 7 years ago

jasmine-ts-console-reporter v3.1.1

Weekly downloads
3,436
License
MIT
Repository
github
Last release
7 years ago

Jasmine Typescript Console Reporter

npm issues license

A Jasmine Console Reporter that remaps Typescript files. This will use source maps to remap the error stack file paths and line numbers to the source typescript files.

Preview

preview

Installation

npm i jasmine-ts-console-reporter

Usage

Create a helper file for jasmine, eg specs/helpers.js

const TSConsoleReporter = require('jasmine-ts-console-reporter');

jasmine.getEnv().clearReporters(); // Clear default console reporter
jasmine.getEnv().addReporter(new TSConsoleReporter());

Load the helper file in Jasmine, eg on node jasmine.json:

{
	"helpers": [
		"specs/helpers.js",
	]
}

Custom sourceMapProvider

For more intricate usage scenarios, like using istanbul where the sourcemaps for instumented files are held in memory, you can locate the sourcemaps via a callback:

new TSConsoleReporter({
	sourceMapProvider: (fileName) => {
		const map = fetchMySourceMap(fileName);
		const sourcesRelativeTo = '< Relative path from source map file to source file. >';
		return map ? { map, sourcesRelativeTo } : null;	// Return null if no source map is found.
	}
});

The return object must be the same as source-map-resolve.

Extra stack filter ignore

You can provide additional ignore patterns for the stack trace (on top the built in exclusion of jasmine sources), this is useful for when you are using test frameworks that show up in the stack trace like typemoq.

// regexp
new TSConsoleReporter({
	stackFilterIgnore: /node_modules\\typemoq/
});
// or glob
new TSConsoleReporter({
	stackFilterIgnore: '**/node_modules/typemoq/**'
});

Custom title filter

You can provide additional filtering for the spec title, this is useful for when you want to limit or decorate the title output in some way.

new TSConsoleReporter({
	titleFilter: (title) => (title.length > 100) ? title.substr(0, 100 - 1) + '...' : title
});

Custom message filter

You can provide additional filtering for the error message, this is useful for when you want to limit or decorate the message output in some way.

new TSConsoleReporter({
	messageFilter: (message) => message.split('\n')[0]
});
3.1.1

7 years ago

3.1.0

7 years ago

3.0.0

7 years ago

2.0.3

7 years ago

2.0.2

7 years ago

2.0.1

7 years ago

2.0.0

7 years ago

1.2.1

7 years ago

1.2.0

7 years ago

1.1.0

7 years ago

1.0.2

7 years ago

1.0.1

7 years ago

1.0.0

7 years ago