protractor
Version:
Webdriver E2E test wrapper for Angular.
115 lines (90 loc) • 3.41 kB
Markdown
Upgrading from Jasmine 1.3 to 2.x
=================================
First, please read [Jasmine's official upgrade documentation](http://jasmine.github.io/2.1/upgrading.html).
### In your conf file
Specify that you want to use jasmine2.x:
```javascript
exports.config = {
// Specify you want to use jasmine 2.x as you would with mocha and cucumber.
framework: 'jasmine2'
};
```
Similar to jasmine 1.3, you may include `jasmineNodeOpts` in the config file. However, because we changed the runner from "https://github.com/juliemr/minijasminenode" to "https://github.com/jasmine/jasmine-npm", the options have changed slightly. In particular, we will only support the options in the official "jasmine-npm":
```javascript
jasmineNodeOpts: {
// If true, print colors to the terminal.
showColors: true,
// Default time to wait in ms before a test fails.
defaultTimeoutInterval: 30000,
// Function called to print jasmine results.
print: function() {},
// If set, only execute specs whose names match the pattern, which is
// internally compiled to a RegExp.
grep: 'pattern',
// Inverts 'grep' matches
invertGrep: false
}
```
Notably options `print` and `grep` are new, but we will no longer support options `isVerbose` and `includeStackTrace` (unless, of course, "jasmine-npm" introduces these options).
### In your specs
#### Focused specs
Instead of `iit`, please use `fit`. Instead of `ddescribe`, please use `fdescribe`.
#### Timeouts
Having a custom timeout for an `it` block as a third parameter is not currently
supported in Jasmine2, but it will be supported in a release soon. See [this issue](https://github.com/angular/protractor/issues/1701).
#### Custom matchers
See http://jasmine.github.io/2.0/upgrading.html#section-Custom_Matchers
Before:
```javascript
toHaveText: function(expectedText) {
return this.actual.getText().then(function(actualText) {
return expectedText === actualText;
});
}
```
Now:
```javascript
toHaveText: function() {
return {
compare: function(actual, expectedText) {
return {
pass: actual.getText().then(function(actualText) {
return actualText === expectedText;
})
};
}
};
}
```
#### Asynchronous specs
Note: `minijasminenode` provided asynchronous support for jasmine1.3 before (i.e. via done callback). Jasmine 2.x now provides the support natively, but the change is mostly transparent to protractor users who are upgrading from jasmine1.3.
You can still pass in the done parameter as part of your asynchronous spec, but the syntax for failing it has changed.
Before:
```javascript
it('async spec', function(done) {
setTimeout(function() {
if (passed) {
done(); // When done
} else {
done('failure message'); // To fail spec
}
}, 5000);
});
```
Now:
```javascript
it('async spec', function(done) {
setTimeout(function() {
if (passed) {
done(); // When done
} else {
done.fail('failure message'); // To fail spec
}
}, 5000);
});
```
#### Reporters
The syntax for custom reporters has changed for Jasmine2. If you were previously
adding reporters from a node module, such as the `jasmine-reporters` package on
npm, make sure you upgrade to a version which supports Jasmine2. If you are
writing your own reporter, see the [Jasmine docs on custom reporters](http://jasmine.github.io/2.1/custom_reporter.html).