| 
									
										
										
										
											2016-06-23 09:47:54 -07:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @license | 
					
						
							|  |  |  |  * Copyright Google Inc. All Rights Reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Use of this source code is governed by an MIT-style license that can be | 
					
						
							|  |  |  |  * found in the LICENSE file at https://angular.io/license
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-02 15:53:34 -07:00
										 |  |  | import {CssRule, ShadowCss, processRules} from '@angular/compiler/src/shadow_css'; | 
					
						
							|  |  |  | import {beforeEach, ddescribe, describe, expect, iit, it} from '@angular/core/testing/testing_internal'; | 
					
						
							|  |  |  | import {normalizeCSS} from '@angular/platform-browser/testing/browser_util'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export function main() { | 
					
						
							|  |  |  |   describe('ShadowCss', function() { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-26 09:25:39 -07:00
										 |  |  |     function s(css: string, contentAttr: string, hostAttr: string = '') { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const shadowCss = new ShadowCss(); | 
					
						
							|  |  |  |       const shim = shadowCss.shimCssText(css, contentAttr, hostAttr); | 
					
						
							|  |  |  |       const nlRegexp = /\n/g; | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       return normalizeCSS(shim.replace(nlRegexp, '')); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-26 09:25:39 -07:00
										 |  |  |     it('should handle empty string', () => { expect(s('', 'a')).toEqual(''); }); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should add an attribute to every rule', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = 'one {color: red;}two {color: red;}'; | 
					
						
							|  |  |  |       const expected = 'one[a] {color:red;}two[a] {color:red;}'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-29 17:27:44 -07:00
										 |  |  |     it('should handle invalid css', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = 'one {color: red;}garbage'; | 
					
						
							|  |  |  |       const expected = 'one[a] {color:red;}garbage'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should add an attribute to every selector', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = 'one, two {color: red;}'; | 
					
						
							|  |  |  |       const expected = 'one[a], two[a] {color:red;}'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |     it('should support newlines in the selector and content ', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = 'one, \ntwo {\ncolor: red;}'; | 
					
						
							|  |  |  |       const expected = 'one[a], two[a] {color:red;}'; | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     it('should handle media rules', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = '@media screen and (max-width:800px, max-height:100%) {div {font-size:50px;}}'; | 
					
						
							|  |  |  |       const expected = | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |           '@media screen and (max-width:800px, max-height:100%) {div[a] {font-size:50px;}}'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle media rules with simple rules', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = '@media screen and (max-width: 800px) {div {font-size: 50px;}} div {}'; | 
					
						
							|  |  |  |       const expected = '@media screen and (max-width:800px) {div[a] {font-size:50px;}} div[a] {}'; | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-17 21:18:11 -04:00
										 |  |  |     it('should handle support rules', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = '@supports (display: flex) {section {display: flex;}}'; | 
					
						
							|  |  |  |       const expected = '@supports (display:flex) {section[a] {display:flex;}}'; | 
					
						
							| 
									
										
										
										
											2016-04-17 21:18:11 -04:00
										 |  |  |       expect(s(css, 'a')).toEqual(expected); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-02 14:59:35 +02:00
										 |  |  |     // Check that the browser supports unprefixed CSS animation
 | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |     it('should handle keyframes rules', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = '@keyframes foo {0% {transform:translate(-50%) scaleX(0);}}'; | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(css); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-05-26 12:30:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |     it('should handle -webkit-keyframes rules', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = '@-webkit-keyframes foo {0% {-webkit-transform:translate(-50%) scaleX(0);}}'; | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(s(css, 'a')).toEqual(css); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-05-26 12:30:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     it('should handle complicated selectors', () => { | 
					
						
							|  |  |  |       expect(s('one::before {}', 'a')).toEqual('one[a]::before {}'); | 
					
						
							|  |  |  |       expect(s('one two {}', 'a')).toEqual('one[a] two[a] {}'); | 
					
						
							| 
									
										
										
										
											2015-09-29 17:27:44 -07:00
										 |  |  |       expect(s('one > two {}', 'a')).toEqual('one[a] > two[a] {}'); | 
					
						
							|  |  |  |       expect(s('one + two {}', 'a')).toEqual('one[a] + two[a] {}'); | 
					
						
							|  |  |  |       expect(s('one ~ two {}', 'a')).toEqual('one[a] ~ two[a] {}'); | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const res = s('.one.two > three {}', 'a');  // IE swap classes
 | 
					
						
							| 
									
										
										
										
											2015-05-27 10:22:30 +02:00
										 |  |  |       expect(res == '.one.two[a] > three[a] {}' || res == '.two.one[a] > three[a] {}') | 
					
						
							|  |  |  |           .toEqual(true); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s('one[attr="value"] {}', 'a')).toEqual('one[attr="value"][a] {}'); | 
					
						
							|  |  |  |       expect(s('one[attr=value] {}', 'a')).toEqual('one[attr="value"][a] {}'); | 
					
						
							|  |  |  |       expect(s('one[attr^="value"] {}', 'a')).toEqual('one[attr^="value"][a] {}'); | 
					
						
							|  |  |  |       expect(s('one[attr$="value"] {}', 'a')).toEqual('one[attr$="value"][a] {}'); | 
					
						
							|  |  |  |       expect(s('one[attr*="value"] {}', 'a')).toEqual('one[attr*="value"][a] {}'); | 
					
						
							|  |  |  |       expect(s('one[attr|="value"] {}', 'a')).toEqual('one[attr|="value"][a] {}'); | 
					
						
							| 
									
										
										
										
											2016-09-19 00:58:19 +02:00
										 |  |  |       expect(s('one[attr~="value"] {}', 'a')).toEqual('one[attr~="value"][a] {}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s('one[attr] {}', 'a')).toEqual('one[attr][a] {}'); | 
					
						
							|  |  |  |       expect(s('[is="one"] {}', 'a')).toEqual('[is="one"][a] {}'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle :host', () => { | 
					
						
							|  |  |  |       expect(s(':host {}', 'a', 'a-host')).toEqual('[a-host] {}'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(s(':host(.x,.y) {}', 'a', 'a-host')).toEqual('[a-host].x, [a-host].y {}'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-26 09:25:39 -07:00
										 |  |  |       expect(s(':host(.x,.y) > .z {}', 'a', 'a-host')) | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |           .toEqual('[a-host].x > .z[a], [a-host].y > .z[a] {}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle :host-context', () => { | 
					
						
							|  |  |  |       expect(s(':host-context(.x) {}', 'a', 'a-host')).toEqual('[a-host].x, .x [a-host] {}'); | 
					
						
							| 
									
										
										
										
											2015-05-26 09:25:39 -07:00
										 |  |  |       expect(s(':host-context(.x) > .y {}', 'a', 'a-host')) | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |           .toEqual('[a-host].x > .y[a], .x [a-host] > .y[a] {}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support polyfill-next-selector', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       let css = s('polyfill-next-selector {content: \'x > y\'} z {}', 'a'); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(css).toEqual('x[a] > y[a]{}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       css = s('polyfill-next-selector {content: "x > y"} z {}', 'a'); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(css).toEqual('x[a] > y[a]{}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should support polyfill-unscoped-rule', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       let css = s('polyfill-unscoped-rule {content: \'#menu > .bar\';color: blue;}', 'a'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       expect(css).toContain('#menu > .bar {;color:blue;}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-21 17:12:10 +02:00
										 |  |  |       css = s('polyfill-unscoped-rule {content: "#menu > .bar";color: blue;}', 'a'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       expect(css).toContain('#menu > .bar {;color:blue;}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-10 10:38:24 -07:00
										 |  |  |     it('should support multiple instances polyfill-unscoped-rule', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  |           s('polyfill-unscoped-rule {content: \'foo\';color: blue;}' + | 
					
						
							|  |  |  |                 'polyfill-unscoped-rule {content: \'bar\';color: blue;}', | 
					
						
							|  |  |  |             'a'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       expect(css).toContain('foo {;color:blue;}'); | 
					
						
							|  |  |  |       expect(css).toContain('bar {;color:blue;}'); | 
					
						
							| 
									
										
										
										
											2015-07-10 10:38:24 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     it('should support polyfill-rule', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       let css = s('polyfill-rule {content: \':host.foo .bar\';color: blue;}', 'a', 'a-host'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       expect(css).toEqual('[a-host].foo .bar[a] {;color:blue;}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-27 10:22:30 +02:00
										 |  |  |       css = s('polyfill-rule {content: ":host.foo .bar";color:blue;}', 'a', 'a-host'); | 
					
						
							| 
									
										
										
										
											2016-08-26 16:11:57 -07:00
										 |  |  |       expect(css).toEqual('[a-host].foo .bar[a] {;color:blue;}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle ::shadow', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = s('x::shadow > y {}', 'a'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |       expect(css).toEqual('x[a] > y[a] {}'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle /deep/', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = s('x /deep/ y {}', 'a'); | 
					
						
							| 
									
										
										
										
											2016-03-11 13:35:28 -08:00
										 |  |  |       expect(css).toEqual('x[a] y {}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should handle >>>', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const css = s('x >>> y {}', 'a'); | 
					
						
							| 
									
										
										
										
											2016-03-11 13:35:28 -08:00
										 |  |  |       expect(css).toEqual('x[a] y {}'); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-10-07 13:37:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |     it('should pass through @import directives', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const styleStr = '@import url("https://fonts.googleapis.com/css?family=Roboto");'; | 
					
						
							|  |  |  |       const css = s(styleStr, 'a'); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(css).toEqual(styleStr); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-10-15 12:15:42 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |     it('should shim rules after @import', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const styleStr = '@import url("a"); div {}'; | 
					
						
							|  |  |  |       const css = s(styleStr, 'a'); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(css).toEqual('@import url("a"); div[a] {}'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('should leave calc() unchanged', () => { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |       const styleStr = 'div {height:calc(100% - 55px);}'; | 
					
						
							|  |  |  |       const css = s(styleStr, 'a'); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |       expect(css).toEqual('div[a] {height:calc(100% - 55px);}'); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |     it('should strip comments', () => { expect(s('/* x */b {c}', 'a')).toEqual('b[a] {c}'); }); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |     it('should ignore special characters in comments', | 
					
						
							|  |  |  |        () => { expect(s('/* {;, */b {c}', 'a')).toEqual('b[a] {c}'); }); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |     it('should support multiline comments', | 
					
						
							|  |  |  |        () => { expect(s('/* \n */b {c}', 'a')).toEqual('b[a] {c}'); }); | 
					
						
							| 
									
										
										
										
											2016-08-12 16:39:43 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('should keep sourceMappingURL comments', () => { | 
					
						
							|  |  |  |       expect(s('b {c}/*# sourceMappingURL=data:x */', 'a')) | 
					
						
							|  |  |  |           .toEqual('b[a] {c}/*# sourceMappingURL=data:x */'); | 
					
						
							|  |  |  |       expect(s('b {c}/* #sourceMappingURL=data:x */', 'a')) | 
					
						
							|  |  |  |           .toEqual('b[a] {c}/* #sourceMappingURL=data:x */'); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |   describe('processRules', () => { | 
					
						
							|  |  |  |     describe('parse rules', () => { | 
					
						
							|  |  |  |       function captureRules(input: string): CssRule[] { | 
					
						
							| 
									
										
										
										
											2016-08-13 06:20:58 +08:00
										 |  |  |         const result: any[] /** TODO #9100 */ = []; | 
					
						
							| 
									
										
										
										
											2016-06-08 15:45:15 -07:00
										 |  |  |         processRules(input, (cssRule: any /** TODO #9100 */) => { | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |           result.push(cssRule); | 
					
						
							|  |  |  |           return cssRule; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         return result; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should work with empty css', () => { expect(captureRules('')).toEqual([]); }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should capture a rule without body', | 
					
						
							|  |  |  |          () => { expect(captureRules('a;')).toEqual([new CssRule('a', '')]); }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should capture css rules with body', | 
					
						
							|  |  |  |          () => { expect(captureRules('a {b}')).toEqual([new CssRule('a', 'b')]); }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should capture css rules with nested rules', () => { | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  |         expect(captureRules('a {b {c}} d {e}')).toEqual([ | 
					
						
							|  |  |  |           new CssRule('a', 'b {c}'), new CssRule('d', 'e') | 
					
						
							|  |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-16 15:47:48 +08:00
										 |  |  |       it('should capture multiple rules where some have no body', () => { | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  |         expect(captureRules('@import a ; b {c}')).toEqual([ | 
					
						
							|  |  |  |           new CssRule('@import a', ''), new CssRule('b', 'c') | 
					
						
							|  |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     describe('modify rules', () => { | 
					
						
							|  |  |  |       it('should allow to change the selector while preserving whitespaces', () => { | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  |         expect(processRules( | 
					
						
							|  |  |  |                    '@import a; b {c {d}} e {f}', (cssRule: any /** TODO #9100 */) => new CssRule( | 
					
						
							|  |  |  |                                                      cssRule.selector + '2', cssRule.content))) | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |             .toEqual('@import a2; b2 {c {d}} e2 {f}'); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       it('should allow to change the content', () => { | 
					
						
							| 
									
										
										
										
											2016-06-08 16:38:52 -07:00
										 |  |  |         expect(processRules( | 
					
						
							|  |  |  |                    'a {b}', (cssRule: any /** TODO #9100 */) => | 
					
						
							|  |  |  |                                 new CssRule(cssRule.selector, cssRule.content + '2'))) | 
					
						
							| 
									
										
										
										
											2015-10-30 15:09:04 -07:00
										 |  |  |             .toEqual('a {b2}'); | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2015-10-29 10:57:54 -07:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2015-03-23 14:10:55 -07:00
										 |  |  |   }); | 
					
						
							|  |  |  | } |