forked from cucumber/cucumber-jvm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ScalaDslTest.scala
159 lines (119 loc) · 3.72 KB
/
ScalaDslTest.scala
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
package cucumber.api.scala
import _root_.org.junit.{Test, Assert}
import Assert._
import _root_.gherkin.I18n
import _root_.gherkin.formatter.model.Tag
import collection.JavaConverters._
import cucumber.api.Scenario
class ScalaDslTest {
object StubScenario extends Scenario{
def getSourceTagNames = null
def getStatus = ""
def isFailed = false
def embed(p1: Array[Byte], p2: String) {}
def write(p1: String) {}
def getName = ""
def getId = ""
}
@Test
def emptyBefore {
var actualScenario : Scenario = null
object Befores extends ScalaDsl with EN {
Before { actualScenario = _ }
}
assertEquals(1, Befores.beforeHooks.size)
val hook = Befores.beforeHooks.head
assertTrue(hook.matches(List[Tag]().asJava))
hook.execute(StubScenario)
assertEquals(Int.MaxValue, hook.getOrder)
assertEquals(StubScenario, actualScenario)
}
@Test
def taggedBefore {
var actualScenario : Scenario = null
object Befores extends ScalaDsl with EN {
Before("@foo,@bar", "@zap"){ actualScenario = _ }
}
assertEquals(1, Befores.beforeHooks.size)
val hook = Befores.beforeHooks.head
assertFalse(hook.matches(List[Tag]().asJava))
assertTrue(hook.matches(List(new Tag("@bar", 0), new Tag("@zap", 0)).asJava))
assertFalse(hook.matches(List(new Tag("@bar", 1)).asJava))
hook.execute(StubScenario)
assertEquals(StubScenario, actualScenario)
assertEquals(Int.MaxValue, hook.getOrder)
}
@Test
def orderedBefore {
object Befores extends ScalaDsl with EN {
Before(10){ scenario : Scenario => }
}
val hook = Befores.beforeHooks(0)
assertEquals(10, hook.getOrder)
}
@Test
def taggedOrderedBefore {
object Befores extends ScalaDsl with EN {
Before(10, "@foo,@bar", "@zap"){ scenario : Scenario => }
}
val hook = Befores.beforeHooks(0)
assertEquals(10, hook.getOrder)
}
@Test
def emptyAfter {
var actualScenario : Scenario = null
object Afters extends ScalaDsl with EN {
After { actualScenario = _ }
}
assertEquals(1, Afters.afterHooks.size)
val hook = Afters.afterHooks.head
assertTrue(hook.matches(List[Tag]().asJava))
hook.execute(StubScenario)
assertEquals(StubScenario, actualScenario)
}
@Test
def taggedAfter {
var actualScenario : Scenario = null
object Afters extends ScalaDsl with EN {
After("@foo,@bar", "@zap"){ actualScenario = _ }
}
assertEquals(1, Afters.afterHooks.size)
val hook = Afters.afterHooks.head
assertFalse(hook.matches(List[Tag]().asJava))
assertTrue(hook.matches(List(new Tag("@bar", 0), new Tag("@zap", 0)).asJava))
assertFalse(hook.matches(List(new Tag("@bar", 1)).asJava))
hook.execute(StubScenario)
assertEquals(StubScenario, actualScenario)
}
@Test
def noArg {
var called = false
object Dummy extends ScalaDsl with EN {
Given("x"){
called = true
}
}
assertEquals(1, Dummy.stepDefinitions.size)
val step = Dummy.stepDefinitions.head
assertEquals("ScalaDslTest.scala:127", step.getLocation(true)) // be careful with formatting or this test will break
assertEquals("x", step.getPattern)
step.execute(new I18n("en"), Array())
assertTrue(called)
}
@Test
def args {
var thenumber = 0
var thecolour = ""
object Dummy extends ScalaDsl with EN {
Given("Oh boy, (\\d+) (\\s+) cukes"){ (num:Int, colour:String) =>
thenumber = num
thecolour = colour
}
}
assertEquals(1, Dummy.stepDefinitions.size)
val step = Dummy.stepDefinitions(0)
step.execute(new I18n("en"), Array(new java.lang.Integer(5), "green"))
assertEquals(5, thenumber)
assertEquals("green", thecolour)
}
}