-
Notifications
You must be signed in to change notification settings - Fork 0
/
test.coffee
126 lines (105 loc) · 2.49 KB
/
test.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
assert = require 'assert'
s = require './mss.coffee'
{log, error: err} = console
test = (desc, t) ->
log desc
try
t()
log 'PASSED'
catch e
err e
err 'FAILED'
test 'keep lowercase prop name', ->
assert.equal(
s.parsePropName 'margin'
'margin'
)
test 'add - before uppercase prop name', ->
assert.equal(
s.parsePropName 'paddingLeft'
'padding-left'
)
assert.equal(
s.parsePropName 'MozBorderRaduis'
'-moz-border-raduis'
)
test 'id selector ', ->
assert.deepEqual(
s.parseSelectors '$Id'
[' #id']
)
test 'class selector ', ->
assert.deepEqual(
s.parseSelectors 'Class'
[' .Class']
)
test 'html tag selector ', ->
assert.deepEqual(
s.parseSelectors 'span'
[' span']
)
test 'pesudo selector ', ->
assert.deepEqual(
s.parseSelectors '$hover'
[':hover']
)
test 'multi selectors', ->
assert.deepEqual(
s.parseSelectors '$hover_$Id_Class'
[':hover', ' #id', ' .Class']
)
test 'simple parse', ->
assert.deepEqual(
s.parse
$Foo:
margin: '2px'
' #foo{margin:2px;}'
)
test 'recursive parse', ->
assert.deepEqual(
s.parse
$Foo:
Bar:
padding:'2px'
margin: '2px'
' #foo{margin:2px;} #foo .Bar{padding:2px;}'
)
test 'mss.merge', ->
assert.deepEqual(
s.parse s.merge [
$Foo:
color: 'red'
,
Bar:
padding:'2px'
]
' #foo{color:red;} .Bar{padding:2px;}'
)
test 'TRAVERSE', ->
testMss =
Foo:
p:
otherProp: '...'
Bar:
otherProp: '...'
span:
background: "url('debug.png')"
mssFn = (selector, mss) ->
if selector == 'Bar'
mss.padding = '2px'
mss
propFn = (propName, propValue) ->
if propName == 'background'
propValue.replace(/^url\(.+\)$/g, 'product.png')
else propValue
assert.deepEqual(
s.TRAVERSE(testMss, mssFn, propFn)
, Foo:
p:
otherProp: '...'
Bar:
otherProp:'...'
span:
background: 'product.png'
padding: '2px'
)