2012-02-01 12 views
5

Tworzę prosty fragment, który powinien przekazać Box[String] z żądaniami user-agent do klasy pomocniczej, która przekazuje klasy css, które powinny zostać dodane do elementu html. Robię to, ponieważ wydaje się trudne uzyskanie polecenia "Podnieś", aby dostarczać html respons z komentarzami warunkowymi, takimi jak te w html5boilerplate. To jest to, co mam teraz i to działa:Testowanie fragmentu w Lift

class LiftBoilerplate { 

    def render = "html [class+]" #> getClassForUserAgent(S.request) 

    private def getClassForUserAgent(request:Box[Req]) = request match { 
     case Full(r) => LiftBoilerplateHelper.getHtmlClass(r.userAgent) 
     case _ => "" 
    } 
} 

Moim problemem jest to, że chciałbym napisać test jednostkowy za to jak:

object LiftBoilerplateSpecs extends Specification { 

    val session = new LiftSession("", randomString(20), Empty) 

    "LiftBoilerplate" should { 
    "add 'no-js' to the class of an html tag element" in { 

     val snippet = new LiftBoilerplate 
     val result = snippet.render(<html><head></head><body>test</body></html>) 

     result must ==/(<html class="no-js"><head></head><body>test</body></html>) 
    } 
    } 
} 

ten test nie powiedzie się, ponieważ S.request jest Empty. Co powinienem zrobić, aby podać fragment kodu z wyśmiewanym żądaniem zawierającym w sobie UserAgent?

Do tej pory wyglądało na http://www.assembla.com/spaces/liftweb/wiki/Unit_Testing_Snippets_With_A_Logged_In_User
i
http://www.assembla.com/spaces/liftweb/wiki/Mocking_HTTP_Requests
ale nie rozumiem jak achive mój cel.

Odpowiedz

3

Aby żądanie i zastosować go automatycznie w każdym przykładzie testowym będzie trzeba użyć cecha AroundExample zawinąć każdy test w rozmowie S.init:

object LiftBoilerplateSpecs extends Specification with AroundExample { 

    val session = new LiftSession("", randomString(20), Empty) 

    def makeReq = { 
    val mockRequest = new MockHttpServletRequest("http://localhost") 
    mockRequest.headers = Map("User-Agent" -> List("Safari")) 

    new Req(Req.NilPath, "", GetRequest, Empty, new HTTPRequestServlet(mockRequest, null), 
     System.nanoTime, System.nanoTime, false, 
    () => ParamCalcInfo(Nil, Map(), Nil, Empty), Map()) 
    } 

    def around[T <% Result](t: => T) = S.init(makeReq, session)(t) 

    "LiftBoilerplate" should { 
    "add 'no-js' to the class of an html tag element" in { 

     val snippet = new LiftBoilerplate 
     val result = snippet.render(<html><head></head><body>test</body></html>) 

     result must ==/(<html class="no-js"><head></head><body>test</body></html>) 
    } 
    } 
} 
+0

doskonała, ale gdzie jest zbiorem kliencka ? Czy powinien on zostać dodany w 'Map' podanej do' ParamCalcInfo'? –

+0

Nie, piąty parametr Req() jest HttpRequest. Powinieneś przekazać jego instancję z żądanymi nagłówkami (np. User-Agent). –

+0

Zaktualizowałem odpowiedź, aby pokazać wyśmiewane żądanie. –