[
http://jira.jboss.com/jira/browse/JBREM-920?page=comments#action_12401856 ]
Ron Sigal commented on JBREM-920:
---------------------------------
Here's another necessary permission - java.io.SerializablePermission
enableSubclassImplementation:
org.jboss.test.remoting.client.ClientSerializationTestCase(java_serialization).testJBossSerialization
Failing for the past 1 build (Since Unstable#88 )
Took 0 seconds.
org.jboss.remoting.CannotConnectException: Can not get connection to server. Problem
establishing socket connection for InvokerLocator
[socket://10.18.0.216:3025/?serializationtype=jboss]
at
org.jboss.remoting.transport.socket.MicroSocketClientInvoker.transport(MicroSocketClientInvoker.java:738)
at org.jboss.remoting.MicroRemoteClientInvoker.invoke(MicroRemoteClientInvoker.java:157)
at org.jboss.remoting.Client.invoke(Client.java:1685)
at org.jboss.remoting.Client.invoke(Client.java:589)
at org.jboss.remoting.Client.invoke(Client.java:577)
at
org.jboss.test.remoting.client.ClientSerializationTestCase.testJBossSerialization(ClientSerializationTestCase.java:118)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Constructor.newInstance(Constructor.java:274)
at
org.jboss.remoting.transport.socket.SocketClientInvoker.createClientSocket(SocketClientInvoker.java:162)
at
org.jboss.remoting.transport.socket.MicroSocketClientInvoker.getConnection(MicroSocketClientInvoker.java:1070)
at
org.jboss.remoting.transport.socket.MicroSocketClientInvoker.transport(MicroSocketClientInvoker.java:728)
... 20 more
Caused by: java.security.AccessControlException: access denied
(java.io.SerializablePermission enableSubclassImplementation)
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:269)
at java.security.AccessController.checkPermission(AccessController.java:401)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:524)
at java.io.ObjectOutputStream.<init>(ObjectOutputStream.java:206)
at
org.jboss.serial.io.JBossObjectOutputStream.<init>(JBossObjectOutputStream.java:126)
at
org.jboss.serial.io.JBossObjectOutputStream.<init>(JBossObjectOutputStream.java:116)
at
org.jboss.remoting.serialization.impl.jboss.JBossSerializationManager.createOutput(JBossSerializationManager.java:63)
at
org.jboss.remoting.marshal.serializable.SerializableMarshaller.getMarshallingStream(SerializableMarshaller.java:89)
at
org.jboss.remoting.marshal.serializable.SerializableMarshaller.getMarshallingStream(SerializableMarshaller.java:72)
at
org.jboss.remoting.transport.socket.ClientSocketWrapper.createOutputStream(ClientSocketWrapper.java:204)
at
org.jboss.remoting.transport.socket.ClientSocketWrapper.createStreams(ClientSocketWrapper.java:163)
at
org.jboss.remoting.transport.socket.ClientSocketWrapper.<init>(ClientSocketWrapper.java:66)
... 27 more
Create build.xml target to run test suite with a Security Manager
-----------------------------------------------------------------
Key: JBREM-920
URL:
http://jira.jboss.com/jira/browse/JBREM-920
Project: JBoss Remoting
Issue Type: Task
Security Level: Public(Everyone can see)
Reporter: Ron Sigal
Assigned To: David Lloyd
Fix For: 2.4.0.CR1 (Pinto)
From Anil Saldana:
Presuming that you have a test suite and either use ANT or Maven, I
recommend an extra target to run the test suite in a Java Security
Manager with minimal permissions. So for ANT, you will have an
additional target. For MAVEN, you can use a profile.
The idea is that you have a Java Security Policy file in which you
provide unlimited permission to third party libraries and minimal
permissions to your own code. This exercise is to detect critical
sections of code that need special privileges and get into privileged
blocks. If you have an extra target for the security manager and your
test runs happen on hudson, you can detect issues with security manager
as new code gets added.
Please do not have one test that does System.setSecurityManager but run
your entire test suite via the security manager
(-Djava.security.manager -Djava.security.policy=somefile).
Example: (Take a look by clicking "Configure" on the LHS)
http://hudson.qa.jboss.com/hudson/job/JBossSX_SecurityManager/
http://anonsvn.jboss.org/repos/jbossas/projects/security/security-jboss-s...
Now if your head is spinning or you do not care about security or do not
have the time to do it, please tell me. I can engage myself, someone
from JBoss Security Team or the QA person handling your project to add a
JIRA issue (and make the build.xml/pom.xml changes for your project).
Why is this important?
* Because many customers run JBAS in a security manager and we need to
detect issues in our own code. Also during a recent integration work
with JBoss Messaging for the SOA platform, there was one issue with
remoting (JBREM-811) that gave some head ache to Clebert and Ron (who is
still reeling). It took some cycles from me also.
* We need to have tests running in a security manager on an ongoing basis.
I understand that there are resource issues in various projects. But
that does not discount the work that we need to do before we ship JBAS. ;)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira