appium-doctor
Version:
Test environment for fitness to run Appium
440 lines (365 loc) • 45.1 kB
JavaScript
require('source-map-support').install();
;
var _Promise = require('babel-runtime/core-js/promise')['default'];
var _regeneratorRuntime = require('babel-runtime/regenerator')['default'];
var _interopRequireDefault = require('babel-runtime/helpers/interop-require-default')['default'];
var _this = this;
var _libDoctor = require('../lib/doctor');
var _chai = require('chai');
var _chai2 = _interopRequireDefault(_chai);
var _appiumTestSupport = require('appium-test-support');
var _libLogger = require('../lib/logger');
var _libLogger2 = _interopRequireDefault(_libLogger);
_chai2['default'].should();
var P = _Promise;
describe('doctor', function () {
it('register', function () {
var doctor = new _libDoctor.Doctor();
doctor.checks.should.have.length(0);
doctor.register(new _libDoctor.DoctorCheck());
doctor.checks.should.have.length(1);
doctor.register([new _libDoctor.DoctorCheck(), new _libDoctor.DoctorCheck()]);
doctor.checks.should.have.length(3);
});
function configure() {
var doctor = new _libDoctor.Doctor();
var checks = [new _libDoctor.DoctorCheck(), new _libDoctor.DoctorCheck(), new _libDoctor.DoctorCheck()];
doctor.register(checks);
return { doctor: doctor, checks: checks };
}
describe('diagnose', (0, _appiumTestSupport.withMocks)({}, function (mocks, S) {
it('should detect all issues', function callee$2$0() {
var logStub, _configure, doctor, checks;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
_configure = configure();
doctor = _configure.doctor;
checks = _configure.checks;
mocks.checks = checks.map(function (check) {
return S.sandbox.mock(check);
});
mocks.checks[0].expects('diagnose').once().returns({ ok: true, message: "All Good!" });
mocks.checks[1].expects('diagnose').once().returns({ ok: false, message: "Oh No!" });
mocks.checks[2].expects('diagnose').once().returns({ ok: false, message: "Oh No!" });
context$3$0.next = 10;
return _regeneratorRuntime.awrap(doctor.diagnose());
case 10:
(0, _appiumTestSupport.verify)(mocks);
doctor.toFix.should.have.length(2);
logStub.output.should.equal(['info: ### Diagnostic starting ###', 'info: ✔ All Good!', 'warn: ✖ Oh No!', 'warn: ✖ Oh No!', 'info: ### Diagnostic completed, 2 fixes needed. ###', 'info: '].join('\n'));
case 13:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
describe('reportSuccess', (0, _appiumTestSupport.withMocks)({}, function (mocks, S) {
var doctor = new _libDoctor.Doctor();
it('should report success when no fixes are needed', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
doctor.toFix = [];
context$3$0.next = 4;
return _regeneratorRuntime.awrap(doctor.reportSuccess());
case 4:
context$3$0.sent.should.equal(true);
logStub.output.should.equal(['info: Everything looks good, bye!', 'info: '].join('\n'));
case 6:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('should return false when fixes are needed', function callee$2$0() {
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
doctor.toFix = [{}];
context$3$0.next = 3;
return _regeneratorRuntime.awrap(doctor.reportSuccess());
case 3:
context$3$0.sent.should.equal(false);
case 4:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
describe('reportManualFixes', (0, _appiumTestSupport.withMocks)({}, function (mocks, S) {
var doctor = new _libDoctor.Doctor();
it('should ask for manual fixes to be applied', function callee$2$0() {
var logStub, i, m;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
doctor.toFix = [{ error: 'Oh no this need to be manually fixed.', check: new _libDoctor.DoctorCheck() }, { error: 'Oh no this is an autofix.', check: new _libDoctor.DoctorCheck({ autofix: true }) }, { error: 'Oh no this also need to be manually fixed.', check: new _libDoctor.DoctorCheck() }, { error: 'Oh no this also need to be manually fixed.', check: new _libDoctor.DoctorCheck() }];
for (i = 0; i < doctor.toFix.length; i++) {
m = S.sandbox.mock(doctor.toFix[i].check);
if (doctor.toFix[i].check.autofix) {
m.expects('fix').never();
} else {
m.expects('fix').once().returns(P.resolve('Manual fix for ' + i + ' is do something.'));
}
}
context$3$0.next = 5;
return _regeneratorRuntime.awrap(doctor.reportManualFixes());
case 5:
context$3$0.sent.should.equal(true);
(0, _appiumTestSupport.verify)(mocks);
logStub.output.should.equal(['info: ### Manual Fixes Needed ###', 'info: The configuration cannot be automatically fixed, please do the following first:', 'warn: - Manual fix for 0 is do something.', 'warn: - Manual fix for 2 is do something.', 'warn: - Manual fix for 3 is do something.', 'info: ###', 'info: ', 'info: Bye! Run appium-doctor again when all manual fixes have been applied!', 'info: '].join('\n'));
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('should return false when there is no manual fix', function callee$2$0() {
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
doctor.toFix = [{ error: 'Oh no!', check: new _libDoctor.DoctorCheck({ autofix: true }) }];
context$3$0.next = 3;
return _regeneratorRuntime.awrap(doctor.reportManualFixes());
case 3:
context$3$0.sent.should.equal(false);
case 4:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
describe('runAutoFix', (0, _appiumTestSupport.withMocks)({}, function (mocks, S) {
var doctor = new _libDoctor.Doctor();
var fix = {
error: 'Something wrong!',
check: {
fix: function fix() {},
diagnose: function diagnose() {}
}
};
it('fix - success', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
mocks.check = S.sandbox.mock(fix.check);
mocks.check.expects('fix').once();
mocks.check.expects('diagnose').once().returns(P.resolve({
ok: true, message: 'It worked' }));
context$3$0.next = 6;
return _regeneratorRuntime.awrap(doctor.runAutoFix(fix));
case 6:
(0, _appiumTestSupport.verify)(mocks);
logStub.output.should.equal(['info: ### Fixing: Something wrong! ###', 'info: Checking if this was fixed:', 'info: ✔ It worked', 'info: ### Fix was successfully applied ###'].join('\n'));
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('fix - skipped', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
mocks.check = S.sandbox.mock(fix.check);
mocks.check.expects('fix').once().throws(new _libDoctor.FixSkippedError());
context$3$0.next = 5;
return _regeneratorRuntime.awrap(doctor.runAutoFix(fix));
case 5:
(0, _appiumTestSupport.verify)(mocks);
logStub.output.should.equal(['info: ### Fixing: Something wrong! ###', 'info: ### Skipped fix ###'].join('\n'));
case 7:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('fix - crash', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
mocks.check = S.sandbox.mock(fix.check);
mocks.check.expects('fix').once().throws(new Error('Oh No!'));
context$3$0.next = 5;
return _regeneratorRuntime.awrap(doctor.runAutoFix(fix));
case 5:
(0, _appiumTestSupport.verify)(mocks);
logStub.output.should.equal(['info: ### Fixing: Something wrong! ###', 'warn: Error: Oh No!', 'info: ### Fix did not succeed ###'].join('\n'));
case 7:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('fix - didn\'t fix', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
mocks.check = S.sandbox.mock(fix.check);
mocks.check.expects('fix').once();
mocks.check.expects('diagnose').once().returns(P.resolve({
ok: false, message: 'Still Weird!' }));
context$3$0.next = 6;
return _regeneratorRuntime.awrap(doctor.runAutoFix(fix));
case 6:
(0, _appiumTestSupport.verify)(mocks);
logStub.output.should.equal(['info: ### Fixing: Something wrong! ###', 'info: Checking if this was fixed:', 'info: ✖ Still Weird!', 'info: ### Fix was applied but issue remains ###'].join('\n'));
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
describe('runAutoFixes', (0, _appiumTestSupport.withSandbox)({}, function (S) {
var doctor = new _libDoctor.Doctor();
it('success', function callee$2$0() {
var logStub;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
doctor.toFix = [{ error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }, { error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }, { error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }];
S.sandbox.stub(doctor, 'runAutoFix', function (f) {
_libLogger2['default'].info('Autofix log go there.');
f.fixed = true;
});
context$3$0.next = 5;
return _regeneratorRuntime.awrap(doctor.runAutoFixes());
case 5:
doctor.runAutoFix.calledThrice.should.be.ok;
logStub.output.should.equal(['info: Autofix log go there.', 'info: ', 'info: Autofix log go there.', 'info: ', 'info: Autofix log go there.', 'info: ', 'info: Bye! All issues have been fixed!', 'info: '].join('\n'));
case 7:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('failure', function callee$2$0() {
var logStub, succeed;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
logStub = (0, _appiumTestSupport.stubLog)(S.sandbox, _libLogger2['default'], { stripColors: true });
doctor.toFix = [{ error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }, { error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }, { error: 'Oh no.', check: new _libDoctor.DoctorCheck({ autofix: true }) }];
succeed = false;
S.sandbox.stub(doctor, 'runAutoFix', function (f) {
if (succeed) {
_libLogger2['default'].info('succeeded, Autofix log go there.');
f.fixed = true;
} else {
_libLogger2['default'].warn('failed, Autofix log go there.');
}
succeed = !succeed;
});
context$3$0.next = 6;
return _regeneratorRuntime.awrap(doctor.runAutoFixes());
case 6:
doctor.runAutoFix.calledThrice.should.be.ok;
logStub.output.should.equal(['warn: failed, Autofix log go there.', 'info: ', 'info: succeeded, Autofix log go there.', 'info: ', 'warn: failed, Autofix log go there.', 'info: ', 'info: Bye! A few issues remain, fix manually and/or rerun appium-doctor!', 'info: '].join('\n'));
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
describe('run', (0, _appiumTestSupport.withMocks)({}, function (mocks, S) {
var doctor = new _libDoctor.Doctor();
it('should work', function callee$2$0() {
var _doctor;
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
context$3$0.prev = 0;
_doctor = new _libDoctor.Doctor();
context$3$0.next = 4;
return _regeneratorRuntime.awrap(_doctor.run());
case 4:
context$3$0.next = 8;
break;
case 6:
context$3$0.prev = 6;
context$3$0.t0 = context$3$0['catch'](0);
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this, [[0, 6]]);
});
it('should report success', function callee$2$0() {
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
mocks.doctor = S.sandbox.mock(doctor);
mocks.doctor.expects('diagnose').once();
mocks.doctor.expects('reportSuccess').once().returns(true);
mocks.doctor.expects('reportManualFixes').never();
mocks.doctor.expects('runAutoFixes').never();
context$3$0.next = 7;
return _regeneratorRuntime.awrap(doctor.run());
case 7:
(0, _appiumTestSupport.verify)(mocks);
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('should report manual fixes', function callee$2$0() {
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
mocks.doctor = S.sandbox.mock(doctor);
mocks.doctor.expects('diagnose').once();
mocks.doctor.expects('reportSuccess').once().returns(false);
mocks.doctor.expects('reportManualFixes').once().returns(true);
mocks.doctor.expects('runAutoFixes').never();
context$3$0.next = 7;
return _regeneratorRuntime.awrap(doctor.run());
case 7:
(0, _appiumTestSupport.verify)(mocks);
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
it('should run autofixes', function callee$2$0() {
return _regeneratorRuntime.async(function callee$2$0$(context$3$0) {
while (1) switch (context$3$0.prev = context$3$0.next) {
case 0:
mocks.doctor = S.sandbox.mock(doctor);
mocks.doctor.expects('diagnose').once();
mocks.doctor.expects('reportSuccess').once().returns(false);
mocks.doctor.expects('reportManualFixes').once().returns(false);
mocks.doctor.expects('runAutoFixes').once();
context$3$0.next = 7;
return _regeneratorRuntime.awrap(doctor.run());
case 7:
(0, _appiumTestSupport.verify)(mocks);
case 8:
case 'end':
return context$3$0.stop();
}
}, null, _this);
});
}));
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/doctor-specs.js"],"names":[],"mappings":"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","file":"test/doctor-specs.js","sourcesContent":["// transpile:mocha\n\nimport { Doctor, DoctorCheck, FixSkippedError } from '../lib/doctor';\nimport chai from 'chai';\nimport { withSandbox, withMocks, verify, stubLog } from 'appium-test-support';\nimport log from '../lib/logger';\n\nchai.should();\nlet P = Promise;\n\ndescribe('doctor', () => {\n\n  it('register', () => {\n    let doctor = new Doctor();\n    doctor.checks.should.have.length(0);\n    doctor.register(new DoctorCheck());\n    doctor.checks.should.have.length(1);\n    doctor.register([new DoctorCheck(), new DoctorCheck()]);\n    doctor.checks.should.have.length(3);\n  });\n\n  function configure () {\n    let doctor = new Doctor();\n    let checks = [new DoctorCheck(), new DoctorCheck(), new DoctorCheck()];\n    doctor.register(checks);\n    return {doctor, checks};\n  }\n\n  describe('diagnose', withMocks({}, (mocks, S) => {\n    it('should detect all issues', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      let {doctor, checks} = configure();\n      mocks.checks = checks.map((check) => { return S.sandbox.mock(check); });\n      mocks.checks[0].expects('diagnose').once().returns({ok: true, message: \"All Good!\"});\n      mocks.checks[1].expects('diagnose').once().returns({ok: false, message: \"Oh No!\"});\n      mocks.checks[2].expects('diagnose').once().returns({ok: false, message: \"Oh No!\"});\n      await doctor.diagnose();\n      verify(mocks);\n      doctor.toFix.should.have.length(2);\n      logStub.output.should.equal([\n        'info: ### Diagnostic starting ###',\n        'info:  ✔ All Good!',\n        'warn:  ✖ Oh No!',\n        'warn:  ✖ Oh No!',\n        'info: ### Diagnostic completed, 2 fixes needed. ###',\n        'info: '\n      ].join('\\n'));\n    });\n  }));\n\n  describe('reportSuccess', withMocks({}, (mocks, S) => {\n    let doctor = new Doctor();\n    it('should report success when no fixes are needed', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      doctor.toFix = [];\n      (await doctor.reportSuccess()).should.equal(true);\n      logStub.output.should.equal([\n        'info: Everything looks good, bye!',\n        'info: '\n      ].join('\\n'));\n    });\n\n    it('should return false when fixes are needed', async () => {\n      doctor.toFix = [{}];\n      (await doctor.reportSuccess()).should.equal(false);\n    });\n  }));\n\n  describe('reportManualFixes', withMocks({}, (mocks, S) => {\n    let doctor = new Doctor();\n    it('should ask for manual fixes to be applied', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      doctor.toFix = [\n        {error: 'Oh no this need to be manually fixed.', check: new DoctorCheck()},\n        {error: 'Oh no this is an autofix.', check: new DoctorCheck({autofix: true})},\n        {error: 'Oh no this also need to be manually fixed.', check: new DoctorCheck()},\n        {error: 'Oh no this also need to be manually fixed.', check: new DoctorCheck()},\n      ];\n      for (let i=0; i<doctor.toFix.length; i++) {\n        let m = S.sandbox.mock(doctor.toFix[i].check);\n        if (doctor.toFix[i].check.autofix) {\n          m.expects('fix').never();\n        } else {\n          m.expects('fix').once().returns(P.resolve(`Manual fix for ${i} is do something.`));\n        }\n      }\n      (await doctor.reportManualFixes()).should.equal(true);\n      verify(mocks);\n      logStub.output.should.equal([\n        'info: ### Manual Fixes Needed ###',\n        'info: The configuration cannot be automatically fixed, please do the following first:',\n        'warn: - Manual fix for 0 is do something.',\n        'warn: - Manual fix for 2 is do something.',\n        'warn: - Manual fix for 3 is do something.',\n        'info: ###',\n        'info: ',\n        'info: Bye! Run appium-doctor again when all manual fixes have been applied!',\n        'info: '\n      ].join('\\n'));\n    });\n\n    it('should return false when there is no manual fix', async () => {\n      doctor.toFix = [{error: 'Oh no!', check: new DoctorCheck({autofix: true}) }];\n      (await doctor.reportManualFixes()).should.equal(false);\n    });\n  }));\n\n  describe('runAutoFix',  withMocks({}, (mocks, S) => {\n    let doctor = new Doctor();\n    let fix = {\n      error: 'Something wrong!',\n      check: {\n        fix: () => {},\n        diagnose: () => {}\n      }\n    };\n\n    it('fix - success', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      mocks.check = S.sandbox.mock(fix.check);\n      mocks.check.expects('fix').once();\n      mocks.check.expects('diagnose').once().returns(P.resolve({\n        ok: true, message: 'It worked'}));\n      await doctor.runAutoFix(fix);\n      verify(mocks);\n      logStub.output.should.equal([\n        'info: ### Fixing: Something wrong! ###',\n        'info: Checking if this was fixed:',\n        'info:  ✔ It worked',\n        'info: ### Fix was successfully applied ###'\n      ].join('\\n'));\n    });\n\n    it('fix - skipped', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      mocks.check = S.sandbox.mock(fix.check);\n      mocks.check.expects('fix').once().throws(new FixSkippedError());\n      await doctor.runAutoFix(fix);\n      verify(mocks);\n      logStub.output.should.equal([\n        'info: ### Fixing: Something wrong! ###',\n        'info: ### Skipped fix ###',\n      ].join('\\n'));\n    });\n\n    it('fix - crash', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      mocks.check = S.sandbox.mock(fix.check);\n      mocks.check.expects('fix').once().throws(new Error('Oh No!'));\n      await doctor.runAutoFix(fix);\n      verify(mocks);\n      logStub.output.should.equal([\n        'info: ### Fixing: Something wrong! ###',\n        'warn: Error: Oh No!',\n        'info: ### Fix did not succeed ###',\n      ].join('\\n'));\n    });\n\n    it('fix - didn\\'t fix', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      mocks.check = S.sandbox.mock(fix.check);\n      mocks.check.expects('fix').once();\n      mocks.check.expects('diagnose').once().returns(P.resolve({\n        ok: false, message: 'Still Weird!'}));\n      await doctor.runAutoFix(fix);\n      verify(mocks);\n      logStub.output.should.equal([\n        'info: ### Fixing: Something wrong! ###',\n        'info: Checking if this was fixed:',\n        'info:  ✖ Still Weird!',\n        'info: ### Fix was applied but issue remains ###'\n      ].join('\\n'));\n    });\n  }));\n\n  describe('runAutoFixes',  withSandbox({}, (S) => {\n    let doctor = new Doctor();\n    it('success', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      doctor.toFix = [\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n      ];\n      S.sandbox.stub(doctor, 'runAutoFix', (f) => {\n        log.info('Autofix log go there.');\n        f.fixed = true;\n      });\n      await doctor.runAutoFixes();\n      doctor.runAutoFix.calledThrice.should.be.ok;\n      logStub.output.should.equal([\n        'info: Autofix log go there.',\n        'info: ',\n        'info: Autofix log go there.',\n        'info: ',\n        'info: Autofix log go there.',\n        'info: ',\n        'info: Bye! All issues have been fixed!',\n        'info: ',\n      ].join('\\n'));\n    });\n\n    it('failure', async () => {\n      let logStub = stubLog(S.sandbox, log, {stripColors: true});\n      doctor.toFix = [\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n        {error: 'Oh no.', check: new DoctorCheck({autofix: true})},\n      ];\n      let succeed = false;\n      S.sandbox.stub(doctor, 'runAutoFix', (f) => {\n        if (succeed) {\n          log.info('succeeded, Autofix log go there.');\n          f.fixed = true;\n        } else {\n          log.warn('failed, Autofix log go there.');\n        }\n        succeed = !succeed;\n      });\n      await doctor.runAutoFixes();\n      doctor.runAutoFix.calledThrice.should.be.ok;\n      logStub.output.should.equal([\n        'warn: failed, Autofix log go there.',\n        'info: ',\n        'info: succeeded, Autofix log go there.',\n        'info: ',\n        'warn: failed, Autofix log go there.',\n        'info: ',\n        'info: Bye! A few issues remain, fix manually and/or rerun appium-doctor!',\n        'info: ',\n      ].join('\\n'));\n    });\n  }));\n\n  describe('run',  withMocks({}, (mocks, S) => {\n    let doctor = new Doctor();\n    it('should work', async () => {\n      try {\n        let doctor = new Doctor();\n        await doctor.run();\n      } catch (err) {\n      }\n    });\n    it('should report success', async () => {\n      mocks.doctor = S.sandbox.mock(doctor);\n      mocks.doctor.expects('diagnose').once();\n      mocks.doctor.expects('reportSuccess').once().returns(true);\n      mocks.doctor.expects('reportManualFixes').never();\n      mocks.doctor.expects('runAutoFixes').never();\n      await doctor.run();\n      verify(mocks);\n    });\n    it('should report manual fixes', async () => {\n      mocks.doctor = S.sandbox.mock(doctor);\n      mocks.doctor.expects('diagnose').once();\n      mocks.doctor.expects('reportSuccess').once().returns(false);\n      mocks.doctor.expects('reportManualFixes').once().returns(true);\n      mocks.doctor.expects('runAutoFixes').never();\n      await doctor.run();\n      verify(mocks);\n    });\n    it('should run autofixes', async () => {\n      mocks.doctor = S.sandbox.mock(doctor);\n      mocks.doctor.expects('diagnose').once();\n      mocks.doctor.expects('reportSuccess').once().returns(false);\n      mocks.doctor.expects('reportManualFixes').once().returns(false);\n      mocks.doctor.expects('runAutoFixes').once();\n      await doctor.run();\n      verify(mocks);\n    });\n  }));\n});\n"],"sourceRoot":"../.."}