Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(9)

Unified Diff: third_party/pkg/angular/test/directive/input_select_spec.dart

Issue 1058283006: Update pubspecs and dependencies to get pkgbuild tests working. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/pkg/angular/test/directive/input_select_spec.dart
diff --git a/third_party/pkg/angular/test/directive/input_select_spec.dart b/third_party/pkg/angular/test/directive/input_select_spec.dart
deleted file mode 100644
index 7fe66c8c7059ff96358635a2ddfb4d0a55589cfb..0000000000000000000000000000000000000000
--- a/third_party/pkg/angular/test/directive/input_select_spec.dart
+++ /dev/null
@@ -1,1287 +0,0 @@
-library input_select_spec;
-
-import '../_specs.dart';
-
-//TODO(misko): re-enabled disabled tests once we have forms.
-
-main() {
- describe('input-select', () {
-
- describe('ng-value', () {
- TestBed _;
- beforeEach(inject((TestBed tb) => _ = tb));
-
- it('should retrieve using ng-value', () {
- _.compile(
- '<select ng-model="robot" probe="p">'
- '<option ng-repeat="r in robots" ng-value="r">{{r.name}}</option>'
- '</select>');
- var r2d2 = {"name":"r2d2"};
- var c3p0 = {"name":"c3p0"};
- _.rootScope.context['robots'] = [ r2d2, c3p0 ];
- _.rootScope.apply();
- _.selectOption(_.rootElement, 'c3p0');
- expect(_.rootScope.context['robot']).toEqual(c3p0);
-
- _.rootScope.context['robot'] = r2d2;
- _.rootScope.apply();
- expect(_.rootScope.context['robot']).toEqual(r2d2);
- expect(_.rootElement).toEqualSelect([['r2d2'], 'c3p0']);
- });
-
- it('should retrieve using ng-value', () {
- _.compile(
- '<select ng-model="robot" probe="p" multiple>'
- '<option ng-repeat="r in robots" ng-value="r">{{r.name}}</option>'
- '</select>');
- var r2d2 = { "name":"r2d2"};
- var c3p0 = {"name":"c3p0"};
- _.rootScope.context['robots'] = [ r2d2, c3p0 ];
- _.rootScope.apply();
- _.selectOption(_.rootElement, 'c3p0');
- expect(_.rootScope.context['robot']).toEqual([c3p0]);
-
- _.rootScope.context['robot'] = [r2d2];
- _.rootScope.apply();
- expect(_.rootScope.context['robot']).toEqual([r2d2]);
- expect(_.rootElement).toEqualSelect([['r2d2'], 'c3p0']);
- });
- });
-
- TestBed _;
-
- beforeEach(inject((TestBed tb) => _ = tb));
-
- describe('select-one', () {
- it('should compile children of a select without a ngModel, but not create a model for it',
- () {
- _.compile(
- '<select>'
- '<option selected="true">{{a}}</option>'
- '<option value="">{{b}}</option>'
- '<option>C</option>'
- '</select>');
- _.rootScope.apply(() {
- _.rootScope.context['a'] = 'foo';
- _.rootScope.context['b'] = 'bar';
- });
-
- expect(_.rootElement.text).toEqual('foobarC');
- });
-
- it('should not interfere with selection via selected attr if ngModel directive is not present',
- () {
- _.compile(
- '<select>'
- '<option>not me</option>'
- '<option selected>me!</option>'
- '<option>nah</option>'
- '</select>');
- _.rootScope.apply();
-
- expect(_.rootElement).toEqualSelect(['not me', ['me!'], 'nah']);
- });
-
- it('should work with repeated value options', () {
- _.compile(
- '<select ng-model="robot" probe="p">'
- '<option ng-repeat="r in robots">{{r}}</option>'
- '</select>');
-
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- _.rootScope.context['robot'] = 'r2d2';
- _.rootScope.apply();
-
- var select = _.rootScope.context['p'].directive(InputSelectDirective);
- expect(_.rootElement).toEqualSelect(['c3p0', ['r2d2']]);
-
- _.rootElement.querySelectorAll('option')[0].selected = true;
- _.triggerEvent(_.rootElement, 'change');
-
-
- expect(_.rootElement).toEqualSelect([['c3p0'], 'r2d2']);
- expect(_.rootScope.context['robot']).toEqual('c3p0');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'].insert(0, 'wallee');
- });
- expect(_.rootElement).toEqualSelect(['wallee', ['c3p0'], 'r2d2']);
- expect(_.rootScope.context['robot']).toEqual('c3p0');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['c3p0+', 'r2d2+'];
- _.rootScope.context['robot'] = 'r2d2+';
- });
-
- expect(_.rootElement).toEqualSelect(['c3p0+', ['r2d2+']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2+');
- });
-
- describe('empty option', () {
- it('should select the empty option when model is undefined', () {
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option value="x">robot x</option>' +
- '<option value="y">robot y</option>' +
- '</select>');
- _.rootScope.apply();
-
- expect(_.rootElement).toEqualSelect([[''], 'x', 'y']);
- });
-
- it('should support defining an empty option anywhere in the option list', () {
- _.compile(
- '<select ng-model="robot">' +
- '<option value="x">robot x</option>' +
- '<option value="">--select--</option>' +
- '<option value="y">robot y</option>' +
- '</select>');
- _.rootScope.apply();
-
- expect(_.rootElement).toEqualSelect(['x', [''], 'y']);
- });
-
- it('should set the model to empty string when empty option is selected', () {
- _.rootScope.context['robot'] = 'x';
- _.compile(
- '<select ng-model="robot" probe="p">' +
- '<option value="">--select--</option>' +
- '<option value="x">robot x</option>' +
- '<option value="y">robot y</option>' +
- '</select>');
- _.rootScope.apply();
-
- var select = _.rootScope.context['p'].directive(InputSelectDirective);
-
- expect(_.rootElement).toEqualSelect(['', ['x'], 'y']);
-
- _.selectOption(_.rootElement, '--select--');
-
- expect(_.rootElement).toEqualSelect([[''], 'x', 'y']);
- expect(_.rootScope.context['robot']).toEqual(null);
- });
-
- describe('interactions with repeated options', () {
- it('should select empty option when model is undefined', () {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect([[''], 'c3p0', 'r2d2']);
- });
-
- it('should set model to empty string when selected', () {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- _.compile(
- '<select ng-model="robot" probe="p">' +
- '<option value="">--select--</option>' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply();
- var select = _.rootScope.context['p'].directive(InputSelectDirective);
-
- _.selectOption(_.rootElement, 'c3p0');
- expect(_.rootElement).toEqualSelect(['', ['c3p0'], 'r2d2']);
- expect( _.rootScope.context['robot']).toEqual('c3p0');
-
- _.selectOption(_.rootElement, '--select--');
-
- expect(_.rootElement).toEqualSelect([[''], 'c3p0', 'r2d2']);
- expect( _.rootScope.context['robot']).toEqual(null);
- });
-
- it('should not break if both the select and repeater models change at once', () {
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- _.rootScope.context['robot'] = 'c3p0';
- });
-
- expect(_.rootElement).toEqualSelect(['', ['c3p0'], 'r2d2']);
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['wallee'];
- _.rootScope.context['robot'] = '';
- });
-
- expect(_.rootElement).toEqualSelect([[''], 'wallee']);
- });
- });
-
- describe('unknown option', () {
-
- it("should insert&select temporary unknown option when no options-model match", () {
- _.compile(
- '<select ng-model="robot">' +
- '<option>c3p0</option>' +
- '<option>r2d2</option>' +
- '</select>');
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect([['?'], 'c3p0', 'r2d2']);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect(['c3p0', ['r2d2']]);
-
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = "wallee";
- });
- expect(_.rootElement).toEqualSelect([['?'], 'c3p0', 'r2d2']);
- });
-
- it("should NOT insert temporary unknown option when model is undefined and empty " +
- "options is present", () {
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option>c3p0</option>' +
- '<option>r2d2</option>' +
- '</select>');
- _.rootScope.apply();
-
- expect(_.rootElement).toEqualSelect([[''], 'c3p0', 'r2d2']);
- expect(_.rootScope.context['robot']).toEqual(null);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'wallee';
- });
- expect(_.rootElement).toEqualSelect([['?'], '', 'c3p0', 'r2d2']);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect(['', 'c3p0', ['r2d2']]);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = null;
- });
- expect(_.rootElement).toEqualSelect([[''], 'c3p0', 'r2d2']);
- });
-
- it("should insert&select temporary unknown option when no options-model match, empty " +
- "option is present and model is defined", () {
- _.rootScope.context['robot'] = 'wallee';
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option>c3p0</option>' +
- '<option>r2d2</option>' +
- '</select>');
- _.rootScope.apply();
-
- expect(_.rootElement).toEqualSelect([['?'], '', 'c3p0', 'r2d2']);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect(['', 'c3p0', ['r2d2']]);
- });
-
- describe('interactions with repeated options', () {
- it('should work with repeated options', () {
- _.rootScope.context['robots'] = [];
- _.compile(
- '<select ng-model="robot">' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = [];
- });
-
- expect(_.rootElement).toEqualSelect([['?']]);
- expect(_.rootScope.context['robot']).toEqual(null);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect([['?']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- });
- expect(_.rootElement).toEqualSelect(['c3p0', ['r2d2']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
- });
-
- it('should work with empty option and repeated options', () {
- _.compile(
- '<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = [];
- });
-
- expect(_.rootElement).toEqualSelect([['']]);
- expect(_.rootScope.context['robot']).toEqual(null);
-
- _.rootScope.apply(() {
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect([['?'], '']);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- });
- expect(_.rootElement).toEqualSelect(['', 'c3p0', ['r2d2']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
- });
-
- it('should insert unknown element when repeater shrinks and selected option is ' +
- 'unavailable', () {
-
- _.compile(
- '<select ng-model="robot">' +
- '<option ng-repeat="r in robots">{{r}}</option>' +
- '</select>');
- _.rootScope.apply(() {
- _.rootScope.context['robots'] = ['c3p0', 'r2d2'];
- _.rootScope.context['robot'] = 'r2d2';
- });
- expect(_.rootElement).toEqualSelect(['c3p0', ['r2d2']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'].remove('r2d2');
- });
- expect(_.rootScope.context['robot']).toEqual('r2d2');
- expect(_.rootElement).toEqualSelect([['?'], 'c3p0']);
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'].insert(0, 'r2d2');
- });
- expect(_.rootElement).toEqualSelect([['r2d2'], 'c3p0']);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
-
- _.rootScope.apply(() {
- _.rootScope.context['robots'].clear();
- });
-
- expect(_.rootElement).toEqualSelect([['?']]);
- expect(_.rootScope.context['robot']).toEqual('r2d2');
- });
- });
- });
- });
-
- it('issue #392', () {
- _.compile(
- '<div>' +
- '<div ng-if="attached">' +
- '<select ng-model="model">' +
- '<option value="a">foo</option>' +
- '<option value="b">bar</option>' +
- '</select>' +
- '</div>' +
- '</div>');
- _.rootScope.context['model'] = 'b';
- _.rootScope.context['attached'] = true;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect(['a', ['b']]);
- _.rootScope.context['attached'] = false;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect([]);
- _.rootScope.context['attached'] = true;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect(['a', ['b']]);
- });
-
-
- it('issue #428', () {
- _.compile(
- '<div>' +
- '<div ng-if="attached">' +
- '<select ng-model="model" multiple>' +
- '<option value="a">foo</option>' +
- '<option value="b">bar</option>' +
- '</select>' +
- '</div>' +
- '</div>');
- _.rootScope.context['model'] = ['b'];
- _.rootScope.context['attached'] = true;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect(['a', ['b']]);
- _.rootScope.context['attached'] = false;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect([]);
- _.rootScope.context['attached'] = true;
- _.rootScope.apply();
- expect(_.rootElement).toEqualSelect(['a', ['b']]);
- });
- });
-
-
- describe('select from angular.js', () {
- TestBed _;
- beforeEach(inject((TestBed tb) => _ = tb));
-
- var scope, formElement, element;
-
- compile(html) {
- _.compile('<form name="form">' + html + '</form>');
- element = _.rootElement.querySelector('select');
- scope.apply();
- }
-
- beforeEach(inject((Scope rootScope) {
- scope = rootScope;
- formElement = element = null;
- }));
-
-
- afterEach(() {
- scope.destroy(); //disables unknown option work during destruction
- });
-
-
- describe('select-one', () {
-
- it('should compile children of a select without a ngModel, but not create a model for it',
- () {
- compile('<select>' +
- '<option selected="true">{{a}}</option>' +
- '<option value="">{{b}}</option>' +
- '<option>C</option>' +
- '</select>');
- scope.apply(() {
- scope.context['a'] = 'foo';
- scope.context['b'] = 'bar';
- });
-
- expect(element.text).toEqual('foobarC');
- });
-
-
- it('should not interfere with selection via selected attr if ngModel directive is not present',
- () {
- compile('<select>' +
- '<option>not me</option>' +
- '<option selected>me!</option>' +
- '<option>nah</option>' +
- '</select>');
- expect(element).toEqualSelect(['not me', ['me!'], 'nah']);
- });
-
- it('should fire ng-change event.', () {
- var log = '';
- compile(
- '<select name="select" ng-model="selection" ng-change="change()">' +
- '<option value=""></option>' +
- '<option value="c">C</option>' +
- '</select>');
-
- scope.context['change'] = () {
- log += 'change:${scope.context['selection']};';
- };
-
- scope.apply(() {
- scope.context['selection'] = 'c';
- });
-
- element.value = 'c';
- _.triggerEvent(element, 'change');
- expect(log).toEqual('change:c;');
- });
-
-
- xit('should require', () {
- compile(
- '<select name="select" ng-model="selection" required ng-change="change()">' +
- '<option value=""></option>' +
- '<option value="c">C</option>' +
- '</select>');
-
- scope.context['change'] = () {
- scope.log += 'change;';
- };
-
- scope.apply(() {
- scope.context['log'] = '';
- scope.context['selection'] = 'c';
- });
-
- expect(scope.context['form'].select.$error.required).toEqual(false);;
- expect(element).toEqualValid();
- expect(element).toEqualPristine();
-
- scope.apply(() {
- scope.context['selection'] = '';
- });
-
- expect(scope.context['form'].select.$error.required).toEqual(true);;
- expect(element).toEqualInvalid();
- expect(element).toEqualPristine();
- expect(scope.context['log']).toEqual('');
-
- element[0].value = 'c';
- _.triggerEvent(element, 'change');
- expect(element).toEqualValid();
- expect(element).toEqualDirty();
- expect(scope.context['log']).toEqual('change;');
- });
-
-
- xit('should not be invalid if no require', () {
- compile(
- '<select name="select" ng-model="selection">' +
- '<option value=""></option>' +
- '<option value="c">C</option>' +
- '</select>');
-
- expect(element).toEqualValid();
- expect(element).toEqualPristine();
- });
-
-
- describe('empty option', () {
-
- it('should select the empty option when model is undefined', () {
- compile('<select ng-model="robot">' +
- '<option value="">--select--</option>' +
- '<option value="x">robot x</option>' +
- '<option value="y">robot y</option>' +
- '</select>');
-
- expect(element).toEqualSelect([[''], 'x', 'y']);
- });
-
-
- it('should support defining an empty option anywhere in the option list', () {
- compile('<select ng-model="robot">' +
- '<option value="x">robot x</option>' +
- '<option value="">--select--</option>' +
- '<option value="y">robot y</option>' +
- '</select>');
-
- expect(element).toEqualSelect(['x', [''], 'y']);
- });
- });
- });
-
-
- describe('select-multiple', () {
-
- it('should support type="select-multiple"', () {
- compile(
- '<select ng-model="selection" multiple>' +
- '<option>A</option>' +
- '<option>B</option>' +
- '</select>');
-
- scope.apply(() {
- scope.context['selection'] = ['A'];
- });
-
- expect(element).toEqualSelect([['A'], 'B']);
-
- scope.apply(() {
- scope.context['selection'].add('B');
- });
-
- expect(element).toEqualSelect([['A'], ['B']]);
- });
-
- it('should work with optgroups', () {
- compile('<select ng-model="selection" multiple>' +
- '<optgroup label="group1">' +
- '<option>A</option>' +
- '<option>B</option>' +
- '</optgroup>' +
- '</select>');
-
- expect(element).toEqualSelect(['A', 'B']);
- expect(scope.context['selection']).toEqual(null);
-
- scope.apply(() {
- scope.context['selection'] = ['A'];
- });
- expect(element).toEqualSelect([['A'], 'B']);
-
- scope.apply(() {
- scope.context['selection'].add('B');
- });
- expect(element).toEqualSelect([['A'], ['B']]);
- });
-
- xit('should require', () {
- compile(
- '<select name="select" ng-model="selection" multiple required>' +
- '<option>A</option>' +
- '<option>B</option>' +
- '</select>');
-
- scope.apply(() {
- scope.context['selection'] = [];
- });
-
- expect(scope.context['form'].select.$error.required).toEqual(true);;
- expect(element).toEqualInvalid();
- expect(element).toEqualPristine();
-
- scope.apply(() {
- scope.context['selection'] = ['A'];
- });
-
- expect(element).toEqualValid();
- expect(element).toEqualPristine();
-
- element[0].value = 'B';
- _.triggerEvent(element, 'change');
- expect(element).toEqualValid();
- expect(element).toEqualDirty();
- });
- });
-
-
- describe('ngOptions', () {
- createSelect(attrs, [blank, unknown, ngRepeat, text, ngValue]) {
- var html = '<select';
- attrs.forEach((key, value) {
- if (value is bool) {
- if (value != null) html += ' $key';
- } else {
- html += ' $key="$value"';
- }
- });
- html += '>' +
- (blank != null ? (blank is String ? blank : '<option value="">blank</option>') : '') +
- (unknown != null ? (unknown is String ? unknown : '<option value="?">unknown</option>') : '') +
- (ngRepeat != null ? '<option ng-repeat="$ngRepeat" ng-value="$ngValue">{{$text}}</option>' : '') +
- '</select>';
-
- compile(html);
- }
-
- createSingleSelect([blank, unknown]) {
- createSelect({
- 'ng-model':'selected'
- }, blank, unknown, 'value in values', 'value.name', 'value');
- }
-
- createMultiSelect([blank, unknown]) {
- createSelect({
- 'ng-model':'selected',
- 'multiple':true
- }, blank, unknown, 'value in values', 'value.name', 'value');
- }
-
-
- it('should render a list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}, {'name': 'C'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- var options = element.querySelectorAll('option');
- expect(options.length).toEqual(3);
- expect(element).toEqualSelect([['A'], 'B', 'C']);
- });
-
- it('should render zero as a valid display value', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': '0'}, {'name': '1'}, {'name': '2'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- var options = element.querySelectorAll('option');
- expect(options.length).toEqual(3);
- expect(element).toEqualSelect([['0'], '1', '2']);
- });
-
- it('should grow list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1); // because we add special empty option
- expect(element.querySelectorAll('option')[0].text).toEqual('');
- expect(element.querySelectorAll('option')[0].value).toEqual('?');
-
- scope.apply(() {
- scope.context['values'].add({'name':'A'});
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1);
- expect(element).toEqualSelect([['A']]);
-
- scope.apply(() {
- scope.context['values'].add({'name':'B'});
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element).toEqualSelect([['A'], 'B']);
- });
-
-
- it('should shrink list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name':'A'}, {'name':'B'}, {'name':'C'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(3);
-
- scope.apply(() {
- scope.context['values'].removeLast();
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element).toEqualSelect([['A'], 'B']);
-
- scope.apply(() {
- scope.context['values'].removeLast();
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1);
- expect(element).toEqualSelect([['A']]);
-
- scope.apply(() {
- scope.context['values'].removeLast();
- scope.context['selected'] = null;
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1); // we add back the special empty option
- });
-
-
- it('should shrink and then grow list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name':'A'}, {'name':'B'}, {'name':'C'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(3);
-
- scope.apply(() {
- scope.context['values'] = [{'name': '1'}, {'name': '2'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}, {'name': 'C'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(3);
- });
-
-
- it('should update list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}, {'name': 'C'}];
- scope.context['selected'] = scope.context['values'][0];
- });
- expect(element).toEqualSelect([['A'], 'B', 'C']);
- scope.apply(() {
- scope.context['values'] = [{'name': 'B'}, {'name': 'C'}, {'name': 'D'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- var options = element.querySelectorAll('option');
- expect(options.length).toEqual(3);
- expect(element).toEqualSelect([['B'], 'C', 'D']);
- });
-
-
- it('should preserve existing options', () {
- createSingleSelect(true);
-
- scope.apply(() {
- scope.context['values'] = [];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1);
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.querySelectorAll('option')[0].text).toEqual('blank');
- expect(element.querySelectorAll('option')[1].text).toEqual('A');
-
- scope.apply(() {
- scope.context['values'] = [];
- scope.context['selected'] = null;
- });
-
- expect(element.querySelectorAll('option').length).toEqual(1);
- expect(element.querySelectorAll('option')[0].text).toEqual('blank');
- });
-
- describe('binding', () {
-
- it('should bind to scope value', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element).toEqualSelect([['A'], 'B']);
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][1];
- });
-
- expect(element).toEqualSelect(['A', ['B']]);
- });
-
-
- // TODO(misko): re-enable once we support group by
- xit('should bind to scope value and group', () {
- createSelect({
- 'ng-model': 'selected',
- 'ng-options': 'item.name group by item.group for item in values'
- });
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'},
- {'name': 'B', group: 'first'},
- {'name': 'C', group: 'second'},
- {'name': 'D', group: 'first'},
- {'name': 'E', group: 'second'}];
- scope.context['selected'] = scope.context['values'][3];
- });
-
- expect(element).toEqualSelect(['A', 'B', ['D'], 'C', 'E']);
-
- var first = element.querySelectorAll('optgroup')[0];
- var b = first.querySelectorAll('option')[0];
- var d = first.querySelectorAll('option')[1];
- expect(first.attr('label')).toEqual('first');
- expect(b.text).toEqual('B');
- expect(d.text).toEqual('D');
-
- var second = element.querySelectorAll('optgroup')[1];
- var c = second.querySelectorAll('option')[0];
- var e = second.querySelectorAll('option')[1];
- expect(second.attr('label')).toEqual('second');
- expect(c.text).toEqual('C');
- expect(e.text).toEqual('E');
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.value).toEqual('0');
- });
-
-
- it('should bind to scope value through experession', () {
- createSelect({'ng-model': 'selected'}, null, null, 'item in values', 'item.name', 'item.id');
-
- scope.apply(() {
- scope.context['values'] = [{'id': 10, 'name': 'A'}, {'id': 20, 'name': 'B'}];
- scope.context['selected'] = scope.context['values'][0]['id'];
- });
-
- expect(element).toEqualSelect([['A'], 'B']);
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][1]['id'];
- });
-
- expect(element).toEqualSelect(['A', ['B']]);
- });
-
-
- it('should insert a blank option if bound to null', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}];
- scope.context['selected'] = null;
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element).toEqualSelect([['?'], 'A']);
- expect(element.querySelectorAll('option')[0].value).toEqual('?');
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element).toEqualSelect([['A']]);
- expect(element.querySelectorAll('option').length).toEqual(1);
- });
-
-
- it('should reuse blank option if bound to null', () {
- createSingleSelect(true);
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}];
- scope.context['selected'] = null;
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.value).toEqual('');
- expect(element.querySelectorAll('option')[0].value).toEqual('');
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element).toEqualSelect(['', ['A']]);
- expect(element.querySelectorAll('option').length).toEqual(2);
- });
-
-
- it('should insert a unknown option if bound to something not in the list', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}];
- scope.context['selected'] = {};
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.value).toEqual('?');
- expect(element.querySelectorAll('option')[0].value).toEqual('?');
-
- scope.apply(() {
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element).toEqualSelect([['A']]);
- expect(element.querySelectorAll('option').length).toEqual(1);
- });
-
-
- it('should select correct input if previously selected option was "?"', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = {};
- });
-
- expect(element.querySelectorAll('option').length).toEqual(3);
- expect(element.value).toEqual('?');
- expect(element.querySelectorAll('option')[0].value).toEqual('?');
-
- _.selectOption(element, 'A');
- expect(scope.context['selected']).toBe(scope.context['values'][0]);
- expect(element.querySelectorAll('option')[0].selected).toEqual(true);
- expect(element.querySelectorAll('option')[0].selected).toEqual(true);;
- expect(element.querySelectorAll('option').length).toEqual(2);
- });
- });
-
-
- describe('blank option', () {
-
- it('should be compiled as template, be watched and updated', () {
- var option;
- createSingleSelect('<option value="">blank is {{blankVal}}</option>');
-
- scope.apply(() {
- scope.context['blankVal'] = 'so blank';
- scope.context['values'] = [{'name': 'A'}];
- });
-
- // check blank option is first and is compiled
- expect(element.querySelectorAll('option').length).toEqual(2);
- option = element.querySelectorAll('option')[0];
- expect(option.value).toEqual('');
- expect(option.text).toEqual('blank is so blank');
-
- scope.apply(() {
- scope.context['blankVal'] = 'not so blank';
- });
-
- // check blank option is first and is compiled
- expect(element.querySelectorAll('option').length).toEqual(2);
- option = element.querySelectorAll('option')[0];
- expect(option.value).toEqual('');
- expect(option.text).toEqual('blank is not so blank');
- });
-
-
- it('should support binding via ngBindTemplate directive', () {
- var option;
- createSingleSelect('<option value="" ng-bind="\'blank is \' + blankVal"></option>');
-
- scope.apply(() {
- scope.context['blankVal'] = 'so blank';
- scope.context['values'] = [{'name': 'A'}];
- });
-
- // check blank option is first and is compiled
- expect(element.querySelectorAll('option').length).toEqual(2);
- option = element.querySelectorAll('option')[0];
- expect(option.value).toEqual('');
- expect(option.text).toEqual('blank is so blank');
- });
-
-
- it('should support biding via ngBind attribute', () {
- var option;
- createSingleSelect('<option value="" ng-bind="blankVal"></option>');
-
- scope.apply(() {
- scope.context['blankVal'] = 'is blank';
- scope.context['values'] = [{'name': 'A'}];
- });
-
- // check blank option is first and is compiled
- expect(element.querySelectorAll('option').length).toEqual(2);
- option = element.querySelectorAll('option')[0];
- expect(option.value).toEqual('');
- expect(option.text).toEqual('is blank');
- });
-
-
- it('should be rendered with the attributes preserved', () {
- var option;
- createSingleSelect('<option value="" class="coyote" id="road-runner" ' +
- 'custom-attr="custom-attr">{{blankVal}}</option>');
-
- scope.apply(() {
- scope.context['blankVal'] = 'is blank';
- });
-
- // check blank option is first and is compiled
- option = element.querySelectorAll('option')[0];
- expect(option.classes.contains('coyote')).toEqual(true);;
- expect(option.attributes['id']).toEqual('road-runner');
- expect(option.attributes['custom-attr']).toEqual('custom-attr');
- });
-
- it('should be selected, if it is available and no other option is selected', () {
- // selectedIndex is used here because $ incorrectly reports element.value
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}];
- });
- createSingleSelect(true);
- // ensure the first option (the blank option) is selected
- expect(element.selectedIndex).toEqual(0);
- scope.apply();
- // ensure the option has not changed following the digest
- expect(element.selectedIndex).toEqual(0);
- });
- });
-
-
- describe('on change', () {
-
- it('should update model on change', () {
- createSingleSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = scope.context['values'][0];
- });
-
- expect(element.querySelectorAll('option')[0].selected).toEqual(true);
-
- element.querySelectorAll('option')[1].selected = true;
- _.triggerEvent(element, 'change');
- expect(scope.context['selected']).toEqual(scope.context['values'][1]);
- });
-
-
- it('should update model on change through expression', () {
- createSelect({'ng-model': 'selected'}, null, null,
- 'item in values', 'item.name', 'item.id');
-
- scope.apply(() {
- scope.context['values'] = [{'id': 10, 'name': 'A'}, {'id': 20, 'name': 'B'}];
- scope.context['selected'] = scope.context['values'][0]['id'];
- });
-
- expect(element).toEqualSelect([['A'], 'B']);
-
- element.querySelectorAll('option')[1].selected = true;
- _.triggerEvent(element, 'change');
- expect(scope.context['selected']).toEqual(scope.context['values'][1]['id']);
- });
-
-
- it('should update model to null on change', () {
- createSingleSelect(true);
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = scope.context['values'][0];
- element.value = '0';
- });
-
- _.selectOption(element, 'blank');
- expect(element).toEqualSelect([[''], 'A', 'B']);
-
- expect(scope.context['selected']).toEqual(null);
- });
- });
-
-
- describe('select-many', () {
-
- it('should read multiple selection', () {
- createMultiSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = [];
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.querySelectorAll('option')[0].selected).toEqual(false);;
- expect(element.querySelectorAll('option')[1].selected).toEqual(false);;
-
- scope.apply(() {
- scope.context['selected'].add(scope.context['values'][1]);
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.querySelectorAll('option')[0].selected).toEqual(false);;
- expect(element.querySelectorAll('option')[1].selected).toEqual(true);;
-
- scope.apply(() {
- scope.context['selected'].add(scope.context['values'][0]);
- });
-
- expect(element.querySelectorAll('option').length).toEqual(2);
- expect(element.querySelectorAll('option')[0].selected).toEqual(true);;
- expect(element.querySelectorAll('option')[1].selected).toEqual(true);;
- });
-
-
- it('should update model on change', () {
- createMultiSelect();
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = [];
- });
-
- element.querySelectorAll('option')[0].selected = true;
-
- _.triggerEvent(element, 'change');
- expect(scope.context['selected']).toEqual([scope.context['values'][0]]);
- });
-
-
- it('should deselect all options when model is emptied', () {
- createMultiSelect();
- scope.apply(() {
- scope.context['values'] = [{'name': 'A'}, {'name': 'B'}];
- scope.context['selected'] = [scope.context['values'][0]];
- });
- expect(element.querySelectorAll('option')[0].selected).toEqual(true);
-
- scope.apply(() {
- scope.context['selected'].removeLast();
- });
-
- expect(element.querySelectorAll('option')[0].selected).toEqual(false);
- });
- });
-
-
- xdescribe('ngRequired', () {
-
- it('should allow bindings on ngRequired', () {
- createSelect({
- 'ng-model': 'value',
- 'ng-options': 'item.name for item in values',
- 'ng-required': 'required'
- }, true);
-
-
- scope.apply(() {
- scope.context['values'] = [{'name': 'A', 'id': 1}, {'name': 'B', 'id': 2}];
- scope.context['required'] = false;
- });
-
- element.value = '';
- _.triggerEvent(element, 'change');
- expect(element).toEqualValid();
-
- scope.apply(() {
- scope.context['required'] = true;
- });
- expect(element).toEqualInvalid();
-
- scope.apply(() {
- scope.context['value'] = scope.context['values'][0];
- });
- expect(element).toEqualValid();
-
- element.value = '';
- _.triggerEvent(element, 'change');
- expect(element).toEqualInvalid();
-
- scope.apply(() {
- scope.context['required'] = false;
- });
- expect(element).toEqualValid();
- });
- });
- });
-
-
- describe('option', () {
-
- it('should populate value attribute on OPTION', () {
- compile('<select ng-model="x"><option selected>abc</option></select>');
- expect(element).toEqualSelect([['?'], 'abc']);
- });
-
- it('should ignore value if already exists', () {
- compile('<select ng-model="x"><option value="abc">xyz</option></select>');
- expect(element).toEqualSelect([['?'], 'abc']);
- });
-
- it('should set value even if self closing HTML', () {
- scope.context['x'] = 'hello';
- compile('<select ng-model="x"><option>hello</select>');
- expect(element).toEqualSelect([['hello']]);
- });
-
- it('should not blow up when option directive is found inside of a datalist',
- () {
- _.compile('<div>' +
- '<datalist><option>some val</option></datalist>' +
- '<span>{{foo}}</span>' +
- '</div>');
-
- _.rootScope.context['foo'] = 'success';
- _.rootScope.apply();
- expect(_.rootElement.querySelector('span').text).toEqual('success');
- });
- });
- });
- });
-}

Powered by Google App Engine
This is Rietveld 408576698