diff options
| author | Elliott Sprehn | 2010-10-18 14:02:18 -0700 |
|---|---|---|
| committer | Elliott Sprehn | 2010-10-19 00:45:38 -0700 |
| commit | e7e894a2e36e042be6d62af56b0f3126f4e4fc77 (patch) | |
| tree | 5b9c8b94bf3e3935a3acd6a3c0ecb142c82f4b17 /scenario/widgets-scenario.js | |
| parent | a1fa23397f12e0b52838530a993f14491ad50869 (diff) | |
| download | angular.js-e7e894a2e36e042be6d62af56b0f3126f4e4fc77.tar.bz2 | |
Significantly clean up the way the scenario DSL works and implement many more DSL statements.
- "this" always means the current chain scope inside a DSL
- addFutureAction callbacks now take ($window, $document, done)
- $document has a special method elements() that uses the currently selected nodes in the document as defined by using() statements.
- $document.elements() allows placeholder insertion into selectors to make them more readable.
ex. $document.elements('input[name="$1"]', myVar) will substitute the value of myVar for $1 in the selector. Subsequent arguments are $2 and so on.
- $document.elements() results have a special method trigger(event) which should be used to events. This method implements some hacks to make sure browser UI controls update and the correct angular events fire.
- futures now allow custom formatting. By default any chain that results in a future can use toJson() or fromJson() to convert the future value to and from json. A custom parser can be provided with parsedWith(fn) where fn is a callback(value) that must return the parsed result.
Note: The entire widgets.html UI is now able to be controlled and asserted through DSL statements!!! Victory! :)
Diffstat (limited to 'scenario/widgets-scenario.js')
| -rw-r--r-- | scenario/widgets-scenario.js | 87 |
1 files changed, 42 insertions, 45 deletions
diff --git a/scenario/widgets-scenario.js b/scenario/widgets-scenario.js index 69fdc10e..befc481c 100644 --- a/scenario/widgets-scenario.js +++ b/scenario/widgets-scenario.js @@ -1,58 +1,55 @@ describe('widgets', function() { it('should verify that basic widgets work', function(){ navigateTo('widgets.html'); - input('text.basic').enter('Carlos'); + + using('#text-basic-box').input('text.basic').enter('Carlos'); expect(binding('text.basic')).toEqual('Carlos'); - pause(2); input('text.basic').enter('Carlos Santana'); - pause(2); expect(binding('text.basic')).not().toEqual('Carlos Boozer'); - pause(2); + input('text.password').enter('secret'); expect(binding('text.password')).toEqual('secret'); + expect(binding('text.hidden')).toEqual('hiddenValue'); + expect(binding('gender')).toEqual('male'); - pause(2); input('gender').select('female'); - expect(binding('gender')).toEqual('female'); - pause(2); - }); - describe('do it again', function() { - it('should verify that basic widgets work', function(){ - navigateTo('widgets.html'); - input('text.basic').enter('Carlos'); - expect(binding('text.basic')).toEqual('Carlos'); - pause(2); - input('text.basic').enter('Carlos Santana'); - pause(2); - expect(binding('text.basic')).toEqual('Carlos Santana'); - pause(2); - input('text.password').enter('secret'); - expect(binding('text.password')).toEqual('secret'); - expect(binding('text.hidden')).toEqual('hiddenValue'); - expect(binding('gender')).toEqual('male'); - pause(2); - input('gender').select('female'); - expect(binding('gender')).toEqual('female'); - pause(2); - }); - }); - it('should verify that basic widgets work', function(){ - navigateTo('widgets.html'); - input('text.basic').enter('Carlos'); - expect(binding('text.basic')).toEqual('Carlos'); - pause(2); - input('text.basic').enter('Carlos Santana'); - pause(2); - expect(binding('text.basic')).toEqual('Carlos Santana'); - pause(2); - input('text.password').enter('secret'); - expect(binding('text.password')).toEqual('secret'); - expect(binding('text.hidden')).toEqual('hiddenValue'); - expect(binding('gender')).toEqual('male'); - pause(2); - input('gender').select('female'); - expect(binding('gender')).toEqual('female'); - pause(2); + expect(using('#gender-box').binding('gender')).toEqual('female'); + + expect(repeater('#repeater-row ul li').count()).toEqual(2); + expect(repeater('#repeater-row ul li').row(1)).toEqual(['adam']); + expect(repeater('#repeater-row ul li').column('name')).toEqual(['misko', 'adam']); + + select('select').option('B'); + expect(binding('select')).toEqual('B'); + + select('multiselect').options('A', 'C'); + expect(binding('multiselect').fromJson()).toEqual(['A', 'C']); + + expect(binding('button').fromJson()).toEqual({'count': 0}); + element('form a').click(); + expect(binding('button').fromJson()).toEqual({'count': 1}); + element('input[value="submit"]').click(); + expect(binding('button').fromJson()).toEqual({'count': 2}); + element('input[value="button"]').click(); + expect(binding('button').fromJson()).toEqual({'count': 3}); + element('input[type="image"]').click(); + expect(binding('button').fromJson()).toEqual({'count': 4}); + + /** + * Custom value parser for futures. + */ + function checkboxParser(value) { + return angular.fromJson(value.substring(value.indexOf('=')+1)); + } + + input('checkbox.tea').check(); + expect(binding('checkbox').parsedWith(checkboxParser)).toEqual({coffee: false, tea: false}); + input('checkbox.coffee').check(); + expect(binding('checkbox').parsedWith(checkboxParser)).toEqual({coffee: true, tea: false}); + input('checkbox.tea').check(); + input('checkbox.tea').check(); + input('checkbox.tea').check(); + expect(binding('checkbox').parsedWith(checkboxParser)).toEqual({coffee: true, tea: true}); }); }); |
