[ 
https://issues.apache.org/jira/browse/LIVY-556?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Marcelo Vanzin resolved LIVY-556.
---------------------------------
    Resolution: Fixed

Issue resolved by pull request 143
[https://github.com/apache/incubator-livy/pull/143]

> HearbeatExpired is not stubbed correctly in test cases
> ------------------------------------------------------
>
>                 Key: LIVY-556
>                 URL: https://issues.apache.org/jira/browse/LIVY-556
>             Project: Livy
>          Issue Type: Bug
>          Components: Server, Tests
>    Affects Versions: 0.6.0
>         Environment: test
>            Reporter: Meisam
>            Assignee: Meisam
>            Priority: Minor
>             Fix For: 0.6.0
>
>   Original Estimate: 2h
>          Time Spent: 20m
>  Remaining Estimate: 1h 40m
>
> {{SessionHearbeatWatchdog.deleteExpiredSesions}} is called 
> nondeterministically.
>  Most of the time, the test cases finish without giving 
> {{deleteExpiredSesions}} a chance to run. But occasionally 
> {{deleteExpiredSesions}} is called before the test cases finishes, which 
> causes the following error message:
> {code:java}
> Exception in thread 
> "HeartbeatWatchdog-org.apache.livy.sessions.InteractiveSessionManager" 
> org.mockito.exceptions.misusing.WrongTypeOfReturnValue: 
> Idle$ cannot be returned by heartbeatExpired()
> heartbeatExpired() should return boolean
> ***
> If you're unsure why you're getting above error read on.
> Due to the nature of the syntax above problem might occur because:
> 1. This exception *might* occur in wrongly written multi-threaded tests.
>    Please refer to Mockito FAQ on limitations of concurrency testing.
> 2. A spy is stubbed using when(spy.foo()).then() syntax. It is safer to stub 
> spies - 
>    - with doReturn|Throw() family of methods. More in javadocs for 
> Mockito.spy() method.
>         at 
> org.apache.livy.server.interactive.SessionHeartbeatWatchdog$$anonfun$deleteExpiredSessions$1.apply(SessionHeartbeat.scala:111)
>         at 
> org.apache.livy.server.interactive.SessionHeartbeatWatchdog$$anonfun$deleteExpiredSessions$1.apply(SessionHeartbeat.scala:110)
>         at scala.collection.Iterator$class.foreach(Iterator.scala:891)
>         at scala.collection.AbstractIterator.foreach(Iterator.scala:1334)
>         at 
> scala.collection.MapLike$DefaultValuesIterable.foreach(MapLike.scala:206)
>         at 
> org.apache.livy.server.interactive.SessionHeartbeatWatchdog$class.deleteExpiredSessions(SessionHeartbeat.scala:110)
>         at 
> org.apache.livy.sessions.InteractiveSessionManager.deleteExpiredSessions(SessionManager.scala:47)
>         at 
> org.apache.livy.server.interactive.SessionHeartbeatWatchdog$$anon$1.run(SessionHeartbeat.scala:92)
> - interactive session should not gc-ed if session timeout check is off (1 
> second, 98 milliseconds)
> {code}



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to