chore(material): add simple e2e smoke tests for components.

This commit is contained in:
Jeremy Elbourn 2015-05-04 18:34:06 -07:00
parent 93c331d103
commit 20a033e4c9
22 changed files with 137 additions and 66 deletions

View File

@ -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

View File

@ -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) {

View File

@ -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_ = [];

View File

@ -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
});

View File

@ -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');
});
});

View File

@ -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);
});
});

View File

@ -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);
});
});

View File

@ -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
});

View File

@ -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>

View File

@ -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>

View File

@ -48,10 +48,17 @@ 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).
return `/packages/${url}`; // 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}`;
} else if (this.isInPubServe) {
return `/examples/packages/${url}`;
} else { } else {
return `/${url}`; return `/${url}`;
} }
} }
} }

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -12,8 +12,8 @@
</head> </head>
<body> <body>
$SCRIPTS$
<demo-app>Loading...</demo-app> <demo-app>Loading...</demo-app>
$SCRIPTS$
</body> </body>
</html> </html>

View File

@ -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!

View File

@ -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!