diff --git a/index.js b/index.js index 06c94e4..9b7794b 100644 --- a/index.js +++ b/index.js @@ -78,20 +78,26 @@ function wrapInControlFlow(flow, globalFn, fnName) { flow.execute(function controlFlowExecute() { return new webdriver.promise.Promise(function(fulfill, reject) { + function wrappedReject(err) { + var wrappedErr = new Error(err); + reject(wrappedErr); + } if (async) { // If testFn is async (it expects a done callback), resolve the promise of this // test whenever that callback says to. Any promises returned from testFn are // ignored. var proxyDone = fulfill; - proxyDone.fail = function(err) { - var wrappedErr = new Error(err); - reject(wrappedErr); - }; + proxyDone.fail = wrappedReject; testFn(proxyDone); } else { // Without a callback, testFn can return a promise, or it will // be assumed to have completed synchronously. - fulfill(testFn()); + var ret = testFn(); + if (webdriver.promise.isPromise(ret)) { + ret.then(fulfill, wrappedReject); + } else { + fulfill(ret); + } } }, flow); }, 'Run ' + fnName + description + ' in control flow').then(seal(done), function(err) { diff --git a/spec/adapterSpec.js b/spec/adapterSpec.js index 6fce99e..9dcbbaf 100644 --- a/spec/adapterSpec.js +++ b/spec/adapterSpec.js @@ -242,4 +242,24 @@ describe('webdriverJS Jasmine adapter', function() { expect(spec3.description).toBe('test3'); }); }); + + describe('should handle returning native promises', () => { + var currentTest = null; + + it('test A', () => { + currentTest = 'A'; + return new Promise((resolve) => { + setTimeout(() => { + fakeDriver.sleep(100).then(() => { + expect(currentTest).toBe('A'); + }); + resolve(); + }, 100); + }); + }); + + it('test B', () => { + currentTest = 'B'; + }); + }); });