From 3d07eaf44f1faa1230aaecfc090a1023a679171d Mon Sep 17 00:00:00 2001 From: Kalven Date: Sat, 31 Aug 2019 03:50:00 +0800 Subject: [PATCH] =?UTF-8?q?KERNEL-1117=20=E6=A0=B9=E6=8D=AE=E6=8F=92?= =?UTF-8?q?=E4=BB=B6=E5=A2=9E=E5=8A=A0=E4=BA=86fineKit=E7=9A=84=E9=83=A8?= =?UTF-8?q?=E5=88=86=E6=96=87=E4=BB=B6=EF=BC=8C=E5=85=B6=E4=B8=AD=E5=8D=95?= =?UTF-8?q?=E4=BE=8B=E6=A8=A1=E5=BC=8F=E8=BF=94=E5=9B=9E=E5=8D=95=E4=BE=8B?= =?UTF-8?q?=E7=9A=84=E6=96=B9=E6=B3=95=E6=B2=A1=E6=9C=89=E8=BF=9B=E8=A1=8C?= =?UTF-8?q?=E5=8D=95=E5=85=83=E6=B5=8B=E8=AF=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../fanruan/api/session/SessionKitTest.java | 372 +++++++++--------- 1 file changed, 186 insertions(+), 186 deletions(-) diff --git a/src/test/java/com/fanruan/api/session/SessionKitTest.java b/src/test/java/com/fanruan/api/session/SessionKitTest.java index 43eda1d..275d52d 100644 --- a/src/test/java/com/fanruan/api/session/SessionKitTest.java +++ b/src/test/java/com/fanruan/api/session/SessionKitTest.java @@ -1,186 +1,186 @@ -//package com.fanruan.api.session; -// -//import com.fanruan.api.Prepare; -//import com.fr.general.web.ParameterConstants; -//import com.fr.invoke.Reflect; -//import com.fr.stable.StringUtils; -//import com.fr.stable.web.SessionProvider; -//import com.fr.stable.web.SessionSource; -//import com.fr.stable.web.Weblet; -//import com.fr.web.core.RemoteAddressManager; -//import com.fr.web.core.SessionPoolManager; -//import com.fr.web.session.SessionIDInfo; -//import com.fr.web.utils.WebUtils; -//import org.easymock.EasyMock; -//import org.easymock.IAnswer; -//import org.easymock.IMocksControl; -//import org.junit.Assert; -//import org.junit.Test; -//import org.junit.runner.RunWith; -//import org.powermock.api.easymock.PowerMock; -//import org.powermock.core.classloader.annotations.PrepareForTest; -//import org.powermock.core.classloader.annotations.SuppressStaticInitializationFor; -//import org.powermock.modules.junit4.PowerMockRunner; -//import org.powermock.reflect.Whitebox; -// -//import javax.servlet.http.HttpServletRequest; -//import java.util.HashMap; -//import java.util.HashSet; -//import java.util.List; -//import java.util.Map; -//import java.util.Set; -//import java.util.concurrent.ConcurrentHashMap; -//import java.util.concurrent.ExecutorService; -//import java.util.concurrent.Executors; -// -//import static org.junit.Assert.assertEquals; -//import static org.junit.Assert.assertFalse; -//import static org.junit.Assert.assertNotNull; -//import static org.junit.Assert.assertTrue; -// -///** -// * @author richie -// * @version 10.0 -// * Created by richie on 2019-08-09 -// */ -//@RunWith(PowerMockRunner.class) -//@PrepareForTest({SessionPoolManager.class, WebUtils.class}) -//@SuppressStaticInitializationFor({"com.fr.web.core.SessionPoolManager"}) -//public class SessionKitTest extends Prepare { -// -// private static final long MIN_ACCESS_INTERVAL = 900; -// private int taskCount = 0; -// private Map sessions = new HashMap(); -// -// @Test -// public void testGenerateSession() throws Exception { -// final SessionIDInfo sessionInfo = new MockSession("session"); -// final Map params = new HashMap(); -// PowerMock.mockStatic(SessionPoolManager.class); -// PowerMock.mockStatic(WebUtils.class); -// IMocksControl control = EasyMock.createControl(); -// final HttpServletRequest request = control.createMock(HttpServletRequest.class); -// EasyMock.expect(WebUtils.getIpAddr(request)).andReturn("127.0.0.1").anyTimes(); -// EasyMock.expect(WebUtils.getHTTPRequestParameter(request, ParameterConstants.OP)).andReturn("view").anyTimes(); -// EasyMock.expect(WebUtils.parameters4SessionIDInforContainMPCache(request)).andReturn(params).anyTimes(); -// final Weblet weblet = control.createMock(Weblet.class); -// EasyMock.expect(weblet.isSessionOccupy()).andReturn(false).anyTimes(); -// EasyMock.expect(weblet.createSessionIDInfor(request, "127.0.0.1", params)).andReturn(sessionInfo).anyTimes(); -// EasyMock.expect(addSessionIDInfo(sessionInfo)).andReturn(sessionInfo.getSessionID()).anyTimes(); -// EasyMock.expect(SessionPoolManager.generateSessionID(request, null, weblet)).andAnswer(new IAnswer() { -// @Override -// public String answer() throws Throwable { -// SessionProvider sessionIDInfor = weblet.createSessionIDInfor(request, "127.0.0.1", params); -// String sessionID = addSessionIDInfo(sessionIDInfor); -// if (weblet.isSessionOccupy()) { -// assert sessionID != null; -// RemoteAddressManager.add("127.0.0.1", sessionID); -// } -// return sessionID; -// } -// }).anyTimes(); -// control.replay(); -// PowerMock.replayAll(); -// sessionInfo.setSource(SessionSource.SINGLE); -// SessionPoolManager.generateSessionID(request, null, weblet); -// Assert.assertSame(sessionInfo.getSource(), SessionSource.SINGLE); -// sessionInfo.setSource(SessionSource.INTEGRATION); -// SessionPoolManager.generateSessionID(request, null, weblet); -// Assert.assertSame(sessionInfo.getSource(), SessionSource.INTEGRATION); -// -// } -// -// @Test -// public void testAddDelayTask() { -// String sessionID = "test"; -// sessions.put("test", new MockSession("test")); -// for (int i = 0; i < 100; i++) { -// accessSession(sessionID); -// } -// Assert.assertEquals(1, this.taskCount); -// for (int i = 0; i < 2; i++) { -// try { -// Thread.sleep(1000); -// } catch (InterruptedException e) { -// //do nothing -// } -// accessSession(sessionID); -// } -// Assert.assertEquals(3, this.taskCount); -// } -// -// private void accessSession(String sessionId) { -// if (StringUtils.isBlank(sessionId)) { -// return; -// } -// -// SessionProvider sessionIDInfor = sessions.get(sessionId); -// if (sessionIDInfor != null) { -// long accessInterval = System.currentTimeMillis() - sessionIDInfor.getLastAccessTime(); -// sessionIDInfor.updateTime(); -// if (accessInterval > MIN_ACCESS_INTERVAL) { -// taskCount++; -// } -// } -// } -// -// @Test -// public void testGetAllSession() { -// Whitebox.setInternalState( -// SessionPoolManager.class, -// "sessionIDMap", -// new ConcurrentHashMap() -// ); -// Whitebox.setInternalState(SessionPoolManager.class, "sessionToDelete", new HashSet()); -// Map sessionIDMap = Reflect.on(SessionPoolManager.class).get("sessionIDMap"); -// String sessionID1 = "Test1"; -// sessionIDMap.put(sessionID1, new MockSession(sessionID1)); -// sessionIDMap.put("Test2", new MockSession("Test2")); -// closeSession(sessionID1); -// List list = SessionPoolManager.getAllSession(SessionProvider.class); -// assertEquals(1, list.size()); -// assertEquals("Test2", list.get(0).getSessionID()); -// assertNotNull(SessionKit.getSession("Test2")); -// } -// -// @Test -// public void testHasSessionID() { -// Whitebox.setInternalState( -// SessionPoolManager.class, -// "sessionIDMap", -// new ConcurrentHashMap() -// ); -// Whitebox.setInternalState(SessionPoolManager.class, "sessionToDelete", new HashSet()); -// Map sessionIDMap = Reflect.on(SessionPoolManager.class).get("sessionIDMap"); -// String sessionID1 = "Test1"; -// sessionIDMap.put(sessionID1, new MockSession(sessionID1)); -// sessionIDMap.put("Test2", new MockSession("Test2")); -// closeSession(sessionID1); -// assertFalse(SessionPoolManager.hasSessionID(sessionID1)); -// assertTrue(SessionPoolManager.hasSessionID("Test2")); -// } -// -// private void closeSession(final String sessionID) { -// final Set sessionToDelete = Reflect.on(SessionPoolManager.class).get("sessionToDelete"); -// sessionToDelete.add(sessionID); -// ExecutorService closeSessionPool = Executors.newFixedThreadPool(1); -// closeSessionPool.submit(new Runnable() { -// @Override -// public void run() { -// try { -// //模拟删除session对象的过程 -// Thread.sleep(1000); -// } catch (InterruptedException e) { -// //do nothing -// } -// synchronized (SessionPoolManager.class) { -// sessionToDelete.remove(sessionID); -// } -// } -// }); -// } -// -// private String addSessionIDInfo(SessionProvider sessionIDInfo) { -// return Reflect.on(SessionPoolManager.class).call("addSessionIDInfor", sessionIDInfo).get(); -// } -//} \ No newline at end of file +package com.fanruan.api.session; + +import com.fanruan.api.Prepare; +import com.fr.general.web.ParameterConstants; +import com.fr.invoke.Reflect; +import com.fr.stable.StringUtils; +import com.fr.stable.web.SessionProvider; +import com.fr.stable.web.SessionSource; +import com.fr.stable.web.Weblet; +import com.fr.web.core.RemoteAddressManager; +import com.fr.web.core.SessionPoolManager; +import com.fr.web.session.SessionIDInfo; +import com.fr.web.utils.WebUtils; +import org.easymock.EasyMock; +import org.easymock.IAnswer; +import org.easymock.IMocksControl; +import org.junit.Assert; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.powermock.api.easymock.PowerMock; +import org.powermock.core.classloader.annotations.PrepareForTest; +import org.powermock.core.classloader.annotations.SuppressStaticInitializationFor; +import org.powermock.modules.junit4.PowerMockRunner; +import org.powermock.reflect.Whitebox; + +import javax.servlet.http.HttpServletRequest; +import java.util.HashMap; +import java.util.HashSet; +import java.util.List; +import java.util.Map; +import java.util.Set; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.Executors; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertFalse; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertTrue; + +/** + * @author richie + * @version 10.0 + * Created by richie on 2019-08-09 + */ +@RunWith(PowerMockRunner.class) +@PrepareForTest({SessionPoolManager.class, WebUtils.class}) +@SuppressStaticInitializationFor({"com.fr.web.core.SessionPoolManager"}) +public class SessionKitTest extends Prepare { + + private static final long MIN_ACCESS_INTERVAL = 900; + private int taskCount = 0; + private Map sessions = new HashMap(); + + @Test + public void testGenerateSession() throws Exception { + final SessionIDInfo sessionInfo = new MockSession("session"); + final Map params = new HashMap(); + PowerMock.mockStatic(SessionPoolManager.class); + PowerMock.mockStatic(WebUtils.class); + IMocksControl control = EasyMock.createControl(); + final HttpServletRequest request = control.createMock(HttpServletRequest.class); + EasyMock.expect(WebUtils.getIpAddr(request)).andReturn("127.0.0.1").anyTimes(); + EasyMock.expect(WebUtils.getHTTPRequestParameter(request, ParameterConstants.OP)).andReturn("view").anyTimes(); + EasyMock.expect(WebUtils.parameters4SessionIDInforContainMPCache(request)).andReturn(params).anyTimes(); + final Weblet weblet = control.createMock(Weblet.class); + EasyMock.expect(weblet.isSessionOccupy()).andReturn(false).anyTimes(); + EasyMock.expect(weblet.createSessionIDInfor(request, "127.0.0.1", params)).andReturn(sessionInfo).anyTimes(); + EasyMock.expect(addSessionIDInfo(sessionInfo)).andReturn(sessionInfo.getSessionID()).anyTimes(); + EasyMock.expect(SessionPoolManager.generateSessionID(request, null, weblet)).andAnswer(new IAnswer() { + @Override + public String answer() throws Throwable { + SessionProvider sessionIDInfor = weblet.createSessionIDInfor(request, "127.0.0.1", params); + String sessionID = addSessionIDInfo(sessionIDInfor); + if (weblet.isSessionOccupy()) { + assert sessionID != null; + RemoteAddressManager.add("127.0.0.1", sessionID); + } + return sessionID; + } + }).anyTimes(); + control.replay(); + PowerMock.replayAll(); + sessionInfo.setSource(SessionSource.SINGLE); + SessionPoolManager.generateSessionID(request, null, weblet); + Assert.assertSame(sessionInfo.getSource(), SessionSource.SINGLE); + sessionInfo.setSource(SessionSource.INTEGRATION); + SessionPoolManager.generateSessionID(request, null, weblet); + Assert.assertSame(sessionInfo.getSource(), SessionSource.INTEGRATION); + + } + + @Test + public void testAddDelayTask() { + String sessionID = "test"; + sessions.put("test", new MockSession("test")); + for (int i = 0; i < 100; i++) { + accessSession(sessionID); + } + Assert.assertEquals(1, this.taskCount); + for (int i = 0; i < 2; i++) { + try { + Thread.sleep(1000); + } catch (InterruptedException e) { + //do nothing + } + accessSession(sessionID); + } + Assert.assertEquals(3, this.taskCount); + } + + private void accessSession(String sessionId) { + if (StringUtils.isBlank(sessionId)) { + return; + } + + SessionProvider sessionIDInfor = sessions.get(sessionId); + if (sessionIDInfor != null) { + long accessInterval = System.currentTimeMillis() - sessionIDInfor.getLastAccessTime(); + sessionIDInfor.updateTime(); + if (accessInterval > MIN_ACCESS_INTERVAL) { + taskCount++; + } + } + } + + @Test + public void testGetAllSession() { + Whitebox.setInternalState( + SessionPoolManager.class, + "sessionIDMap", + new ConcurrentHashMap() + ); + Whitebox.setInternalState(SessionPoolManager.class, "sessionToDelete", new HashSet()); + Map sessionIDMap = Reflect.on(SessionPoolManager.class).get("sessionIDMap"); + String sessionID1 = "Test1"; + sessionIDMap.put(sessionID1, new MockSession(sessionID1)); + sessionIDMap.put("Test2", new MockSession("Test2")); + closeSession(sessionID1); + List list = SessionPoolManager.getAllSession(SessionProvider.class); + assertEquals(1, list.size()); + assertEquals("Test2", list.get(0).getSessionID()); + assertNotNull(SessionKit.getSession("Test2")); + } + + @Test + public void testHasSessionID() { + Whitebox.setInternalState( + SessionPoolManager.class, + "sessionIDMap", + new ConcurrentHashMap() + ); + Whitebox.setInternalState(SessionPoolManager.class, "sessionToDelete", new HashSet()); + Map sessionIDMap = Reflect.on(SessionPoolManager.class).get("sessionIDMap"); + String sessionID1 = "Test1"; + sessionIDMap.put(sessionID1, new MockSession(sessionID1)); + sessionIDMap.put("Test2", new MockSession("Test2")); + closeSession(sessionID1); + assertFalse(SessionPoolManager.hasSessionID(sessionID1)); + assertTrue(SessionPoolManager.hasSessionID("Test2")); + } + + private void closeSession(final String sessionID) { + final Set sessionToDelete = Reflect.on(SessionPoolManager.class).get("sessionToDelete"); + sessionToDelete.add(sessionID); + ExecutorService closeSessionPool = Executors.newFixedThreadPool(1); + closeSessionPool.submit(new Runnable() { + @Override + public void run() { + try { + //模拟删除session对象的过程 + Thread.sleep(1000); + } catch (InterruptedException e) { + //do nothing + } + synchronized (SessionPoolManager.class) { + sessionToDelete.remove(sessionID); + } + } + }); + } + + private String addSessionIDInfo(SessionProvider sessionIDInfo) { + return Reflect.on(SessionPoolManager.class).call("addSessionIDInfor", sessionIDInfo).get(); + } +} \ No newline at end of file