Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(config): Allow custom context and debug files #1825

Merged
merged 1 commit into from
Feb 22, 2016
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 17 additions & 1 deletion docs/config/01-configuration-file.md
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,23 @@ upon the completion of running the tests. Setting this to false is useful when

**Description:** How many browser Karma launches in parallel.

Especially on sevices like SauceLabs and Browserstack it makes sense to only launch a limited amount of browsers at once, and only start more when those have finished. Using this configuration you can sepcify how many browsers should be running at once at any given point in time.
Especially on services like SauceLabs and Browserstack it makes sense to only launch a limited amount of browsers at once, and only start more when those have finished. Using this configuration you can specify how many browsers should be running at once at any given point in time.


## customContextFile
**Type:** string

**Default:** `null`

**Description:** If `null` (default), uses karma's own `context.html` file.


## customDebugFile
**Type:** string

**Default:** `null`

**Description:** If `null` (default), uses karma's own `debug.html` file.


## customHeaders
Expand Down
6 changes: 6 additions & 0 deletions lib/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -109,11 +109,15 @@ var normalizeConfig = function (config, configFilePath) {

config.files = config.files.map(createPatternObject).map(createPatternMapper(basePathResolve))
config.exclude = config.exclude.map(basePathResolve)
config.customContextFile = config.customContextFile && basePathResolve(config.customContextFile)
config.customDebugFile = config.customDebugFile && basePathResolve(config.customDebugFile)

// normalize paths on windows
config.basePath = helper.normalizeWinPath(config.basePath)
config.files = config.files.map(createPatternMapper(helper.normalizeWinPath))
config.exclude = config.exclude.map(helper.normalizeWinPath)
config.customContextFile = helper.normalizeWinPath(config.customContextFile)
config.customDebugFile = helper.normalizeWinPath(config.customDebugFile)

// normalize urlRoot
config.urlRoot = normalizeUrlRoot(config.urlRoot)
Expand Down Expand Up @@ -235,6 +239,8 @@ var Config = function () {
this.httpsServerConfig = {}
this.basePath = ''
this.files = []
this.customContextFile = null
this.customDebugFile = null
this.exclude = []
this.logLevel = constant.LOG_INFO
this.colors = true
Expand Down
29 changes: 23 additions & 6 deletions lib/middleware/karma.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,8 +59,9 @@ var getXUACompatibleUrl = function (url) {
return value
}

var createKarmaMiddleware = function (filesPromise, serveStaticFile,
/* config.basePath */ basePath, /* config.urlRoot */ urlRoot, /* config.client */ client) {
var createKarmaMiddleware = function (filesPromise, serveStaticFile, serveFile,
/* config.basePath */ basePath, /* config.urlRoot */ urlRoot, /* config.client */ client,
/* config.customContextFile */ customContextFile, /* config.customDebugFile */ customDebugFile) {
return function (request, response, next) {
var requestUrl = request.normalizedUrl.replace(/\?.*/, '')

Expand Down Expand Up @@ -103,9 +104,24 @@ var createKarmaMiddleware = function (filesPromise, serveStaticFile,

// serve context.html - execution context within the iframe
// or debug.html - execution context without channel to the server
if (requestUrl === '/context.html' || requestUrl === '/debug.html') {
var isRequestingContextFile = requestUrl === '/context.html'
var isRequestingDebugFile = requestUrl === '/debug.html'
if (isRequestingContextFile || isRequestingDebugFile) {
return filesPromise.then(function (files) {
serveStaticFile(requestUrl, response, function (data) {
var fileServer
var requestedFileUrl
if (isRequestingContextFile && customContextFile) {
fileServer = serveFile
requestedFileUrl = customContextFile
} else if (isRequestingDebugFile && customDebugFile) {
fileServer = serveFile
requestedFileUrl = customDebugFile
} else {
fileServer = serveStaticFile
requestedFileUrl = requestUrl
}

fileServer(requestedFileUrl, response, function (data) {
common.setNoCacheHeaders(response)

var scriptTags = files.included.map(function (file) {
Expand Down Expand Up @@ -178,8 +194,9 @@ var createKarmaMiddleware = function (filesPromise, serveStaticFile,
}
}

createKarmaMiddleware.$inject = ['filesPromise', 'serveStaticFile',
'config.basePath', 'config.urlRoot', 'config.client']
createKarmaMiddleware.$inject = ['filesPromise', 'serveStaticFile', 'serveFile',
'config.basePath', 'config.urlRoot', 'config.client', 'config.customContextFile',
'config.customDebugFile']

// PUBLIC API
exports.create = createKarmaMiddleware
22 changes: 22 additions & 0 deletions test/e2e/custom-context.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
Feature: Custom Context File
In order to use Karma
As a person who wants to write great tests
I want Karma to use a custom context file

Scenario: Custom context.html file
Given a configuration with:
"""
files = ['context/*.js'];
browsers = ['PhantomJS'];
plugins = [
'karma-jasmine',
'karma-phantomjs-launcher'
];
customContextFile = 'context/context2.html'
"""
When I start Karma
Then it passes with:
"""
.
PhantomJS
"""
2 changes: 1 addition & 1 deletion test/e2e/steps/core_steps.js
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ module.exports = function coreSteps () {
actualOutput = lines.join('\n')
}

if (actualOutput.indexOf(expectedOutput) === 0) {
if (actualOutput.indexOf(expectedOutput) >= 0) {
return callback()
}

Expand Down
37 changes: 37 additions & 0 deletions test/e2e/support/context/context2.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
<!DOCTYPE html>
<!--
This is the execution context.
Loaded within the iframe.
Reloaded before every execution run.
-->
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />
</head>
<body>
<!-- The scripts need to be in the body DOM element, as some test running frameworks need the body
to have already been created so they can insert their magic into it. For example, if loaded
before body, Angular Scenario test framework fails to find the body and crashes and burns in
an epic manner. -->
<div id="custom-context"></div>
<script type="text/javascript">
// sets window.__karma__ and overrides console and error handling
// Use window.opener if this was opened by someone else - in a new window
if (window.opener) {
window.opener.karma.setupContext(window);
} else {
window.parent.karma.setupContext(window);
}

// All served files with the latest timestamps
%MAPPINGS%
</script>
<!-- Dynamically replaced with <script> tags -->
%SCRIPTS%
<script type="text/javascript">
window.__karma__.loaded();
</script>
</body>
</html>
5 changes: 5 additions & 0 deletions test/e2e/support/context/test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
describe('custom context file', function () {
it('should be able to find custom DOM elements', function () {
expect(document.querySelector('#custom-context') == null).toBe(false)
})
})
7 changes: 6 additions & 1 deletion test/unit/config.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,9 @@ describe('config', () => {
it('should convert patterns to objects and set defaults', () => {
var config = normalizeConfigWithDefaults({
basePath: '/base',
files: ['a/*.js', {pattern: 'b.js', watched: false, included: false}, {pattern: 'c.js'}]
files: ['a/*.js', {pattern: 'b.js', watched: false, included: false}, {pattern: 'c.js'}],
customContextFile: 'context.html',
customDebugFile: 'debug.html'
})

expect(config.files.length).to.equal(3)
Expand All @@ -283,6 +285,9 @@ describe('config', () => {
expect(file.included).to.equal(true)
expect(file.served).to.equal(true)
expect(file.watched).to.equal(true)

expect(config.customContextFile).to.equal(resolveWinPath('/base/context.html'))
expect(config.customDebugFile).to.equal(resolveWinPath('/base/debug.html'))
})

it('should normalize preprocessors to an array', () => {
Expand Down
8 changes: 4 additions & 4 deletions test/unit/middleware/karma.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ describe('middleware.karma', () => {
response = new HttpResponseMock()
filesDeferred = helper.defer()
serveFile = createServeFile(fsMock, '/karma/static')
handler = createKarmaMiddleware(filesDeferred.promise, serveFile, '/base/path', '/__karma__/', clientConfig)
handler = createKarmaMiddleware(filesDeferred.promise, serveFile, null, '/base/path', '/__karma__/', clientConfig)
})

// helpers
Expand Down Expand Up @@ -92,7 +92,7 @@ describe('middleware.karma', () => {
})

it('should serve client.html', (done) => {
handler = createKarmaMiddleware(null, serveFile, '/base', '/')
handler = createKarmaMiddleware(null, serveFile, null, '/base', '/')

response.once('end', () => {
expect(nextSpy).not.to.have.been.called
Expand All @@ -104,7 +104,7 @@ describe('middleware.karma', () => {
})

it('should serve /?id=xxx', (done) => {
handler = createKarmaMiddleware(null, serveFile, '/base', '/')
handler = createKarmaMiddleware(null, serveFile, null, '/base', '/')

response.once('end', () => {
expect(nextSpy).not.to.have.been.called
Expand All @@ -116,7 +116,7 @@ describe('middleware.karma', () => {
})

it('should serve /?x-ua-compatible with replaced values', (done) => {
handler = createKarmaMiddleware(null, serveFile, '/base', '/')
handler = createKarmaMiddleware(null, serveFile, null, '/base', '/')

response.once('end', () => {
expect(nextSpy).not.to.have.been.called
Expand Down