jasmine-core 2.0.2 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/console/console.js +26 -2
- data/lib/jasmine-core.js +31 -23
- data/lib/jasmine-core/boot.js +1 -1
- data/lib/jasmine-core/boot/boot.js +1 -1
- data/lib/jasmine-core/example/node_example/spec/PlayerSpec.js +2 -2
- data/lib/jasmine-core/jasmine-html.js +16 -2
- data/lib/jasmine-core/jasmine.css +11 -10
- data/lib/jasmine-core/jasmine.js +709 -395
- data/lib/jasmine-core/json2.js +73 -62
- data/lib/jasmine-core/spec/console/ConsoleReporterSpec.js +39 -8
- data/lib/jasmine-core/spec/core/ClockSpec.js +19 -1
- data/lib/jasmine-core/spec/core/DelayedFunctionSchedulerSpec.js +13 -0
- data/lib/jasmine-core/spec/core/EnvSpec.js +0 -63
- data/lib/jasmine-core/spec/core/ExpectationSpec.js +15 -53
- data/lib/jasmine-core/spec/core/JsApiReporterSpec.js +37 -0
- data/lib/jasmine-core/spec/core/MockDateSpec.js +1 -0
- data/lib/jasmine-core/spec/core/PrettyPrintSpec.js +8 -2
- data/lib/jasmine-core/spec/core/QueueRunnerSpec.js +91 -66
- data/lib/jasmine-core/spec/core/SpecSpec.js +25 -26
- data/lib/jasmine-core/spec/core/SpyRegistrySpec.js +55 -0
- data/lib/jasmine-core/spec/core/SpySpec.js +10 -0
- data/lib/jasmine-core/spec/core/SpyStrategySpec.js +13 -0
- data/lib/jasmine-core/spec/core/SuiteSpec.js +108 -10
- data/lib/jasmine-core/spec/core/integration/CustomMatchersSpec.js +34 -32
- data/lib/jasmine-core/spec/core/integration/EnvSpec.js +950 -35
- data/lib/jasmine-core/spec/core/integration/SpecRunningSpec.js +279 -3
- data/lib/jasmine-core/spec/core/matchers/matchersUtilSpec.js +10 -1
- data/lib/jasmine-core/spec/core/matchers/toThrowErrorSpec.js +5 -5
- data/lib/jasmine-core/spec/html/HtmlReporterSpec.js +30 -2
- data/lib/jasmine-core/spec/node_suite.js +195 -0
- data/lib/jasmine-core/spec/npmPackage/npmPackageSpec.js +104 -0
- data/lib/jasmine-core/version.rb +1 -1
- metadata +6 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b3c55f40da8c8da5e3d89ae36a5aaae867bd50ea
|
4
|
+
data.tar.gz: 3d48a8581f0ca9decccbb8fe75ae82f22bd99e40
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e506e314ceeef5435bdd4ad916f93efe9c006cc71f5404c0376c2718fe10af4a83a4d51ffc3df7b143d9000484d6ae19013675e00cda8607db9cb0f3f27dbae9
|
7
|
+
data.tar.gz: d1856674ca87ce7da66ec763ba372bbc034631943f607ae4b1ece8ee395112cd2027feecb217c115a90de4e0201a614894ff25dff6fd6d6746954af075585113
|
data/lib/console/console.js
CHANGED
@@ -54,7 +54,10 @@ getJasmineRequireObj().ConsoleReporter = function() {
|
|
54
54
|
red: '\x1B[31m',
|
55
55
|
yellow: '\x1B[33m',
|
56
56
|
none: '\x1B[0m'
|
57
|
-
}
|
57
|
+
},
|
58
|
+
failedSuites = [];
|
59
|
+
|
60
|
+
print('ConsoleReporter is deprecated and will be removed in a future version.');
|
58
61
|
|
59
62
|
this.jasmineStarted = function() {
|
60
63
|
specCount = 0;
|
@@ -89,9 +92,12 @@ getJasmineRequireObj().ConsoleReporter = function() {
|
|
89
92
|
printNewline();
|
90
93
|
var seconds = timer.elapsed() / 1000;
|
91
94
|
print('Finished in ' + seconds + ' ' + plural('second', seconds));
|
92
|
-
|
93
95
|
printNewline();
|
94
96
|
|
97
|
+
for(i = 0; i < failedSuites.length; i++) {
|
98
|
+
suiteFailureDetails(failedSuites[i]);
|
99
|
+
}
|
100
|
+
|
95
101
|
onComplete(failureCount === 0);
|
96
102
|
};
|
97
103
|
|
@@ -116,6 +122,13 @@ getJasmineRequireObj().ConsoleReporter = function() {
|
|
116
122
|
}
|
117
123
|
};
|
118
124
|
|
125
|
+
this.suiteDone = function(result) {
|
126
|
+
if (result.failedExpectations && result.failedExpectations.length > 0) {
|
127
|
+
failureCount++;
|
128
|
+
failedSuites.push(result);
|
129
|
+
}
|
130
|
+
};
|
131
|
+
|
119
132
|
return this;
|
120
133
|
|
121
134
|
function printNewline() {
|
@@ -160,6 +173,17 @@ getJasmineRequireObj().ConsoleReporter = function() {
|
|
160
173
|
|
161
174
|
printNewline();
|
162
175
|
}
|
176
|
+
|
177
|
+
function suiteFailureDetails(result) {
|
178
|
+
for (var i = 0; i < result.failedExpectations.length; i++) {
|
179
|
+
printNewline();
|
180
|
+
print(colored('red', 'An error was thrown in an afterAll'));
|
181
|
+
printNewline();
|
182
|
+
print(colored('red', 'AfterAll ' + result.failedExpectations[i].message));
|
183
|
+
|
184
|
+
}
|
185
|
+
printNewline();
|
186
|
+
}
|
163
187
|
}
|
164
188
|
|
165
189
|
return ConsoleReporter;
|
data/lib/jasmine-core.js
CHANGED
@@ -1,29 +1,37 @@
|
|
1
1
|
module.exports = require("./jasmine-core/jasmine.js");
|
2
2
|
module.exports.boot = require('./jasmine-core/node_boot.js');
|
3
3
|
|
4
|
-
|
5
|
-
|
6
|
-
fs = require('fs'),
|
7
|
-
glob = require('glob');
|
4
|
+
var path = require('path'),
|
5
|
+
fs = require('fs');
|
8
6
|
|
9
|
-
|
10
|
-
|
11
|
-
|
7
|
+
var rootPath = path.join(__dirname, "jasmine-core"),
|
8
|
+
bootFiles = ['boot.js'],
|
9
|
+
nodeBootFiles = ['node_boot.js'],
|
10
|
+
cssFiles = [],
|
11
|
+
jsFiles = [],
|
12
|
+
jsFilesToSkip = ['jasmine.js'].concat(bootFiles, nodeBootFiles);
|
12
13
|
|
13
|
-
|
14
|
-
|
14
|
+
fs.readdirSync(rootPath).forEach(function(file) {
|
15
|
+
if(fs.statSync(path.join(rootPath, file)).isFile()) {
|
16
|
+
switch(path.extname(file)) {
|
17
|
+
case '.css':
|
18
|
+
cssFiles.push(file);
|
19
|
+
break;
|
20
|
+
case '.js':
|
21
|
+
if (jsFilesToSkip.indexOf(file) < 0) {
|
22
|
+
jsFiles.push(file);
|
23
|
+
}
|
24
|
+
break;
|
25
|
+
}
|
26
|
+
}
|
27
|
+
});
|
15
28
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
cssFiles: cssFiles,
|
26
|
-
jsFiles: ['jasmine.js'].concat(jsFiles),
|
27
|
-
imagesDir: path.join(__dirname, '../images')
|
28
|
-
};
|
29
|
-
}());
|
29
|
+
module.exports.files = {
|
30
|
+
path: rootPath,
|
31
|
+
bootDir: rootPath,
|
32
|
+
bootFiles: bootFiles,
|
33
|
+
nodeBootFiles: nodeBootFiles,
|
34
|
+
cssFiles: cssFiles,
|
35
|
+
jsFiles: ['jasmine.js'].concat(jsFiles),
|
36
|
+
imagesDir: path.join(__dirname, '../images')
|
37
|
+
};
|
data/lib/jasmine-core/boot.js
CHANGED
@@ -21,7 +21,7 @@ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
21
21
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
22
22
|
*/
|
23
23
|
/**
|
24
|
-
Starting with version 2.0, this file "boots" Jasmine, performing all of the necessary initialization before executing the loaded environment and all of a project's specs. This file should be loaded after `jasmine.js`, but before any project source files or spec files are loaded. Thus this file can also be used to customize Jasmine for a project.
|
24
|
+
Starting with version 2.0, this file "boots" Jasmine, performing all of the necessary initialization before executing the loaded environment and all of a project's specs. This file should be loaded after `jasmine.js` and `jasmine_html.js`, but before any project source files or spec files are loaded. Thus this file can also be used to customize Jasmine for a project.
|
25
25
|
|
26
26
|
If a project is using Jasmine via the standalone distribution, this file can be customized directly. If a project is using Jasmine via the [Ruby gem][jasmine-gem], this file can be copied into the support directory via `jasmine copy_boot_js`. Other environments (e.g., Python) will have different mechanisms.
|
27
27
|
|
@@ -1,5 +1,5 @@
|
|
1
1
|
/**
|
2
|
-
Starting with version 2.0, this file "boots" Jasmine, performing all of the necessary initialization before executing the loaded environment and all of a project's specs. This file should be loaded after `jasmine.js`, but before any project source files or spec files are loaded. Thus this file can also be used to customize Jasmine for a project.
|
2
|
+
Starting with version 2.0, this file "boots" Jasmine, performing all of the necessary initialization before executing the loaded environment and all of a project's specs. This file should be loaded after `jasmine.js` and `jasmine_html.js`, but before any project source files or spec files are loaded. Thus this file can also be used to customize Jasmine for a project.
|
3
3
|
|
4
4
|
If a project is using Jasmine via the standalone distribution, this file can be customized directly. If a project is using Jasmine via the [Ruby gem][jasmine-gem], this file can be copied into the support directory via `jasmine copy_boot_js`. Other environments (e.g., Python) will have different mechanisms.
|
5
5
|
|
@@ -46,7 +46,8 @@ jasmineRequire.HtmlReporter = function(j$) {
|
|
46
46
|
failureCount = 0,
|
47
47
|
pendingSpecCount = 0,
|
48
48
|
htmlReporterMain,
|
49
|
-
symbols
|
49
|
+
symbols,
|
50
|
+
failedSuites = [];
|
50
51
|
|
51
52
|
this.initialize = function() {
|
52
53
|
clearPrior();
|
@@ -83,6 +84,10 @@ jasmineRequire.HtmlReporter = function(j$) {
|
|
83
84
|
};
|
84
85
|
|
85
86
|
this.suiteDone = function(result) {
|
87
|
+
if (result.status == 'failed') {
|
88
|
+
failedSuites.push(result);
|
89
|
+
}
|
90
|
+
|
86
91
|
if (currentParent == topResults) {
|
87
92
|
return;
|
88
93
|
}
|
@@ -96,7 +101,7 @@ jasmineRequire.HtmlReporter = function(j$) {
|
|
96
101
|
|
97
102
|
var failures = [];
|
98
103
|
this.specDone = function(result) {
|
99
|
-
if(noExpectations(result) && console && console.error) {
|
104
|
+
if(noExpectations(result) && typeof console !== 'undefined' && typeof console.error !== 'undefined') {
|
100
105
|
console.error('Spec \'' + result.fullName + '\' has no expectations.');
|
101
106
|
}
|
102
107
|
|
@@ -178,6 +183,15 @@ jasmineRequire.HtmlReporter = function(j$) {
|
|
178
183
|
|
179
184
|
alert.appendChild(createDom('span', {className: statusBarClassName}, statusBarMessage));
|
180
185
|
|
186
|
+
for(i = 0; i < failedSuites.length; i++) {
|
187
|
+
var failedSuite = failedSuites[i];
|
188
|
+
for(var j = 0; j < failedSuite.failedExpectations.length; j++) {
|
189
|
+
var errorBarMessage = 'AfterAll ' + failedSuite.failedExpectations[j].message;
|
190
|
+
var errorBarClassName = 'bar errored';
|
191
|
+
alert.appendChild(createDom('span', {className: errorBarClassName}, errorBarMessage));
|
192
|
+
}
|
193
|
+
}
|
194
|
+
|
181
195
|
var results = find('.results');
|
182
196
|
results.appendChild(summary);
|
183
197
|
|
@@ -1,18 +1,18 @@
|
|
1
1
|
body { overflow-y: scroll; }
|
2
2
|
|
3
|
-
.jasmine_html-reporter { background-color: #
|
3
|
+
.jasmine_html-reporter { background-color: #eee; padding: 5px; margin: -8px; font-size: 11px; font-family: Monaco, "Lucida Console", monospace; line-height: 14px; color: #333; }
|
4
4
|
.jasmine_html-reporter a { text-decoration: none; }
|
5
5
|
.jasmine_html-reporter a:hover { text-decoration: underline; }
|
6
6
|
.jasmine_html-reporter p, .jasmine_html-reporter h1, .jasmine_html-reporter h2, .jasmine_html-reporter h3, .jasmine_html-reporter h4, .jasmine_html-reporter h5, .jasmine_html-reporter h6 { margin: 0; line-height: 14px; }
|
7
7
|
.jasmine_html-reporter .banner, .jasmine_html-reporter .symbol-summary, .jasmine_html-reporter .summary, .jasmine_html-reporter .result-message, .jasmine_html-reporter .spec .description, .jasmine_html-reporter .spec-detail .description, .jasmine_html-reporter .alert .bar, .jasmine_html-reporter .stack-trace { padding-left: 9px; padding-right: 9px; }
|
8
8
|
.jasmine_html-reporter .banner { position: relative; }
|
9
|
-
.jasmine_html-reporter .banner .title { background: url('') no-repeat; background: url('') no-repeat, none; -webkit-background-size: 100%; -moz-background-size: 100%; -o-background-size: 100%; background-size: 100%; display: block; float: left; width: 90px; height: 25px; }
|
9
|
+
.jasmine_html-reporter .banner .title { background: url('') no-repeat; background: url('') no-repeat, none; -moz-background-size: 100%; -o-background-size: 100%; -webkit-background-size: 100%; background-size: 100%; display: block; float: left; width: 90px; height: 25px; }
|
10
10
|
.jasmine_html-reporter .banner .version { margin-left: 14px; position: relative; top: 6px; }
|
11
11
|
.jasmine_html-reporter .banner .duration { position: absolute; right: 14px; top: 6px; }
|
12
12
|
.jasmine_html-reporter #jasmine_content { position: fixed; right: 100%; }
|
13
|
-
.jasmine_html-reporter .version { color: #
|
13
|
+
.jasmine_html-reporter .version { color: #aaa; }
|
14
14
|
.jasmine_html-reporter .banner { margin-top: 14px; }
|
15
|
-
.jasmine_html-reporter .duration { color: #
|
15
|
+
.jasmine_html-reporter .duration { color: #aaa; float: right; }
|
16
16
|
.jasmine_html-reporter .symbol-summary { overflow: hidden; *zoom: 1; margin: 14px 0; }
|
17
17
|
.jasmine_html-reporter .symbol-summary li { display: inline-block; height: 8px; width: 14px; font-size: 16px; }
|
18
18
|
.jasmine_html-reporter .symbol-summary li.passed { font-size: 14px; }
|
@@ -30,12 +30,13 @@ body { overflow-y: scroll; }
|
|
30
30
|
.jasmine_html-reporter .bar.failed { background-color: #ca3a11; }
|
31
31
|
.jasmine_html-reporter .bar.passed { background-color: #007069; }
|
32
32
|
.jasmine_html-reporter .bar.skipped { background-color: #bababa; }
|
33
|
-
.jasmine_html-reporter .bar.
|
34
|
-
.jasmine_html-reporter .bar.menu
|
33
|
+
.jasmine_html-reporter .bar.errored { background-color: #ca3a11; }
|
34
|
+
.jasmine_html-reporter .bar.menu { background-color: #fff; color: #aaa; }
|
35
|
+
.jasmine_html-reporter .bar.menu a { color: #333; }
|
35
36
|
.jasmine_html-reporter .bar a { color: white; }
|
36
37
|
.jasmine_html-reporter.spec-list .bar.menu.failure-list, .jasmine_html-reporter.spec-list .results .failures { display: none; }
|
37
38
|
.jasmine_html-reporter.failure-list .bar.menu.spec-list, .jasmine_html-reporter.failure-list .summary { display: none; }
|
38
|
-
.jasmine_html-reporter .running-alert { background-color: #
|
39
|
+
.jasmine_html-reporter .running-alert { background-color: #666; }
|
39
40
|
.jasmine_html-reporter .results { margin-top: 14px; }
|
40
41
|
.jasmine_html-reporter.showDetails .summaryMenuItem { font-weight: normal; text-decoration: inherit; }
|
41
42
|
.jasmine_html-reporter.showDetails .summaryMenuItem:hover { text-decoration: underline; }
|
@@ -52,10 +53,10 @@ body { overflow-y: scroll; }
|
|
52
53
|
.jasmine_html-reporter .summary li.pending a { color: #ba9d37; }
|
53
54
|
.jasmine_html-reporter .description + .suite { margin-top: 0; }
|
54
55
|
.jasmine_html-reporter .suite { margin-top: 14px; }
|
55
|
-
.jasmine_html-reporter .suite a { color: #
|
56
|
+
.jasmine_html-reporter .suite a { color: #333; }
|
56
57
|
.jasmine_html-reporter .failures .spec-detail { margin-bottom: 28px; }
|
57
58
|
.jasmine_html-reporter .failures .spec-detail .description { background-color: #ca3a11; }
|
58
59
|
.jasmine_html-reporter .failures .spec-detail .description a { color: white; }
|
59
|
-
.jasmine_html-reporter .result-message { padding-top: 14px; color: #
|
60
|
+
.jasmine_html-reporter .result-message { padding-top: 14px; color: #333; white-space: pre; }
|
60
61
|
.jasmine_html-reporter .result-message span.result { display: block; }
|
61
|
-
.jasmine_html-reporter .stack-trace { margin: 5px 0 0 0; max-height: 224px; overflow: auto; line-height: 18px; color: #
|
62
|
+
.jasmine_html-reporter .stack-trace { margin: 5px 0 0 0; max-height: 224px; overflow: auto; line-height: 18px; color: #666; border: 1px solid #ddd; background: white; white-space: pre; }
|
data/lib/jasmine-core/jasmine.js
CHANGED
@@ -20,45 +20,54 @@ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
20
20
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
21
21
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
22
22
|
*/
|
23
|
-
function
|
23
|
+
getJasmineRequireObj = (function (jasmineGlobal) {
|
24
|
+
var jasmineRequire;
|
25
|
+
|
24
26
|
if (typeof module !== 'undefined' && module.exports) {
|
25
|
-
|
27
|
+
jasmineGlobal = global;
|
28
|
+
jasmineRequire = exports;
|
26
29
|
} else {
|
27
|
-
|
28
|
-
return window.jasmineRequire;
|
30
|
+
jasmineRequire = jasmineGlobal.jasmineRequire = jasmineGlobal.jasmineRequire || {};
|
29
31
|
}
|
30
|
-
}
|
31
32
|
|
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
|
-
|
33
|
+
function getJasmineRequire() {
|
34
|
+
return jasmineRequire;
|
35
|
+
}
|
36
|
+
|
37
|
+
getJasmineRequire().core = function(jRequire) {
|
38
|
+
var j$ = {};
|
39
|
+
|
40
|
+
jRequire.base(j$, jasmineGlobal);
|
41
|
+
j$.util = jRequire.util();
|
42
|
+
j$.Any = jRequire.Any();
|
43
|
+
j$.CallTracker = jRequire.CallTracker();
|
44
|
+
j$.MockDate = jRequire.MockDate();
|
45
|
+
j$.Clock = jRequire.Clock();
|
46
|
+
j$.DelayedFunctionScheduler = jRequire.DelayedFunctionScheduler();
|
47
|
+
j$.Env = jRequire.Env(j$);
|
48
|
+
j$.ExceptionFormatter = jRequire.ExceptionFormatter();
|
49
|
+
j$.Expectation = jRequire.Expectation();
|
50
|
+
j$.buildExpectationResult = jRequire.buildExpectationResult();
|
51
|
+
j$.JsApiReporter = jRequire.JsApiReporter();
|
52
|
+
j$.matchersUtil = jRequire.matchersUtil(j$);
|
53
|
+
j$.ObjectContaining = jRequire.ObjectContaining(j$);
|
54
|
+
j$.pp = jRequire.pp(j$);
|
55
|
+
j$.QueueRunner = jRequire.QueueRunner(j$);
|
56
|
+
j$.ReportDispatcher = jRequire.ReportDispatcher();
|
57
|
+
j$.Spec = jRequire.Spec(j$);
|
58
|
+
j$.SpyRegistry = jRequire.SpyRegistry(j$);
|
59
|
+
j$.SpyStrategy = jRequire.SpyStrategy();
|
60
|
+
j$.Suite = jRequire.Suite();
|
61
|
+
j$.Timer = jRequire.Timer();
|
62
|
+
j$.version = jRequire.version();
|
63
|
+
|
64
|
+
j$.matchers = jRequire.requireMatchers(jRequire, j$);
|
65
|
+
|
66
|
+
return j$;
|
67
|
+
};
|
68
|
+
|
69
|
+
return getJasmineRequire;
|
70
|
+
})(this);
|
62
71
|
|
63
72
|
getJasmineRequireObj().requireMatchers = function(jRequire, j$) {
|
64
73
|
var availableMatchers = [
|
@@ -90,108 +99,107 @@ getJasmineRequireObj().requireMatchers = function(jRequire, j$) {
|
|
90
99
|
return matchers;
|
91
100
|
};
|
92
101
|
|
93
|
-
getJasmineRequireObj().base = (
|
94
|
-
|
95
|
-
|
96
|
-
}
|
97
|
-
|
98
|
-
return function(j$) {
|
99
|
-
j$.unimplementedMethod_ = function() {
|
100
|
-
throw new Error('unimplemented method');
|
101
|
-
};
|
102
|
-
|
103
|
-
j$.MAX_PRETTY_PRINT_DEPTH = 40;
|
104
|
-
j$.MAX_PRETTY_PRINT_ARRAY_LENGTH = 100;
|
105
|
-
j$.DEFAULT_TIMEOUT_INTERVAL = 5000;
|
102
|
+
getJasmineRequireObj().base = function(j$, jasmineGlobal) {
|
103
|
+
j$.unimplementedMethod_ = function() {
|
104
|
+
throw new Error('unimplemented method');
|
105
|
+
};
|
106
106
|
|
107
|
-
|
108
|
-
|
109
|
-
|
107
|
+
j$.MAX_PRETTY_PRINT_DEPTH = 40;
|
108
|
+
j$.MAX_PRETTY_PRINT_ARRAY_LENGTH = 100;
|
109
|
+
j$.DEFAULT_TIMEOUT_INTERVAL = 5000;
|
110
110
|
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
return env;
|
115
|
-
};
|
111
|
+
j$.getGlobal = function() {
|
112
|
+
return jasmineGlobal;
|
113
|
+
};
|
116
114
|
|
117
|
-
|
118
|
-
|
119
|
-
|
115
|
+
j$.getEnv = function(options) {
|
116
|
+
var env = j$.currentEnv_ = j$.currentEnv_ || new j$.Env(options);
|
117
|
+
//jasmine. singletons in here (setTimeout blah blah).
|
118
|
+
return env;
|
119
|
+
};
|
120
120
|
|
121
|
-
|
122
|
-
|
123
|
-
|
121
|
+
j$.isArray_ = function(value) {
|
122
|
+
return j$.isA_('Array', value);
|
123
|
+
};
|
124
124
|
|
125
|
-
|
126
|
-
|
127
|
-
|
125
|
+
j$.isString_ = function(value) {
|
126
|
+
return j$.isA_('String', value);
|
127
|
+
};
|
128
128
|
|
129
|
-
|
130
|
-
|
131
|
-
|
129
|
+
j$.isNumber_ = function(value) {
|
130
|
+
return j$.isA_('Number', value);
|
131
|
+
};
|
132
132
|
|
133
|
-
|
134
|
-
|
135
|
-
|
133
|
+
j$.isA_ = function(typeName, value) {
|
134
|
+
return Object.prototype.toString.apply(value) === '[object ' + typeName + ']';
|
135
|
+
};
|
136
136
|
|
137
|
-
|
138
|
-
|
139
|
-
|
137
|
+
j$.isDomNode = function(obj) {
|
138
|
+
return obj.nodeType > 0;
|
139
|
+
};
|
140
140
|
|
141
|
-
|
142
|
-
|
143
|
-
|
141
|
+
j$.any = function(clazz) {
|
142
|
+
return new j$.Any(clazz);
|
143
|
+
};
|
144
144
|
|
145
|
-
|
145
|
+
j$.objectContaining = function(sample) {
|
146
|
+
return new j$.ObjectContaining(sample);
|
147
|
+
};
|
146
148
|
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
149
|
+
j$.createSpy = function(name, originalFn) {
|
150
|
+
|
151
|
+
var spyStrategy = new j$.SpyStrategy({
|
152
|
+
name: name,
|
153
|
+
fn: originalFn,
|
154
|
+
getSpy: function() { return spy; }
|
155
|
+
}),
|
156
|
+
callTracker = new j$.CallTracker(),
|
157
|
+
spy = function() {
|
158
|
+
var callData = {
|
159
|
+
object: this,
|
160
|
+
args: Array.prototype.slice.apply(arguments)
|
159
161
|
};
|
160
162
|
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
}
|
163
|
+
callTracker.track(callData);
|
164
|
+
var returnValue = spyStrategy.exec.apply(this, arguments);
|
165
|
+
callData.returnValue = returnValue;
|
165
166
|
|
166
|
-
|
167
|
+
return returnValue;
|
168
|
+
};
|
169
|
+
|
170
|
+
for (var prop in originalFn) {
|
171
|
+
if (prop === 'and' || prop === 'calls') {
|
172
|
+
throw new Error('Jasmine spies would overwrite the \'and\' and \'calls\' properties on the object being spied upon');
|
167
173
|
}
|
168
174
|
|
169
|
-
spy
|
170
|
-
|
175
|
+
spy[prop] = originalFn[prop];
|
176
|
+
}
|
171
177
|
|
172
|
-
|
173
|
-
|
178
|
+
spy.and = spyStrategy;
|
179
|
+
spy.calls = callTracker;
|
174
180
|
|
175
|
-
|
176
|
-
|
177
|
-
return false;
|
178
|
-
}
|
179
|
-
return putativeSpy.and instanceof j$.SpyStrategy &&
|
180
|
-
putativeSpy.calls instanceof j$.CallTracker;
|
181
|
-
};
|
181
|
+
return spy;
|
182
|
+
};
|
182
183
|
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
obj[methodNames[i]] = j$.createSpy(baseName + '.' + methodNames[i]);
|
190
|
-
}
|
191
|
-
return obj;
|
192
|
-
};
|
184
|
+
j$.isSpy = function(putativeSpy) {
|
185
|
+
if (!putativeSpy) {
|
186
|
+
return false;
|
187
|
+
}
|
188
|
+
return putativeSpy.and instanceof j$.SpyStrategy &&
|
189
|
+
putativeSpy.calls instanceof j$.CallTracker;
|
193
190
|
};
|
194
|
-
|
191
|
+
|
192
|
+
j$.createSpyObj = function(baseName, methodNames) {
|
193
|
+
if (!j$.isArray_(methodNames) || methodNames.length === 0) {
|
194
|
+
throw 'createSpyObj requires a non-empty array of method names to create spies for';
|
195
|
+
}
|
196
|
+
var obj = {};
|
197
|
+
for (var i = 0; i < methodNames.length; i++) {
|
198
|
+
obj[methodNames[i]] = j$.createSpy(baseName + '.' + methodNames[i]);
|
199
|
+
}
|
200
|
+
return obj;
|
201
|
+
};
|
202
|
+
};
|
195
203
|
|
196
204
|
getJasmineRequireObj().util = function() {
|
197
205
|
|
@@ -228,13 +236,28 @@ getJasmineRequireObj().util = function() {
|
|
228
236
|
util.arrayContains = function(array, search) {
|
229
237
|
var i = array.length;
|
230
238
|
while (i--) {
|
231
|
-
if (array[i]
|
239
|
+
if (array[i] === search) {
|
232
240
|
return true;
|
233
241
|
}
|
234
242
|
}
|
235
243
|
return false;
|
236
244
|
};
|
237
245
|
|
246
|
+
util.clone = function(obj) {
|
247
|
+
if (Object.prototype.toString.apply(obj) === '[object Array]') {
|
248
|
+
return obj.slice();
|
249
|
+
}
|
250
|
+
|
251
|
+
var cloned = {};
|
252
|
+
for (var prop in obj) {
|
253
|
+
if (obj.hasOwnProperty(prop)) {
|
254
|
+
cloned[prop] = obj[prop];
|
255
|
+
}
|
256
|
+
}
|
257
|
+
|
258
|
+
return cloned;
|
259
|
+
};
|
260
|
+
|
238
261
|
return util;
|
239
262
|
};
|
240
263
|
|
@@ -244,17 +267,16 @@ getJasmineRequireObj().Spec = function(j$) {
|
|
244
267
|
this.resultCallback = attrs.resultCallback || function() {};
|
245
268
|
this.id = attrs.id;
|
246
269
|
this.description = attrs.description || '';
|
247
|
-
this.
|
248
|
-
this.
|
249
|
-
this.
|
270
|
+
this.queueableFn = attrs.queueableFn;
|
271
|
+
this.beforeAndAfterFns = attrs.beforeAndAfterFns || function() { return {befores: [], afters: []}; };
|
272
|
+
this.userContext = attrs.userContext || function() { return {}; };
|
250
273
|
this.onStart = attrs.onStart || function() {};
|
251
|
-
this.exceptionFormatter = attrs.exceptionFormatter || function() {};
|
252
274
|
this.getSpecName = attrs.getSpecName || function() { return ''; };
|
253
275
|
this.expectationResultFactory = attrs.expectationResultFactory || function() { };
|
254
276
|
this.queueRunnerFactory = attrs.queueRunnerFactory || function() {};
|
255
277
|
this.catchingExceptions = attrs.catchingExceptions || function() { return true; };
|
256
278
|
|
257
|
-
if (!this.fn) {
|
279
|
+
if (!this.queueableFn.fn) {
|
258
280
|
this.pend();
|
259
281
|
}
|
260
282
|
|
@@ -290,30 +312,16 @@ getJasmineRequireObj().Spec = function(j$) {
|
|
290
312
|
return;
|
291
313
|
}
|
292
314
|
|
293
|
-
var
|
315
|
+
var fns = this.beforeAndAfterFns();
|
316
|
+
var allFns = fns.befores.concat(this.queueableFn).concat(fns.afters);
|
294
317
|
|
295
318
|
this.queueRunnerFactory({
|
296
|
-
|
297
|
-
onException: onException,
|
319
|
+
queueableFns: allFns,
|
320
|
+
onException: function() { self.onException.apply(self, arguments); },
|
298
321
|
onComplete: complete,
|
299
|
-
|
322
|
+
userContext: this.userContext()
|
300
323
|
});
|
301
324
|
|
302
|
-
function onException(e) {
|
303
|
-
if (Spec.isPendingSpecException(e)) {
|
304
|
-
self.pend();
|
305
|
-
return;
|
306
|
-
}
|
307
|
-
|
308
|
-
self.addExpectationResult(false, {
|
309
|
-
matcherName: '',
|
310
|
-
passed: false,
|
311
|
-
expected: '',
|
312
|
-
actual: '',
|
313
|
-
error: e
|
314
|
-
});
|
315
|
-
}
|
316
|
-
|
317
325
|
function complete() {
|
318
326
|
self.result.status = self.status();
|
319
327
|
self.resultCallback(self.result);
|
@@ -324,6 +332,21 @@ getJasmineRequireObj().Spec = function(j$) {
|
|
324
332
|
}
|
325
333
|
};
|
326
334
|
|
335
|
+
Spec.prototype.onException = function onException(e) {
|
336
|
+
if (Spec.isPendingSpecException(e)) {
|
337
|
+
this.pend();
|
338
|
+
return;
|
339
|
+
}
|
340
|
+
|
341
|
+
this.addExpectationResult(false, {
|
342
|
+
matcherName: '',
|
343
|
+
passed: false,
|
344
|
+
expected: '',
|
345
|
+
actual: '',
|
346
|
+
error: e
|
347
|
+
});
|
348
|
+
};
|
349
|
+
|
327
350
|
Spec.prototype.disable = function() {
|
328
351
|
this.disabled = true;
|
329
352
|
};
|
@@ -348,6 +371,10 @@ getJasmineRequireObj().Spec = function(j$) {
|
|
348
371
|
}
|
349
372
|
};
|
350
373
|
|
374
|
+
Spec.prototype.isExecutable = function() {
|
375
|
+
return !this.disabled && !this.markedPending;
|
376
|
+
};
|
377
|
+
|
351
378
|
Spec.prototype.getFullName = function() {
|
352
379
|
return this.getSpecName(this);
|
353
380
|
};
|
@@ -381,11 +408,19 @@ getJasmineRequireObj().Env = function(j$) {
|
|
381
408
|
this.clock = new j$.Clock(global, new j$.DelayedFunctionScheduler(), new j$.MockDate(global));
|
382
409
|
|
383
410
|
var runnableLookupTable = {};
|
384
|
-
|
385
|
-
var spies = [];
|
411
|
+
var runnableResources = {};
|
386
412
|
|
387
413
|
var currentSpec = null;
|
388
|
-
var
|
414
|
+
var currentlyExecutingSuites = [];
|
415
|
+
var currentDeclarationSuite = null;
|
416
|
+
|
417
|
+
var currentSuite = function() {
|
418
|
+
return currentlyExecutingSuites[currentlyExecutingSuites.length - 1];
|
419
|
+
};
|
420
|
+
|
421
|
+
var currentRunnable = function() {
|
422
|
+
return currentSpec || currentSuite();
|
423
|
+
};
|
389
424
|
|
390
425
|
var reporter = new j$.ReportDispatcher([
|
391
426
|
'jasmineStarted',
|
@@ -400,11 +435,21 @@ getJasmineRequireObj().Env = function(j$) {
|
|
400
435
|
return true;
|
401
436
|
};
|
402
437
|
|
403
|
-
var equalityTesters = [];
|
404
|
-
|
405
|
-
var customEqualityTesters = [];
|
406
438
|
this.addCustomEqualityTester = function(tester) {
|
407
|
-
|
439
|
+
if(!currentRunnable()) {
|
440
|
+
throw new Error('Custom Equalities must be added in a before function or a spec');
|
441
|
+
}
|
442
|
+
runnableResources[currentRunnable().id].customEqualityTesters.push(tester);
|
443
|
+
};
|
444
|
+
|
445
|
+
this.addMatchers = function(matchersToAdd) {
|
446
|
+
if(!currentRunnable()) {
|
447
|
+
throw new Error('Matchers must be added in a before function or a spec');
|
448
|
+
}
|
449
|
+
var customMatchers = runnableResources[currentRunnable().id].customMatchers;
|
450
|
+
for (var matcherName in matchersToAdd) {
|
451
|
+
customMatchers[matcherName] = matchersToAdd[matcherName];
|
452
|
+
}
|
408
453
|
};
|
409
454
|
|
410
455
|
j$.Expectation.addCoreMatchers(j$.matchers);
|
@@ -422,7 +467,8 @@ getJasmineRequireObj().Env = function(j$) {
|
|
422
467
|
var expectationFactory = function(actual, spec) {
|
423
468
|
return j$.Expectation.Factory({
|
424
469
|
util: j$.matchersUtil,
|
425
|
-
customEqualityTesters: customEqualityTesters,
|
470
|
+
customEqualityTesters: runnableResources[spec.id].customEqualityTesters,
|
471
|
+
customMatchers: runnableResources[spec.id].customMatchers,
|
426
472
|
actual: actual,
|
427
473
|
addExpectationResult: addExpectationResult
|
428
474
|
});
|
@@ -432,30 +478,44 @@ getJasmineRequireObj().Env = function(j$) {
|
|
432
478
|
}
|
433
479
|
};
|
434
480
|
|
435
|
-
var
|
436
|
-
|
437
|
-
|
481
|
+
var defaultResourcesForRunnable = function(id, parentRunnableId) {
|
482
|
+
var resources = {spies: [], customEqualityTesters: [], customMatchers: {}};
|
483
|
+
|
484
|
+
if(runnableResources[parentRunnableId]){
|
485
|
+
resources.customEqualityTesters = j$.util.clone(runnableResources[parentRunnableId].customEqualityTesters);
|
486
|
+
resources.customMatchers = j$.util.clone(runnableResources[parentRunnableId].customMatchers);
|
487
|
+
}
|
488
|
+
|
489
|
+
runnableResources[id] = resources;
|
438
490
|
};
|
439
491
|
|
440
|
-
var
|
441
|
-
|
442
|
-
|
443
|
-
while(suite) {
|
444
|
-
befores = befores.concat(suite.beforeFns);
|
445
|
-
suite = suite.parentSuite;
|
446
|
-
}
|
447
|
-
return befores.reverse();
|
448
|
-
};
|
492
|
+
var clearResourcesForRunnable = function(id) {
|
493
|
+
spyRegistry.clearSpies();
|
494
|
+
delete runnableResources[id];
|
449
495
|
};
|
450
496
|
|
451
|
-
var
|
497
|
+
var beforeAndAfterFns = function(suite, runnablesExplictlySet) {
|
452
498
|
return function() {
|
453
|
-
var
|
499
|
+
var befores = [],
|
500
|
+
afters = [],
|
501
|
+
beforeAlls = [],
|
502
|
+
afterAlls = [];
|
503
|
+
|
454
504
|
while(suite) {
|
505
|
+
befores = befores.concat(suite.beforeFns);
|
455
506
|
afters = afters.concat(suite.afterFns);
|
507
|
+
|
508
|
+
if (runnablesExplictlySet()) {
|
509
|
+
beforeAlls = beforeAlls.concat(suite.beforeAllFns);
|
510
|
+
afterAlls = afterAlls.concat(suite.afterAllFns);
|
511
|
+
}
|
512
|
+
|
456
513
|
suite = suite.parentSuite;
|
457
514
|
}
|
458
|
-
return
|
515
|
+
return {
|
516
|
+
befores: beforeAlls.reverse().concat(befores.reverse()),
|
517
|
+
afters: afters.concat(afterAlls)
|
518
|
+
};
|
459
519
|
};
|
460
520
|
};
|
461
521
|
|
@@ -504,6 +564,7 @@ getJasmineRequireObj().Env = function(j$) {
|
|
504
564
|
options.catchException = catchException;
|
505
565
|
options.clearStack = options.clearStack || clearStack;
|
506
566
|
options.timer = {setTimeout: realSetTimeout, clearTimeout: realClearTimeout};
|
567
|
+
options.fail = self.fail;
|
507
568
|
|
508
569
|
new j$.QueueRunner(options).execute();
|
509
570
|
};
|
@@ -513,65 +574,54 @@ getJasmineRequireObj().Env = function(j$) {
|
|
513
574
|
id: getNextSuiteId(),
|
514
575
|
description: 'Jasmine__TopLevel__Suite',
|
515
576
|
queueRunner: queueRunnerFactory,
|
516
|
-
resultCallback: function() {
|
577
|
+
resultCallback: function(attrs) {
|
578
|
+
reporter.suiteDone(attrs);
|
579
|
+
}
|
517
580
|
});
|
518
581
|
runnableLookupTable[topSuite.id] = topSuite;
|
519
|
-
|
582
|
+
defaultResourcesForRunnable(topSuite.id);
|
583
|
+
currentDeclarationSuite = topSuite;
|
520
584
|
|
521
585
|
this.topSuite = function() {
|
522
586
|
return topSuite;
|
523
587
|
};
|
524
588
|
|
525
589
|
this.execute = function(runnablesToRun) {
|
526
|
-
runnablesToRun
|
590
|
+
if(runnablesToRun) {
|
591
|
+
runnablesExplictlySet = true;
|
592
|
+
} else if (focusedRunnables.length) {
|
593
|
+
runnablesExplictlySet = true;
|
594
|
+
runnablesToRun = focusedRunnables;
|
595
|
+
} else {
|
596
|
+
runnablesToRun = [topSuite.id];
|
597
|
+
}
|
527
598
|
|
528
599
|
var allFns = [];
|
529
600
|
for(var i = 0; i < runnablesToRun.length; i++) {
|
530
601
|
var runnable = runnableLookupTable[runnablesToRun[i]];
|
531
|
-
allFns.push((function(runnable) { return function(done) { runnable.execute(done); }; })(runnable));
|
602
|
+
allFns.push((function(runnable) { return { fn: function(done) { runnable.execute(done); } }; })(runnable));
|
532
603
|
}
|
533
604
|
|
534
605
|
reporter.jasmineStarted({
|
535
606
|
totalSpecsDefined: totalSpecsDefined
|
536
607
|
});
|
537
608
|
|
538
|
-
queueRunnerFactory({
|
609
|
+
queueRunnerFactory({queueableFns: allFns, onComplete: reporter.jasmineDone});
|
539
610
|
};
|
540
611
|
|
541
612
|
this.addReporter = function(reporterToAdd) {
|
542
613
|
reporter.addReporter(reporterToAdd);
|
543
614
|
};
|
544
615
|
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
this.spyOn = function(obj, methodName) {
|
550
|
-
if (j$.util.isUndefined(obj)) {
|
551
|
-
throw new Error('spyOn could not find an object to spy upon for ' + methodName + '()');
|
616
|
+
var spyRegistry = new j$.SpyRegistry({currentSpies: function() {
|
617
|
+
if(!currentRunnable()) {
|
618
|
+
throw new Error('Spies must be created in a before function or a spec');
|
552
619
|
}
|
620
|
+
return runnableResources[currentRunnable().id].spies;
|
621
|
+
}});
|
553
622
|
|
554
|
-
|
555
|
-
|
556
|
-
}
|
557
|
-
|
558
|
-
if (obj[methodName] && j$.isSpy(obj[methodName])) {
|
559
|
-
//TODO?: should this return the current spy? Downside: may cause user confusion about spy state
|
560
|
-
throw new Error(methodName + ' has already been spied upon');
|
561
|
-
}
|
562
|
-
|
563
|
-
var spy = j$.createSpy(methodName, obj[methodName]);
|
564
|
-
|
565
|
-
spies.push({
|
566
|
-
spy: spy,
|
567
|
-
baseObj: obj,
|
568
|
-
methodName: methodName,
|
569
|
-
originalValue: obj[methodName]
|
570
|
-
});
|
571
|
-
|
572
|
-
obj[methodName] = spy;
|
573
|
-
|
574
|
-
return spy;
|
623
|
+
this.spyOn = function() {
|
624
|
+
return spyRegistry.spyOn.apply(spyRegistry, arguments);
|
575
625
|
};
|
576
626
|
|
577
627
|
var suiteFactory = function(description) {
|
@@ -579,24 +629,59 @@ getJasmineRequireObj().Env = function(j$) {
|
|
579
629
|
env: self,
|
580
630
|
id: getNextSuiteId(),
|
581
631
|
description: description,
|
582
|
-
parentSuite:
|
632
|
+
parentSuite: currentDeclarationSuite,
|
583
633
|
queueRunner: queueRunnerFactory,
|
584
634
|
onStart: suiteStarted,
|
635
|
+
expectationFactory: expectationFactory,
|
636
|
+
expectationResultFactory: expectationResultFactory,
|
585
637
|
resultCallback: function(attrs) {
|
638
|
+
if (!suite.disabled) {
|
639
|
+
clearResourcesForRunnable(suite.id);
|
640
|
+
currentlyExecutingSuites.pop();
|
641
|
+
}
|
586
642
|
reporter.suiteDone(attrs);
|
587
643
|
}
|
588
644
|
});
|
589
645
|
|
590
646
|
runnableLookupTable[suite.id] = suite;
|
591
647
|
return suite;
|
648
|
+
|
649
|
+
function suiteStarted(suite) {
|
650
|
+
currentlyExecutingSuites.push(suite);
|
651
|
+
defaultResourcesForRunnable(suite.id, suite.parentSuite.id);
|
652
|
+
reporter.suiteStarted(suite.result);
|
653
|
+
}
|
592
654
|
};
|
593
655
|
|
594
656
|
this.describe = function(description, specDefinitions) {
|
595
657
|
var suite = suiteFactory(description);
|
658
|
+
addSpecsToSuite(suite, specDefinitions);
|
659
|
+
return suite;
|
660
|
+
};
|
661
|
+
|
662
|
+
this.xdescribe = function(description, specDefinitions) {
|
663
|
+
var suite = this.describe(description, specDefinitions);
|
664
|
+
suite.disable();
|
665
|
+
return suite;
|
666
|
+
};
|
667
|
+
|
668
|
+
var focusedRunnables = [];
|
669
|
+
|
670
|
+
this.fdescribe = function(description, specDefinitions) {
|
671
|
+
var suite = suiteFactory(description);
|
672
|
+
suite.isFocused = true;
|
673
|
+
|
674
|
+
focusedRunnables.push(suite.id);
|
675
|
+
unfocusAncestor();
|
676
|
+
addSpecsToSuite(suite, specDefinitions);
|
677
|
+
|
678
|
+
return suite;
|
679
|
+
};
|
596
680
|
|
597
|
-
|
681
|
+
function addSpecsToSuite(suite, specDefinitions) {
|
682
|
+
var parentSuite = currentDeclarationSuite;
|
598
683
|
parentSuite.addChild(suite);
|
599
|
-
|
684
|
+
currentDeclarationSuite = suite;
|
600
685
|
|
601
686
|
var declarationError = null;
|
602
687
|
try {
|
@@ -606,31 +691,49 @@ getJasmineRequireObj().Env = function(j$) {
|
|
606
691
|
}
|
607
692
|
|
608
693
|
if (declarationError) {
|
609
|
-
|
694
|
+
self.it('encountered a declaration exception', function() {
|
610
695
|
throw declarationError;
|
611
696
|
});
|
612
697
|
}
|
613
698
|
|
614
|
-
|
699
|
+
currentDeclarationSuite = parentSuite;
|
700
|
+
}
|
615
701
|
|
616
|
-
|
617
|
-
|
702
|
+
function findFocusedAncestor(suite) {
|
703
|
+
while (suite) {
|
704
|
+
if (suite.isFocused) {
|
705
|
+
return suite.id;
|
706
|
+
}
|
707
|
+
suite = suite.parentSuite;
|
708
|
+
}
|
618
709
|
|
619
|
-
|
620
|
-
|
621
|
-
|
622
|
-
|
710
|
+
return null;
|
711
|
+
}
|
712
|
+
|
713
|
+
function unfocusAncestor() {
|
714
|
+
var focusedAncestor = findFocusedAncestor(currentDeclarationSuite);
|
715
|
+
if (focusedAncestor) {
|
716
|
+
for (var i = 0; i < focusedRunnables.length; i++) {
|
717
|
+
if (focusedRunnables[i] === focusedAncestor) {
|
718
|
+
focusedRunnables.splice(i, 1);
|
719
|
+
break;
|
720
|
+
}
|
721
|
+
}
|
722
|
+
}
|
723
|
+
}
|
724
|
+
|
725
|
+
var runnablesExplictlySet = false;
|
726
|
+
|
727
|
+
var runnablesExplictlySetGetter = function(){
|
728
|
+
return runnablesExplictlySet;
|
623
729
|
};
|
624
730
|
|
625
|
-
var specFactory = function(description, fn, suite) {
|
731
|
+
var specFactory = function(description, fn, suite, timeout) {
|
626
732
|
totalSpecsDefined++;
|
627
|
-
|
628
733
|
var spec = new j$.Spec({
|
629
734
|
id: getNextSpecId(),
|
630
|
-
|
631
|
-
afterFns: afterFns(suite),
|
735
|
+
beforeAndAfterFns: beforeAndAfterFns(suite, runnablesExplictlySetGetter),
|
632
736
|
expectationFactory: expectationFactory,
|
633
|
-
exceptionFormatter: exceptionFormatter,
|
634
737
|
resultCallback: specResultCallback,
|
635
738
|
getSpecName: function(spec) {
|
636
739
|
return getSpecName(spec, suite);
|
@@ -639,7 +742,11 @@ getJasmineRequireObj().Env = function(j$) {
|
|
639
742
|
description: description,
|
640
743
|
expectationResultFactory: expectationResultFactory,
|
641
744
|
queueRunnerFactory: queueRunnerFactory,
|
642
|
-
|
745
|
+
userContext: function() { return suite.clonedSharedUserContext(); },
|
746
|
+
queueableFn: {
|
747
|
+
fn: fn,
|
748
|
+
timeout: function() { return timeout || j$.DEFAULT_TIMEOUT_INTERVAL; }
|
749
|
+
}
|
643
750
|
});
|
644
751
|
|
645
752
|
runnableLookupTable[spec.id] = spec;
|
@@ -650,58 +757,94 @@ getJasmineRequireObj().Env = function(j$) {
|
|
650
757
|
|
651
758
|
return spec;
|
652
759
|
|
653
|
-
function removeAllSpies() {
|
654
|
-
for (var i = 0; i < spies.length; i++) {
|
655
|
-
var spyEntry = spies[i];
|
656
|
-
spyEntry.baseObj[spyEntry.methodName] = spyEntry.originalValue;
|
657
|
-
}
|
658
|
-
spies = [];
|
659
|
-
}
|
660
|
-
|
661
760
|
function specResultCallback(result) {
|
662
|
-
|
663
|
-
j$.Expectation.resetMatchers();
|
664
|
-
customEqualityTesters = [];
|
761
|
+
clearResourcesForRunnable(spec.id);
|
665
762
|
currentSpec = null;
|
666
763
|
reporter.specDone(result);
|
667
764
|
}
|
668
|
-
};
|
669
765
|
|
670
|
-
|
671
|
-
|
766
|
+
function specStarted(spec) {
|
767
|
+
currentSpec = spec;
|
768
|
+
defaultResourcesForRunnable(spec.id, suite.id);
|
769
|
+
reporter.specStarted(spec.result);
|
770
|
+
}
|
672
771
|
};
|
673
772
|
|
674
|
-
this.it = function(description, fn) {
|
675
|
-
var spec = specFactory(description, fn,
|
676
|
-
|
773
|
+
this.it = function(description, fn, timeout) {
|
774
|
+
var spec = specFactory(description, fn, currentDeclarationSuite, timeout);
|
775
|
+
currentDeclarationSuite.addChild(spec);
|
677
776
|
return spec;
|
678
777
|
};
|
679
778
|
|
680
|
-
this.xit = function(
|
681
|
-
var spec = this.it(
|
779
|
+
this.xit = function() {
|
780
|
+
var spec = this.it.apply(this, arguments);
|
682
781
|
spec.pend();
|
683
782
|
return spec;
|
684
783
|
};
|
685
784
|
|
785
|
+
this.fit = function(){
|
786
|
+
var spec = this.it.apply(this, arguments);
|
787
|
+
|
788
|
+
focusedRunnables.push(spec.id);
|
789
|
+
unfocusAncestor();
|
790
|
+
return spec;
|
791
|
+
};
|
792
|
+
|
686
793
|
this.expect = function(actual) {
|
687
|
-
if (!
|
794
|
+
if (!currentRunnable()) {
|
688
795
|
throw new Error('\'expect\' was used when there was no current spec, this could be because an asynchronous test timed out');
|
689
796
|
}
|
690
797
|
|
691
|
-
return
|
798
|
+
return currentRunnable().expect(actual);
|
799
|
+
};
|
800
|
+
|
801
|
+
this.beforeEach = function(beforeEachFunction, timeout) {
|
802
|
+
currentDeclarationSuite.beforeEach({
|
803
|
+
fn: beforeEachFunction,
|
804
|
+
timeout: function() { return timeout || j$.DEFAULT_TIMEOUT_INTERVAL; }
|
805
|
+
});
|
806
|
+
};
|
807
|
+
|
808
|
+
this.beforeAll = function(beforeAllFunction, timeout) {
|
809
|
+
currentDeclarationSuite.beforeAll({
|
810
|
+
fn: beforeAllFunction,
|
811
|
+
timeout: function() { return timeout || j$.DEFAULT_TIMEOUT_INTERVAL; }
|
812
|
+
});
|
692
813
|
};
|
693
814
|
|
694
|
-
this.
|
695
|
-
|
815
|
+
this.afterEach = function(afterEachFunction, timeout) {
|
816
|
+
currentDeclarationSuite.afterEach({
|
817
|
+
fn: afterEachFunction,
|
818
|
+
timeout: function() { return timeout || j$.DEFAULT_TIMEOUT_INTERVAL; }
|
819
|
+
});
|
696
820
|
};
|
697
821
|
|
698
|
-
this.
|
699
|
-
|
822
|
+
this.afterAll = function(afterAllFunction, timeout) {
|
823
|
+
currentDeclarationSuite.afterAll({
|
824
|
+
fn: afterAllFunction,
|
825
|
+
timeout: function() { return timeout || j$.DEFAULT_TIMEOUT_INTERVAL; }
|
826
|
+
});
|
700
827
|
};
|
701
828
|
|
702
829
|
this.pending = function() {
|
703
830
|
throw j$.Spec.pendingSpecExceptionMessage;
|
704
831
|
};
|
832
|
+
|
833
|
+
this.fail = function(error) {
|
834
|
+
var message = 'Failed';
|
835
|
+
if (error) {
|
836
|
+
message += ': ';
|
837
|
+
message += error.message || error;
|
838
|
+
}
|
839
|
+
|
840
|
+
currentRunnable().addExpectationResult(false, {
|
841
|
+
matcherName: '',
|
842
|
+
passed: false,
|
843
|
+
expected: '',
|
844
|
+
actual: '',
|
845
|
+
message: message
|
846
|
+
});
|
847
|
+
};
|
705
848
|
}
|
706
849
|
|
707
850
|
return Env;
|
@@ -739,26 +882,31 @@ getJasmineRequireObj().JsApiReporter = function() {
|
|
739
882
|
return status;
|
740
883
|
};
|
741
884
|
|
742
|
-
var suites =
|
885
|
+
var suites = [],
|
886
|
+
suites_hash = {};
|
743
887
|
|
744
888
|
this.suiteStarted = function(result) {
|
745
|
-
|
889
|
+
suites_hash[result.id] = result;
|
746
890
|
};
|
747
891
|
|
748
892
|
this.suiteDone = function(result) {
|
749
893
|
storeSuite(result);
|
750
894
|
};
|
751
895
|
|
896
|
+
this.suiteResults = function(index, length) {
|
897
|
+
return suites.slice(index, index + length);
|
898
|
+
};
|
899
|
+
|
752
900
|
function storeSuite(result) {
|
753
|
-
suites
|
901
|
+
suites.push(result);
|
902
|
+
suites_hash[result.id] = result;
|
754
903
|
}
|
755
904
|
|
756
905
|
this.suites = function() {
|
757
|
-
return
|
906
|
+
return suites_hash;
|
758
907
|
};
|
759
908
|
|
760
909
|
var specs = [];
|
761
|
-
this.specStarted = function(result) { };
|
762
910
|
|
763
911
|
this.specDone = function(result) {
|
764
912
|
specs.push(result);
|
@@ -1112,11 +1260,12 @@ getJasmineRequireObj().DelayedFunctionScheduler = function() {
|
|
1112
1260
|
|
1113
1261
|
for (var i = 0; i < funcsToRun.length; ++i) {
|
1114
1262
|
var funcToRun = funcsToRun[i];
|
1115
|
-
funcToRun.funcToCall.apply(null, funcToRun.params || []);
|
1116
1263
|
|
1117
1264
|
if (funcToRun.recurring) {
|
1118
1265
|
reschedule(funcToRun);
|
1119
1266
|
}
|
1267
|
+
|
1268
|
+
funcToRun.funcToCall.apply(null, funcToRun.params || []);
|
1120
1269
|
}
|
1121
1270
|
} while (scheduledLookup.length > 0 &&
|
1122
1271
|
// checking first if we're out of time prevents setTimeout(0)
|
@@ -1161,8 +1310,6 @@ getJasmineRequireObj().ExceptionFormatter = function() {
|
|
1161
1310
|
|
1162
1311
|
getJasmineRequireObj().Expectation = function() {
|
1163
1312
|
|
1164
|
-
var matchers = {};
|
1165
|
-
|
1166
1313
|
function Expectation(options) {
|
1167
1314
|
this.util = options.util || { buildFailureMessage: function() {} };
|
1168
1315
|
this.customEqualityTesters = options.customEqualityTesters || [];
|
@@ -1170,8 +1317,9 @@ getJasmineRequireObj().Expectation = function() {
|
|
1170
1317
|
this.addExpectationResult = options.addExpectationResult || function(){};
|
1171
1318
|
this.isNot = options.isNot;
|
1172
1319
|
|
1173
|
-
|
1174
|
-
|
1320
|
+
var customMatchers = options.customMatchers || {};
|
1321
|
+
for (var matcherName in customMatchers) {
|
1322
|
+
this[matcherName] = Expectation.prototype.wrapCompare(matcherName, customMatchers[matcherName]);
|
1175
1323
|
}
|
1176
1324
|
}
|
1177
1325
|
|
@@ -1238,19 +1386,6 @@ getJasmineRequireObj().Expectation = function() {
|
|
1238
1386
|
}
|
1239
1387
|
};
|
1240
1388
|
|
1241
|
-
Expectation.addMatchers = function(matchersToAdd) {
|
1242
|
-
for (var name in matchersToAdd) {
|
1243
|
-
var matcher = matchersToAdd[name];
|
1244
|
-
matchers[name] = Expectation.prototype.wrapCompare(name, matcher);
|
1245
|
-
}
|
1246
|
-
};
|
1247
|
-
|
1248
|
-
Expectation.resetMatchers = function() {
|
1249
|
-
for (var name in matchers) {
|
1250
|
-
delete matchers[name];
|
1251
|
-
}
|
1252
|
-
};
|
1253
|
-
|
1254
1389
|
Expectation.Factory = function(options) {
|
1255
1390
|
options = options || {};
|
1256
1391
|
|
@@ -1376,6 +1511,7 @@ getJasmineRequireObj().MockDate = function() {
|
|
1376
1511
|
}
|
1377
1512
|
|
1378
1513
|
function createDateProperties() {
|
1514
|
+
FakeDate.prototype = GlobalDate.prototype;
|
1379
1515
|
|
1380
1516
|
FakeDate.now = function() {
|
1381
1517
|
if (GlobalDate.now) {
|
@@ -1581,31 +1717,32 @@ getJasmineRequireObj().QueueRunner = function(j$) {
|
|
1581
1717
|
}
|
1582
1718
|
|
1583
1719
|
function QueueRunner(attrs) {
|
1584
|
-
this.
|
1720
|
+
this.queueableFns = attrs.queueableFns || [];
|
1585
1721
|
this.onComplete = attrs.onComplete || function() {};
|
1586
1722
|
this.clearStack = attrs.clearStack || function(fn) {fn();};
|
1587
1723
|
this.onException = attrs.onException || function() {};
|
1588
1724
|
this.catchException = attrs.catchException || function() { return true; };
|
1589
|
-
this.
|
1590
|
-
this.userContext = {};
|
1725
|
+
this.userContext = attrs.userContext || {};
|
1591
1726
|
this.timer = attrs.timeout || {setTimeout: setTimeout, clearTimeout: clearTimeout};
|
1727
|
+
this.fail = attrs.fail || function() {};
|
1592
1728
|
}
|
1593
1729
|
|
1594
1730
|
QueueRunner.prototype.execute = function() {
|
1595
|
-
this.run(this.
|
1731
|
+
this.run(this.queueableFns, 0);
|
1596
1732
|
};
|
1597
1733
|
|
1598
|
-
QueueRunner.prototype.run = function(
|
1599
|
-
var length =
|
1600
|
-
|
1601
|
-
|
1734
|
+
QueueRunner.prototype.run = function(queueableFns, recursiveIndex) {
|
1735
|
+
var length = queueableFns.length,
|
1736
|
+
self = this,
|
1737
|
+
iterativeIndex;
|
1738
|
+
|
1602
1739
|
|
1603
1740
|
for(iterativeIndex = recursiveIndex; iterativeIndex < length; iterativeIndex++) {
|
1604
|
-
var
|
1605
|
-
if (fn.length > 0) {
|
1606
|
-
return attemptAsync(
|
1741
|
+
var queueableFn = queueableFns[iterativeIndex];
|
1742
|
+
if (queueableFn.fn.length > 0) {
|
1743
|
+
return attemptAsync(queueableFn);
|
1607
1744
|
} else {
|
1608
|
-
attemptSync(
|
1745
|
+
attemptSync(queueableFn);
|
1609
1746
|
}
|
1610
1747
|
}
|
1611
1748
|
|
@@ -1615,41 +1752,51 @@ getJasmineRequireObj().QueueRunner = function(j$) {
|
|
1615
1752
|
this.clearStack(this.onComplete);
|
1616
1753
|
}
|
1617
1754
|
|
1618
|
-
function attemptSync(
|
1755
|
+
function attemptSync(queueableFn) {
|
1619
1756
|
try {
|
1620
|
-
fn.call(self.userContext);
|
1757
|
+
queueableFn.fn.call(self.userContext);
|
1621
1758
|
} catch (e) {
|
1622
|
-
handleException(e);
|
1759
|
+
handleException(e, queueableFn);
|
1623
1760
|
}
|
1624
1761
|
}
|
1625
1762
|
|
1626
|
-
function attemptAsync(
|
1763
|
+
function attemptAsync(queueableFn) {
|
1627
1764
|
var clearTimeout = function () {
|
1628
1765
|
Function.prototype.apply.apply(self.timer.clearTimeout, [j$.getGlobal(), [timeoutId]]);
|
1629
1766
|
},
|
1630
1767
|
next = once(function () {
|
1631
1768
|
clearTimeout(timeoutId);
|
1632
|
-
self.run(
|
1769
|
+
self.run(queueableFns, iterativeIndex + 1);
|
1633
1770
|
}),
|
1634
1771
|
timeoutId;
|
1635
1772
|
|
1636
|
-
|
1773
|
+
next.fail = function() {
|
1774
|
+
self.fail.apply(null, arguments);
|
1775
|
+
next();
|
1776
|
+
};
|
1777
|
+
|
1778
|
+
if (queueableFn.timeout) {
|
1637
1779
|
timeoutId = Function.prototype.apply.apply(self.timer.setTimeout, [j$.getGlobal(), [function() {
|
1638
|
-
|
1780
|
+
var error = new Error('Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.');
|
1781
|
+
onException(error, queueableFn);
|
1639
1782
|
next();
|
1640
|
-
},
|
1783
|
+
}, queueableFn.timeout()]]);
|
1641
1784
|
}
|
1642
1785
|
|
1643
1786
|
try {
|
1644
|
-
fn.call(self.userContext, next);
|
1787
|
+
queueableFn.fn.call(self.userContext, next);
|
1645
1788
|
} catch (e) {
|
1646
|
-
handleException(e);
|
1789
|
+
handleException(e, queueableFn);
|
1647
1790
|
next();
|
1648
1791
|
}
|
1649
1792
|
}
|
1650
1793
|
|
1651
|
-
function
|
1794
|
+
function onException(e, queueableFn) {
|
1652
1795
|
self.onException(e);
|
1796
|
+
}
|
1797
|
+
|
1798
|
+
function handleException(e, queueableFn) {
|
1799
|
+
onException(e, queueableFn);
|
1653
1800
|
if (!self.catchException(e)) {
|
1654
1801
|
//TODO: set a var when we catch an exception and
|
1655
1802
|
//use a finally block to close the loop in a nice way..
|
@@ -1697,6 +1844,52 @@ getJasmineRequireObj().ReportDispatcher = function() {
|
|
1697
1844
|
};
|
1698
1845
|
|
1699
1846
|
|
1847
|
+
getJasmineRequireObj().SpyRegistry = function(j$) {
|
1848
|
+
|
1849
|
+
function SpyRegistry(options) {
|
1850
|
+
options = options || {};
|
1851
|
+
var currentSpies = options.currentSpies || function() { return []; };
|
1852
|
+
|
1853
|
+
this.spyOn = function(obj, methodName) {
|
1854
|
+
if (j$.util.isUndefined(obj)) {
|
1855
|
+
throw new Error('spyOn could not find an object to spy upon for ' + methodName + '()');
|
1856
|
+
}
|
1857
|
+
|
1858
|
+
if (j$.util.isUndefined(obj[methodName])) {
|
1859
|
+
throw new Error(methodName + '() method does not exist');
|
1860
|
+
}
|
1861
|
+
|
1862
|
+
if (obj[methodName] && j$.isSpy(obj[methodName])) {
|
1863
|
+
//TODO?: should this return the current spy? Downside: may cause user confusion about spy state
|
1864
|
+
throw new Error(methodName + ' has already been spied upon');
|
1865
|
+
}
|
1866
|
+
|
1867
|
+
var spy = j$.createSpy(methodName, obj[methodName]);
|
1868
|
+
|
1869
|
+
currentSpies().push({
|
1870
|
+
spy: spy,
|
1871
|
+
baseObj: obj,
|
1872
|
+
methodName: methodName,
|
1873
|
+
originalValue: obj[methodName]
|
1874
|
+
});
|
1875
|
+
|
1876
|
+
obj[methodName] = spy;
|
1877
|
+
|
1878
|
+
return spy;
|
1879
|
+
};
|
1880
|
+
|
1881
|
+
this.clearSpies = function() {
|
1882
|
+
var spies = currentSpies();
|
1883
|
+
for (var i = 0; i < spies.length; i++) {
|
1884
|
+
var spyEntry = spies[i];
|
1885
|
+
spyEntry.baseObj[spyEntry.methodName] = spyEntry.originalValue;
|
1886
|
+
}
|
1887
|
+
};
|
1888
|
+
}
|
1889
|
+
|
1890
|
+
return SpyRegistry;
|
1891
|
+
};
|
1892
|
+
|
1700
1893
|
getJasmineRequireObj().SpyStrategy = function() {
|
1701
1894
|
|
1702
1895
|
function SpyStrategy(options) {
|
@@ -1727,6 +1920,14 @@ getJasmineRequireObj().SpyStrategy = function() {
|
|
1727
1920
|
return getSpy();
|
1728
1921
|
};
|
1729
1922
|
|
1923
|
+
this.returnValues = function() {
|
1924
|
+
var values = Array.prototype.slice.call(arguments);
|
1925
|
+
plan = function () {
|
1926
|
+
return values.shift();
|
1927
|
+
};
|
1928
|
+
return getSpy();
|
1929
|
+
};
|
1930
|
+
|
1730
1931
|
this.throwError = function(something) {
|
1731
1932
|
var error = (something instanceof Error) ? something : new Error(something);
|
1732
1933
|
plan = function() {
|
@@ -1758,9 +1959,13 @@ getJasmineRequireObj().Suite = function() {
|
|
1758
1959
|
this.onStart = attrs.onStart || function() {};
|
1759
1960
|
this.resultCallback = attrs.resultCallback || function() {};
|
1760
1961
|
this.clearStack = attrs.clearStack || function(fn) {fn();};
|
1962
|
+
this.expectationFactory = attrs.expectationFactory;
|
1963
|
+
this.expectationResultFactory = attrs.expectationResultFactory;
|
1761
1964
|
|
1762
1965
|
this.beforeFns = [];
|
1763
1966
|
this.afterFns = [];
|
1967
|
+
this.beforeAllFns = [];
|
1968
|
+
this.afterAllFns = [];
|
1764
1969
|
this.queueRunner = attrs.queueRunner || function() {};
|
1765
1970
|
this.disabled = false;
|
1766
1971
|
|
@@ -1768,12 +1973,16 @@ getJasmineRequireObj().Suite = function() {
|
|
1768
1973
|
|
1769
1974
|
this.result = {
|
1770
1975
|
id: this.id,
|
1771
|
-
status: this.disabled ? 'disabled' : '',
|
1772
1976
|
description: this.description,
|
1773
|
-
fullName: this.getFullName()
|
1977
|
+
fullName: this.getFullName(),
|
1978
|
+
failedExpectations: []
|
1774
1979
|
};
|
1775
1980
|
}
|
1776
1981
|
|
1982
|
+
Suite.prototype.expect = function(actual) {
|
1983
|
+
return this.expectationFactory(actual, this);
|
1984
|
+
};
|
1985
|
+
|
1777
1986
|
Suite.prototype.getFullName = function() {
|
1778
1987
|
var fullName = this.description;
|
1779
1988
|
for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
|
@@ -1786,21 +1995,40 @@ getJasmineRequireObj().Suite = function() {
|
|
1786
1995
|
|
1787
1996
|
Suite.prototype.disable = function() {
|
1788
1997
|
this.disabled = true;
|
1789
|
-
this.result.status = 'disabled';
|
1790
1998
|
};
|
1791
1999
|
|
1792
2000
|
Suite.prototype.beforeEach = function(fn) {
|
1793
2001
|
this.beforeFns.unshift(fn);
|
1794
2002
|
};
|
1795
2003
|
|
2004
|
+
Suite.prototype.beforeAll = function(fn) {
|
2005
|
+
this.beforeAllFns.push(fn);
|
2006
|
+
};
|
2007
|
+
|
1796
2008
|
Suite.prototype.afterEach = function(fn) {
|
1797
2009
|
this.afterFns.unshift(fn);
|
1798
2010
|
};
|
1799
2011
|
|
2012
|
+
Suite.prototype.afterAll = function(fn) {
|
2013
|
+
this.afterAllFns.push(fn);
|
2014
|
+
};
|
2015
|
+
|
1800
2016
|
Suite.prototype.addChild = function(child) {
|
1801
2017
|
this.children.push(child);
|
1802
2018
|
};
|
1803
2019
|
|
2020
|
+
Suite.prototype.status = function() {
|
2021
|
+
if (this.disabled) {
|
2022
|
+
return 'disabled';
|
2023
|
+
}
|
2024
|
+
|
2025
|
+
if (this.result.failedExpectations.length > 0) {
|
2026
|
+
return 'failed';
|
2027
|
+
} else {
|
2028
|
+
return 'finished';
|
2029
|
+
}
|
2030
|
+
};
|
2031
|
+
|
1804
2032
|
Suite.prototype.execute = function(onComplete) {
|
1805
2033
|
var self = this;
|
1806
2034
|
|
@@ -1813,16 +2041,25 @@ getJasmineRequireObj().Suite = function() {
|
|
1813
2041
|
|
1814
2042
|
var allFns = [];
|
1815
2043
|
|
1816
|
-
|
1817
|
-
allFns.
|
2044
|
+
if (this.isExecutable()) {
|
2045
|
+
allFns = allFns.concat(this.beforeAllFns);
|
2046
|
+
|
2047
|
+
for (var i = 0; i < this.children.length; i++) {
|
2048
|
+
allFns.push(wrapChildAsAsync(this.children[i]));
|
2049
|
+
}
|
2050
|
+
|
2051
|
+
allFns = allFns.concat(this.afterAllFns);
|
1818
2052
|
}
|
1819
2053
|
|
1820
2054
|
this.queueRunner({
|
1821
|
-
|
1822
|
-
onComplete: complete
|
2055
|
+
queueableFns: allFns,
|
2056
|
+
onComplete: complete,
|
2057
|
+
userContext: this.sharedUserContext(),
|
2058
|
+
onException: function() { self.onException.apply(self, arguments); }
|
1823
2059
|
});
|
1824
2060
|
|
1825
2061
|
function complete() {
|
2062
|
+
self.result.status = self.status();
|
1826
2063
|
self.resultCallback(self.result);
|
1827
2064
|
|
1828
2065
|
if (onComplete) {
|
@@ -1831,10 +2068,82 @@ getJasmineRequireObj().Suite = function() {
|
|
1831
2068
|
}
|
1832
2069
|
|
1833
2070
|
function wrapChildAsAsync(child) {
|
1834
|
-
return function(done) { child.execute(done); };
|
2071
|
+
return { fn: function(done) { child.execute(done); } };
|
2072
|
+
}
|
2073
|
+
};
|
2074
|
+
|
2075
|
+
Suite.prototype.isExecutable = function() {
|
2076
|
+
var foundActive = false;
|
2077
|
+
for(var i = 0; i < this.children.length; i++) {
|
2078
|
+
if(this.children[i].isExecutable()) {
|
2079
|
+
foundActive = true;
|
2080
|
+
break;
|
2081
|
+
}
|
2082
|
+
}
|
2083
|
+
return foundActive;
|
2084
|
+
};
|
2085
|
+
|
2086
|
+
Suite.prototype.sharedUserContext = function() {
|
2087
|
+
if (!this.sharedContext) {
|
2088
|
+
this.sharedContext = this.parentSuite ? clone(this.parentSuite.sharedUserContext()) : {};
|
1835
2089
|
}
|
2090
|
+
|
2091
|
+
return this.sharedContext;
|
2092
|
+
};
|
2093
|
+
|
2094
|
+
Suite.prototype.clonedSharedUserContext = function() {
|
2095
|
+
return clone(this.sharedUserContext());
|
1836
2096
|
};
|
1837
2097
|
|
2098
|
+
Suite.prototype.onException = function() {
|
2099
|
+
if(isAfterAll(this.children)) {
|
2100
|
+
var data = {
|
2101
|
+
matcherName: '',
|
2102
|
+
passed: false,
|
2103
|
+
expected: '',
|
2104
|
+
actual: '',
|
2105
|
+
error: arguments[0]
|
2106
|
+
};
|
2107
|
+
this.result.failedExpectations.push(this.expectationResultFactory(data));
|
2108
|
+
} else {
|
2109
|
+
for (var i = 0; i < this.children.length; i++) {
|
2110
|
+
var child = this.children[i];
|
2111
|
+
child.onException.apply(child, arguments);
|
2112
|
+
}
|
2113
|
+
}
|
2114
|
+
};
|
2115
|
+
|
2116
|
+
Suite.prototype.addExpectationResult = function () {
|
2117
|
+
if(isAfterAll(this.children) && isFailure(arguments)){
|
2118
|
+
var data = arguments[1];
|
2119
|
+
this.result.failedExpectations.push(this.expectationResultFactory(data));
|
2120
|
+
} else {
|
2121
|
+
for (var i = 0; i < this.children.length; i++) {
|
2122
|
+
var child = this.children[i];
|
2123
|
+
child.addExpectationResult.apply(child, arguments);
|
2124
|
+
}
|
2125
|
+
}
|
2126
|
+
};
|
2127
|
+
|
2128
|
+
function isAfterAll(children) {
|
2129
|
+
return children && children[0].result.status;
|
2130
|
+
}
|
2131
|
+
|
2132
|
+
function isFailure(args) {
|
2133
|
+
return !args[0];
|
2134
|
+
}
|
2135
|
+
|
2136
|
+
function clone(obj) {
|
2137
|
+
var clonedObj = {};
|
2138
|
+
for (var prop in obj) {
|
2139
|
+
if (obj.hasOwnProperty(prop)) {
|
2140
|
+
clonedObj[prop] = obj[prop];
|
2141
|
+
}
|
2142
|
+
}
|
2143
|
+
|
2144
|
+
return clonedObj;
|
2145
|
+
}
|
2146
|
+
|
1838
2147
|
return Suite;
|
1839
2148
|
};
|
1840
2149
|
|
@@ -1878,7 +2187,9 @@ getJasmineRequireObj().matchersUtil = function(j$) {
|
|
1878
2187
|
contains: function(haystack, needle, customTesters) {
|
1879
2188
|
customTesters = customTesters || [];
|
1880
2189
|
|
1881
|
-
if (Object.prototype.toString.apply(haystack) === '[object Array]')
|
2190
|
+
if ((Object.prototype.toString.apply(haystack) === '[object Array]') ||
|
2191
|
+
(!!haystack && !haystack.indexOf))
|
2192
|
+
{
|
1882
2193
|
for (var i = 0; i < haystack.length; i++) {
|
1883
2194
|
if (eq(haystack[i], needle, [], [], customTesters)) {
|
1884
2195
|
return true;
|
@@ -1886,6 +2197,7 @@ getJasmineRequireObj().matchersUtil = function(j$) {
|
|
1886
2197
|
}
|
1887
2198
|
return false;
|
1888
2199
|
}
|
2200
|
+
|
1889
2201
|
return !!haystack && haystack.indexOf(needle) >= 0;
|
1890
2202
|
},
|
1891
2203
|
|
@@ -2378,18 +2690,13 @@ getJasmineRequireObj().toThrowError = function(j$) {
|
|
2378
2690
|
var threw = false,
|
2379
2691
|
pass = {pass: true},
|
2380
2692
|
fail = {pass: false},
|
2381
|
-
thrown
|
2382
|
-
errorType,
|
2383
|
-
message,
|
2384
|
-
regexp,
|
2385
|
-
name,
|
2386
|
-
constructorName;
|
2693
|
+
thrown;
|
2387
2694
|
|
2388
2695
|
if (typeof actual != 'function') {
|
2389
2696
|
throw new Error('Actual is not a Function');
|
2390
2697
|
}
|
2391
2698
|
|
2392
|
-
|
2699
|
+
var errorMatcher = getMatcher.apply(null, arguments);
|
2393
2700
|
|
2394
2701
|
try {
|
2395
2702
|
actual();
|
@@ -2408,121 +2715,108 @@ getJasmineRequireObj().toThrowError = function(j$) {
|
|
2408
2715
|
return fail;
|
2409
2716
|
}
|
2410
2717
|
|
2411
|
-
if (
|
2718
|
+
if (errorMatcher.hasNoSpecifics()) {
|
2412
2719
|
pass.message = 'Expected function not to throw an Error, but it threw ' + fnNameFor(thrown) + '.';
|
2413
2720
|
return pass;
|
2414
2721
|
}
|
2415
2722
|
|
2416
|
-
if (
|
2417
|
-
|
2418
|
-
|
2723
|
+
if (errorMatcher.matches(thrown)) {
|
2724
|
+
pass.message = function() {
|
2725
|
+
return 'Expected function not to throw ' + errorMatcher.errorTypeDescription + errorMatcher.messageDescription() + '.';
|
2726
|
+
};
|
2727
|
+
return pass;
|
2728
|
+
} else {
|
2729
|
+
fail.message = function() {
|
2730
|
+
return 'Expected function to throw ' + errorMatcher.errorTypeDescription + errorMatcher.messageDescription() +
|
2731
|
+
', but it threw ' + errorMatcher.thrownDescription(thrown) + '.';
|
2732
|
+
};
|
2733
|
+
return fail;
|
2419
2734
|
}
|
2735
|
+
}
|
2736
|
+
};
|
2420
2737
|
|
2421
|
-
|
2422
|
-
|
2423
|
-
|
2424
|
-
return pass;
|
2425
|
-
} else {
|
2426
|
-
fail.message = function() { return 'Expected function to throw ' + name + ' with message ' + j$.pp(message) +
|
2427
|
-
', but it threw ' + constructorName + ' with message ' + j$.pp(thrown.message) + '.'; };
|
2428
|
-
return fail;
|
2429
|
-
}
|
2430
|
-
}
|
2738
|
+
function getMatcher() {
|
2739
|
+
var expected = null,
|
2740
|
+
errorType = null;
|
2431
2741
|
|
2432
|
-
|
2433
|
-
|
2434
|
-
|
2435
|
-
|
2436
|
-
|
2437
|
-
fail.message = function() { return 'Expected function to throw ' + name + ' with message matching ' + j$.pp(regexp) +
|
2438
|
-
', but it threw ' + constructorName + ' with message ' + j$.pp(thrown.message) + '.'; };
|
2439
|
-
return fail;
|
2440
|
-
}
|
2742
|
+
if (arguments.length == 2) {
|
2743
|
+
expected = arguments[1];
|
2744
|
+
if (isAnErrorType(expected)) {
|
2745
|
+
errorType = expected;
|
2746
|
+
expected = null;
|
2441
2747
|
}
|
2442
|
-
|
2443
|
-
|
2444
|
-
|
2445
|
-
|
2446
|
-
|
2447
|
-
} else {
|
2448
|
-
fail.message = 'Expected function to throw ' + name + ', but it threw ' + constructorName + '.';
|
2449
|
-
return fail;
|
2450
|
-
}
|
2748
|
+
} else if (arguments.length > 2) {
|
2749
|
+
errorType = arguments[1];
|
2750
|
+
expected = arguments[2];
|
2751
|
+
if (!isAnErrorType(errorType)) {
|
2752
|
+
throw new Error('Expected error type is not an Error.');
|
2451
2753
|
}
|
2754
|
+
}
|
2452
2755
|
|
2453
|
-
|
2454
|
-
|
2455
|
-
|
2456
|
-
|
2457
|
-
|
2458
|
-
fail.message = function() { return 'Expected function to throw an exception with message ' + j$.pp(message) +
|
2459
|
-
', but it threw an exception with message ' + j$.pp(thrown.message) + '.'; };
|
2460
|
-
return fail;
|
2461
|
-
}
|
2756
|
+
if (expected && !isStringOrRegExp(expected)) {
|
2757
|
+
if (errorType) {
|
2758
|
+
throw new Error('Expected error message is not a string or RegExp.');
|
2759
|
+
} else {
|
2760
|
+
throw new Error('Expected is not an Error, string, or RegExp.');
|
2462
2761
|
}
|
2762
|
+
}
|
2463
2763
|
|
2464
|
-
|
2465
|
-
|
2466
|
-
|
2467
|
-
|
2468
|
-
|
2469
|
-
fail.message = function() { return 'Expected function to throw an exception with a message matching ' + j$.pp(regexp) +
|
2470
|
-
', but it threw an exception with message ' + j$.pp(thrown.message) + '.'; };
|
2471
|
-
return fail;
|
2472
|
-
}
|
2764
|
+
function messageMatch(message) {
|
2765
|
+
if (typeof expected == 'string') {
|
2766
|
+
return expected == message;
|
2767
|
+
} else {
|
2768
|
+
return expected.test(message);
|
2473
2769
|
}
|
2770
|
+
}
|
2474
2771
|
|
2475
|
-
|
2476
|
-
|
2477
|
-
|
2772
|
+
return {
|
2773
|
+
errorTypeDescription: errorType ? fnNameFor(errorType) : 'an exception',
|
2774
|
+
thrownDescription: function(thrown) {
|
2775
|
+
var thrownName = errorType ? fnNameFor(thrown.constructor) : 'an exception',
|
2776
|
+
thrownMessage = '';
|
2478
2777
|
|
2479
|
-
|
2480
|
-
|
2481
|
-
return;
|
2778
|
+
if (expected) {
|
2779
|
+
thrownMessage = ' with message ' + j$.pp(thrown.message);
|
2482
2780
|
}
|
2483
2781
|
|
2484
|
-
|
2485
|
-
|
2486
|
-
|
2487
|
-
|
2488
|
-
|
2489
|
-
|
2490
|
-
|
2491
|
-
} else if (checkForAnErrorType(expected)) {
|
2492
|
-
errorType = expected;
|
2493
|
-
}
|
2494
|
-
|
2495
|
-
if (!(errorType || message || regexp)) {
|
2496
|
-
throw new Error('Expected is not an Error, string, or RegExp.');
|
2497
|
-
}
|
2782
|
+
return thrownName + thrownMessage;
|
2783
|
+
},
|
2784
|
+
messageDescription: function() {
|
2785
|
+
if (expected === null) {
|
2786
|
+
return '';
|
2787
|
+
} else if (expected instanceof RegExp) {
|
2788
|
+
return ' with a message matching ' + j$.pp(expected);
|
2498
2789
|
} else {
|
2499
|
-
|
2500
|
-
errorType = arguments[1];
|
2501
|
-
} else {
|
2502
|
-
throw new Error('Expected error type is not an Error.');
|
2503
|
-
}
|
2504
|
-
|
2505
|
-
if (arguments[2] instanceof RegExp) {
|
2506
|
-
regexp = arguments[2];
|
2507
|
-
} else if (typeof arguments[2] == 'string') {
|
2508
|
-
message = arguments[2];
|
2509
|
-
} else {
|
2510
|
-
throw new Error('Expected error message is not a string or RegExp.');
|
2511
|
-
}
|
2790
|
+
return ' with message ' + j$.pp(expected);
|
2512
2791
|
}
|
2792
|
+
},
|
2793
|
+
hasNoSpecifics: function() {
|
2794
|
+
return expected === null && errorType === null;
|
2795
|
+
},
|
2796
|
+
matches: function(error) {
|
2797
|
+
return (errorType === null || error.constructor === errorType) &&
|
2798
|
+
(expected === null || messageMatch(error.message));
|
2513
2799
|
}
|
2800
|
+
};
|
2801
|
+
}
|
2514
2802
|
|
2515
|
-
|
2516
|
-
|
2517
|
-
|
2518
|
-
}
|
2803
|
+
function fnNameFor(func) {
|
2804
|
+
return func.name || func.toString().match(/^\s*function\s*(\w*)\s*\(/)[1];
|
2805
|
+
}
|
2519
2806
|
|
2520
|
-
|
2521
|
-
|
2522
|
-
|
2523
|
-
|
2807
|
+
function isStringOrRegExp(potential) {
|
2808
|
+
return potential instanceof RegExp || (typeof potential == 'string');
|
2809
|
+
}
|
2810
|
+
|
2811
|
+
function isAnErrorType(type) {
|
2812
|
+
if (typeof type !== 'function') {
|
2813
|
+
return false;
|
2524
2814
|
}
|
2525
|
-
|
2815
|
+
|
2816
|
+
var Surrogate = function() {};
|
2817
|
+
Surrogate.prototype = type.prototype;
|
2818
|
+
return (new Surrogate()) instanceof Error;
|
2819
|
+
}
|
2526
2820
|
}
|
2527
2821
|
|
2528
2822
|
return toThrowError;
|
@@ -2538,6 +2832,10 @@ getJasmineRequireObj().interface = function(jasmine, env) {
|
|
2538
2832
|
return env.xdescribe(description, specDefinitions);
|
2539
2833
|
},
|
2540
2834
|
|
2835
|
+
fdescribe: function(description, specDefinitions) {
|
2836
|
+
return env.fdescribe(description, specDefinitions);
|
2837
|
+
},
|
2838
|
+
|
2541
2839
|
it: function(desc, func) {
|
2542
2840
|
return env.it(desc, func);
|
2543
2841
|
},
|
@@ -2546,6 +2844,10 @@ getJasmineRequireObj().interface = function(jasmine, env) {
|
|
2546
2844
|
return env.xit(desc, func);
|
2547
2845
|
},
|
2548
2846
|
|
2847
|
+
fit: function(desc, func) {
|
2848
|
+
return env.fit(desc, func);
|
2849
|
+
},
|
2850
|
+
|
2549
2851
|
beforeEach: function(beforeEachFunction) {
|
2550
2852
|
return env.beforeEach(beforeEachFunction);
|
2551
2853
|
},
|
@@ -2554,6 +2856,14 @@ getJasmineRequireObj().interface = function(jasmine, env) {
|
|
2554
2856
|
return env.afterEach(afterEachFunction);
|
2555
2857
|
},
|
2556
2858
|
|
2859
|
+
beforeAll: function(beforeAllFunction) {
|
2860
|
+
return env.beforeAll(beforeAllFunction);
|
2861
|
+
},
|
2862
|
+
|
2863
|
+
afterAll: function(afterAllFunction) {
|
2864
|
+
return env.afterAll(afterAllFunction);
|
2865
|
+
},
|
2866
|
+
|
2557
2867
|
expect: function(actual) {
|
2558
2868
|
return env.expect(actual);
|
2559
2869
|
},
|
@@ -2562,6 +2872,10 @@ getJasmineRequireObj().interface = function(jasmine, env) {
|
|
2562
2872
|
return env.pending();
|
2563
2873
|
},
|
2564
2874
|
|
2875
|
+
fail: function() {
|
2876
|
+
return env.fail.apply(env, arguments);
|
2877
|
+
},
|
2878
|
+
|
2565
2879
|
spyOn: function(obj, methodName) {
|
2566
2880
|
return env.spyOn(obj, methodName);
|
2567
2881
|
},
|
@@ -2589,5 +2903,5 @@ getJasmineRequireObj().interface = function(jasmine, env) {
|
|
2589
2903
|
};
|
2590
2904
|
|
2591
2905
|
getJasmineRequireObj().version = function() {
|
2592
|
-
return '2.0
|
2906
|
+
return '2.1.0';
|
2593
2907
|
};
|