chore(material): add simple e2e smoke tests for components.
This commit is contained in:
parent
93c331d103
commit
20a033e4c9
15
gulpfile.js
15
gulpfile.js
|
@ -746,11 +746,22 @@ gulp.task('build', ['build.js', 'build.dart']);
|
||||||
|
|
||||||
// ------------
|
// ------------
|
||||||
// angular material testing rules
|
// angular material testing rules
|
||||||
gulp.task('build.js.material', ['build.js.dev'], function() {
|
gulp.task('build.css.material', function() {
|
||||||
return gulp.src('modules/*/src/**/*.scss')
|
return gulp.src('modules/*/src/**/*.scss')
|
||||||
.pipe(sass())
|
.pipe(sass())
|
||||||
.pipe(autoprefixer())
|
.pipe(autoprefixer())
|
||||||
.pipe(gulp.dest(CONFIG.dest.js.dev.es5));
|
.pipe(gulp.dest(CONFIG.dest.js.prod.es5))
|
||||||
|
.pipe(gulp.dest(CONFIG.dest.js.dev.es5))
|
||||||
|
.pipe(gulp.dest(CONFIG.dest.js.dart2js + '/examples/packages'));
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
gulp.task('build.js.material', function(done) {
|
||||||
|
runSequence('build.js.dev', 'build.css.material', done);
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('build.dart2js.material', function(done) {
|
||||||
|
runSequence('build.dart', 'build.css.material', done);
|
||||||
});
|
});
|
||||||
|
|
||||||
// TODO: this target is temporary until we find a way to use the SASS transformer
|
// TODO: this target is temporary until we find a way to use the SASS transformer
|
||||||
|
|
|
@ -19,7 +19,7 @@ import {NumberWrapper} from 'angular2/src/facade/lang';
|
||||||
'tabindex': 'tabindex',
|
'tabindex': 'tabindex',
|
||||||
'role': 'attr.role',
|
'role': 'attr.role',
|
||||||
'checked': 'attr.aria-checked',
|
'checked': 'attr.aria-checked',
|
||||||
'disabled_': 'attr.aria-disabled'
|
'disabled': 'attr.aria-disabled'
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@View({
|
@View({
|
||||||
|
@ -31,7 +31,7 @@ export class MdCheckbox {
|
||||||
checked: boolean;
|
checked: boolean;
|
||||||
|
|
||||||
/** Whether this checkbox is disabled. */
|
/** Whether this checkbox is disabled. */
|
||||||
disabled_: boolean;
|
_disabled: boolean;
|
||||||
|
|
||||||
/** Setter for `role` attribute. */
|
/** Setter for `role` attribute. */
|
||||||
role: string;
|
role: string;
|
||||||
|
@ -43,14 +43,15 @@ export class MdCheckbox {
|
||||||
this.role = 'checkbox';
|
this.role = 'checkbox';
|
||||||
this.checked = false;
|
this.checked = false;
|
||||||
this.tabindex = isPresent(tabindex) ? NumberWrapper.parseInt(tabindex, 10) : 0;
|
this.tabindex = isPresent(tabindex) ? NumberWrapper.parseInt(tabindex, 10) : 0;
|
||||||
|
this._disabled = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
get disabled() {
|
get disabled() {
|
||||||
return this.disabled_;
|
return this._disabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
set disabled(value) {
|
set disabled(value) {
|
||||||
this.disabled_ = isPresent(value) && value !== false;
|
this._disabled = isPresent(value) && value !== false;
|
||||||
}
|
}
|
||||||
|
|
||||||
onKeydown(event: KeyboardEvent) {
|
onKeydown(event: KeyboardEvent) {
|
||||||
|
|
|
@ -77,8 +77,8 @@ export class MdRadioButton {
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@Optional() @Parent() radioGroup: MdRadioGroup,
|
@Optional() @Parent() radioGroup: MdRadioGroup,
|
||||||
@Attribute('id') id: string,
|
@Attribute('id') id: String,
|
||||||
@Attribute('tabindex') tabindex: string,
|
@Attribute('tabindex') tabindex: String,
|
||||||
radioDispatcher: MdRadioDispatcher) {
|
radioDispatcher: MdRadioDispatcher) {
|
||||||
// Assertions. Ideally these should be stripped out by the compiler.
|
// Assertions. Ideally these should be stripped out by the compiler.
|
||||||
// TODO(jelbourn): Assert that there's no name binding AND a parent radio group.
|
// TODO(jelbourn): Assert that there's no name binding AND a parent radio group.
|
||||||
|
@ -213,8 +213,8 @@ export class MdRadioGroup {
|
||||||
role: string;
|
role: string;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@Attribute('tabindex') tabindex: string,
|
@Attribute('tabindex') tabindex: String,
|
||||||
@Attribute('disabled') disabled: string,
|
@Attribute('disabled') disabled: String,
|
||||||
radioDispatcher: MdRadioDispatcher) {
|
radioDispatcher: MdRadioDispatcher) {
|
||||||
this.name_ = `md-radio-group-${_uniqueIdCounter++}`;
|
this.name_ = `md-radio-group-${_uniqueIdCounter++}`;
|
||||||
this.radios_ = [];
|
this.radios_ = [];
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
||||||
|
|
||||||
|
describe('md-button', function () {
|
||||||
|
var url = 'examples/src/material/button/index.html';
|
||||||
|
|
||||||
|
beforeEach(() => { browser.get(url); });
|
||||||
|
afterEach(testUtil.verifyNoBrowserErrors);
|
||||||
|
|
||||||
|
// Buttons are broken right now, see https://github.com/angular/angular/issues/1602
|
||||||
|
});
|
|
@ -0,0 +1,18 @@
|
||||||
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
||||||
|
|
||||||
|
describe('md-checkbox', function () {
|
||||||
|
var url = 'examples/src/material/checkbox/index.html';
|
||||||
|
|
||||||
|
beforeEach(() => { browser.get(url); });
|
||||||
|
afterEach(testUtil.verifyNoBrowserErrors);
|
||||||
|
|
||||||
|
it('should toggle a checkbox', function() {
|
||||||
|
var checkbox = element.all(by.css('md-checkbox')).first();
|
||||||
|
|
||||||
|
checkbox.click();
|
||||||
|
expect(checkbox.getAttribute('aria-checked')).toBe('true');
|
||||||
|
|
||||||
|
checkbox.click();
|
||||||
|
expect(checkbox.getAttribute('aria-checked')).toBe('false');
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,19 @@
|
||||||
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
||||||
|
|
||||||
|
describe('md-dialog', function () {
|
||||||
|
var url = 'examples/src/material/dialog/index.html';
|
||||||
|
|
||||||
|
beforeEach(() => { browser.get(url); });
|
||||||
|
afterEach(testUtil.verifyNoBrowserErrors);
|
||||||
|
|
||||||
|
it('should open a dialog', function() {
|
||||||
|
var openButton = element(by.id('open'));
|
||||||
|
openButton.click();
|
||||||
|
expect(element(by.css('.md-dialog')).isPresent()).toBe(true);
|
||||||
|
|
||||||
|
var dialog = element(by.css('.md-dialog'));
|
||||||
|
dialog.sendKeys(protractor.Key.ESCAPE);
|
||||||
|
|
||||||
|
expect(element(by.css('.md-dialog')).isPresent()).toBe(false);
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,23 @@
|
||||||
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
||||||
|
|
||||||
|
describe('md-progress-linear', function () {
|
||||||
|
var url = 'examples/src/material/progress-linear/index.html';
|
||||||
|
|
||||||
|
beforeEach(() => { browser.get(url); });
|
||||||
|
afterEach(testUtil.verifyNoBrowserErrors);
|
||||||
|
|
||||||
|
it('should increment and decrement progress', function() {
|
||||||
|
var progressBar = element.all(by.css('md-progress-linear')).first();
|
||||||
|
var incrementButton = element(by.id('increment'));
|
||||||
|
var decrementButton = element(by.id('decrement'));
|
||||||
|
|
||||||
|
var initialValue = progressBar.getAttribute('aria-valuenow');
|
||||||
|
|
||||||
|
incrementButton.click();
|
||||||
|
expect(progressBar.getAttribute('aria-valuenow')).toBeGreaterThan(initialValue);
|
||||||
|
|
||||||
|
decrementButton.click();
|
||||||
|
decrementButton.click();
|
||||||
|
expect(progressBar.getAttribute('aria-valuenow')).toBeLessThan(initialValue);
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,10 @@
|
||||||
|
var testUtil = require('angular2/src/test_lib/e2e_util');
|
||||||
|
|
||||||
|
describe('md-radio-button', function () {
|
||||||
|
var url = 'examples/src/material/radio/index.html';
|
||||||
|
|
||||||
|
beforeEach(() => { browser.get(url); });
|
||||||
|
afterEach(testUtil.verifyNoBrowserErrors);
|
||||||
|
|
||||||
|
// Radio buttons are broken right now, see https://github.com/angular/angular/issues/1643
|
||||||
|
});
|
|
@ -7,10 +7,7 @@
|
||||||
<style> * { font-family: RobotoDraft, Roboto, 'Helvetica Neue', sans-serif; } </style>
|
<style> * { font-family: RobotoDraft, Roboto, 'Helvetica Neue', sans-serif; } </style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
|
||||||
$SCRIPTS$
|
$SCRIPTS$
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -4,15 +4,10 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material checkbox demo</title>
|
<title>ng-material checkbox demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -48,8 +48,15 @@ export class DemoUrlResolver extends UrlResolver {
|
||||||
return `${baseUrl}/${url}`;
|
return `${baseUrl}/${url}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.isInPubServe) {
|
// Whether the `examples/` dir is being directly served (as the server root).
|
||||||
|
// For cases when this is not true AND we're in pub-serve, `examples/` needs to be
|
||||||
|
// prepended to the URL.
|
||||||
|
var isDirectlyServingExamplesDir = !StringWrapper.contains(baseUrl, 'examples/');
|
||||||
|
|
||||||
|
if (this.isInPubServe && isDirectlyServingExamplesDir) {
|
||||||
return `/packages/${url}`;
|
return `/packages/${url}`;
|
||||||
|
} else if (this.isInPubServe) {
|
||||||
|
return `/examples/packages/${url}`;
|
||||||
} else {
|
} else {
|
||||||
return `/${url}`;
|
return `/${url}`;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<div>
|
<div>
|
||||||
<h2>Dialog demo</h2>
|
<h2>Dialog demo</h2>
|
||||||
|
|
||||||
<button type="button" (click)="open()" [disabled]="!!dialogRef">
|
<button id="open" type="button" (click)="open()" [disabled]="!!dialogRef">
|
||||||
Open a dialog
|
Open a dialog
|
||||||
</button>
|
</button>
|
||||||
|
|
||||||
|
|
|
@ -4,15 +4,10 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material dialog demo</title>
|
<title>ng-material dialog demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body class="dialog-demo">
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -4,17 +4,10 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material grid-list demo</title>
|
<title>ng-material grid-list demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -4,16 +4,12 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material input demo</title>
|
<title>ng-material input demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -37,6 +37,6 @@
|
||||||
<!--<md-progress-linear></md-progress-linear>-->
|
<!--<md-progress-linear></md-progress-linear>-->
|
||||||
|
|
||||||
<p>Progress: {{progress}}</p>
|
<p>Progress: {{progress}}</p>
|
||||||
<button type="button" (click)="step(10)">Increment</button>
|
<button type="button" (click)="step(10)" id="increment">Increment</button>
|
||||||
<button type="button" (click)="step(-10)">Decrement</button>
|
<button type="button" (click)="step(-10)" id="decrement">Decrement</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -4,15 +4,12 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material progress-linear demo</title>
|
<title>ng-material progress-linear demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<h2>Radio buttons</h2>
|
<h2>Radio buttons</h2>
|
||||||
<h3>Inside of a radiogroup</h3>
|
<h3>Inside of a radiogroup</h3>
|
||||||
|
|
||||||
<md-radio-group #scifi (change)="onGroupChange()">
|
<md-radio-group #scifi (change)="onGroupChange()" id="scifi-group">
|
||||||
<md-radio-button value="star-wars">Star Wars</md-radio-button>
|
<md-radio-button value="star-wars">Star Wars</md-radio-button>
|
||||||
<md-radio-button value="star-trek" id="special-radio">Star Trek</md-radio-button>
|
<md-radio-button value="star-trek" id="special-radio">Star Trek</md-radio-button>
|
||||||
<md-radio-button value="bsg" disabled>Battlestar Galactica</md-radio-button>
|
<md-radio-button value="bsg" disabled>Battlestar Galactica</md-radio-button>
|
||||||
|
|
|
@ -4,17 +4,12 @@
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>ng-material radio demo</title>
|
<title>ng-material radio demo</title>
|
||||||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=RobotoDraft:400,500,700,400italic">
|
||||||
<style>
|
<style> * { font-family: RobotoDraft, Roboto; } </style>
|
||||||
* {
|
|
||||||
font-family: RobotoDraft, Roboto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -12,8 +12,8 @@
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
$SCRIPTS$
|
|
||||||
|
|
||||||
<demo-app>Loading...</demo-app>
|
<demo-app>Loading...</demo-app>
|
||||||
|
|
||||||
|
$SCRIPTS$
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -15,6 +15,8 @@ function killServer () {
|
||||||
./node_modules/.bin/gulp serve.js.dart2js&
|
./node_modules/.bin/gulp serve.js.dart2js&
|
||||||
serverPid=$!
|
serverPid=$!
|
||||||
|
|
||||||
|
./node_modules/.bin/gulp build.css.material&
|
||||||
|
|
||||||
trap killServer EXIT
|
trap killServer EXIT
|
||||||
|
|
||||||
# wait for server to come up!
|
# wait for server to come up!
|
||||||
|
|
|
@ -15,6 +15,8 @@ function killServer () {
|
||||||
./node_modules/.bin/gulp serve.js.prod&
|
./node_modules/.bin/gulp serve.js.prod&
|
||||||
serverPid=$!
|
serverPid=$!
|
||||||
|
|
||||||
|
./node_modules/.bin/gulp build.css.material&
|
||||||
|
|
||||||
trap killServer EXIT
|
trap killServer EXIT
|
||||||
|
|
||||||
# wait for server to come up!
|
# wait for server to come up!
|
||||||
|
|
Loading…
Reference in New Issue