I’m sorry to ask such question, but I’m still newbie to scala and really need some quick solution.
The system under test is distributed among several servers. Thus to check if the whole system works well I need to perform several checks for every page. I would like to extract these checks to one method, but cannot manage to find out how to do it in scala.
Below is my test scenario sample:
class SimpleTest extends Simulation {
val httpConf = httpConfig
.baseURL(“https://192.168.1.21:443”)
.acceptHeader("/")
.acceptEncodingHeader(“gzip, deflate”)
.acceptLanguageHeader(“en-us”)
.connection(“Keep-Alive”)
.userAgentHeader(“Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)”)
val userCredentials = csv(“user_credentials.csv”).queue
val headers_Content_Length_0 = Map(
“Content-Length” → “0”)
val chain_login = exec(http(“Login request”)
.post("/sys/loginBrowser/login")
.param(""“login”"", “${username}”)
.param(""“passwd”"", “${password}”)
.check(status.is(200))
.check(regex(""“Please contact your personal manager”"").notExists)
.check(regex(""“NotAcceptingRequests”"").notExists)
)
val chain_welcome = exec(http(“Welcome page”)
.get("/sys/external/welcome")
.check(status.is(200))
.check(regex(""“Please contact your personal manager”"").notExists)
.check(regex(""“NotAcceptingRequests”"").notExists)
)
.pause(30 milliseconds)
.exec(http(“Business day status”)
.get("/sys/external/business_day_status")
.check(status.is(200))
.check(regex(""“Please contact your personal manager”"").notExists)
.check(regex(""“NotAcceptingRequests”"").notExists)
)
.pause(300 milliseconds)
.exec(http(“Account list”)
.post("/sys/external/account-list")
.headers(headers_Content_Length_0)
.check(status.is(200))
.check(regex(""“Please contact your personal manager”"").notExists)
.check(regex(""“NotAcceptingRequests”"").notExists)
)
val chain_logout = exec(http(“Logout request”)
.get("/sys/logout")
.check(status.is(200))
.check(regex(""“Please contact your personal manager”"").notExists)
.check(regex(""“NotAcceptingRequests”"").notExists)
)
val scn = scenario(“Simple scenario”)
.feed(userCredentials)
.repeat(1) {
exec(chain_login)
.pause(500 milliseconds)
.exec(chain_welcome)
.pause(500 milliseconds)
.exec(chain_logout)
}
setUp(
scn.inject(
ramp(100 users) over (30 seconds)
).protocolConfig(httpConf)
)
}