123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- import org.specs2.mutable._
- import org.specs2.runner._
- import org.junit.runner._
- import play.api.test._
- import play.api.test.Helpers._
- import models.Card
- import models.Team
- @RunWith(classOf[JUnitRunner])
- class ApplicationSpec extends Specification {
- "Card" should {
- val card = Card("test", Set("these", "words", "are", "not", "allowed"))
- "Check Taboo words correctly" in {
- card.isTaboo("test") must beTrue
- card.isTaboo("these") must beTrue
- card.isTaboo("words") must beTrue
- card.isTaboo("are") must beTrue
- card.isTaboo("not") must beTrue
- card.isTaboo("allowed") must beTrue
- }
- "Check guessed words correctly" in {
- card.isCorrect("test") must beTrue
- card.isCorrect("these") must beFalse
- card.isCorrect("words") must beFalse
- card.isCorrect("are") must beFalse
- card.isCorrect("not") must beFalse
- card.isCorrect("allowed") must beFalse
- }
- "Check case insensitively" in {
- card.isCorrect("test") must beTrue
- card.isCorrect("Test") must beTrue
- card.isCorrect("tEst") must beTrue
- card.isCorrect("teSt") must beTrue
- card.isCorrect("tesT") must beTrue
- card.isCorrect("TEST") must beTrue
- card.isTaboo("These") must beTrue
- card.isTaboo("wOrds") must beTrue
- card.isTaboo("arE") must beTrue
- card.isTaboo("nOt") must beTrue
- card.isTaboo("ALLOWED") must beTrue
- }
- "Check the entire message" in {
- card.isTaboo("The word is test") must beTrue
- card.isTaboo("I am not allowed to say") must beTrue
- card.isTaboo("*words*") must beTrue
- card.isTaboo("these/not/allowed") must beTrue
- }
- "Don't check parts of words" in {
- card.isTaboo("area") must beFalse
- card.isTaboo("knots") must beFalse
- card.isTaboo("care") must beFalse
- card.isTaboo("swords") must beFalse
- }
- val compoundCard = Card("test card", Set("much words", "such test", "very pass"))
- "Check compound taboo word variations" in {
- compoundCard.isTaboo("test") must beTrue
- compoundCard.isTaboo("card") must beTrue
- compoundCard.isTaboo("much") must beTrue
- compoundCard.isTaboo("such") must beTrue
- compoundCard.isTaboo("words") must beTrue
- compoundCard.isTaboo("very") must beTrue
- compoundCard.isTaboo("pass") must beTrue
- compoundCard.isTaboo("testcard") must beTrue
- compoundCard.isTaboo("muchwords") must beTrue
- compoundCard.isTaboo("suchtest") must beTrue
- compoundCard.isTaboo("verypass") must beTrue
- }
- }
- "Team" should {
- val team = new Team()
- "Allow players to join" in {
- team.join("player1")
- team.join("player2")
- team.join("player2")
- team.join("player3")
- team.hasPlayer("player1") must beTrue
- team.hasPlayer("player2") must beTrue
- team.hasPlayer("player3") must beTrue
- team.hasPlayer("player4") must beFalse
- }
- "Allow players to leave" in {
- team.leave("player3")
- team.hasPlayer("player3") must beFalse
- // should be a noop
- team.leave("player3")
- team.hasPlayer("player3") must beFalse
- }
- "Cycle between players correctly" in {
- team.nextPlayer() must equalTo("player1")
- team.nextPlayer() must equalTo("player2")
- team.nextPlayer() must equalTo("player1")
- team.join("player3")
- team.join("player4")
- team.nextPlayer() must equalTo("player2")
- team.nextPlayer() must equalTo("player3")
- team.nextPlayer() must equalTo("player4")
- team.nextPlayer() must equalTo("player1")
- team.nextPlayer() must equalTo("player2")
- team.leave("player3")
- team.nextPlayer() must equalTo("player4")
- team.leave("player4")
- team.nextPlayer() must equalTo("player1")
- team.nextPlayer() must equalTo("player2")
- }
- "Give the correct current player and guessers" in {
- team.nextPlayer() must equalTo("player1")
- team.player must equalTo("player1")
- team.guessers("player2") must beTrue
- }
- }
- }
|