From 0def28e594f61fbf2e98167d1611a997b74c020b Mon Sep 17 00:00:00 2001 From: Marc Laval Date: Fri, 9 Oct 2015 15:05:38 +0200 Subject: [PATCH] fix(compiler): shadow CSS @import test in some browsers Closes #4629 --- modules/angular2/src/test_lib/utils.ts | 3 ++- .../angular2/test/core/compiler/shadow_css_spec.ts | 14 +++++++++----- 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/modules/angular2/src/test_lib/utils.ts b/modules/angular2/src/test_lib/utils.ts index 50d2a1793ed239..281c818a52afa0 100644 --- a/modules/angular2/src/test_lib/utils.ts +++ b/modules/angular2/src/test_lib/utils.ts @@ -88,7 +88,8 @@ export function normalizeCSS(css: string): string { css = StringWrapper.replaceAll(css, /:\s/g, ':'); css = StringWrapper.replaceAll(css, /'/g, '"'); css = StringWrapper.replaceAll(css, / }/g, '}'); - css = StringWrapper.replaceAllMapped(css, /url\(\"(.+)\\"\)/g, (match) => `url(${match[1]})`); + css = StringWrapper.replaceAllMapped(css, /url\((\"|\s)(.+)(\"|\s)\)(\s*)/g, + (match) => `url("${match[2]}")`); css = StringWrapper.replaceAllMapped(css, /\[(.+)=([^"\]]+)\]/g, (match) => `[${match[1]}="${match[2]}"]`); return css; diff --git a/modules/angular2/test/core/compiler/shadow_css_spec.ts b/modules/angular2/test/core/compiler/shadow_css_spec.ts index 1e9c334fd24b9d..6159b71206b7f0 100644 --- a/modules/angular2/test/core/compiler/shadow_css_spec.ts +++ b/modules/angular2/test/core/compiler/shadow_css_spec.ts @@ -155,10 +155,14 @@ export function main() { expect(css).toEqual('x[a] y[a] {}'); }); - it('should pass through @import directives', () => { - var styleStr = '@import url("https://fonts.googleapis.com/css?family=Roboto");'; - var css = s(styleStr, 'a'); - expect(css).toEqual(styleStr); - }); + // TODO: can't work in Firefox, see https://bugzilla.mozilla.org/show_bug.cgi?id=625013 + // Issue opened to track that: https://github.com/angular/angular/issues/4628 + if (!browserDetection.isFirefox) { + it('should pass through @import directives', () => { + var styleStr = '@import url("https://fonts.googleapis.com/css?family=Roboto");'; + var css = s(styleStr, 'a'); + expect(css).toEqual(styleStr); + }); + } }); }