⌈⌋ ⎇ branch:  Bitrhythm


Hex Artifact Content

Artifact 56d8ceddab1cd5af81a4e75bbf2cdf71d4558e3e501d2b1a5e3f33e12b0019dd:


0000: 69 6d 70 6f 72 74 20 7b 0a 20 20 69 6e 6a 65 63  import {.  injec
0010: 74 48 54 4d 4c 2c 0a 20 20 67 65 74 52 69 6f 74  tHTML,.  getRiot
0020: 53 74 79 6c 65 73 2c 0a 20 20 24 0a 7d 20 66 72  Styles,.  $.} fr
0030: 6f 6d 20 27 2e 2e 2f 2e 2e 2f 2e 2e 2f 68 65 6c  om '../../../hel
0040: 70 65 72 73 2f 69 6e 64 65 78 27 0a 0a 2f 2f 20  pers/index'..// 
0050: 69 6e 63 6c 75 64 65 20 73 70 65 63 69 61 6c 20  include special 
0060: 74 61 67 73 20 74 6f 20 74 65 73 74 20 73 70 65  tags to test spe
0070: 63 69 66 69 63 20 66 65 61 74 75 72 65 73 0a 69  cific features.i
0080: 6d 70 6f 72 74 20 27 2e 2e 2f 2e 2e 2f 2e 2e 2f  mport '../../../
0090: 74 61 67 2f 73 74 79 6c 65 2d 74 61 67 2e 74 61  tag/style-tag.ta
00a0: 67 27 0a 69 6d 70 6f 72 74 20 27 2e 2e 2f 2e 2e  g'.import '../..
00b0: 2f 2e 2e 2f 74 61 67 2f 73 74 79 6c 65 2d 74 61  /../tag/style-ta
00c0: 67 32 2e 74 61 67 27 0a 69 6d 70 6f 72 74 20 27  g2.tag'.import '
00d0: 2e 2e 2f 2e 2e 2f 2e 2e 2f 74 61 67 2f 73 74 79  ../../../tag/sty
00e0: 6c 65 2d 74 61 67 34 2e 74 61 67 27 0a 69 6d 70  le-tag4.tag'.imp
00f0: 6f 72 74 20 27 2e 2e 2f 2e 2e 2f 2e 2e 2f 74 61  ort '../../../ta
0100: 67 2f 73 63 6f 70 65 64 2e 74 61 67 27 0a 0a 64  g/scoped.tag'..d
0110: 65 73 63 72 69 62 65 28 27 52 69 6f 74 20 73 74  escribe('Riot st
0120: 79 6c 65 27 2c 20 66 75 6e 63 74 69 6f 6e 28 29  yle', function()
0130: 20 7b 0a 20 20 69 74 28 27 73 74 79 6c 65 20 69   {.  it('style i
0140: 6e 6a 65 63 74 69 6f 6e 20 74 6f 20 73 69 6e 67  njection to sing
0150: 6c 65 20 73 74 79 6c 65 20 74 61 67 27 2c 20 66  le style tag', f
0160: 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20  unction() {.    
0170: 69 6e 6a 65 63 74 48 54 4d 4c 28 27 3c 73 74 79  injectHTML('<sty
0180: 6c 65 2d 74 61 67 3e 3c 2f 73 74 79 6c 65 2d 74  le-tag></style-t
0190: 61 67 3e 3c 73 74 79 6c 65 2d 74 61 67 32 3e 3c  ag><style-tag2><
01a0: 2f 73 74 79 6c 65 2d 74 61 67 32 3e 27 29 0a 20  /style-tag2>'). 
01b0: 20 20 20 76 61 72 20 74 61 67 73 20 3d 20 72 69     var tags = ri
01c0: 6f 74 2e 6d 6f 75 6e 74 28 27 73 74 79 6c 65 2d  ot.mount('style-
01d0: 74 61 67 2c 20 73 74 79 6c 65 2d 74 61 67 32 27  tag, style-tag2'
01e0: 29 0a 20 20 20 20 76 61 72 20 73 74 79 6c 65 73  ).    var styles
01f0: 20 3d 20 67 65 74 52 69 6f 74 53 74 79 6c 65 73   = getRiotStyles
0200: 28 72 69 6f 74 29 0a 20 20 20 20 65 78 70 65 63  (riot).    expec
0210: 74 28 73 74 79 6c 65 73 29 2e 74 6f 2e 6d 61 74  t(styles).to.mat
0220: 63 68 28 2f 5c 62 70 5c 73 2a 5c 7b 63 6f 6c 6f  ch(/\bp\s*\{colo
0230: 72 3a 20 62 6c 75 65 3b 7d 2f 29 0a 20 20 20 20  r: blue;}/).    
0240: 65 78 70 65 63 74 28 73 74 79 6c 65 73 29 2e 74  expect(styles).t
0250: 6f 2e 6d 61 74 63 68 28 2f 5c 62 64 69 76 5c 73  o.match(/\bdiv\s
0260: 2a 5c 7b 63 6f 6c 6f 72 3a 20 72 65 64 3b 7d 2f  *\{color: red;}/
0270: 29 0a 20 20 20 20 74 61 67 73 2e 66 6f 72 45 61  ).    tags.forEa
0280: 63 68 28 74 61 67 20 3d 3e 20 74 61 67 2e 75 6e  ch(tag => tag.un
0290: 6d 6f 75 6e 74 28 29 29 0a 20 20 7d 29 0a 0a 20  mount()).  }).. 
02a0: 20 69 74 28 27 73 74 79 6c 65 20 69 6e 6a 65 63   it('style injec
02b0: 74 69 6f 6e 20 72 65 6d 6f 76 65 73 20 74 79 70  tion removes typ
02c0: 65 20 72 69 6f 74 20 73 74 79 6c 65 20 74 61 67  e riot style tag
02d0: 27 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a  ', function() {.
02e0: 20 20 20 20 76 61 72 20 73 74 61 67 20 3d 20 24      var stag = $
02f0: 28 27 73 74 79 6c 65 5b 74 79 70 65 3d 72 69 6f  ('style[type=rio
0300: 74 5d 27 29 0a 20 20 20 20 65 78 70 65 63 74 28  t]').    expect(
0310: 73 74 61 67 29 2e 74 6f 2e 62 65 2e 65 71 75 61  stag).to.be.equa
0320: 6c 28 6e 75 6c 6c 29 0a 20 20 7d 29 0a 0a 20 20  l(null).  })..  
0330: 69 74 28 27 73 63 6f 70 65 64 20 63 73 73 20 74  it('scoped css t
0340: 61 67 20 73 75 70 70 6f 72 74 73 20 68 74 6d 35  ag supports htm5
0350: 20 73 79 6e 74 61 78 2c 20 6d 75 6c 74 69 70 6c   syntax, multipl
0360: 65 20 73 74 79 6c 65 20 74 61 67 73 27 2c 20 66  e style tags', f
0370: 75 6e 63 74 69 6f 6e 20 28 29 20 7b 0a 0a 20 20  unction () {..  
0380: 20 20 69 6e 6a 65 63 74 48 54 4d 4c 28 27 3c 73    injectHTML('<s
0390: 74 79 6c 65 2d 74 61 67 34 3e 3c 2f 73 74 79 6c  tyle-tag4></styl
03a0: 65 2d 74 61 67 34 3e 27 29 0a 0a 20 20 20 20 63  e-tag4>')..    c
03b0: 68 65 63 6b 43 53 53 28 72 69 6f 74 2e 6d 6f 75  heckCSS(riot.mou
03c0: 6e 74 28 27 73 74 79 6c 65 2d 74 61 67 34 27 29  nt('style-tag4')
03d0: 5b 30 5d 2c 20 27 33 70 78 27 29 0a 0a 20 20 20  [0], '3px')..   
03e0: 20 66 75 6e 63 74 69 6f 6e 20 63 68 65 63 6b 43   function checkC
03f0: 53 53 28 74 2c 20 78 2c 20 70 32 29 20 7b 0a 20  SS(t, x, p2) {. 
0400: 20 20 20 20 20 74 2e 75 70 64 61 74 65 28 29 0a       t.update().
0410: 20 20 20 20 20 20 76 61 72 20 65 20 3d 20 74 2e        var e = t.
0420: 72 6f 6f 74 2e 66 69 72 73 74 45 6c 65 6d 65 6e  root.firstElemen
0430: 74 43 68 69 6c 64 0a 20 20 20 20 20 20 65 78 70  tChild.      exp
0440: 65 63 74 28 65 2e 74 61 67 4e 61 6d 65 29 2e 74  ect(e.tagName).t
0450: 6f 2e 62 65 2e 65 71 75 61 6c 28 27 50 27 29 0a  o.be.equal('P').
0460: 20 20 20 20 20 20 65 78 70 65 63 74 28 77 69 6e        expect(win
0470: 64 6f 77 2e 67 65 74 43 6f 6d 70 75 74 65 64 53  dow.getComputedS
0480: 74 79 6c 65 28 65 2c 20 6e 75 6c 6c 29 2e 62 6f  tyle(e, null).bo
0490: 72 64 65 72 54 6f 70 57 69 64 74 68 29 2e 74 6f  rderTopWidth).to
04a0: 2e 62 65 2e 65 71 75 61 6c 28 78 29 0a 20 20 20  .be.equal(x).   
04b0: 20 20 20 69 66 20 28 70 32 29 20 7b 0a 20 20 20     if (p2) {.   
04c0: 20 20 20 20 20 65 20 3d 20 74 2e 72 6f 6f 74 2e       e = t.root.
04d0: 67 65 74 45 6c 65 6d 65 6e 74 73 42 79 54 61 67  getElementsByTag
04e0: 4e 61 6d 65 28 27 50 27 29 5b 31 5d 0a 20 20 20  Name('P')[1].   
04f0: 20 20 20 20 20 65 78 70 65 63 74 28 65 2e 69 6e       expect(e.in
0500: 6e 65 72 48 54 4d 4c 29 2e 74 6f 2e 62 65 2e 65  nerHTML).to.be.e
0510: 71 75 61 6c 28 27 78 27 29 0a 20 20 20 20 20 20  qual('x').      
0520: 20 20 65 78 70 65 63 74 28 77 69 6e 64 6f 77 2e    expect(window.
0530: 67 65 74 43 6f 6d 70 75 74 65 64 53 74 79 6c 65  getComputedStyle
0540: 28 65 2c 20 6e 75 6c 6c 29 2e 62 6f 72 64 65 72  (e, null).border
0550: 54 6f 70 57 69 64 74 68 29 2e 74 6f 2e 62 65 2e  TopWidth).to.be.
0560: 65 71 75 61 6c 28 27 34 70 78 27 29 0a 20 20 20  equal('4px').   
0570: 20 20 20 7d 0a 20 20 20 20 20 20 74 2e 75 6e 6d     }.      t.unm
0580: 6f 75 6e 74 28 29 0a 20 20 20 20 7d 0a 20 20 7d  ount().    }.  }
0590: 29 0a 0a 0a 20 20 69 74 28 27 73 63 6f 70 65 64  )...  it('scoped
05a0: 20 63 73 73 20 61 6e 64 20 64 61 74 61 2d 69 73   css and data-is
05b0: 2c 20 6d 6f 75 6e 74 28 73 65 6c 65 63 74 6f 72  , mount(selector
05c0: 2c 20 74 61 67 6e 61 6d 65 29 27 2c 20 66 75 6e  , tagname)', fun
05d0: 63 74 69 6f 6e 28 29 20 7b 0a 0a 0a 20 20 20 20  ction() {...    
05e0: 66 75 6e 63 74 69 6f 6e 20 63 68 65 63 6b 42 6f  function checkBo
05f0: 72 64 65 72 28 74 29 20 7b 0a 20 20 20 20 20 20  rder(t) {.      
0600: 76 61 72 20 65 20 3d 20 74 2e 72 6f 6f 74 2e 66  var e = t.root.f
0610: 69 72 73 74 45 6c 65 6d 65 6e 74 43 68 69 6c 64  irstElementChild
0620: 0a 20 20 20 20 20 20 76 61 72 20 73 20 3d 20 77  .      var s = w
0630: 69 6e 64 6f 77 2e 67 65 74 43 6f 6d 70 75 74 65  indow.getCompute
0640: 64 53 74 79 6c 65 28 65 2c 20 6e 75 6c 6c 29 2e  dStyle(e, null).
0650: 62 6f 72 64 65 72 54 6f 70 57 69 64 74 68 0a 20  borderTopWidth. 
0660: 20 20 20 20 20 65 78 70 65 63 74 28 73 29 2e 74       expect(s).t
0670: 6f 2e 62 65 2e 65 71 75 61 6c 28 27 31 70 78 27  o.be.equal('1px'
0680: 29 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 6a  ).    }..    inj
0690: 65 63 74 48 54 4d 4c 28 5b 0a 20 20 20 20 20 20  ectHTML([.      
06a0: 27 3c 73 63 6f 70 65 64 2d 74 61 67 3e 3c 2f 73  '<scoped-tag></s
06b0: 63 6f 70 65 64 2d 74 61 67 3e 27 2c 0a 20 20 20  coped-tag>',.   
06c0: 20 20 20 27 3c 64 69 76 20 64 61 74 61 2d 69 73     '<div data-is
06d0: 3d 22 73 63 6f 70 65 64 2d 74 61 67 22 3e 3c 2f  ="scoped-tag"></
06e0: 64 69 76 3e 27 2c 0a 20 20 20 20 20 20 27 3c 64  div>',.      '<d
06f0: 69 76 20 69 64 3d 22 73 63 6f 70 65 64 74 61 67  iv id="scopedtag
0700: 22 3e 3c 2f 64 69 76 3e 27 0a 20 20 20 20 5d 29  "></div>'.    ])
0710: 0a 0a 20 20 20 20 76 61 72 20 73 74 61 67 73 20  ..    var stags 
0720: 3d 20 72 69 6f 74 2e 6d 6f 75 6e 74 28 27 73 63  = riot.mount('sc
0730: 6f 70 65 64 2d 74 61 67 27 29 0a 0a 20 20 20 20  oped-tag')..    
0740: 76 61 72 20 74 61 67 20 3d 20 73 74 61 67 73 5b  var tag = stags[
0750: 30 5d 0a 20 20 20 20 63 68 65 63 6b 42 6f 72 64  0].    checkBord
0760: 65 72 28 74 61 67 29 0a 0a 20 20 20 20 76 61 72  er(tag)..    var
0770: 20 72 74 61 67 20 3d 20 73 74 61 67 73 5b 31 5d   rtag = stags[1]
0780: 0a 20 20 20 20 63 68 65 63 6b 42 6f 72 64 65 72  .    checkBorder
0790: 28 72 74 61 67 29 0a 0a 20 20 20 20 76 61 72 20  (rtag)..    var 
07a0: 64 69 76 74 61 67 20 3d 20 72 69 6f 74 2e 6d 6f  divtag = riot.mo
07b0: 75 6e 74 28 27 23 73 63 6f 70 65 64 74 61 67 27  unt('#scopedtag'
07c0: 2c 20 27 73 63 6f 70 65 64 2d 74 61 67 27 29 5b  , 'scoped-tag')[
07d0: 30 5d 0a 20 20 20 20 63 68 65 63 6b 42 6f 72 64  0].    checkBord
07e0: 65 72 28 64 69 76 74 61 67 29 0a 0a 20 20 20 20  er(divtag)..    
07f0: 64 69 76 74 61 67 2e 75 6e 6d 6f 75 6e 74 28 29  divtag.unmount()
0800: 0a 20 20 20 20 72 74 61 67 2e 75 6e 6d 6f 75 6e  .    rtag.unmoun
0810: 74 28 29 0a 20 20 20 20 74 61 67 2e 75 6e 6d 6f  t().    tag.unmo
0820: 75 6e 74 28 29 0a 20 20 7d 29 0a 0a 20 20 69 74  unt().  })..  it
0830: 28 27 64 65 66 65 72 72 65 64 20 69 6e 6a 65 63  ('deferred injec
0840: 74 69 6f 6e 20 6f 66 20 73 74 79 6c 65 73 20 69  tion of styles i
0850: 6e 20 62 61 74 63 68 27 2c 20 66 75 6e 63 74 69  n batch', functi
0860: 6f 6e 28 29 20 7b 0a 0a 20 20 20 20 2f 2f 20 74  on() {..    // t
0870: 65 73 74 20 72 69 6f 74 2e 75 74 69 6c 2e 73 74  est riot.util.st
0880: 79 6c 65 4e 6f 64 65 0a 20 20 20 20 65 78 70 65  yleNode.    expe
0890: 63 74 28 72 69 6f 74 2e 75 74 69 6c 2e 73 74 79  ct(riot.util.sty
08a0: 6c 65 4e 6f 64 65 29 2e 74 6f 2e 6e 6f 74 2e 62  leNode).to.not.b
08b0: 65 2e 65 71 75 61 6c 28 75 6e 64 65 66 69 6e 65  e.equal(undefine
08c0: 64 29 0a 20 20 20 20 65 78 70 65 63 74 28 72 69  d).    expect(ri
08d0: 6f 74 2e 75 74 69 6c 2e 73 74 79 6c 65 4e 6f 64  ot.util.styleNod
08e0: 65 2e 74 61 67 4e 61 6d 65 29 2e 74 6f 2e 62 65  e.tagName).to.be
08f0: 2e 65 71 75 61 6c 28 27 53 54 59 4c 45 27 29 0a  .equal('STYLE').
0900: 0a 20 20 20 20 2f 2f 20 74 65 73 74 20 73 74 79  .    // test sty
0910: 6c 65 20 69 73 6e 27 74 20 69 6e 6a 65 63 74 65  le isn't injecte
0920: 64 20 79 65 74 0a 20 20 20 20 76 61 72 20 73 74  d yet.    var st
0930: 79 6c 65 73 20 3d 20 67 65 74 52 69 6f 74 53 74  yles = getRiotSt
0940: 79 6c 65 73 28 72 69 6f 74 29 0a 20 20 20 20 65  yles(riot).    e
0950: 78 70 65 63 74 28 73 74 79 6c 65 73 29 2e 6e 6f  xpect(styles).no
0960: 74 2e 74 6f 2e 6d 61 74 63 68 28 2f 5c 62 70 61  t.to.match(/\bpa
0970: 72 73 65 64 2d 73 74 79 6c 65 5c 73 2a 5c 7b 2f  rsed-style\s*\{/
0980: 29 0a 0a 20 20 20 20 2f 2f 20 64 65 66 69 6e 65  )..    // define
0990: 20 61 20 73 74 79 6c 65 64 20 74 61 67 0a 20 20   a styled tag.  
09a0: 20 20 72 69 6f 74 2e 74 61 67 28 27 72 75 6e 74    riot.tag('runt
09b0: 69 6d 65 2d 73 74 79 6c 65 2d 70 61 72 73 69 6e  ime-style-parsin
09c0: 67 27 2c 20 27 3c 64 69 76 3e 3c 2f 64 69 76 3e  g', '<div></div>
09d0: 27 2c 20 27 2e 70 61 72 73 65 64 2d 73 74 79 6c  ', '.parsed-styl
09e0: 65 20 7b 20 63 6f 6c 6f 72 3a 20 72 65 64 3b 20  e { color: red; 
09f0: 7d 27 2c 20 27 27 2c 20 66 75 6e 63 74 69 6f 6e  }', '', function
0a00: 28 29 20 7b 20 7d 29 0a 0a 20 20 20 20 2f 2f 20  () { })..    // 
0a10: 74 65 73 74 20 73 74 79 6c 65 20 69 73 6e 27 74  test style isn't
0a20: 20 69 6e 6a 65 63 74 65 64 20 62 79 20 74 68 65   injected by the
0a30: 20 73 69 6d 70 6c 65 20 74 61 67 20 64 65 66 69   simple tag defi
0a40: 6e 69 74 69 6f 6e 0a 20 20 20 20 73 74 79 6c 65  nition.    style
0a50: 73 20 3d 20 67 65 74 52 69 6f 74 53 74 79 6c 65  s = getRiotStyle
0a60: 73 28 72 69 6f 74 29 0a 20 20 20 20 65 78 70 65  s(riot).    expe
0a70: 63 74 28 73 74 79 6c 65 73 29 2e 6e 6f 74 2e 74  ct(styles).not.t
0a80: 6f 2e 6d 61 74 63 68 28 2f 5c 62 70 61 72 73 65  o.match(/\bparse
0a90: 64 2d 73 74 79 6c 65 5c 73 2a 5c 7b 2f 29 0a 0a  d-style\s*\{/)..
0aa0: 20 20 20 20 2f 2f 20 6d 6f 75 6e 74 20 74 68 65      // mount the
0ab0: 20 74 61 67 0a 20 20 20 20 69 6e 6a 65 63 74 48   tag.    injectH
0ac0: 54 4d 4c 28 5b 27 3c 72 75 6e 74 69 6d 65 2d 73  TML(['<runtime-s
0ad0: 74 79 6c 65 2d 70 61 72 73 69 6e 67 3e 3c 2f 72  tyle-parsing></r
0ae0: 75 6e 74 69 6d 65 2d 73 74 79 6c 65 2d 70 61 72  untime-style-par
0af0: 73 69 6e 67 3e 27 20 5d 29 0a 20 20 20 20 76 61  sing>' ]).    va
0b00: 72 20 74 61 67 20 3d 20 72 69 6f 74 2e 6d 6f 75  r tag = riot.mou
0b10: 6e 74 28 27 72 75 6e 74 69 6d 65 2d 73 74 79 6c  nt('runtime-styl
0b20: 65 2d 70 61 72 73 69 6e 67 27 29 5b 30 5d 0a 0a  e-parsing')[0]..
0b30: 20 20 20 20 2f 2f 20 74 65 73 74 20 73 74 79 6c      // test styl
0b40: 65 20 69 73 20 63 6f 72 72 65 63 74 6c 79 20 69  e is correctly i
0b50: 6e 6a 65 63 74 65 64 0a 20 20 20 20 73 74 79 6c  njected.    styl
0b60: 65 73 20 3d 20 67 65 74 52 69 6f 74 53 74 79 6c  es = getRiotStyl
0b70: 65 73 28 72 69 6f 74 29 0a 20 20 20 20 65 78 70  es(riot).    exp
0b80: 65 63 74 28 73 74 79 6c 65 73 29 2e 74 6f 2e 6d  ect(styles).to.m
0b90: 61 74 63 68 28 2f 5c 62 70 61 72 73 65 64 2d 73  atch(/\bparsed-s
0ba0: 74 79 6c 65 5c 73 2a 5c 7b 5c 73 2a 63 6f 6c 6f  tyle\s*\{\s*colo
0bb0: 72 3a 5c 73 2a 72 65 64 3b 5c 73 2a 7d 2f 29 0a  r:\s*red;\s*}/).
0bc0: 0a 20 20 20 20 2f 2f 20 72 65 6d 6f 75 6e 74 20  .    // remount 
0bd0: 28 75 6e 6d 6f 75 6e 74 2b 6d 6f 75 6e 74 29 0a  (unmount+mount).
0be0: 20 20 20 20 74 61 67 2e 75 6e 6d 6f 75 6e 74 28      tag.unmount(
0bf0: 74 72 75 65 29 0a 20 20 20 20 74 61 67 20 3d 20  true).    tag = 
0c00: 72 69 6f 74 2e 6d 6f 75 6e 74 28 27 72 75 6e 74  riot.mount('runt
0c10: 69 6d 65 2d 73 74 79 6c 65 2d 70 61 72 73 69 6e  ime-style-parsin
0c20: 67 27 29 5b 30 5d 0a 20 20 20 20 65 78 70 65 63  g')[0].    expec
0c30: 74 28 74 61 67 29 2e 74 6f 2e 6e 6f 74 2e 62 65  t(tag).to.not.be
0c40: 2e 65 71 75 61 6c 28 75 6e 64 65 66 69 6e 65 64  .equal(undefined
0c50: 29 0a 0a 20 20 20 20 2f 2f 20 74 65 73 74 20 72  )..    // test r
0c60: 65 6d 6f 75 6e 74 20 64 6f 65 73 20 6e 6f 74 20  emount does not 
0c70: 61 66 66 65 63 74 20 73 74 79 6c 65 0a 20 20 20  affect style.   
0c80: 20 73 74 79 6c 65 73 20 3d 20 67 65 74 52 69 6f   styles = getRio
0c90: 74 53 74 79 6c 65 73 28 72 69 6f 74 29 0a 20 20  tStyles(riot).  
0ca0: 20 20 65 78 70 65 63 74 28 73 74 79 6c 65 73 29    expect(styles)
0cb0: 2e 74 6f 2e 6d 61 74 63 68 28 2f 5c 62 70 61 72  .to.match(/\bpar
0cc0: 73 65 64 2d 73 74 79 6c 65 5c 73 2a 5c 7b 5c 73  sed-style\s*\{\s
0cd0: 2a 63 6f 6c 6f 72 3a 5c 73 2a 72 65 64 3b 5c 73  *color:\s*red;\s
0ce0: 2a 7d 2f 29 0a 0a 20 20 20 20 2f 2f 20 74 65 73  *}/)..    // tes
0cf0: 74 20 72 65 6d 6f 75 6e 74 20 64 6f 65 73 20 6e  t remount does n
0d00: 6f 74 20 64 75 70 6c 69 63 61 74 65 20 72 75 6c  ot duplicate rul
0d10: 65 0a 20 20 20 20 65 78 70 65 63 74 28 73 74 79  e.    expect(sty
0d20: 6c 65 73 2e 6d 61 74 63 68 28 2f 5c 62 70 61 72  les.match(/\bpar
0d30: 73 65 64 2d 73 74 79 6c 65 5c 73 2a 5c 7b 2f 67  sed-style\s*\{/g
0d40: 29 29 2e 74 6f 2e 68 61 76 65 2e 6c 65 6e 67 74  )).to.have.lengt
0d50: 68 28 31 29 0a 0a 20 20 20 20 74 61 67 2e 75 6e  h(1)..    tag.un
0d60: 6d 6f 75 6e 74 28 29 0a 20 20 7d 29 0a 0a 0a 7d  mount().  })...}
0d70: 29 0a                                            ).