diff options
Diffstat (limited to 'id/server/idserverlib/src/test')
10 files changed, 815 insertions, 87 deletions
| diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java index 66dffe311..3ecbb84a2 100644 --- a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/module/test/TestRequestImpl.java @@ -24,8 +24,11 @@ package at.gv.egovernment.moa.id.module.test;  import java.util.Collection; +import org.opensaml.saml2.metadata.provider.MetadataProvider; +  import at.gv.egovernment.moa.id.commons.api.IOAAuthParameters;  import at.gv.egovernment.moa.id.commons.api.IRequest; +import at.gv.egovernment.moa.id.commons.api.data.IAuthenticationSession;  import at.gv.egovernment.moa.id.commons.api.exceptions.SessionDataStorageException;  /** @@ -118,15 +121,6 @@ public class TestRequestImpl implements IRequest {  	}  	/* (non-Javadoc) -	 * @see at.gv.egovernment.moa.id.moduls.IRequest#getMOASessionIdentifier() -	 */ -	@Override -	public String getMOASessionIdentifier() { -		// TODO Auto-generated method stub -		return null; -	} - -	/* (non-Javadoc)  	 * @see at.gv.egovernment.moa.id.moduls.IRequest#getUniqueTransactionIdentifier()  	 */  	@Override @@ -254,10 +248,37 @@ public class TestRequestImpl implements IRequest {  	 * @see at.gv.egovernment.moa.id.moduls.IRequest#getRequestedAttributes()  	 */  	@Override -	public Collection<String> getRequestedAttributes() { +	public Collection<String> getRequestedAttributes(MetadataProvider metadataProvider) { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.commons.api.IRequest#getInternalSSOSessionIdentifier() +	 */ +	@Override +	public String getInternalSSOSessionIdentifier() {  		// TODO Auto-generated method stub  		return null;  	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.commons.api.IRequest#getMOASession() +	 */ +	@Override +	public IAuthenticationSession getMOASession() { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.commons.api.IRequest#populateMOASessionWithSSOInformation(at.gv.egovernment.moa.id.commons.api.data.IAuthenticationSession) +	 */ +	@Override +	public void populateMOASessionWithSSOInformation(IAuthenticationSession ssoSession) { +		// TODO Auto-generated method stub +		 +	} diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/DummyTransactionStorage.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/DummyTransactionStorage.java new file mode 100644 index 000000000..ab08c0f5c --- /dev/null +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/DummyTransactionStorage.java @@ -0,0 +1,147 @@ +package at.gv.egovernment.moa.id.process.spring.test; + +import java.util.ArrayList; +import java.util.Date; +import java.util.Iterator; +import java.util.List; + +import javax.sql.DataSource; + +import at.gv.egovernment.moa.id.auth.exception.AuthenticationException; +import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException; +import at.gv.egovernment.moa.id.storage.ITransactionStorage; +import at.gv.egovernment.moa.logging.Logger; + +/** + * Dummy DataSource implementation for convenience in test cases where a + * database connection will never actually be acquired. + * + * @see DataSource + * @author Chris Beams + */ +public class DummyTransactionStorage implements ITransactionStorage { + +	public class DummyDBEntry{ +		public DummyDBEntry(String key, Object value){ +			this.obj =value; +			this.key = key; +		} +		public String getKey() { +			return key; +		} +		public void setKey(String key) { +			this.key = key; +		} +		public Object getObj() { +			return obj; +		} +		public void setObj(Object obj) { +			this.obj = obj; +		} +		private String key; +		private Object obj; +	} +	 +	private ArrayList<DummyDBEntry> ds = new ArrayList<DummyDBEntry>(); +	 + +	 +	@Override +	public boolean containsKey(String key) { +		// TODO Auto-generated method stub +		Iterator<DummyDBEntry> it = ds.iterator(); +		while(it.hasNext()){ +			DummyDBEntry t = it.next(); +			if(t.getKey().equals(key)) +				return true; +		} +		return false; +	} + +	@Override +	public void put(String key, Object value, int timeout_ms) +			throws MOADatabaseException { +		// TODO Auto-generated method stub +		this.remove(key); +		this.ds.add(new DummyDBEntry(key, value)); +		 +	} + +	@Override +	public Object get(String key) throws MOADatabaseException { +		// TODO Auto-generated method stub +		Iterator<DummyDBEntry> it = ds.iterator(); +		while(it.hasNext()){ +			DummyDBEntry t = it.next(); +			if(t.getKey().equals(key)) +				return t; +		} +		return null; +	} + +	@Override +	public <T> T get(String key, Class<T> clazz) throws MOADatabaseException { +		 +		  DummyDBEntry o = (DummyDBEntry) get(key); +		  if(o == null) +			  return null; +		  try { +			  @SuppressWarnings("unchecked") +			T test = (T) (clazz.cast(o.getObj())); +			return test; +			 +		  } catch (Exception e) { +			Logger.warn("Sessioninformation Cast-Exception by using Artifact=" + key); +			throw new MOADatabaseException("Sessioninformation Cast-Exception"); +			 +		  } +	} + +	@Override +	public <T> T get(String key, Class<T> clazz, long dataTimeOut) +			throws MOADatabaseException, AuthenticationException { +		// TODO Auto-generated method stub +		return get(key,clazz); +	} + +	@Override +	public void changeKey(String oldKey, String newKey, Object value) +			throws MOADatabaseException { +		this.remove(oldKey); +		this.put(newKey, value, -1); +		 +	} + +	@Override +	public void remove(String key) { +		Iterator<DummyDBEntry> it = ds.iterator(); +		while(it.hasNext()){ +			DummyDBEntry t = it.next(); +			if(t.getKey().equals(key)){ +				this.ds.remove(t); +				return; +			} +		} +		 +	} + +	@Override +	public List<String> clean(Date now, long dataTimeOut) { +		// TODO Auto-generated method stub +		return null; +	} + +	@Override +	public Object getAssertionStore(String key) throws MOADatabaseException { +		// TODO Auto-generated method stub +		return null; +	} + +	@Override +	public void putAssertionStore(Object element) throws MOADatabaseException { +		// TODO Auto-generated method stub +		 +	} + +     +}
\ No newline at end of file diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest.java index 2cb2a3278..c06735f9e 100644 --- a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest.java +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest.java @@ -18,7 +18,6 @@ import org.springframework.context.ApplicationContext;  import org.springframework.test.context.ContextConfiguration;  import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; -import at.gv.egovernment.moa.id.commons.db.MOASessionDBUtils;  import at.gv.egovernment.moa.id.commons.db.dao.session.AssertionStore;  import at.gv.egovernment.moa.id.module.test.TestRequestImpl;  import at.gv.egovernment.moa.id.process.ProcessDefinitionParserException; @@ -78,7 +77,7 @@ public class SpringExpressionAwareProcessEngineTest {  			config.addProperties(props);  			//config.addAnnotatedClass(ProcessInstanceStore.class);  			config.addAnnotatedClass(AssertionStore.class); -			MOASessionDBUtils.initHibernate(config, props); +			//MOASessionDBUtils.initHibernate(config, props);  		} catch (Exception e) {  			e.printStackTrace();  		} diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/test/ProcessEngineTest.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/test/ProcessEngineTest.java index a7e351e25..6744c0403 100644 --- a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/test/ProcessEngineTest.java +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/process/test/ProcessEngineTest.java @@ -17,7 +17,6 @@ import org.springframework.context.ApplicationContext;  import org.springframework.test.context.ContextConfiguration;  import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; -import at.gv.egovernment.moa.id.commons.db.MOASessionDBUtils;  import at.gv.egovernment.moa.id.commons.db.dao.session.AssertionStore;  import at.gv.egovernment.moa.id.module.test.TestRequestImpl;  import at.gv.egovernment.moa.id.process.ProcessDefinitionParser; @@ -73,7 +72,7 @@ public class ProcessEngineTest {  			config.addProperties(props);  			//config.addAnnotatedClass(ProcessInstanceStore.class);  			config.addAnnotatedClass(AssertionStore.class); -			MOASessionDBUtils.initHibernate(config, props); +			//MOASessionDBUtils.initHibernate(config, props);  		} catch (Exception e) {  			e.printStackTrace();  		} diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/DBTransactionStorageTest.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/DBTransactionStorageTest.java new file mode 100644 index 000000000..4b7f61ef5 --- /dev/null +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/DBTransactionStorageTest.java @@ -0,0 +1,122 @@ +package at.gv.egovernment.moa.id.storage.test; + +import java.io.IOException; + +import javax.xml.parsers.ParserConfigurationException; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.ApplicationContext; +import org.springframework.context.ConfigurableApplicationContext; +import org.springframework.context.support.FileSystemXmlApplicationContext; +import org.w3c.dom.Element; +import org.xml.sax.SAXException; + +import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException; +import at.gv.egovernment.moa.id.storage.DBTransactionStorage; +import at.gv.egovernment.moa.id.storage.ITransactionStorage; +import at.gv.egovernment.moa.util.Constants; +import at.gv.util.DOMUtils; + +public class DBTransactionStorageTest { + +	public static void main (String[] args) throws SAXException, IOException, ParserConfigurationException, MOADatabaseException{ +		DBTransactionStorageTest t = new DBTransactionStorageTest(); +		t.test(); +	} +	 +	@Autowired +	DBTransactionStorage rts; +	 +	public DBTransactionStorageTest(){ + +	} + +	 +	public void test() throws SAXException, IOException, ParserConfigurationException, MOADatabaseException{ + + +		ApplicationContext context = new FileSystemXmlApplicationContext("src/test/java/testBeans.xml"); + + +		String requestString = +				"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +						"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"123456\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +						"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +						"</samlp:Request>"; +		Element request = DOMUtils.parseDocument(requestString, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); + +		ITransactionStorage rts = (ITransactionStorage) context.getBean("DBTransactionStorage"); +		//GenericToStringSerializer redisStringSerializer = (GenericToStringSerializer) context.getBean("valueObjectSerializer"); + +		//				rts.getTemplate().setValueSerializer(new GenericToStringSerializer<Object>(Object.class)); +		//				rts.getTemplate().setHashValueSerializer(new GenericToStringSerializer<Object>(Object.class)); + +		int cnt = 10; +		int averageCnt = 10; +		long putTime = 0, getTime = 0, changeTime = 0, removeTime = 0; +		long total = 0; +		for(int a=0;a<averageCnt;a++){ +			long totalPerRound = 0; +			 +			System.out.println("Starting MySql store operation."); +			long start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.put("test"+i, request,-1); +			long end = System.currentTimeMillis(); +			putTime += end-start; +			System.out.println("MySql store operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); + +			Element test; +			System.out.println("Starting MySql get operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				test = (Element)rts.get("test"+i); +			end = System.currentTimeMillis(); +			getTime += end-start; +			System.out.println("MySql get operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			//Element test = (Element)rts.get("test0"); +			//System.out.println("Read Element from Redis Store: "+test.getTextContent()); + +			String requestString2 = +					"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +							"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"test_new\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +							"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +							"</samlp:Request>"; +			Element request2 = DOMUtils.parseDocument(requestString2, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); + +			System.out.println("Starting MySql change operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.changeKey("test"+i, "test_new"+i, request2); +			end = System.currentTimeMillis(); +			changeTime += end-start; +			System.out.println("MySql change operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			 +			 +			 +			System.out.println("Starting MySql remove operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.remove("test_new"+i); +			end = System.currentTimeMillis(); +			removeTime += end-start; +			System.out.println("MySql remove operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			total+=totalPerRound; +			 +			System.out.println("Redis Total Time in this round: "+totalPerRound+" ms."); +			System.out.println("______________________________________________________"); +		} +		System.out.println("______________________________________________________"); +		System.out.println("Redis average get time over " + averageCnt +" rounds: "+getTime/averageCnt+" ms."); +		System.out.println("Redis average put time over " + averageCnt +" rounds: "+putTime/averageCnt+" ms."); +		System.out.println("Redis average change time over " + averageCnt +" rounds: "+changeTime/averageCnt+" ms."); +		System.out.println("Redis average remove time over " + averageCnt +" rounds: "+removeTime/averageCnt+" ms."); +		System.out.println("Redis average total time over " + averageCnt +" rounds: "+total/averageCnt+" ms."); +		((ConfigurableApplicationContext)context).close(); +	} + +} diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionMultiThreadTest.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionMultiThreadTest.java new file mode 100644 index 000000000..60b55f497 --- /dev/null +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionMultiThreadTest.java @@ -0,0 +1,130 @@ +package at.gv.egovernment.moa.id.storage.test; + +import java.io.IOException; + +import javax.xml.parsers.ParserConfigurationException; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.context.ApplicationContext; +import org.springframework.context.ConfigurableApplicationContext; +import org.springframework.context.support.FileSystemXmlApplicationContext; +import org.springframework.core.task.TaskExecutor; +import org.w3c.dom.Element; +import org.xml.sax.SAXException; + +import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException; +import at.gv.egovernment.moa.id.storage.RedisTransactionStorage; +import at.gv.egovernment.moa.util.Constants; +import at.gv.util.DOMUtils; + +public class RedisTransactionMultiThreadTest { + +	private ApplicationContext context; +     +    public RedisTransactionMultiThreadTest() throws SAXException, IOException, ParserConfigurationException, MOADatabaseException{ +    	this.context = new FileSystemXmlApplicationContext("src/test/java/testBeans.xml"); +		TaskExecutor te = (TaskExecutor) context.getBean("taskExecutor"); +		 +		for(int i=0;i<50;i++){ +			te.execute(new RedisTask("Task"+i)); +		} +		 +		 +    } +     +	public static void main(String[] args) throws SAXException, IOException, ParserConfigurationException, MOADatabaseException{ + +		RedisTransactionMultiThreadTest t = new RedisTransactionMultiThreadTest(); +		System.out.println("End"); + +//		String requestString = +//		  	"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +//		  	"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"123456\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +//		  	"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +//				"</samlp:Request>"; +//				Element request = DOMUtils.parseDocument(requestString, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); +//				 +// +//				 +//				 +//				RedisTransactionStorage rts = (RedisTransactionStorage) context.getBean("TransactionStorage"); +//				//GenericToStringSerializer redisStringSerializer = (GenericToStringSerializer) context.getBean("valueObjectSerializer"); +// +////				rts.getTemplate().setValueSerializer(new GenericToStringSerializer<Object>(Object.class)); +////				rts.getTemplate().setHashValueSerializer(new GenericToStringSerializer<Object>(Object.class)); +//				 +//				 +//				rts.put("test", request,-1); +//				System.out.println("Redis store operation done!"); +//				 +//				Element test = (Element)rts.get("test"); +//				System.out.println("Read Element from Redis Store: "+test.getTextContent()); +//				 +//				String requestString2 = +//					  	"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +//					  	"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"test_new\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +//					  	"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +//							"</samlp:Request>"; +//				Element request2 = DOMUtils.parseDocument(requestString2, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); +//				 +//				 +//				rts.changeKey("test", "test_new", request2); +// +//				rts.remove("test"); +//				rts.remove("test_new"); +//				 +//				((ConfigurableApplicationContext)context).close(); +	} +	 +	private class RedisTask implements Runnable { + +        private String message; + +        public RedisTask(String message) throws SAXException, IOException, ParserConfigurationException, MOADatabaseException { +             +        	this.message = message; +             + +             +        } + +        public void run() { +            String requestString = +        		  	"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +        		  	"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"123456\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +        		  	"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +        				"</samlp:Request>"; +        	 +            Element request = null; +			try { +				request = DOMUtils.parseDocument(requestString, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); +			} catch (SAXException e) { +				// TODO Auto-generated catch block +				e.printStackTrace(); +				return; +			} catch (IOException e) { +				// TODO Auto-generated catch block +				e.printStackTrace(); +				return; +			} catch (ParserConfigurationException e) { +				// TODO Auto-generated catch block +				e.printStackTrace(); +				return; +			} +        			 +        	RedisTransactionStorage rts = (RedisTransactionStorage) context.getBean("RedisTransactionStorage"); +        				 +        	try { +				rts.put(message, request,-1); +				rts.changeKey(message, message+"n", request); +			} catch (MOADatabaseException e) { +				// TODO Auto-generated catch block +				e.printStackTrace(); +				return; +			} +        	System.out.println("Done with task "+message); +        } + +    } + +} diff --git a/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionStorageTest.java b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionStorageTest.java new file mode 100644 index 000000000..e957ffe05 --- /dev/null +++ b/id/server/idserverlib/src/test/java/at/gv/egovernment/moa/id/storage/test/RedisTransactionStorageTest.java @@ -0,0 +1,116 @@ +package at.gv.egovernment.moa.id.storage.test; + +import java.io.IOException; + +import javax.xml.parsers.ParserConfigurationException; + +import org.springframework.context.ApplicationContext; +import org.springframework.context.ConfigurableApplicationContext; +import org.springframework.context.support.FileSystemXmlApplicationContext; +import org.w3c.dom.Element; +import org.xml.sax.SAXException; + +import at.gv.egovernment.moa.id.commons.db.ex.MOADatabaseException; +import at.gv.egovernment.moa.id.storage.DBTransactionStorage; +import at.gv.egovernment.moa.id.storage.RedisTransactionStorage; +import at.gv.egovernment.moa.util.Constants; +import at.gv.util.DOMUtils; + +public class RedisTransactionStorageTest { + + +	public RedisTransactionStorageTest(){ + +	} + +	public static void main(String[] args) throws SAXException, IOException, ParserConfigurationException, MOADatabaseException{ + + +		ApplicationContext context = new FileSystemXmlApplicationContext("src/test/java/testBeans.xml"); +		 +		 +		String requestString = +				"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +						"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"123456\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +						"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +						"</samlp:Request>"; +		Element request = DOMUtils.parseDocument(requestString, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); + +		RedisTransactionStorage rts = (RedisTransactionStorage) context.getBean("RedisTransactionStorage"); +		//GenericToStringSerializer redisStringSerializer = (GenericToStringSerializer) context.getBean("valueObjectSerializer"); + +		//				rts.getTemplate().setValueSerializer(new GenericToStringSerializer<Object>(Object.class)); +		//				rts.getTemplate().setHashValueSerializer(new GenericToStringSerializer<Object>(Object.class)); + +		int cnt = 100; +		int averageCnt = 10; +		long putTime = 0, getTime = 0, changeTime = 0, removeTime = 0; +		long total = 0; +		for(int a=0;a<averageCnt;a++){ +			long totalPerRound = 0; +			 +			System.out.println("Starting Redis store operation."); +			long start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.put("test"+i, request,-1); +			long end = System.currentTimeMillis(); +			putTime += end-start; +			System.out.println("Redis store operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); + +			Element test; +			System.out.println("Starting Redis get operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				test = (Element)rts.get("test"+i); +			end = System.currentTimeMillis(); +			getTime += end-start; +			System.out.println("Redis get operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			//Element test = (Element)rts.get("test0"); +			//System.out.println("Read Element from Redis Store: "+test.getTextContent()); + +			String requestString2 = +					"<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" + +							"<samlp:Request xmlns:samlp=\"urn:oasis:names:tc:SAML:1.0:protocol\" xmlns:saml=\"urn:oasis:names:tc:SAML:1.0:assertion\" RequestID=\"test_new\" MajorVersion=\"1\" MinorVersion=\"0\" IssueInstant=\"2003-02-13T13:59:00\">" + +							"<samlp:AssertionArtifact>WRONGARTIFACT</samlp:AssertionArtifact>" + +							"</samlp:Request>"; +			Element request2 = DOMUtils.parseDocument(requestString2, false, Constants.ALL_SCHEMA_LOCATIONS, null).getDocumentElement(); + +			System.out.println("Starting Redis change operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.changeKey("test"+i, "test_new"+i, request2); +			end = System.currentTimeMillis(); +			changeTime += end-start; +			System.out.println("Redis change operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			 +			 +			 +			System.out.println("Starting Redis remove operation."); +			start = System.currentTimeMillis(); +			for(int i=0; i<cnt;i++) +				rts.remove("test_new"+i); +			end = System.currentTimeMillis(); +			removeTime += end-start; +			System.out.println("Redis remove operation done in "+(end-start)+" ms."); +			totalPerRound+=(end-start); +			total+=totalPerRound; +			 +			System.out.println("Redis Total Time in this round: "+totalPerRound+" ms."); +			System.out.println("______________________________________________________"); +		} +		System.out.println("______________________________________________________"); +		System.out.println("Redis average get time over " + averageCnt +" rounds: "+getTime/averageCnt+" ms."); +		System.out.println("Redis average put time over " + averageCnt +" rounds: "+putTime/averageCnt+" ms."); +		System.out.println("Redis average change time over " + averageCnt +" rounds: "+changeTime/averageCnt+" ms."); +		System.out.println("Redis average remove time over " + averageCnt +" rounds: "+removeTime/averageCnt+" ms."); +		System.out.println("Redis average total time over " + averageCnt +" rounds: "+total/averageCnt+" ms."); +		 +		((ConfigurableApplicationContext)context).close(); +		 +		 +	} + +} diff --git a/id/server/idserverlib/src/test/java/test/tlenz/simpletest.java b/id/server/idserverlib/src/test/java/test/tlenz/simpletest.java index 2c80b7ffd..05cd74ed2 100644 --- a/id/server/idserverlib/src/test/java/test/tlenz/simpletest.java +++ b/id/server/idserverlib/src/test/java/test/tlenz/simpletest.java @@ -1,23 +1,23 @@  package test.tlenz; -import java.io.File;  import java.io.FileInputStream; -import java.io.InputStream; -import java.io.ObjectInputStream; -import java.net.URI; -import java.net.URISyntaxException; +import java.util.HashMap; +import java.util.List; -import org.w3c.dom.Element; +import org.apache.commons.io.IOUtils; +import org.w3c.dom.NodeList; -import iaik.asn1.structures.Name; -import iaik.utils.RFC2253NameParser; -import iaik.utils.RFC2253NameParserException; -import at.gv.egovernment.moa.id.auth.data.IdentityLink; -import at.gv.egovernment.moa.id.auth.parser.IdentityLinkAssertionParser; -import at.gv.egovernment.moa.id.data.AuthenticationRole; -import at.gv.egovernment.moa.id.data.AuthenticationRoleFactory; -import at.gv.egovernment.moa.id.util.IdentityLinkReSigner; -import at.gv.egovernment.moa.util.DOMUtils; +import at.gv.egovernment.moa.spss.api.SPSSFactory; +import at.gv.egovernment.moa.spss.api.SignatureVerificationService; +import at.gv.egovernment.moa.spss.api.common.Content; +import at.gv.egovernment.moa.spss.api.common.ContentBinary; +import at.gv.egovernment.moa.spss.api.common.ContentXML; +import at.gv.egovernment.moa.spss.api.common.InputData; +import at.gv.egovernment.moa.spss.api.common.SignerInfo; +import at.gv.egovernment.moa.spss.api.xmlverify.VerifySignatureInfo; +import at.gv.egovernment.moa.spss.api.xmlverify.VerifySignatureLocation; +import at.gv.egovernment.moa.spss.api.xmlverify.VerifyXMLSignatureRequest; +import at.gv.egovernment.moa.spss.api.xmlverify.VerifyXMLSignatureResponse;  /*******************************************************************************   * Copyright 2014 Federal Chancellery Austria @@ -62,71 +62,130 @@ import at.gv.egovernment.moa.util.DOMUtils;  public class simpletest {  //  	public static void main(String[] args) { -				 -		URI fileURI = null; -		try { -			fileURI = new URI("file:c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); -			File propertiesFile = new File(fileURI); +		try  { +			FileInputStream sigDocFIS = null; +			sigDocFIS = new FileInputStream("D:/idl_test/identity_link.xml"); -			InputStream in = new FileInputStream(propertiesFile); -			ObjectInputStream testOIS = new ObjectInputStream(in); +			SPSSFactory spssFac = SPSSFactory.getInstance(); +	        SignatureVerificationService sigVerifyService = SignatureVerificationService.getInstance(); +	        Content sigDocContent = spssFac.createContent(sigDocFIS, null); +	         +	         +	     // Position der zu pruefenden Signatur +	        HashMap nSMap = new HashMap(); +	        nSMap.put("dsig", "http://www.w3.org/2000/09/xmldsig#"); +	        VerifySignatureLocation sigLocation = spssFac.createVerifySignatureLocation("//dsig:Signature", nSMap); + +	        // Pruefrequest zusammenstellen +	        VerifySignatureInfo sigInfo = spssFac.createVerifySignatureInfo(sigDocContent, sigLocation); +	        VerifyXMLSignatureRequest verifyRequest = spssFac.createVerifyXMLSignatureRequest( +	                null,    // Verwende aktuelle Zeit als Pruefzeit +	                sigInfo, +	                null,    // Keine Ergaenzungsobjekte +	                null,    // Signaturmanifest-Pruefung soll nicht durchgefuehrt werden +	                true,   // Hash-Inputdaten, d.h. tatsaechlich signierte Daten werden nicht zurueckgeliefert +	                "MOAIDBuergerkarteAuthentisierungsDaten"); +	         +	         +	        VerifyXMLSignatureResponse verifyResponse = null; +	        verifyResponse = sigVerifyService.verifyXMLSignature(verifyRequest); +	         +	        SignerInfo signerInfo = verifyResponse.getSignerInfo(); +	        String signerCertificateEncoded = null; + +	        List hashInputDatas = verifyResponse.getHashInputDatas(); +	        if (hashInputDatas != null && !hashInputDatas.isEmpty()) { +	        	for (Object el : hashInputDatas) { +	        		InputData inputData = (InputData) el; +	        		switch (inputData.getContentType()) { +	        	      case Content.XML_CONTENT : +	        	        ContentXML contentXml = (ContentXML) inputData; +	        	        NodeList input_XML = contentXml.getXMLContent(); +	        	      +	        	        break; +	        	      case Content.BINARY_CONTENT : +	        	          ContentBinary contentBinary = (ContentBinary) inputData;	        	        +	        	          String input_Binary = IOUtils.toString(contentBinary.getBinaryContent()); +	        	          	        	         +	        		}	        		 +	        	}	        	 +	        } +	         +	         -			Object test = testOIS.readObject(); +		} catch (Exception e) { -		} catch (Exception e1) { -			e1.printStackTrace(); -		} -		 -		try { -			fileURI = new URI("file:/c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); -			File propertiesFile = new File(fileURI); -		} catch (Exception e1) { -			e1.printStackTrace(); -		} -		 -		try { -			fileURI = new URI("file://c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); -			File propertiesFile = new File(fileURI); -		} catch (Exception e1) { -			e1.printStackTrace(); -		} -		 -		try { -			fileURI = new URI("file:///c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); -			File propertiesFile = new File(fileURI); -		} catch (Exception e1) { -			e1.printStackTrace();  		} -		try { -		InputStream s = new FileInputStream("D:/idl_test/identity_link.xml"); -		Element idlTemplate = DOMUtils.parseXmlValidating(s); -		 -        //resign IDL -		IdentityLinkReSigner identitylinkresigner = IdentityLinkReSigner.getInstance(); -		Element resignedilAssertion = identitylinkresigner.resignIdentityLink(idlTemplate, "IDLSigning"); -		IdentityLink identityLink = new IdentityLinkAssertionParser(resignedilAssertion).parseIdentityLink(); -		 -		} catch (Exception e) { -			System.out.println(e.getMessage()); -			 -		} -		String subjectName = "serialNumber=896929130327, givenName=OCSP, SN=Responder 03-1, CN=OCSP Responder 03-1, C=AT"; -		try { -			Name test = new RFC2253NameParser(subjectName).parse(); -			 -			System.out.println(test.getRFC2253String()); -			 -		} catch (RFC2253NameParserException e) { -			// TODO Auto-generated catch block -			e.printStackTrace(); -		} +//		URI fileURI = null; +//		try { +//			fileURI = new URI("file:c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); +//			File propertiesFile = new File(fileURI); +//			 +//			InputStream in = new FileInputStream(propertiesFile); +//			ObjectInputStream testOIS = new ObjectInputStream(in); +//			 +//			Object test = testOIS.readObject(); +//			 +//			 +//		} catch (Exception e1) { +//			e1.printStackTrace(); +//		} +//		 +//		try { +//			fileURI = new URI("file:/c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); +//			File propertiesFile = new File(fileURI); +//		} catch (Exception e1) { +//			e1.printStackTrace(); +//		} +//		 +//		try { +//			fileURI = new URI("file://c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); +//			File propertiesFile = new File(fileURI); +//		} catch (Exception e1) { +//			e1.printStackTrace(); +//		} +//		 +//		try { +//			fileURI = new URI("file:///c:/moa3/tomcat8/conf/moa-id/moa-id.properties"); +//			File propertiesFile = new File(fileURI); +//		} catch (Exception e1) { +//			e1.printStackTrace(); +//		} +//		 +//		 +//		 +//		try { +//		InputStream s = new FileInputStream("D:/idl_test/identity_link.xml"); +//		Element idlTemplate = DOMUtils.parseXmlValidating(s); +//		 +//        //resign IDL +//		IdentityLinkReSigner identitylinkresigner = IdentityLinkReSigner.getInstance(); +//		Element resignedilAssertion = identitylinkresigner.resignIdentityLink(idlTemplate, "IDLSigning"); +//		IdentityLink identityLink = new IdentityLinkAssertionParser(resignedilAssertion).parseIdentityLink(); +//		 +//		} catch (Exception e) { +//			System.out.println(e.getMessage()); +//			 +//		} +//		 +//		String subjectName = "serialNumber=896929130327, givenName=OCSP, SN=Responder 03-1, CN=OCSP Responder 03-1, C=AT"; +//		 +//		try { +//			Name test = new RFC2253NameParser(subjectName).parse(); +//			 +//			System.out.println(test.getRFC2253String()); +//			 +//		} catch (RFC2253NameParserException e) { +//			// TODO Auto-generated catch block +//			e.printStackTrace(); +//		}  //		AuthenticationRole test = AuthenticationRoleFactory.buildFormPVPole("ecas-demo-EUROPEAN_COMMISSION(key=A\\,B)"); diff --git a/id/server/idserverlib/src/test/java/testBeans.xml b/id/server/idserverlib/src/test/java/testBeans.xml new file mode 100644 index 000000000..238a571cb --- /dev/null +++ b/id/server/idserverlib/src/test/java/testBeans.xml @@ -0,0 +1,130 @@ +<?xml version="1.0" encoding="UTF-8"?> +<beans xmlns="http://www.springframework.org/schema/beans" +	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" +	xmlns:context="http://www.springframework.org/schema/context" +	xmlns:tx="http://www.springframework.org/schema/tx" +	xmlns:aop="http://www.springframework.org/schema/aop" +	xmlns:p="http://www.springframework.org/schema/p" +	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd +		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd +		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd +		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> +  +<context:annotation-config /> +	<bean id="configPropertyDao"  +				class="at.gv.egovernment.moa.id.commons.db.dao.config.DatabaseConfigPropertyImpl"/> +		 +	<bean id="moaidconfig" class="at.gv.egovernment.moa.id.commons.config.persistence.MOAIDConfigurationImpl" /> + +	<bean name="config" id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> +		<property name="dataSource" ref="dataSource" /> +		<property name="jpaVendorAdapter" ref="jpaVendorAdapter" /> +		<property name="persistenceUnitName" value="config" /> +	</bean> +	 +	 <bean name="transactionManager" id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> +		<property name="entityManagerFactory" ref="entityManagerFactory" /> +	</bean>   +	<tx:annotation-driven transaction-manager="transactionManager"/> +	 +	<bean id="RedisTransactionStorage"  +				class="at.gv.egovernment.moa.id.storage.RedisTransactionStorage"/> +				 +	<bean id="DBTransactionStorage"  +				class="at.gv.egovernment.moa.id.storage.DBTransactionStorage"/> +	 +	<!-- Redis Beans -->			 +	<bean id="jedisConnFactory"  +    	class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"  +    	p:use-pool="true" +    	p:poolConfig-ref="jedisPoolConfig"/> +    	 +    <bean id="jedisPoolConfig"  +    	class="redis.clients.jedis.JedisPoolConfig"  +    	p:maxTotal="100" +    	p:maxIdle="10"/> +    	 +    <bean id="RedisStringSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer" /> +    <bean id="assertionStoreSerializer" class="org.springframework.data.redis.serializer.JacksonJsonRedisSerializer"> +			<constructor-arg type="java.lang.Class" value="at.gv.egovernment.moa.id.commons.db.dao.session.AssertionStore"/>	 +	</bean> + +	<bean id="redisTemplate"  +   	 	class="org.springframework.data.redis.core.RedisTemplate"  +    	p:connection-factory-ref="jedisConnFactory" +    	p:value-serializer-ref="RedisStringSerializer" +    	p:key-serializer-ref="RedisStringSerializer" +    	p:enableTransactionSupport="true"/>	 +  +	<context:property-placeholder location="${moa.id.configuration}"/>  + +	<bean id="moaidauthconfig" class="at.gv.egovernment.moa.id.config.auth.PropertyBasedAuthConfigurationProvider"> +		<constructor-arg value="#{systemProperties['moa.id.configuration']}"/> +	</bean> +	 +	<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" lazy-init="true" destroy-method="close"> +		<aop:scoped-proxy/> +		<property name="driverClassName" value="${configuration.hibernate.connection.driver_class}" /> +		<property name="url" value="${configuration.hibernate.connection.url}"/> +		<property name="username" value="${configuration.hibernate.connection.username}" /> +		<property name="password" value="${configuration.hibernate.connection.password}" /> +				 +		<property name="connectionProperties" value="${configuration.dbcp.connectionProperties}" /> +		<property name="initialSize" value="${configuration.dbcp.initialSize}" />		 +		<property name="maxTotal" value="${configuration.dbcp.maxActive}" /> +		<property name="maxIdle" value="${configuration.dbcp.maxIdle}" /> +		<property name="minIdle" value="${configuration.dbcp.minIdle}" /> +		<!-- property name="maxWait" value="${configuration.dbcp.maxWaitMillis}" / --> +		<property name="testOnBorrow" value="${configuration.dbcp.testOnBorrow}" /> +		<property name="testOnReturn" value="${configuration.dbcp.testOnReturn}" /> +		<property name="testWhileIdle" value="${configuration.dbcp.testWhileIdle}" /> +		<property name="validationQuery" value="${configuration.dbcp.validationQuery}" /> +	</bean>			 +			 +	<bean id="jpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> +		<property name="showSql" value="${configuration.hibernate.show_sql}" /> +		<property name="generateDdl" value="${configuration.jpaVendorAdapter.generateDdl}" /> +		<property name="databasePlatform" value="${configuration.hibernate.dialect}" /> +	</bean>	 +	 +	<bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor"> +    	<property name="corePoolSize" value="1" /> +    	<property name="maxPoolSize" value="50" /> +    	<property name="queueCapacity" value="50" /> +	</bean> +	 +	<bean id="sessionDataSource" class="org.apache.commons.dbcp2.BasicDataSource" lazy-init="true" destroy-method="close"> +		<aop:scoped-proxy/> +		<property name="driverClassName" value="${moasession.hibernate.connection.driver_class}" /> +		<property name="url" value="${moasession.hibernate.connection.url}"/> +		<property name="username" value="${moasession.hibernate.connection.username}" /> +		<property name="password" value="${moasession.hibernate.connection.password}" /> +				 +		<property name="connectionProperties" value="${moasession.dbcp.connectionProperties}" /> +		<property name="initialSize" value="${moasession.dbcp.initialSize}" />		 +		<property name="maxTotal" value="${moasession.dbcp.maxActive}" /> +		<property name="maxIdle" value="${moasession.dbcp.maxIdle}" /> +		<property name="minIdle" value="${moasession.dbcp.minIdle}" /> +		<!-- property name="maxWait" value="${moasession.dbcp.maxWaitMillis}" / --> +		<property name="testOnBorrow" value="${moasession.dbcp.testOnBorrow}" /> +		<property name="testOnReturn" value="${moasession.dbcp.testOnReturn}" /> +		<property name="testWhileIdle" value="${moasession.dbcp.testWhileIdle}" /> +		<property name="validationQuery" value="${moasession.dbcp.validationQuery}" /> +	</bean> +	 +	<bean id="sessionJpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> +		<property name="showSql" value="${moasession.hibernate.show_sql}" /> +		<property name="generateDdl" value="${moasession.jpaVendorAdapter.generateDdl}" /> +		<property name="databasePlatform" value="${moasession.hibernate.dialect}" /> +	</bean> +	 +	<bean name="sessionEntityManagerFactory" id="sessionEntityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> +		<property name="dataSource" ref="sessionDataSource" /> +		<property name="jpaVendorAdapter" ref="sessionJpaVendorAdapter" /> +		<property name="persistenceUnitName" value="session" /> +	</bean> +	 +	 <bean name="sessionTransactionManager" id="sessionTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> +		<property name="entityManagerFactory" ref="sessionEntityManagerFactory" /> +	</bean>   +</beans>
\ No newline at end of file diff --git a/id/server/idserverlib/src/test/resources/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest-context.xml b/id/server/idserverlib/src/test/resources/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest-context.xml index bf47c0445..7d9db0ab7 100644 --- a/id/server/idserverlib/src/test/resources/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest-context.xml +++ b/id/server/idserverlib/src/test/resources/at/gv/egovernment/moa/id/process/spring/test/SpringExpressionAwareProcessEngineTest-context.xml @@ -1,9 +1,13 @@  <?xml version="1.0" encoding="UTF-8"?>  <beans xmlns="http://www.springframework.org/schema/beans"  	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" -	xmlns:task="http://www.springframework.org/schema/task" -	xsi:schemaLocation="http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task.xsd -		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> +	xmlns:context="http://www.springframework.org/schema/context" +	xmlns:tx="http://www.springframework.org/schema/tx" +	xmlns:aop="http://www.springframework.org/schema/aop" +	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd +		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd +		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd +		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">  	<bean id="springElAwareExpressionEvaluator" class="at.gv.egovernment.moa.id.process.spring.SpringExpressionEvaluator" /> @@ -12,7 +16,7 @@  	</bean>  	<bean id="TransactionStorage"  -				class="at.gv.egovernment.moa.id.storage.DBTransactionStorage"/> +				class="at.gv.egovernment.moa.id.process.spring.test.DummyTransactionStorage"/>  	<bean id="ProcessInstanceStoreage"   				class="at.gv.egovernment.moa.id.process.dao.ProcessInstanceStoreDAOImpl"/>	 @@ -40,4 +44,5 @@  	<bean id="ValidateSignedAuthBlockTask"   				class="at.gv.egovernment.moa.id.process.spring.test.task.ValidateSignedAuthBlockTask"/>																	 +	  </beans> | 
