|
1 | 1 | "use strict";
|
2 | 2 | var utils_1 = require('./utils');
|
3 | 3 | var createRunner_1 = require('./createRunner');
|
4 |
| -function runner(files, config, handleTestResult, handleLog) { |
| 4 | +var path = require('path'); |
| 5 | +function runner(files, config, handleResult, handleLog) { |
| 6 | + files = files.map(function (subArray) { |
| 7 | + return subArray.map(function (test) { |
| 8 | + return path.join(config.tutorialDir, test); |
| 9 | + }); |
| 10 | + }); |
5 | 11 | var tests = utils_1.concatAll(files);
|
6 | 12 | var runner = createRunner_1.createRunner(config, tests);
|
7 |
| - runner.stdout.on('data', function (data) { |
8 |
| - var result = { |
9 |
| - pass: false, |
10 |
| - position: 0, |
11 |
| - failedAt: null, |
12 |
| - failure: null |
13 |
| - }; |
14 |
| - var signalMatch = new RegExp(utils_1.signal); |
15 |
| - var match = signalMatch.exec(data); |
16 |
| - if (!!match) { |
17 |
| - var printed = data.toString().substring(0, match.index); |
18 |
| - if (!!printed.length) { |
19 |
| - var start = printed.substring(0, printed.length / 2); |
20 |
| - var end = printed.substring(printed.length / 2, printed.length); |
21 |
| - var message = ''; |
22 |
| - if (start === end) { |
23 |
| - message = start; |
| 13 | + var result = { |
| 14 | + pass: false, |
| 15 | + taskPosition: 0, |
| 16 | + failedAtFile: null, |
| 17 | + msg: null |
| 18 | + }; |
| 19 | + return new Promise(function (resolve, reject) { |
| 20 | + runner.stdout.on('data', function (data) { |
| 21 | + var signalMatch = new RegExp(utils_1.signal); |
| 22 | + var match = signalMatch.exec(data); |
| 23 | + if (!!match) { |
| 24 | + var printed = data.toString().substring(0, match.index); |
| 25 | + if (!!printed.length) { |
| 26 | + var start = printed.substring(0, printed.length / 2); |
| 27 | + var end = printed.substring(printed.length / 2, printed.length); |
| 28 | + var message = ''; |
| 29 | + if (start === end) { |
| 30 | + message = start; |
| 31 | + } |
| 32 | + else { |
| 33 | + message = printed; |
| 34 | + } |
| 35 | + handleLog(message); |
| 36 | + } |
| 37 | + var testResultString = data.toString().substring(match.index + utils_1.signal.length); |
| 38 | + var testResult = JSON.parse(JSON.stringify(testResultString)); |
| 39 | + if (typeof testResult === 'string') { |
| 40 | + testResult = JSON.parse(testResult); |
| 41 | + } |
| 42 | + if (testResult.failedAtFile) { |
| 43 | + result.pass = false; |
| 44 | + result.taskPosition = findFailureTestPosition(files, testResult.failedAtFile); |
| 45 | + result.msg = testResult.failures[0].msg; |
| 46 | + result.failedAtFile = testResult.failedAtFile; |
24 | 47 | }
|
25 | 48 | else {
|
26 |
| - message = printed; |
| 49 | + result.pass = true; |
| 50 | + result.taskPosition = files.length; |
| 51 | + result.msg = testResult.passes[testResult.passes.length - 1].msg; |
27 | 52 | }
|
28 |
| - handleLog(message); |
29 | 53 | }
|
30 |
| - var testResultString = data.toString().substring(match.index + 22); |
31 |
| - var testResult = JSON.parse(testResultString); |
32 |
| - if (!testResult.failed) { |
33 |
| - result.pass = false; |
34 |
| - result.failure = testResult.failures[0]; |
35 |
| - result.position = findFailureTestPosition(files, testResult.failedAt); |
| 54 | + else { |
| 55 | + console.log('Result test data doesn\'t match signal string', data.toString()); |
| 56 | + } |
| 57 | + handleResult(result); |
| 58 | + }); |
| 59 | + runner.stderr.on('data', function (data) { |
| 60 | + console.log('test error', data.toString()); |
| 61 | + }); |
| 62 | + runner.on('close', function (code) { |
| 63 | + if (code === 0) { |
| 64 | + resolve(result); |
36 | 65 | }
|
37 | 66 | else {
|
38 |
| - result.pass = true; |
39 |
| - result.position = files.length; |
| 67 | + resolve(result); |
40 | 68 | }
|
41 |
| - } |
42 |
| - else { |
43 |
| - console.log('Error with test', data); |
44 |
| - } |
45 |
| - handleTestResult(result); |
46 |
| - }); |
47 |
| - runner.stderr.on('error', function (data) { |
48 |
| - console.log('test error', data); |
49 |
| - }); |
50 |
| - runner.on('close', function (code) { |
51 |
| - if (code === 1) { |
52 |
| - console.error('Error running test'); |
53 |
| - } |
| 69 | + }); |
54 | 70 | });
|
55 | 71 | }
|
56 |
| -Object.defineProperty(exports, "__esModule", { value: true }); |
57 |
| -exports.default = runner; |
| 72 | +exports.runner = runner; |
58 | 73 | function findFailureTestPosition(files, file) {
|
59 | 74 | for (var i = 0; i < files.length; i++) {
|
60 | 75 | if (files[i].indexOf(file) > -1) {
|
|
0 commit comments