Implement different intervals for scavenge and idlepassivation checks; update all tests
This commit is contained in:
parent
436c4835a4
commit
3c2f5bbcb6
|
@ -245,10 +245,10 @@ public class GCloudSessionDataStore extends AbstractSessionDataStore
|
|||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
if (LOG.isDebugEnabled()) LOG.debug("Writing session {} to DataStore", data.getId());
|
||||
|
||||
|
|
|
@ -125,6 +125,8 @@ public class InfinispanSessionDataStore extends AbstractSessionDataStore
|
|||
@Override
|
||||
public boolean delete(String id) throws Exception
|
||||
{
|
||||
if (LOG.isDebugEnabled())
|
||||
LOG.debug("Deleting session with id {} from infinispan", id);
|
||||
return (_cache.remove(getCacheKey(id, _context)) != null);
|
||||
}
|
||||
|
||||
|
@ -166,10 +168,10 @@ public class InfinispanSessionDataStore extends AbstractSessionDataStore
|
|||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(org.eclipse.jetty.server.session.SessionKey, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(org.eclipse.jetty.server.session.SessionKey, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
//Put an idle timeout on the cache entry if the session is not immortal -
|
||||
//if no requests arrive at any node before this timeout occurs, or no node
|
||||
|
|
|
@ -264,7 +264,7 @@ public class InfinispanSessionIdManager extends AbstractSessionIdManager
|
|||
* @param id the session id
|
||||
* @return unique cache id
|
||||
*/
|
||||
protected String makeKey (String id)
|
||||
public String makeKey (String id)
|
||||
{
|
||||
return ID_KEY+id;
|
||||
}
|
||||
|
|
|
@ -397,10 +397,10 @@ public class MongoSessionDataStore extends NoSqlSessionDataStore
|
|||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(org.eclipse.jetty.server.session.SessionKey, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(org.eclipse.jetty.server.session.SessionKey, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
NoSqlSessionData nsqd = (NoSqlSessionData)data;
|
||||
|
||||
|
@ -416,7 +416,7 @@ public class MongoSessionDataStore extends NoSqlSessionDataStore
|
|||
Object version = ((NoSqlSessionData)data).getVersion();
|
||||
|
||||
// New session
|
||||
if (isNew)
|
||||
if (lastSaveTime <= 0)
|
||||
{
|
||||
upsert = true;
|
||||
version = new Long(1);
|
||||
|
@ -455,7 +455,7 @@ public class MongoSessionDataStore extends NoSqlSessionDataStore
|
|||
|
||||
Set<String> names = nsqd.takeDirtyAttributes();
|
||||
|
||||
if (isNew)
|
||||
if (lastSaveTime <= 0)
|
||||
{
|
||||
names.addAll(nsqd.getAllAttributeNames()); // note dirty may include removed names
|
||||
}
|
||||
|
|
|
@ -143,7 +143,6 @@ public class MongoSessionIdManager extends AbstractSessionIdManager
|
|||
Long expiry = (Long)o.get(MongoSessionDataStore.__EXPIRY);
|
||||
if (expiry < System.currentTimeMillis())
|
||||
return false;
|
||||
|
||||
return valid;
|
||||
}
|
||||
|
||||
|
|
|
@ -29,6 +29,7 @@ import javax.servlet.http.HttpSession;
|
|||
|
||||
import org.eclipse.jetty.http.HttpCookie;
|
||||
import org.eclipse.jetty.server.session.SessionHandler;
|
||||
import org.eclipse.jetty.server.session.SessionStore;
|
||||
import org.eclipse.jetty.util.component.LifeCycle;
|
||||
|
||||
/* --------------------------------------------------------------------- */
|
||||
|
@ -308,4 +309,13 @@ public interface SessionManager extends LifeCycle
|
|||
* @param newExtendedId the new session id including worker suffix
|
||||
*/
|
||||
public void renewSessionId(String oldId, String oldExtendedId, String newId, String newExtendedId);
|
||||
|
||||
|
||||
/**
|
||||
* Get the session store for this manager
|
||||
* @return
|
||||
*/
|
||||
public SessionStore getSessionStore();
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -37,10 +37,10 @@ public abstract class AbstractSessionDataStore extends AbstractLifeCycle impleme
|
|||
*
|
||||
* @param id identity of session to store
|
||||
* @param data info of the session
|
||||
* @param isNew has session been written out before or not
|
||||
* @param lastSaveTime time of previous save or 0 if never saved
|
||||
* @throws Exception
|
||||
*/
|
||||
public abstract void doStore(String id, SessionData data, boolean isNew) throws Exception;
|
||||
public abstract void doStore(String id, SessionData data, long lastSaveTime) throws Exception;
|
||||
|
||||
|
||||
|
||||
|
@ -63,19 +63,19 @@ public abstract class AbstractSessionDataStore extends AbstractLifeCycle impleme
|
|||
{
|
||||
long lastSave = data.getLastSaved();
|
||||
|
||||
//set the last saved time to now
|
||||
data.setLastSaved(System.currentTimeMillis());
|
||||
try
|
||||
{
|
||||
doStore(id, data, (lastSave<=0));
|
||||
//call the specific store method, passing in previous save time
|
||||
doStore(id, data, lastSave);
|
||||
data.setDirty(false); //only undo the dirty setting if we saved it
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
//reset last save time
|
||||
//reset last save time if save failed
|
||||
data.setLastSaved(lastSave);
|
||||
}
|
||||
finally
|
||||
{
|
||||
data.setDirty(false);
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -55,7 +55,7 @@ public abstract class AbstractSessionIdManager extends AbstractLifeCycle impleme
|
|||
protected String _workerAttr;
|
||||
protected long _reseed=100000L;
|
||||
protected Server _server;
|
||||
protected PeriodicSessionInspector _scavenger;
|
||||
protected PeriodicSessionInspector _inspector;
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
|
@ -100,12 +100,12 @@ public abstract class AbstractSessionIdManager extends AbstractLifeCycle impleme
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* @param scavenger a SessionScavenger
|
||||
* @param period inspector of sessions
|
||||
*/
|
||||
public void setSessionScavenger (PeriodicSessionInspector scavenger)
|
||||
public void setSessionInspector (PeriodicSessionInspector inspector)
|
||||
{
|
||||
_scavenger = scavenger;
|
||||
_scavenger.setSessionIdManager(this);
|
||||
_inspector = inspector;
|
||||
_inspector.setSessionIdManager(this);
|
||||
}
|
||||
|
||||
|
||||
|
@ -282,14 +282,14 @@ public abstract class AbstractSessionIdManager extends AbstractLifeCycle impleme
|
|||
initRandom();
|
||||
_workerAttr=(_workerName!=null && _workerName.startsWith("$"))?_workerName.substring(1):null;
|
||||
|
||||
if (_scavenger == null)
|
||||
if (_inspector == null)
|
||||
{
|
||||
LOG.warn("No SessionScavenger set, using defaults");
|
||||
_scavenger = new PeriodicSessionInspector();
|
||||
_scavenger.setSessionIdManager(this);
|
||||
_inspector = new PeriodicSessionInspector();
|
||||
_inspector.setSessionIdManager(this);
|
||||
}
|
||||
|
||||
_scavenger.start();
|
||||
_inspector.start();
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
@ -299,7 +299,7 @@ public abstract class AbstractSessionIdManager extends AbstractLifeCycle impleme
|
|||
@Override
|
||||
protected void doStop() throws Exception
|
||||
{
|
||||
_scavenger.stop();
|
||||
_inspector.stop();
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
|
|
@ -19,15 +19,15 @@
|
|||
|
||||
package org.eclipse.jetty.server.session;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
import java.util.function.Consumer;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.eclipse.jetty.util.MultiException;
|
||||
import org.eclipse.jetty.util.StringUtil;
|
||||
import org.eclipse.jetty.util.component.AbstractLifeCycle;
|
||||
import org.eclipse.jetty.util.log.Log;
|
||||
import org.eclipse.jetty.util.log.Logger;
|
||||
|
@ -43,12 +43,15 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
{
|
||||
final static Logger LOG = Log.getLogger("org.eclipse.jetty.server.session");
|
||||
|
||||
protected ArrayList<SessionInspector> _inspectors = new ArrayList<SessionInspector>();
|
||||
protected SessionDataStore _sessionDataStore;
|
||||
protected SessionManager _manager;
|
||||
protected SessionContext _context;
|
||||
protected int _idlePassivationTimeoutSec;
|
||||
protected int _expiryTimeoutSec;
|
||||
private IdleInspector _idleInspector;
|
||||
private ExpiryInspector _expiryInspector;
|
||||
private boolean _passivateOnComplete;
|
||||
|
||||
|
||||
/**
|
||||
|
@ -176,11 +179,19 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
|
||||
if (_context == null)
|
||||
throw new IllegalStateException ("No ContextId");
|
||||
|
||||
|
||||
_sessionDataStore.initialize(_context);
|
||||
_sessionDataStore.start();
|
||||
|
||||
_expiryInspector = new ExpiryInspector(this, _manager.getSessionIdManager());
|
||||
|
||||
if (_expiryTimeoutSec >= 0)
|
||||
{
|
||||
synchronized (_inspectors)
|
||||
{
|
||||
_expiryInspector = new ExpiryInspector(this, _manager.getSessionIdManager());
|
||||
_expiryInspector.setTimeoutSet(_expiryTimeoutSec);
|
||||
_inspectors.add(0, _expiryInspector);
|
||||
}
|
||||
}
|
||||
|
||||
super.doStart();
|
||||
}
|
||||
|
@ -229,11 +240,46 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
*/
|
||||
public void setIdlePassivationTimeoutSec(int idleTimeoutSec)
|
||||
{
|
||||
_idlePassivationTimeoutSec = idleTimeoutSec;
|
||||
if (_idlePassivationTimeoutSec == 0)
|
||||
_idleInspector = null;
|
||||
else if (_idleInspector == null)
|
||||
_idleInspector = new IdleInspector(this);
|
||||
synchronized (_inspectors)
|
||||
{
|
||||
_idlePassivationTimeoutSec = idleTimeoutSec;
|
||||
if (_idlePassivationTimeoutSec == 0)
|
||||
{
|
||||
if (_idleInspector != null)
|
||||
_inspectors.remove(_idleInspector);
|
||||
_idleInspector = null;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (_idleInspector == null)
|
||||
{
|
||||
_idleInspector = new IdleInspector(this);
|
||||
_inspectors.add(_idleInspector);
|
||||
}
|
||||
|
||||
_idleInspector.setTimeoutSet(_idlePassivationTimeoutSec);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @return the expiryTimeoutSec
|
||||
*/
|
||||
public int getExpiryTimeoutSec()
|
||||
{
|
||||
return _expiryTimeoutSec;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @param expiryTimeoutSec the expiryTimeoutSec to set
|
||||
*/
|
||||
public void setExpiryTimeoutSec(int expiryTimeoutSec)
|
||||
{
|
||||
_expiryTimeoutSec = expiryTimeoutSec;
|
||||
}
|
||||
|
||||
|
||||
|
@ -245,10 +291,10 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
* the data for it from a SessionDataStore associated with the
|
||||
* session manager.
|
||||
*
|
||||
* @see org.eclipse.jetty.server.session.SessionStore#get(java.lang.String, boolean)
|
||||
* @see org.eclipse.jetty.server.session.SessionStore#get(java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public Session get(String id, boolean staleCheck) throws Exception
|
||||
public Session get(String id) throws Exception
|
||||
{
|
||||
Session session = null;
|
||||
Exception ex = null;
|
||||
|
@ -380,7 +426,10 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
}
|
||||
|
||||
/**
|
||||
* Put the Session object into the session store.
|
||||
* Put the Session object back into the session store.
|
||||
*
|
||||
* This should be called by Session.complete when a request exists the session.
|
||||
*
|
||||
* If the session manager supports a session data store, write the
|
||||
* session data through to the session data store.
|
||||
*
|
||||
|
@ -394,7 +443,7 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
|
||||
|
||||
|
||||
//if the session is new, the data has changed, or the cache is considered stale, write it to any backing store
|
||||
//if the session is new or data has changed write it to any backing store
|
||||
try (Lock lock = session.lock())
|
||||
{
|
||||
session.setSessionManager(_manager);
|
||||
|
@ -405,7 +454,45 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
if (!session.isValid())
|
||||
return;
|
||||
|
||||
if ((session.isNew() || session.getSessionData().isDirty()) && _sessionDataStore != null)
|
||||
if (_sessionDataStore == null)
|
||||
{
|
||||
doPutIfAbsent(id, session); //ensure it is in our map
|
||||
return;
|
||||
}
|
||||
|
||||
if ((session.getRequests() <= 0))
|
||||
{
|
||||
//only save if all requests have finished
|
||||
if (!_sessionDataStore.isPassivating())
|
||||
{
|
||||
//if our backing datastore isn't the passivating kind, just save the session
|
||||
_sessionDataStore.store(id, session.getSessionData());
|
||||
}
|
||||
else
|
||||
{
|
||||
//backing store supports passivation
|
||||
session.willPassivate();
|
||||
_sessionDataStore.store(id, session.getSessionData());
|
||||
session.setPassivated();
|
||||
if (isPassivateOnComplete())
|
||||
{
|
||||
//throw out the passivated session object from the map
|
||||
doDelete(id);
|
||||
}
|
||||
else
|
||||
{
|
||||
//reactivate the session
|
||||
session.setActive();
|
||||
session.didActivate();
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
doPutIfAbsent(id,session); //ensure it is in our map
|
||||
}
|
||||
|
||||
/* if ((session.isNew() || session.getSessionData().isDirty()) && _sessionDataStore != null)
|
||||
{
|
||||
if (_sessionDataStore.isPassivating())
|
||||
{
|
||||
|
@ -424,8 +511,7 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
|
||||
|
||||
}
|
||||
doPutIfAbsent(id,session);
|
||||
}
|
||||
doPutIfAbsent(id,session);*/
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -450,7 +536,7 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
public Session delete(String id) throws Exception
|
||||
{
|
||||
//get the session, if its not in memory, this will load it
|
||||
Session session = get(id, false);
|
||||
Session session = get(id);
|
||||
|
||||
//Always delete it from the backing data store
|
||||
if (_sessionDataStore != null)
|
||||
|
@ -490,18 +576,30 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
public void inspect ()
|
||||
{
|
||||
Stream<Session> stream = getStream();
|
||||
try
|
||||
|
||||
synchronized (_inspectors)
|
||||
{
|
||||
_expiryInspector.preInspection();
|
||||
if (_idleInspector != null)
|
||||
_idleInspector.preInspection();
|
||||
stream.forEach(s->{_expiryInspector.inspect(s); if (_idleInspector != null) _idleInspector.inspect(s);});
|
||||
_expiryInspector.postInspection();
|
||||
_idleInspector.postInspection();
|
||||
}
|
||||
finally
|
||||
{
|
||||
stream.close();
|
||||
try
|
||||
{
|
||||
final ArrayList<Boolean> wantInspect = new ArrayList<Boolean>();
|
||||
for (SessionInspector i:_inspectors)
|
||||
wantInspect.add(Boolean.valueOf(i.preInspection()));
|
||||
|
||||
stream.forEach(s->{for (int i=0;i<_inspectors.size(); i++) { if (wantInspect.get(i)) _inspectors.get(i).inspect(s);}});
|
||||
}
|
||||
finally
|
||||
{
|
||||
try
|
||||
{
|
||||
for (SessionInspector i:_inspectors)
|
||||
i.postInspection();
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
LOG.warn(e);
|
||||
}
|
||||
stream.close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -548,7 +646,6 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
LOG.debug("Passivating idle session {}", id);
|
||||
s.willPassivate();
|
||||
_sessionDataStore.store(id, s.getSessionData());
|
||||
s.getSessionData().setDirty(false);
|
||||
s.setPassivated();
|
||||
doDelete(id); //Take the session object of this session store
|
||||
}
|
||||
|
@ -564,6 +661,57 @@ public abstract class AbstractSessionStore extends AbstractLifeCycle implements
|
|||
}
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.SessionStore#renewSessionId(java.lang.String, java.lang.String)
|
||||
*/
|
||||
public Session renewSessionId (String oldId, String newId)
|
||||
throws Exception
|
||||
{
|
||||
if (StringUtil.isBlank(oldId))
|
||||
throw new IllegalArgumentException ("Old session id is null");
|
||||
if (StringUtil.isBlank(newId))
|
||||
throw new IllegalArgumentException ("New session id is null");
|
||||
|
||||
Session session = get(oldId);
|
||||
if (session == null)
|
||||
return null;
|
||||
|
||||
try (Lock lock = session.lock())
|
||||
{
|
||||
session.checkValidForWrite(); //can't change id on invalid session
|
||||
session.getSessionData().setId(newId);
|
||||
session.getSessionData().setLastSaved(0); //pretend that the session has never been saved before to get a full save
|
||||
session.getSessionData().setDirty(true); //ensure we will try to write the session out
|
||||
doPutIfAbsent(newId, session); //put the new id into our map
|
||||
doDelete (oldId); //take old out of map
|
||||
if (_sessionDataStore != null)
|
||||
{
|
||||
_sessionDataStore.delete(oldId); //delete the session data with the old id
|
||||
_sessionDataStore.store(newId, session.getSessionData()); //save the session data with the new id
|
||||
}
|
||||
LOG.info("Session id {} swapped for new id {}", oldId, newId);
|
||||
return session;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param passivateOnComplete
|
||||
*/
|
||||
public void setPassivateOnComplete (boolean passivateOnComplete)
|
||||
{
|
||||
_passivateOnComplete = passivateOnComplete;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @return
|
||||
*/
|
||||
public boolean isPassivateOnComplete ()
|
||||
{
|
||||
return _passivateOnComplete;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.SessionStore#newSession(javax.servlet.http.HttpServletRequest, java.lang.String, long, long)
|
||||
|
|
|
@ -127,14 +127,14 @@ public class CachingSessionDataStore extends AbstractSessionDataStore
|
|||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
//write to the SessionDataStore first
|
||||
if (_delegateDataStore instanceof AbstractSessionDataStore)
|
||||
((AbstractSessionDataStore)_delegateDataStore).doStore(id, data, isNew);
|
||||
((AbstractSessionDataStore)_delegateDataStore).doStore(id, data, lastSaveTime);
|
||||
|
||||
//else??????
|
||||
|
||||
|
|
|
@ -31,11 +31,11 @@ import org.eclipse.jetty.util.log.Logger;
|
|||
*
|
||||
*
|
||||
*/
|
||||
public class ExpiryInspector implements SessionInspector
|
||||
public class ExpiryInspector extends AbstractSessionInspector
|
||||
{
|
||||
private final static Logger LOG = Log.getLogger("org.eclipse.jetty.server.session");
|
||||
|
||||
protected Set<String> _expiryCandidates;
|
||||
protected Set<String> _expiryCandidates = new HashSet<String>();
|
||||
protected SessionIdManager _idManager;
|
||||
protected AbstractSessionStore _sessionStore;
|
||||
|
||||
|
@ -78,11 +78,16 @@ public class ExpiryInspector implements SessionInspector
|
|||
* @see org.eclipse.jetty.server.session.SessionInspector#preInspection()
|
||||
*/
|
||||
@Override
|
||||
public void preInspection()
|
||||
public boolean preInspection()
|
||||
{
|
||||
_expiryCandidates.clear();
|
||||
|
||||
boolean shouldInspect = super.preInspection();
|
||||
|
||||
if (LOG.isDebugEnabled())
|
||||
LOG.debug("PreInspection");
|
||||
_expiryCandidates = new HashSet<String>();
|
||||
LOG.debug("ExpiryInspector, will inspect:{}", shouldInspect);
|
||||
|
||||
return shouldInspect;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -108,7 +113,7 @@ public class ExpiryInspector implements SessionInspector
|
|||
}
|
||||
finally
|
||||
{
|
||||
_expiryCandidates = null;
|
||||
_expiryCandidates.clear();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -179,10 +179,10 @@ public class FileSessionDataStore extends AbstractSessionDataStore
|
|||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
File file = null;
|
||||
if (_storeDir != null)
|
||||
|
|
|
@ -28,12 +28,19 @@ package org.eclipse.jetty.server.session;
|
|||
public class HashSessionManager extends SessionManager
|
||||
{
|
||||
protected NullSessionDataStore _sessionDataStore = new NullSessionDataStore();
|
||||
|
||||
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
public HashSessionManager ()
|
||||
{
|
||||
_sessionStore = new MemorySessionStore();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doStart() throws Exception
|
||||
{
|
||||
_sessionStore = new MemorySessionStore();
|
||||
((AbstractSessionStore)_sessionStore).setSessionDataStore(_sessionDataStore);
|
||||
|
||||
super.doStart();
|
||||
|
|
|
@ -31,11 +31,11 @@ import org.eclipse.jetty.util.log.Logger;
|
|||
*
|
||||
* Checks if a session is idle
|
||||
*/
|
||||
public class IdleInspector implements SessionInspector
|
||||
public class IdleInspector extends AbstractSessionInspector
|
||||
{
|
||||
private final static Logger LOG = Log.getLogger("org.eclipse.jetty.server.session");
|
||||
|
||||
protected Set<String> _idleCandidates;
|
||||
protected Set<String> _idleCandidates = new HashSet<String>();;
|
||||
protected AbstractSessionStore _sessionStore;
|
||||
|
||||
/**
|
||||
|
@ -72,21 +72,22 @@ public class IdleInspector implements SessionInspector
|
|||
{
|
||||
return _idleCandidates;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.SessionInspector#preInspection()
|
||||
*/
|
||||
@Override
|
||||
public void preInspection()
|
||||
public boolean preInspection()
|
||||
{
|
||||
_idleCandidates = new HashSet<String>();
|
||||
boolean shouldInspect = super.preInspection();
|
||||
if (LOG.isDebugEnabled())
|
||||
LOG.debug("IdleInspector preinspection");
|
||||
LOG.debug("IdleInspector will inspect:{}", shouldInspect);
|
||||
return shouldInspect;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.SessionInspector#postInspection()
|
||||
*/
|
||||
|
@ -108,6 +109,6 @@ public class IdleInspector implements SessionInspector
|
|||
}
|
||||
}
|
||||
|
||||
_idleCandidates = null;
|
||||
_idleCandidates.clear();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -750,12 +750,12 @@ public class JDBCSessionDataStore extends AbstractSessionDataStore
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
if (data==null || id==null)
|
||||
return;
|
||||
|
||||
if (isNew)
|
||||
if (lastSaveTime <= 0)
|
||||
{
|
||||
doInsert(id, data);
|
||||
}
|
||||
|
@ -807,6 +807,7 @@ public class JDBCSessionDataStore extends AbstractSessionDataStore
|
|||
private void doUpdate (String id, SessionData data)
|
||||
throws Exception
|
||||
{
|
||||
//TODO check if it is actually dirty && try to optimize the writing of lastAccessTime and expiryTime
|
||||
try (Connection connection = _dbAdaptor.getConnection())
|
||||
{
|
||||
connection.setAutoCommit(true);
|
||||
|
|
|
@ -59,10 +59,10 @@ public class NullSessionDataStore extends AbstractSessionDataStore
|
|||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, boolean)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionDataStore#doStore(java.lang.String, org.eclipse.jetty.server.session.SessionData, long)
|
||||
*/
|
||||
@Override
|
||||
public void doStore(String id, SessionData data, boolean isNew) throws Exception
|
||||
public void doStore(String id, SessionData data, long lastSaveTime) throws Exception
|
||||
{
|
||||
//noop
|
||||
}
|
||||
|
|
|
@ -46,7 +46,7 @@ public class PeriodicSessionInspector extends AbstractLifeCycle
|
|||
protected Runner _runner;
|
||||
protected boolean _ownScheduler = false;
|
||||
private long _intervalMs = DEFAULT_PERIOD_MS;
|
||||
private long _lastTime = 0L;
|
||||
|
||||
|
||||
|
||||
|
||||
|
@ -97,7 +97,6 @@ public class PeriodicSessionInspector extends AbstractLifeCycle
|
|||
if (!(_sessionIdManager instanceof AbstractSessionIdManager))
|
||||
throw new IllegalStateException ("SessionIdManager is not an AbstractSessionIdManager");
|
||||
|
||||
_lastTime = System.currentTimeMillis(); //set it to a non zero value
|
||||
|
||||
//try and use a common scheduler, fallback to own
|
||||
_scheduler = ((AbstractSessionIdManager)_sessionIdManager).getServer().getBean(Scheduler.class);
|
||||
|
@ -199,8 +198,6 @@ public class PeriodicSessionInspector extends AbstractLifeCycle
|
|||
|
||||
if (LOG.isDebugEnabled())
|
||||
LOG.debug("Inspecting sessions");
|
||||
|
||||
long now = System.currentTimeMillis();
|
||||
|
||||
//find the session managers
|
||||
for (SessionManager manager:((AbstractSessionIdManager)_sessionIdManager).getSessionManagers())
|
||||
|
@ -208,25 +205,6 @@ public class PeriodicSessionInspector extends AbstractLifeCycle
|
|||
if (manager != null)
|
||||
{
|
||||
manager.inspect();
|
||||
|
||||
/*
|
||||
//call scavenge on each manager to find keys for sessions that have expired
|
||||
Set<String> expiredKeys = manager.scavenge();
|
||||
|
||||
//for each expired session, tell the session id manager to invalidate its key on all contexts
|
||||
for (String key:expiredKeys)
|
||||
{
|
||||
|
||||
// if it recently expired
|
||||
try
|
||||
{
|
||||
((AbstractSessionIdManager)_sessionIdManager).expireAll(key);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
LOG.warn(e);
|
||||
}
|
||||
}*/
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -671,7 +671,7 @@ public class Session implements SessionManager.SessionIf
|
|||
* @param newId
|
||||
* @param newExtendedId
|
||||
*/
|
||||
public void renewId (String oldId, String oldExtendedId, String newId, String newExtendedId)
|
||||
/* public void renewId (String oldId, String oldExtendedId, String newId, String newExtendedId)
|
||||
{
|
||||
try (Lock lock = _lock.lockIfNotHeld())
|
||||
{
|
||||
|
@ -680,13 +680,12 @@ public class Session implements SessionManager.SessionIf
|
|||
if (!oldId.equals(getId()))
|
||||
throw new IllegalStateException("Id clash detected on renewal: was "+oldId+" but is "+ getId());
|
||||
|
||||
//save session with new id
|
||||
_sessionData.setId(newId);
|
||||
setExtendedId(newExtendedId);
|
||||
_sessionData.setLastSaved(0); //forces an insert
|
||||
_sessionData.setDirty(true); //forces an insert
|
||||
}
|
||||
}
|
||||
}*/
|
||||
|
||||
/* ------------------------------------------------------------- */
|
||||
/** Called by users to invalidate a session, or called by the
|
||||
|
|
|
@ -28,7 +28,9 @@ package org.eclipse.jetty.server.session;
|
|||
*/
|
||||
public interface SessionInspector
|
||||
{
|
||||
public void preInspection();
|
||||
public int getTimeoutSec();
|
||||
public void setTimeoutSet(int sec);
|
||||
public boolean preInspection();
|
||||
public void inspect(Session s);
|
||||
public void postInspection (); //on completion
|
||||
}
|
||||
|
|
|
@ -588,9 +588,7 @@ public class SessionManager extends ContainerLifeCycle implements org.eclipse.je
|
|||
try
|
||||
{
|
||||
_sessionStore.put(id, session);
|
||||
|
||||
_sessionsCreatedStats.increment();
|
||||
|
||||
_sessionsCreatedStats.increment();
|
||||
_sessionIdManager.useId(session);
|
||||
|
||||
if (_sessionListeners!=null)
|
||||
|
@ -714,7 +712,7 @@ public class SessionManager extends ContainerLifeCycle implements org.eclipse.je
|
|||
{
|
||||
try
|
||||
{
|
||||
Session session = _sessionStore.get(id, true);
|
||||
Session session = _sessionStore.get(id);
|
||||
if (session != null)
|
||||
{
|
||||
//If the session we got back has expired
|
||||
|
@ -951,20 +949,9 @@ public class SessionManager extends ContainerLifeCycle implements org.eclipse.je
|
|||
{
|
||||
try
|
||||
{
|
||||
Session session =_sessionStore.delete(oldId);
|
||||
if (session == null)
|
||||
{
|
||||
LOG.warn("Unable to renew id to "+newId+" for non-existant session "+oldId);
|
||||
return;
|
||||
}
|
||||
|
||||
//swap the ids
|
||||
session.renewId(oldId, oldExtendedId, newId, newExtendedId);
|
||||
|
||||
_sessionStore.put(newId, session);
|
||||
|
||||
//tell session id manager the id is in use
|
||||
_sessionIdManager.useId(session);
|
||||
Session session = _sessionStore.renewSessionId (oldId, newId); //swap the id over
|
||||
session.setExtendedId(newExtendedId); //remember the extended id
|
||||
_sessionIdManager.useId(session); //tell id manager new id is in use
|
||||
|
||||
//inform the listeners
|
||||
if (!_sessionIdListeners.isEmpty())
|
||||
|
@ -975,6 +962,36 @@ public class SessionManager extends ContainerLifeCycle implements org.eclipse.je
|
|||
l.sessionIdChanged(event, oldId);
|
||||
}
|
||||
}
|
||||
|
||||
/* Session session =_sessionStore.get(oldId);
|
||||
if (session == null)
|
||||
{
|
||||
LOG.warn("Unable to renew id to "+newId+" for non-existant session "+oldId);
|
||||
return;
|
||||
}
|
||||
|
||||
try (Lock lock = session.lock())
|
||||
{
|
||||
//swap the ids
|
||||
session.renewId(oldId, oldExtendedId, newId, newExtendedId);
|
||||
|
||||
_sessionStore.put(newId, session);
|
||||
|
||||
//tell session id manager the id is in use
|
||||
_sessionIdManager.useId(session);
|
||||
|
||||
//inform the listeners
|
||||
if (!_sessionIdListeners.isEmpty())
|
||||
{
|
||||
HttpSessionEvent event = new HttpSessionEvent(session);
|
||||
for (HttpSessionIdListener l:_sessionIdListeners)
|
||||
{
|
||||
l.sessionIdChanged(event, oldId);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}*/
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
|
@ -1025,7 +1042,6 @@ public class SessionManager extends ContainerLifeCycle implements org.eclipse.je
|
|||
return;
|
||||
|
||||
_sessionStore.inspect();
|
||||
//return _sessionStore.getExpired();
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -19,7 +19,6 @@
|
|||
|
||||
package org.eclipse.jetty.server.session;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
|
@ -40,7 +39,8 @@ public interface SessionStore extends LifeCycle
|
|||
{
|
||||
void initialize(SessionContext context);
|
||||
Session newSession (HttpServletRequest request, String id, long time, long maxInactiveMs);
|
||||
Session get(String id, boolean staleCheck) throws Exception;
|
||||
Session renewSessionId (String oldId, String newId) throws Exception;
|
||||
Session get(String id) throws Exception;
|
||||
void put(String id, Session session) throws Exception;
|
||||
boolean exists (String id) throws Exception;
|
||||
Session delete (String id) throws Exception;
|
||||
|
@ -49,5 +49,7 @@ public interface SessionStore extends LifeCycle
|
|||
void inspect();
|
||||
void setIdlePassivationTimeoutSec(int sec);
|
||||
int getIdlePassivationTimeoutSec();
|
||||
int getExpiryTimeoutSec();
|
||||
void setExpiryTimeoutSec(int sec);
|
||||
Stream<Session> getStream();
|
||||
}
|
||||
|
|
|
@ -122,12 +122,12 @@ public class FileTestServer extends AbstractTestServer
|
|||
|
||||
public FileTestServer(int port)
|
||||
{
|
||||
super(port, 30, 10);
|
||||
super(port, 30, 10,1,2);
|
||||
}
|
||||
|
||||
public FileTestServer(int port, int maxInactivePeriod, int scavengePeriod)
|
||||
public FileTestServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -48,25 +48,9 @@ public class IdleSessionTest extends AbstractIdleSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractIdleSessionTest#createServer(int, int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(final int port, final int max, final int scavenge, final int idleSec)
|
||||
public AbstractTestServer createServer(final int port, final int max, final int scavenge, int inspectPeriod, final int idleSec)
|
||||
{
|
||||
FileTestServer server = new FileTestServer(port,max,scavenge)
|
||||
{
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.FileTestServer#newSessionManager()
|
||||
*/
|
||||
@Override
|
||||
public SessionManager newSessionManager()
|
||||
{
|
||||
FileSessionManager manager = (FileSessionManager)super.newSessionManager();
|
||||
manager.getSessionStore().setIdlePassivationTimeoutSec(idleSec);
|
||||
return manager;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
return server;
|
||||
return new FileTestServer(port,max,scavenge, inspectPeriod, idleSec);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -37,9 +37,9 @@ public class ImmortalSessionTest extends AbstractImmortalSessionTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge, inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -40,9 +40,9 @@ public class NewSessionTest extends AbstractNewSessionTest
|
|||
FileTestServer.teardown();
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge,inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -39,9 +39,9 @@ public class OrphanedSessionTest extends AbstractOrphanedSessionTest
|
|||
FileTestServer.teardown();
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge,inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -50,9 +50,9 @@ public class ProxySerializationTest extends AbstractProxySerializationTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractProxySerializationTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod )
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge, inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -40,9 +40,10 @@ public class ReentrantRequestSessionTest extends AbstractReentrantRequestSession
|
|||
FileTestServer.teardown();
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port)
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port);
|
||||
return new FileTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -38,9 +38,9 @@ public class RemoveSessionTest extends AbstractRemoveSessionTest
|
|||
}
|
||||
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge,inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -40,9 +40,9 @@ public class SessionCookieTest extends AbstractSessionCookieTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port, max, scavenge);
|
||||
return new FileTestServer(port, max, scavenge,inspectionPeriod,idlePassivatePeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -38,9 +38,9 @@ public class SessionInvalidateAndCreateTest extends AbstractSessionInvalidateAnd
|
|||
}
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge,inspectionPeriod,idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -43,9 +43,9 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
}
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port, max, scavenge);
|
||||
return new FileTestServer(port, max, scavenge,inspectionPeriod,idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -54,5 +54,16 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
super.testSessionRenewal();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
((FileTestServer)_server).assertFileExists(oldSessionId, false);
|
||||
((FileTestServer)_server).assertFileExists(newSessionId, true);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -38,9 +38,9 @@ public class SessionValueSharedSaving extends AbstractSessionValueSavingTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new FileTestServer(port,max,scavenge);
|
||||
return new FileTestServer(port,max,scavenge,inspectionPeriod,idlePassivatePeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -35,8 +35,10 @@ import java.nio.channels.Channels;
|
|||
import java.nio.channels.ReadableByteChannel;
|
||||
import java.nio.file.Files;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Locale;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jetty.util.IO;
|
||||
import org.eclipse.jetty.util.resource.JarResource;
|
||||
|
@ -311,6 +313,25 @@ public class GCloudSessionTestSupport
|
|||
System.err.println("END OF SESSIONS::::::::");
|
||||
}
|
||||
|
||||
public Set<String> getSessionIds () throws Exception
|
||||
{
|
||||
HashSet<String> ids = new HashSet<String>();
|
||||
ensureDatastore();
|
||||
GqlQuery.Builder builder = Query.gqlQueryBuilder(ResultType.ENTITY, "select * from "+GCloudSessionDataStore.KIND);
|
||||
|
||||
Query<Entity> query = builder.build();
|
||||
|
||||
QueryResults<Entity> results = _ds.run(query);
|
||||
assertNotNull(results);
|
||||
while (results.hasNext())
|
||||
{
|
||||
Entity e = results.next();
|
||||
ids.add(e.getString("id"));
|
||||
}
|
||||
|
||||
return ids;
|
||||
}
|
||||
|
||||
public void assertSessions(int count) throws Exception
|
||||
{
|
||||
ensureDatastore();
|
||||
|
|
|
@ -37,6 +37,11 @@ import com.google.gcloud.datastore.DatastoreFactory;
|
|||
public class GCloudTestServer extends AbstractTestServer
|
||||
{
|
||||
static int __workers=0;
|
||||
|
||||
static protected int __maxInactivePeriod = 30;
|
||||
static protected int __scavengePeriod = 10;
|
||||
static protected int __inspectPeriod = 1;
|
||||
static protected int __idlePeriod = 2;
|
||||
|
||||
|
||||
|
||||
|
@ -46,9 +51,9 @@ public class GCloudTestServer extends AbstractTestServer
|
|||
* @param scavengePeriod
|
||||
* @param sessionIdMgrConfig
|
||||
*/
|
||||
public GCloudTestServer(int port, int maxInactivePeriod, int scavengePeriod, GCloudConfiguration config)
|
||||
public GCloudTestServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod, GCloudConfiguration config)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod, config);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod, config);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -57,7 +62,7 @@ public class GCloudTestServer extends AbstractTestServer
|
|||
*/
|
||||
public GCloudTestServer(int port, GCloudConfiguration configuration)
|
||||
{
|
||||
super(port, 30,10, configuration);
|
||||
super(port, 30,10, __inspectPeriod, __idlePeriod, configuration);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -53,9 +53,9 @@ public class ImmortalSessionTest extends AbstractImmortalSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractImmortalSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs)
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, maxInactiveMs, scavengeMs, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, maxInactiveMs, scavengeMs, inspectionPeriod, idlePassivatePeriod,_testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -53,9 +53,9 @@ public class InvalidationSessionTest extends AbstractInvalidationSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractInvalidationSessionTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int inspectInterval)
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int scavengeInterval, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
GCloudTestServer server = new GCloudTestServer(port, maxInactive, inspectInterval, _testSupport.getConfiguration())
|
||||
GCloudTestServer server = new GCloudTestServer(port, maxInactive, scavengeInterval, inspectInterval, idlePassivateInterval,_testSupport.getConfiguration())
|
||||
{
|
||||
/**
|
||||
* @see org.eclipse.jetty.gcloud.session.GCloudTestServer#newSessionManager()
|
||||
|
|
|
@ -50,9 +50,9 @@ public class LastAccessTimeTest extends AbstractLastAccessTimeTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractLastAccessTimeTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -51,9 +51,9 @@ public class LocalSessionScavengingTest extends AbstractLocalSessionScavengingTe
|
|||
* @see org.eclipse.jetty.server.session.AbstractLocalSessionScavengingTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -57,9 +57,9 @@ public class NewSessionTest extends AbstractNewSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractNewSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -52,9 +52,9 @@ public class OrphanedSessionTest extends AbstractOrphanedSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractOrphanedSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -51,9 +51,9 @@ public class ReentrantRequestSessionTest extends AbstractReentrantRequestSession
|
|||
* @see org.eclipse.jetty.server.session.AbstractReentrantRequestSessionTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port,int max, int scavengePeriod,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavengePeriod, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -54,9 +54,9 @@ public class RemoveSessionTest extends AbstractRemoveSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractRemoveSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge,int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -47,13 +47,15 @@ public class SameNodeLoadTest extends AbstractSameNodeLoadTest
|
|||
_testSupport.tearDown();
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSameNodeLoadTest#createServer(int)
|
||||
* @see org.eclipse.jetty.server.session.AbstractSameNodeLoadTest#createServer(int, int, int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivationPeriod, _testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -57,9 +57,9 @@ public class SessionExpiryTest extends AbstractSessionExpiryTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionExpiryTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivationPeriod,_testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -53,9 +53,9 @@ public class SessionInvalidateAndCreateTest extends AbstractSessionInvalidateAnd
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionInvalidateAndCreateTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivationPeriod,_testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -19,8 +19,11 @@
|
|||
|
||||
package org.eclipse.jetty.gcloud.session;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.jetty.server.session.AbstractSessionRenewTest;
|
||||
import org.eclipse.jetty.server.session.AbstractTestServer;
|
||||
import static org.junit.Assert.fail;
|
||||
import org.junit.AfterClass;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
@ -51,9 +54,9 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new GCloudTestServer(port,max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port,max, scavenge, inspectionPeriod, idlePassivationPeriod,_testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -63,5 +66,24 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
super.testSessionRenewal();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
try
|
||||
{
|
||||
Set<String> ids = _testSupport.getSessionIds();
|
||||
return (!ids.contains(oldSessionId) && ids.contains(newSessionId));
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
fail(e.getMessage());
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -52,9 +52,9 @@ public class SessionValueSavingTest extends AbstractSessionValueSavingTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionValueSavingTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new GCloudTestServer(port, max, scavenge, _testSupport.getConfiguration());
|
||||
return new GCloudTestServer(port, max, scavenge, inspectionPeriod, idlePassivationPeriod,_testSupport.getConfiguration());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -30,12 +30,12 @@ public class HashTestServer extends AbstractTestServer
|
|||
|
||||
public HashTestServer(int port)
|
||||
{
|
||||
super(port, 30, 10);
|
||||
super(port, 30, 10, 1, 2);
|
||||
}
|
||||
|
||||
public HashTestServer(int port, int maxInactivePeriod, int scavengePeriod)
|
||||
public HashTestServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -22,9 +22,9 @@ public class ImmortalSessionTest extends AbstractImmortalSessionTest
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port,max,scavenge);
|
||||
return new HashTestServer(port,max,scavenge,inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -26,9 +26,9 @@ import org.junit.Test;
|
|||
public class NewSessionTest extends AbstractNewSessionTest
|
||||
{
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port,max,scavenge);
|
||||
return new HashTestServer(port,max,scavenge,inspectionPeriod,idlePassivationPeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -25,9 +25,14 @@ import org.junit.Test;
|
|||
*/
|
||||
public class ReentrantRequestSessionTest extends AbstractReentrantRequestSessionTest
|
||||
{
|
||||
public AbstractTestServer createServer(int port)
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractReentrantRequestSessionTest#createServer(int, int, int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new HashTestServer(port);
|
||||
return new HashTestServer(port, max, scavenge, inspectionPeriod, idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -23,10 +23,6 @@ import org.junit.Test;
|
|||
public class RemoveSessionTest extends AbstractRemoveSessionTest
|
||||
{
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
{
|
||||
return new HashTestServer(port,max,scavenge);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testRemoveSession() throws Exception
|
||||
|
@ -34,4 +30,13 @@ public class RemoveSessionTest extends AbstractRemoveSessionTest
|
|||
super.testRemoveSession();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractRemoveSessionTest#createServer(int, int, int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer (port, max, scavenge, inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -22,9 +22,9 @@ public class SessionCookieTest extends AbstractSessionCookieTest
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port, max, scavenge);
|
||||
return new HashTestServer(port, max, scavenge, inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -24,9 +24,9 @@ public class SessionInvalidateAndCreateTest extends AbstractSessionInvalidateAnd
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port,max,scavenge);
|
||||
return new HashTestServer(port,max,scavenge,inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -30,9 +30,9 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port, max, scavenge);
|
||||
return new HashTestServer(port, max, scavenge,inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -41,5 +41,14 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
super.testSessionRenewal();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
return true; //no other tests possible, sessions only in memory
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -22,9 +22,9 @@ public class SessionValueSharedSaving extends AbstractSessionValueSavingTest
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivationPeriod)
|
||||
{
|
||||
return new HashTestServer(port,max,scavenge);
|
||||
return new HashTestServer(port,max,scavenge,inspectionPeriod, idlePassivationPeriod);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -56,9 +56,9 @@ public class ImmortalSessionTest extends AbstractImmortalSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractImmortalSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs)
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, maxInactiveMs, scavengeMs, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, maxInactiveMs, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -37,14 +37,14 @@ public class InfinispanTestSessionServer extends AbstractTestServer
|
|||
|
||||
public InfinispanTestSessionServer(int port, BasicCache config)
|
||||
{
|
||||
this(port, 30, 10, config);
|
||||
this(port, 30, 10, 1, 2, config);
|
||||
}
|
||||
|
||||
|
||||
|
||||
public InfinispanTestSessionServer(int port, int maxInactivePeriod, int scavengePeriod, BasicCache config)
|
||||
public InfinispanTestSessionServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod, BasicCache config)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod, config);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod, config);
|
||||
}
|
||||
|
||||
|
||||
|
@ -79,7 +79,7 @@ public class InfinispanTestSessionServer extends AbstractTestServer
|
|||
BasicCache cache = ((InfinispanSessionIdManager)_sessionIdManager).getCache();
|
||||
if (cache != null)
|
||||
{
|
||||
return cache.containsKey(id);
|
||||
return cache.containsKey(((InfinispanSessionIdManager)_sessionIdManager).makeKey(id));
|
||||
}
|
||||
|
||||
return false;
|
||||
|
@ -90,7 +90,7 @@ public class InfinispanTestSessionServer extends AbstractTestServer
|
|||
BasicCache cache = ((InfinispanSessionIdManager)_sessionIdManager).getCache();
|
||||
if (cache != null)
|
||||
{
|
||||
return cache.get(id);
|
||||
return cache.get(((InfinispanSessionIdManager)_sessionIdManager).makeKey(id));
|
||||
}
|
||||
|
||||
return null;
|
||||
|
|
|
@ -42,9 +42,9 @@ public class LastAccessTimeTest extends AbstractLastAccessTimeTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -51,9 +51,9 @@ public class LocalSessionScavengingTest extends AbstractLocalSessionScavengingTe
|
|||
* @see org.eclipse.jetty.server.session.AbstractLocalSessionScavengingTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -50,9 +50,9 @@ public class NewSessionTest extends AbstractNewSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractNewSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -49,9 +49,9 @@ public class ReentrantRequestSessionTest extends AbstractReentrantRequestSession
|
|||
* @see org.eclipse.jetty.server.session.AbstractReentrantRequestSessionTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port,int maxInactive, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, maxInactive, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -43,9 +43,9 @@ public class RemoveSessionTest extends AbstractRemoveSessionTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer s = new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
InfinispanTestSessionServer s = new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
return s;
|
||||
}
|
||||
|
||||
|
|
|
@ -51,9 +51,9 @@ public class SameNodeLoadTest extends AbstractSameNodeLoadTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSameNodeLoadTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port,int maxInactive, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, __testSupport.getCache());
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port,maxInactive, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
return server;
|
||||
}
|
||||
|
||||
|
|
|
@ -42,9 +42,9 @@ public class SessionExpiryTest extends AbstractSessionExpiryTest
|
|||
}
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
return server;
|
||||
}
|
||||
|
||||
|
|
|
@ -50,9 +50,9 @@ public class SessionInvalidateAndCreateTest extends AbstractSessionInvalidateAnd
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionInvalidateAndCreateTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -19,6 +19,8 @@
|
|||
|
||||
package org.eclipse.jetty.server.session;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import org.junit.AfterClass;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
@ -52,9 +54,9 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -63,5 +65,16 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
super.testSessionRenewal();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
assertTrue(((InfinispanTestSessionServer)_server).exists(newSessionId));
|
||||
assertFalse(((InfinispanTestSessionServer)_server).exists(oldSessionId));
|
||||
return (!((InfinispanTestSessionServer)_server).exists(oldSessionId)) && ((InfinispanTestSessionServer)_server).exists(newSessionId);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -59,9 +59,9 @@ public class RemoteImmortalSessionTest extends AbstractImmortalSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractImmortalSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs)
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, maxInactiveMs, scavengeMs, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, maxInactiveMs, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -58,24 +58,9 @@ public class RemoteInvalidationSessionTest extends AbstractInvalidationSessionTe
|
|||
* @see org.eclipse.jetty.server.session.AbstractInvalidationSessionTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInterval, int inspectInterval)
|
||||
public AbstractTestServer createServer(int port, int maxInterval, int scavengeInterval, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, maxInterval, inspectInterval, __testSupport.getCache())
|
||||
{
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.InfinispanTestSessionServer#newSessionManager()
|
||||
*/
|
||||
@Override
|
||||
public SessionManager newSessionManager()
|
||||
{
|
||||
InfinispanSessionManager mgr = (InfinispanSessionManager)super.newSessionManager();
|
||||
mgr.getSessionStore().setIdlePassivationTimeoutSec(IDLE_PASSIVATE_SEC);
|
||||
return mgr;
|
||||
}
|
||||
|
||||
};
|
||||
return server;
|
||||
return new InfinispanTestSessionServer(port, maxInterval, scavengeInterval, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -52,9 +52,9 @@ public class RemoteLastAccessTimeTest extends AbstractLastAccessTimeTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -53,9 +53,9 @@ public class RemoteLocalSessionScavengingTest extends AbstractLocalSessionScaven
|
|||
* @see org.eclipse.jetty.server.session.AbstractLocalSessionScavengingTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -53,9 +53,9 @@ public class RemoteNewSessionTest extends AbstractNewSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractNewSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -52,9 +52,9 @@ public class RemoteReentrantRequestSessionTest extends AbstractReentrantRequestS
|
|||
* @see org.eclipse.jetty.server.session.AbstractReentrantRequestSessionTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, maxInactive, scavenge, inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -46,9 +46,9 @@ public class RemoteRemoveSessionTest extends AbstractRemoveSessionTest
|
|||
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer s = new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
InfinispanTestSessionServer s = new InfinispanTestSessionServer(port, max, scavenge,inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
return s;
|
||||
}
|
||||
|
||||
|
|
|
@ -54,9 +54,9 @@ public class RemoteSameNodeLoadTest extends AbstractSameNodeLoadTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSameNodeLoadTest#createServer(int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, __testSupport.getCache());
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, maxInactive, scavenge,inspectInterval, idlePassivateInterval, __testSupport.getCache());
|
||||
return server;
|
||||
}
|
||||
|
||||
|
|
|
@ -45,9 +45,9 @@ public class RemoteSessionExpiryTest extends AbstractSessionExpiryTest
|
|||
}
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
InfinispanTestSessionServer server = new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
return server;
|
||||
}
|
||||
|
||||
|
|
|
@ -53,9 +53,9 @@ public class RemoteSessionInvalidateAndCreateTest extends AbstractSessionInvalid
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionInvalidateAndCreateTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -55,9 +55,9 @@ public class RemoteSessionRenewTest extends AbstractSessionRenewTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, __testSupport.getCache());
|
||||
return new InfinispanTestSessionServer(port, max, scavenge, inspectInterval, idlePassivateInterval,__testSupport.getCache());
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -66,5 +66,12 @@ public class RemoteSessionRenewTest extends AbstractSessionRenewTest
|
|||
super.testSessionRenewal();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
return !((InfinispanTestSessionServer)_server).exists(oldSessionId) && ((InfinispanTestSessionServer)_server).exists(newSessionId);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -57,11 +57,13 @@ public class DirtyAttributeTest
|
|||
public static String THE_NAME = "__theName";
|
||||
public static int INACTIVE = 4;
|
||||
public static int SCAVENGE = 1;
|
||||
public static int INSPECT = 1;
|
||||
public static int IDLE_PASSIVATE = 3;
|
||||
|
||||
@Test
|
||||
public void testDirtyWrite() throws Exception
|
||||
{
|
||||
AbstractTestServer server = new JdbcTestServer(0,INACTIVE,SCAVENGE);
|
||||
AbstractTestServer server = new JdbcTestServer(0,INACTIVE,SCAVENGE, INSPECT, IDLE_PASSIVATE);
|
||||
|
||||
ServletContextHandler ctxA = server.addContext("/mod");
|
||||
ctxA.addServlet(TestDirtyServlet.class, "/test");
|
||||
|
|
|
@ -29,9 +29,9 @@ import org.junit.Test;
|
|||
|
||||
public class ImmortalSessionTest extends AbstractImmortalSessionTest
|
||||
{
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs)
|
||||
public AbstractTestServer createServer(int port, int maxInactiveMs, int scavengeMs, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port, maxInactiveMs, scavengeMs);
|
||||
return new JdbcTestServer(port, maxInactiveMs, scavengeMs, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -29,24 +29,9 @@ public class InvalidationSessionTest extends AbstractInvalidationSessionTest
|
|||
{
|
||||
public static final int IDLE_PASSIVATE_SEC = 3;
|
||||
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int inspectInterval)
|
||||
public AbstractTestServer createServer(int port, int maxInactive, int scavengeInterval, int inspectInterval, int idlePassivateInterval)
|
||||
{
|
||||
JdbcTestServer server = new JdbcTestServer(port, maxInactive, inspectInterval)
|
||||
{
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.JdbcTestServer#newSessionManager()
|
||||
*/
|
||||
@Override
|
||||
public SessionManager newSessionManager()
|
||||
{
|
||||
JDBCSessionManager manager = (JDBCSessionManager)super.newSessionManager();
|
||||
manager.getSessionStore().setIdlePassivationTimeoutSec(IDLE_PASSIVATE_SEC);
|
||||
return manager;
|
||||
}
|
||||
|
||||
};
|
||||
return server;
|
||||
return new JdbcTestServer(port, maxInactive, scavengeInterval, inspectInterval, idlePassivateInterval);
|
||||
}
|
||||
|
||||
public void pause()
|
||||
|
|
|
@ -85,14 +85,14 @@ public class JdbcTestServer extends AbstractTestServer
|
|||
super(port);
|
||||
}
|
||||
|
||||
public JdbcTestServer(int port, int maxInactivePeriod, int scavengePeriod, String connectionUrl)
|
||||
public JdbcTestServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod, String connectionUrl)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod, connectionUrl);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod, connectionUrl);
|
||||
}
|
||||
|
||||
public JdbcTestServer(int port, int maxInactivePeriod, int scavengePeriod)
|
||||
public JdbcTestServer(int port, int maxInactivePeriod, int scavengePeriod, int inspectPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
super(port, maxInactivePeriod, scavengePeriod, DEFAULT_CONNECTION_URL);
|
||||
super(port, maxInactivePeriod, scavengePeriod, inspectPeriod, idlePassivatePeriod, DEFAULT_CONNECTION_URL);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -26,9 +26,9 @@ import org.junit.Test;
|
|||
*/
|
||||
public class LastAccessTimeTest extends AbstractLastAccessTimeTest
|
||||
{
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -43,9 +43,9 @@ public class LocalSessionScavengingTest extends AbstractLocalSessionScavengingTe
|
|||
}
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -61,8 +61,8 @@ public class MaxInactiveMigrationTest
|
|||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
testServer1 = new JdbcTestServer(0, -1, 2);
|
||||
testServer2 = new JdbcTestServer(0, -1, 2);
|
||||
testServer1 = new JdbcTestServer(0, -1, 2, 1, -1);
|
||||
testServer2 = new JdbcTestServer(0, -1, 2, 1, -1);
|
||||
ServletContextHandler context = testServer1.addContext("");
|
||||
context.addServlet(TestServlet.class, "/test");
|
||||
ServletContextHandler context2 = testServer2.addContext("");
|
||||
|
|
|
@ -45,15 +45,17 @@ import org.junit.Test;
|
|||
*/
|
||||
public class ModifyMaxInactiveIntervalTest
|
||||
{
|
||||
|
||||
public static int inactive = 4;
|
||||
public static int newMaxInactive = 20;
|
||||
public static int scavenge = 1;
|
||||
|
||||
public static int __inactive = 4;
|
||||
public static int newMaxInactive = 20;
|
||||
public static int __scavenge = 1;
|
||||
public static int __inspect = 1;
|
||||
public static int __idlePassivate = -1;
|
||||
|
||||
@Test
|
||||
public void testSessionExpiryAfterModifiedMaxInactiveInterval() throws Exception
|
||||
{
|
||||
AbstractTestServer server = new JdbcTestServer(0,inactive,scavenge);
|
||||
AbstractTestServer server = new JdbcTestServer(0,__inactive,__scavenge, __inspect, __idlePassivate);
|
||||
|
||||
ServletContextHandler ctxA = server.addContext("/mod");
|
||||
ctxA.addServlet(TestModServlet.class, "/test");
|
||||
|
|
|
@ -29,9 +29,9 @@ public class NewSessionTest extends AbstractNewSessionTest
|
|||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractNewSessionTest#createServer(int, int, int)
|
||||
*/
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -26,9 +26,9 @@ import org.junit.Test;
|
|||
*/
|
||||
public class OrphanedSessionTest extends AbstractOrphanedSessionTest
|
||||
{
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge,inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -35,9 +35,9 @@ public class ProxySerializationTest extends AbstractProxySerializationTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractProxySerializationTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port, max, scavenge);
|
||||
return new JdbcTestServer(port, max, scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -28,9 +28,9 @@ import org.junit.Test;
|
|||
public class ReentrantRequestSessionTest extends AbstractReentrantRequestSessionTest
|
||||
{
|
||||
|
||||
public AbstractTestServer createServer(int port)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectionPeriod, int idlePassivatePeriod)
|
||||
{
|
||||
return new JdbcTestServer(port);
|
||||
return new JdbcTestServer(port,max,scavenge,inspectionPeriod,idlePassivatePeriod);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -59,7 +59,7 @@ public class SaveIntervalTest
|
|||
@Test
|
||||
public void testSaveInterval() throws Exception
|
||||
{
|
||||
AbstractTestServer server = new JdbcTestServer(0,INACTIVE,SCAVENGE);
|
||||
AbstractTestServer server = new JdbcTestServer(0,INACTIVE,SCAVENGE, 20, -1);
|
||||
|
||||
ServletContextHandler ctxA = server.addContext("/mod");
|
||||
ServletHolder holder = new ServletHolder();
|
||||
|
|
|
@ -34,9 +34,9 @@ public class SessionExpiryTest extends AbstractSessionExpiryTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractSessionExpiryTest#createServer(int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -26,9 +26,9 @@ public class SessionInvalidateAndCreateTest extends AbstractSessionInvalidateAnd
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge,inspect,idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -18,6 +18,9 @@
|
|||
|
||||
package org.eclipse.jetty.server.session;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.fail;
|
||||
import org.junit.After;
|
||||
import org.junit.Test;
|
||||
|
||||
|
@ -25,10 +28,35 @@ public class SessionRenewTest extends AbstractSessionRenewTest
|
|||
{
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port, max, scavenge);
|
||||
return new JdbcTestServer(port, max, scavenge, inspect, idlePassivate);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.server.session.AbstractSessionRenewTest#verifyChange(java.lang.String, java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public boolean verifyChange(String oldSessionId, String newSessionId)
|
||||
{
|
||||
try
|
||||
{
|
||||
//assert the new one exists
|
||||
assertTrue(((JdbcTestServer)_server).existsInSessionTable(newSessionId, false));
|
||||
assertFalse(((JdbcTestServer)_server).existsInSessionTable(oldSessionId, false));
|
||||
return true;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
fail(e.getMessage());
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Test
|
||||
public void testSessionRenewal() throws Exception
|
||||
|
|
|
@ -26,9 +26,9 @@ import org.junit.Test;
|
|||
*/
|
||||
public class SessionValueSavingTest extends AbstractSessionValueSavingTest
|
||||
{
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
{
|
||||
return new JdbcTestServer(port,max,scavenge);
|
||||
return new JdbcTestServer(port,max,scavenge,inspect, idlePassivate);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -64,10 +64,10 @@ public class AttributeNameTest
|
|||
MongoTestServer.dropCollection();
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspect, int idlePassivate)
|
||||
throws Exception
|
||||
{
|
||||
MongoTestServer server = new MongoTestServer(port,max,scavenge,true);
|
||||
MongoTestServer server = new MongoTestServer(port,max,scavenge,inspect, idlePassivate, true);
|
||||
|
||||
return server;
|
||||
|
||||
|
@ -80,12 +80,14 @@ public class AttributeNameTest
|
|||
String servletMapping = "/server";
|
||||
int maxInactivePeriod = 10000;
|
||||
int scavengePeriod = 20000;
|
||||
AbstractTestServer server1 = createServer(0,maxInactivePeriod,scavengePeriod);
|
||||
int inspectPeriod = 60;
|
||||
int idlePassivatePeriod = -1;
|
||||
AbstractTestServer server1 = createServer(0,maxInactivePeriod,scavengePeriod, inspectPeriod, idlePassivatePeriod);
|
||||
server1.addContext(contextPath).addServlet(TestServlet.class,servletMapping);
|
||||
server1.start();
|
||||
int port1 = server1.getPort();
|
||||
|
||||
AbstractTestServer server2 = createServer(0,maxInactivePeriod,scavengePeriod);
|
||||
AbstractTestServer server2 = createServer(0,maxInactivePeriod,scavengePeriod,inspectPeriod, idlePassivatePeriod);
|
||||
server2.addContext(contextPath).addServlet(TestServlet.class,servletMapping);
|
||||
server2.start();
|
||||
int port2 = server2.getPort();
|
||||
|
|
|
@ -43,24 +43,9 @@ public class IdleSessionTest extends AbstractIdleSessionTest
|
|||
* @see org.eclipse.jetty.server.session.AbstractIdleSessionTest#createServer(int, int, int, int)
|
||||
*/
|
||||
@Override
|
||||
public AbstractTestServer createServer(final int port, final int max, final int scavenge, final int idleSec)
|
||||
public AbstractTestServer createServer(final int port, final int max, final int scavenge, final int inspectSec, final int idleSec)
|
||||
{
|
||||
MongoTestServer server = new MongoTestServer(port,max,scavenge)
|
||||
{
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.nosql.mongodb.MongoTestServer#newSessionManager()
|
||||
*/
|
||||
@Override
|
||||
public SessionManager newSessionManager()
|
||||
{
|
||||
MongoSessionManager manager = (MongoSessionManager)super.newSessionManager();
|
||||
manager.getSessionStore().setIdlePassivationTimeoutSec(idleSec);
|
||||
return manager;
|
||||
}
|
||||
|
||||
};
|
||||
return server;
|
||||
return new MongoTestServer(port,max,scavenge, inspectSec, idleSec);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -44,24 +44,9 @@ public class InvalidateSessionTest extends AbstractInvalidationSessionTest
|
|||
}
|
||||
|
||||
@Override
|
||||
public AbstractTestServer createServer(int port, int maxInterval, int inspectInterval)
|
||||
public AbstractTestServer createServer(int port, int maxInterval, int scavengeInterval, int inspectInterval, int idleInterval)
|
||||
{
|
||||
MongoTestServer server = new MongoTestServer(port, maxInterval, inspectInterval)
|
||||
{
|
||||
|
||||
/**
|
||||
* @see org.eclipse.jetty.nosql.mongodb.MongoTestServer#newSessionManager()
|
||||
*/
|
||||
@Override
|
||||
public SessionManager newSessionManager()
|
||||
{
|
||||
MongoSessionManager manager = (MongoSessionManager)super.newSessionManager();
|
||||
manager.getSessionStore().setIdlePassivationTimeoutSec(IDLE_PASSIVATE_SEC);
|
||||
return manager;
|
||||
}
|
||||
|
||||
};
|
||||
return server;
|
||||
return new MongoTestServer(port, maxInterval, scavengeInterval, inspectInterval, idleInterval);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -41,9 +41,9 @@ public class LastAccessTimeTest extends AbstractLastAccessTimeTest
|
|||
MongoTestServer.dropCollection();
|
||||
}
|
||||
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge)
|
||||
public AbstractTestServer createServer(int port, int max, int scavenge, int inspectSec, int idlePassivateSec)
|
||||
{
|
||||
return new MongoTestServer(port,max,scavenge);
|
||||
return new MongoTestServer(port,max,scavenge, inspectSec, idlePassivateSec);
|
||||
}
|
||||
|
||||
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue