From 7c85f3510cb84881ff232548fbcc933ef4b34972 Mon Sep 17 00:00:00 2001 From: Stuart Marks Date: Thu, 27 May 2021 15:19:45 +0000 Subject: [PATCH] 8267123: Remove RMI Activation Reviewed-by: erikj, rriggs, alanb --- make/modules/java.rmi/Launcher.gmk | 6 +- .../share/conf/security/java.security | 1 - .../sun/rmi/rmid/ExecOptionPermission.java | 352 --- .../com/sun/rmi/rmid/ExecPermission.java | 302 -- .../classes/java/rmi/AccessException.java | 6 +- .../java/rmi/NoSuchObjectException.java | 6 +- .../share/classes/java/rmi/Remote.java | 13 +- .../java/rmi/StubNotFoundException.java | 6 +- .../java/rmi/activation/Activatable.java | 584 ---- .../activation/ActivateFailedException.java | 66 - .../java/rmi/activation/ActivationDesc.java | 352 --- .../rmi/activation/ActivationException.java | 122 - .../java/rmi/activation/ActivationGroup.java | 543 ---- .../rmi/activation/ActivationGroupDesc.java | 381 --- .../rmi/activation/ActivationGroupID.java | 123 - .../rmi/activation/ActivationGroup_Stub.java | 112 - .../java/rmi/activation/ActivationID.java | 328 --- .../activation/ActivationInstantiator.java | 94 - .../rmi/activation/ActivationMonitor.java | 113 - .../java/rmi/activation/ActivationSystem.java | 234 -- .../java/rmi/activation/Activator.java | 119 - .../rmi/activation/UnknownGroupException.java | 65 - .../activation/UnknownObjectException.java | 67 - .../java/rmi/activation/package-info.java | 48 - .../java/rmi/server/ExportException.java | 6 +- .../rmi/server/RMIClientSocketFactory.java | 6 +- .../rmi/server/RMIServerSocketFactory.java | 6 +- .../classes/java/rmi/server/RemoteObject.java | 49 +- .../server/RemoteObjectInvocationHandler.java | 6 +- src/java.rmi/share/classes/module-info.java | 13 +- .../sun/rmi/registry/RegistryImpl.java | 3 +- .../sun/rmi/server/ActivatableRef.java | 411 --- .../sun/rmi/server/ActivatableServerRef.java | 94 - .../Activation$ActivationSystemImpl_Stub.java | 239 -- .../classes/sun/rmi/server/Activation.java | 2605 ----------------- .../sun/rmi/server/ActivationGroupImpl.java | 502 ---- .../sun/rmi/server/ActivationGroupInit.java | 86 - .../rmi/server/InactiveGroupException.java | 51 - .../sun/rmi/server/MarshalInputStream.java | 17 +- .../sun/rmi/server/resources/rmid.properties | 136 - .../rmi/server/resources/rmid_de.properties | 96 - .../rmi/server/resources/rmid_es.properties | 96 - .../rmi/server/resources/rmid_fr.properties | 96 - .../rmi/server/resources/rmid_it.properties | 96 - .../rmi/server/resources/rmid_ja.properties | 99 - .../rmi/server/resources/rmid_ko.properties | 96 - .../server/resources/rmid_pt_BR.properties | 96 - .../rmi/server/resources/rmid_sv.properties | 96 - .../server/resources/rmid_zh_CN.properties | 99 - .../server/resources/rmid_zh_TW.properties | 96 - src/java.rmi/share/man/rmid.1 | 413 --- test/jdk/ProblemList.txt | 6 - test/jdk/TEST.groups | 1 - .../RemoteException/chaining/Chaining.java | 6 +- .../checkActivateRef/ActivateMe.java | 32 - .../checkActivateRef/CheckActivateRef.java | 275 -- .../CheckActivateRef_Stub.java | 104 - .../checkActivateRef/group.security.policy | 11 - .../checkActivateRef/rmid.security.policy | 9 - .../checkActivateRef/security.policy | 43 - .../checkAnnotations/CheckAnnotations.java | 280 -- .../CheckAnnotations_Stub.java | 140 - .../Activatable/checkAnnotations/MyRMI.java | 33 - .../checkAnnotations/group.security.policy | 9 - .../checkAnnotations/rmid.security.policy | 8 - .../checkAnnotations/security.policy | 34 - .../checkImplClassLoader/ActivatableImpl.java | 64 - .../ActivatableImpl_Stub.java | 75 - .../CheckImplClassLoader.java | 124 - .../checkImplClassLoader/MyRMI.java | 33 - .../checkImplClassLoader/rmid.security.policy | 8 - .../checkImplClassLoader/security.policy | 45 - .../checkRegisterInLog/ActivateMe.java | 32 - .../CheckRegisterInLog.java | 175 -- .../CheckRegisterInLog_Stub.java | 104 - .../checkRegisterInLog/group.security.policy | 9 - .../checkRegisterInLog/rmid.security.policy | 9 - .../checkRegisterInLog/security.policy | 37 - .../createPrivateActivable/ActivateMe.java | 32 - .../CreatePrivateActivatable.java | 167 -- .../group.security.policy | 9 - .../rmid.security.policy | 8 - .../createPrivateActivable/security.policy | 37 - .../downloadParameterClass/Bar.java | 25 - .../DownloadParameterClass.java | 149 - .../downloadParameterClass/Foo.java | 25 - .../FooReceiverImpl.java | 46 - .../FooReceiverImpl_Stub.java | 65 - .../group.security.policy | 15 - .../manual.security.policy | 40 - .../rmid.security.policy | 8 - .../downloadParameterClass/security.policy | 41 - .../elucidateNoSuchMethod/ActivateMe.java | 32 - .../ElucidateNoSuchMethod.java | 146 - .../ElucidateNoSuchMethod_Stub.java | 104 - .../group.security.policy | 13 - .../rmid.security.policy | 9 - .../elucidateNoSuchMethod/security.policy | 43 - .../extLoadedImpl/CheckLoader.java | 26 - .../extLoadedImpl/ExtLoadedImpl.java | 50 - .../extLoadedImpl/ExtLoadedImplTest.java | 75 - .../extLoadedImpl/ExtLoadedImpl_Stub.java | 66 - .../Activatable/extLoadedImpl/ext.sh | 60 - .../extLoadedImpl/group.security.policy | 9 - .../extLoadedImpl/rmid.security.policy | 8 - .../Activatable/extLoadedImpl/security.policy | 25 - .../forceLogSnapshot/ActivateMe.java | 32 - .../forceLogSnapshot/ForceLogSnapshot.java | 290 -- .../ForceLogSnapshot_Skel.java | 99 - .../ForceLogSnapshot_Stub.java | 111 - .../forceLogSnapshot/group.security.policy | 9 - .../forceLogSnapshot/rmid.security.policy | 9 - .../forceLogSnapshot/security.policy | 37 - .../Activatable/inactiveGroup/ActivateMe.java | 33 - .../inactiveGroup/InactiveGroup.java | 187 -- .../inactiveGroup/InactiveGroup_Stub.java | 140 - .../inactiveGroup/group.security.policy | 9 - .../inactiveGroup/rmid.security.policy | 8 - .../Activatable/inactiveGroup/security.policy | 37 - .../LookupActivationSystem.java | 129 - .../rmid.security.policy | 6 - .../nestedActivate/ActivateMe.java | 33 - .../nestedActivate/NestedActivate.java | 176 -- .../nestedActivate/NestedActivate_Stub.java | 120 - .../nestedActivate/group.security.policy | 9 - .../nestedActivate/rmid.security.policy | 8 - .../nestedActivate/security.policy | 37 - .../nonExistentActivatable/ActivateMe.java | 33 - .../NonExistentActivatable.java | 150 - .../NonExistentActivatable_Stub.java | 120 - .../group.security.policy | 9 - .../rmid.security.policy | 8 - .../nonExistentActivatable/security.policy | 37 - .../notSerializable/NotSerializable.java | 146 - .../restartCrashedService/ActivateMe.java | 34 - .../RestartCrashedService.java | 243 -- .../RestartCrashedService_Stub.java | 146 - .../group.security.policy | 9 - .../rmid.security.policy | 9 - .../restartCrashedService/security.policy | 34 - .../restartLatecomer/RestartLatecomer.java | 268 -- .../RestartLatecomer_Stub.java | 99 - .../restartLatecomer/group.security.policy | 9 - .../restartLatecomer/rmid.security.policy | 8 - .../restartLatecomer/security.policy | 39 - .../restartService/ActivateMe.java | 31 - .../restartService/RestartService.java | 234 -- .../restartService/RestartService_Stub.java | 94 - .../restartService/group.security.policy | 9 - .../restartService/rmid.security.policy | 9 - .../restartService/security.policy | 39 - .../RegisteringActivatable.java | 32 - .../ShutdownGracefully.java | 195 -- .../ShutdownGracefully_Stub.java | 57 - .../TestSecurityManager.java | 50 - .../shutdownGracefully/group.security.policy | 9 - .../shutdownGracefully/rmid.security.policy | 9 - .../shutdownGracefully/security.policy | 31 - .../unregisterInactive/ActivateMe.java | 35 - .../UnregisterInactive.java | 136 - .../UnregisterInactive_Stub.java | 120 - .../unregisterInactive/group.security.policy | 9 - .../unregisterInactive/rmid.security.policy | 8 - .../unregisterInactive/security.policy | 34 - .../activateFails/ActivateFails.java | 174 -- .../activateFails/ActivateFails_Stub.java | 116 - .../activateFails/ActivateMe.java | 32 - .../activateFails/ShutdownThread.java | 50 - .../activateFails/group.security.policy | 9 - .../activateFails/rmid.security.policy | 8 - .../activateFails/security.policy | 34 - .../DownloadActivationGroup.java | 186 -- .../DownloadActivationGroup_Stub.java | 74 - .../MyActivationGroupImpl.java | 37 - .../group.security.policy | 11 - .../rmid.security.policy | 7 - .../downloadActivationGroup/security.policy | 7 - .../CheckDefaultGroupName.java | 65 - .../activeGroup/IdempotentActiveGroup.java | 132 - .../activeGroup/rmid.security.policy | 7 - .../activeGroup/security.policy | 24 - .../modifyDescriptor/ActivateMe.java | 35 - .../modifyDescriptor/ModifyDescriptor.java | 261 -- .../ModifyDescriptor_Stub.java | 194 -- .../modifyDescriptor/group.security.policy | 9 - .../modifyDescriptor/rmid.security.policy | 11 - .../modifyDescriptor/security.policy | 31 - .../stubClassesPermitted/CanCreateStubs.java | 36 - .../StubClassesPermitted.java | 264 -- .../StubClassesPermitted_Stub.java | 180 -- .../group.security.policy | 11 - .../stubClassesPermitted/rmid.security.policy | 12 - .../stubClassesPermitted/security.policy | 37 - .../unregisterGroup/ActivateMe.java | 32 - .../unregisterGroup/UnregisterGroup.java | 167 -- .../unregisterGroup/group.security.policy | 9 - .../unregisterGroup/rmid.security.policy | 9 - .../unregisterGroup/security.policy | 37 - .../activation/CommandEnvironment/Doctor.java | 91 - .../CommandEnvironment/Doctor_Stub.java | 83 - .../activation/CommandEnvironment/Eliza.java | 29 - .../CommandEnvironment/NullOptions.java | 51 - .../CommandEnvironment/Retireable.java | 29 - .../CommandEnvironment/SetChildEnv.java | 253 -- .../CommandEnvironment/group.security.policy | 9 - .../CommandEnvironment/rmid.security.policy | 14 - .../CommandEnvironment/security.policy | 32 - test/jdk/java/rmi/activation/log/LogTest.java | 196 -- .../NonLocalActivationTest.java | 181 -- .../InheritedChannelNotServerSocket.java | 198 -- .../rmid.security.policy | 7 - .../AltSecurityManager.java | 29 +- .../TestSecurityManager.java | 7 +- .../altSecurityManager/rmid.security.policy | 2 - .../activatable/CompressConstants.java | 35 - .../activatable/CompressInputStream.java | 110 - .../activatable/CompressOutputStream.java | 84 - .../useSocketFactory/activatable/Echo.java | 33 - .../activatable/EchoImpl.java | 141 - .../activatable/EchoImpl_Stub.java | 75 - .../activatable/MultiSocketFactory.java | 226 -- .../activatable/UseCustomSocketFactory.java | 173 -- .../activatable/group.security.policy | 9 - .../activatable/rmid.security.policy | 7 - .../activatable/security.policy | 43 - .../useSocketFactory/registry/security.policy | 2 +- .../unicast/UseCustomSocketFactory.java | 2 +- .../useSocketFactory/unicast/security.policy | 2 +- .../UnrecognizedRefType.java | 3 +- .../server/clientStackTrace/security.policy | 2 +- .../rmi/testlibrary/ActivationLibrary.java | 92 - test/jdk/java/rmi/testlibrary/JavaVM.java | 36 +- test/jdk/java/rmi/testlibrary/README.jcov | 14 +- test/jdk/java/rmi/testlibrary/RMID.java | 506 ---- .../rmi/testlibrary/RMIDSelectorProvider.java | 139 - .../jdk/java/rmi/testlibrary/TestLibrary.java | 2 - test/jdk/java/rmi/testlibrary/TestParams.java | 14 +- .../checkLeaseInfoLeak/security.policy | 2 +- .../dgcDeadLock/registry.security.policy | 2 +- .../rmi/transport/dgcDeadLock/security.policy | 2 +- .../PermissionCollection/Concurrent.java | 5 +- test/jdk/tools/launcher/HelpFlagsTest.java | 1 - test/jdk/tools/launcher/VersionCheck.java | 1 - 243 files changed, 52 insertions(+), 21982 deletions(-) delete mode 100644 src/java.rmi/share/classes/com/sun/rmi/rmid/ExecOptionPermission.java delete mode 100644 src/java.rmi/share/classes/com/sun/rmi/rmid/ExecPermission.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/Activatable.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivateFailedException.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationDesc.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationException.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationGroup.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationGroupDesc.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationGroupID.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationGroup_Stub.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationID.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationInstantiator.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationMonitor.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/ActivationSystem.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/Activator.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/UnknownGroupException.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/UnknownObjectException.java delete mode 100644 src/java.rmi/share/classes/java/rmi/activation/package-info.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/ActivatableRef.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/ActivatableServerRef.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/Activation$ActivationSystemImpl_Stub.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/Activation.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/ActivationGroupImpl.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/ActivationGroupInit.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/InactiveGroupException.java delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_de.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_es.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_fr.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_it.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ja.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ko.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_pt_BR.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_sv.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_CN.properties delete mode 100644 src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_TW.properties delete mode 100644 src/java.rmi/share/man/rmid.1 delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkActivateRef/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/MyRMI.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkAnnotations/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/CheckImplClassLoader.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/MyRMI.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/createPrivateActivable/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/createPrivateActivable/CreatePrivateActivatable.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/createPrivateActivable/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/createPrivateActivable/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/createPrivateActivable/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Bar.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/DownloadParameterClass.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Foo.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/manual.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/downloadParameterClass/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/CheckLoader.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImplTest.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ext.sh delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/extLoadedImpl/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Skel.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/inactiveGroup/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/LookupActivationSystem.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nestedActivate/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/notSerializable/NotSerializable.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartCrashedService/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartLatecomer/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartLatecomer/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartLatecomer/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/RestartService.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/RestartService_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/restartService/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/RegisteringActivatable.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/TestSecurityManager.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/shutdownGracefully/security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive_Stub.java delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/Activatable/unregisterInactive/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails.java delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails_Stub.java delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ShutdownThread.java delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivateFailedException/activateFails/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup.java delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup_Stub.java delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/MyActivationGroupImpl.java delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationGroupDesc/checkDefaultGroupName/CheckDefaultGroupName.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/activeGroup/IdempotentActiveGroup.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/activeGroup/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/activeGroup/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor_Stub.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/CanCreateStubs.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted_Stub.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/ActivateMe.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/UnregisterGroup.java delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/security.policy delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/Doctor.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/Doctor_Stub.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/Eliza.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/NullOptions.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/Retireable.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/SetChildEnv.java delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/group.security.policy delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/rmid.security.policy delete mode 100644 test/jdk/java/rmi/activation/CommandEnvironment/security.policy delete mode 100644 test/jdk/java/rmi/activation/log/LogTest.java delete mode 100644 test/jdk/java/rmi/activation/nonLocalActivation/NonLocalActivationTest.java delete mode 100644 test/jdk/java/rmi/activation/rmidViaInheritedChannel/InheritedChannelNotServerSocket.java delete mode 100644 test/jdk/java/rmi/activation/rmidViaInheritedChannel/rmid.security.policy delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressConstants.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressInputStream.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressOutputStream.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/Echo.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl_Stub.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/MultiSocketFactory.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/UseCustomSocketFactory.java delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/group.security.policy delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/rmid.security.policy delete mode 100644 test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/security.policy delete mode 100644 test/jdk/java/rmi/testlibrary/ActivationLibrary.java delete mode 100644 test/jdk/java/rmi/testlibrary/RMID.java delete mode 100644 test/jdk/java/rmi/testlibrary/RMIDSelectorProvider.java diff --git a/make/modules/java.rmi/Launcher.gmk b/make/modules/java.rmi/Launcher.gmk index a69a90bcc81..8a540da898b 100644 --- a/make/modules/java.rmi/Launcher.gmk +++ b/make/modules/java.rmi/Launcher.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2011, 2021, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -25,10 +25,6 @@ include LauncherCommon.gmk -$(eval $(call SetupBuildLauncher, rmid, \ - MAIN_CLASS := sun.rmi.server.Activation, \ -)) - $(eval $(call SetupBuildLauncher, rmiregistry, \ MAIN_CLASS := sun.rmi.registry.RegistryImpl, \ )) diff --git a/src/java.base/share/conf/security/java.security b/src/java.base/share/conf/security/java.security index 378445ee175..2d7742a3b2a 100644 --- a/src/java.base/share/conf/security/java.security +++ b/src/java.base/share/conf/security/java.security @@ -1061,7 +1061,6 @@ jdk.xml.dsig.secureValidationPolicy=\ # sun.rmi.server.UnicastRef;\ # sun.rmi.server.RMIClientSocketFactory;\ # sun.rmi.server.RMIServerSocketFactory;\ -# java.rmi.activation.ActivationID;\ # java.rmi.server.UID # # RMI Distributed Garbage Collector (DGC) Serial Filter diff --git a/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecOptionPermission.java b/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecOptionPermission.java deleted file mode 100644 index 2d11c630594..00000000000 --- a/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecOptionPermission.java +++ /dev/null @@ -1,352 +0,0 @@ -/* - * Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package com.sun.rmi.rmid; - -import java.security.*; -import java.io.*; -import java.util.*; - -/** - * The ExecOptionPermission class represents permission for rmid to use - * a specific command-line option when launching an activation group. - * - * @author Ann Wollrath - * - * @serial exclude - * @deprecated See the - * - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -public final class ExecOptionPermission extends Permission -{ - /** - * does this permission have a wildcard at the end? - */ - private transient boolean wildcard; - - /** - * the name without the wildcard on the end - */ - private transient String name; - - /** - * UID for serialization - */ - private static final long serialVersionUID = 5842294756823092756L; - - public ExecOptionPermission(String name) { - super(name); - init(name); - } - - public ExecOptionPermission(String name, String actions) { - this(name); - } - - /** - * Checks if the specified permission is "implied" by - * this object. - *

- * More specifically, this method returns true if: - *

- * - * @param p the permission to check against. - * - * @return true if the passed permission is equal to or - * implied by this permission, false otherwise. - */ - public boolean implies(Permission p) { - if (!(p instanceof ExecOptionPermission)) - return false; - - ExecOptionPermission that = (ExecOptionPermission) p; - - if (this.wildcard) { - if (that.wildcard) { - // one wildcard can imply another - return that.name.startsWith(name); - } else { - // make sure p.name is longer so a.b.* doesn't imply a.b - return (that.name.length() > this.name.length()) && - that.name.startsWith(this.name); - } - } else { - if (that.wildcard) { - // a non-wildcard can't imply a wildcard - return false; - } else { - return this.name.equals(that.name); - } - } - } - - /** - * Checks two ExecOptionPermission objects for equality. - * Checks that obj's class is the same as this object's class - * and has the same name as this object. - * - * @param obj the object we are testing for equality with this object. - * @return true if obj is an ExecOptionPermission, and has the same - * name as this ExecOptionPermission object, false otherwise. - */ - public boolean equals(Object obj) { - if (obj == this) - return true; - - if ((obj == null) || (obj.getClass() != getClass())) - return false; - - ExecOptionPermission that = (ExecOptionPermission) obj; - - return this.getName().equals(that.getName()); - } - - - /** - * Returns the hash code value for this object. - * The hash code used is the hash code of the name, that is, - * getName().hashCode(), where getName is - * from the Permission superclass. - * - * @return a hash code value for this object. - */ - public int hashCode() { - return this.getName().hashCode(); - } - - /** - * Returns the canonical string representation of the actions. - * - * @return the canonical string representation of the actions. - */ - public String getActions() { - return ""; - } - - /** - * Returns a new PermissionCollection object for storing - * ExecOptionPermission objects. - *

- * An ExecOptionPermissionCollection stores a collection of - * ExecOptionPermission permissions. - * - *

ExecOptionPermission objects must be stored in a manner that allows - * them to be inserted in any order, but that also enables the - * PermissionCollection implies method - * to be implemented in an efficient (and consistent) manner. - * - * @return a new PermissionCollection object suitable for - * storing ExecOptionPermissions. - */ - public PermissionCollection newPermissionCollection() { - return new ExecOptionPermissionCollection(); - } - - /** - * readObject is called to restore the state of the ExecOptionPermission - * from a stream. - */ - private synchronized void readObject(java.io.ObjectInputStream s) - throws IOException, ClassNotFoundException - { - s.defaultReadObject(); - // init is called to initialize the rest of the values. - init(getName()); - } - - /** - * Initialize a ExecOptionPermission object. Common to all constructors. - * Also called during de-serialization. - */ - private void init(String name) - { - if (name == null) - throw new NullPointerException("name can't be null"); - - if (name.isEmpty()) { - throw new IllegalArgumentException("name can't be empty"); - } - - if (name.endsWith(".*") || name.endsWith("=*") || name.equals("*")) { - wildcard = true; - if (name.length() == 1) { - this.name = ""; - } else { - this.name = name.substring(0, name.length()-1); - } - } else { - this.name = name; - } - } - - /** - * A ExecOptionPermissionCollection stores a collection - * of ExecOptionPermission permissions. ExecOptionPermission objects - * must be stored in a manner that allows them to be inserted in any - * order, but enable the implies function to evaluate the implies - * method in an efficient (and consistent) manner. - * - * A ExecOptionPermissionCollection handles comparing a permission like - * "a.b.c.d.e" * with a Permission such as "a.b.*", or "*". - * - * @serial include - */ - private static class ExecOptionPermissionCollection - extends PermissionCollection - implements java.io.Serializable - { - - private Hashtable permissions; - private boolean all_allowed; // true if "*" is in the collection - private static final long serialVersionUID = -1242475729790124375L; - - /** - * Create an empty ExecOptionPermissionCollection. - */ - public ExecOptionPermissionCollection() { - permissions = new Hashtable<>(11); - all_allowed = false; - } - - /** - * Adds a permission to the collection. The key for the hash is - * permission.name. - * - * @param permission the Permission object to add. - * - * @exception IllegalArgumentException - if the permission is not a - * ExecOptionPermission - * - * @exception SecurityException - if this ExecOptionPermissionCollection - * object has been marked readonly - */ - - public void add(Permission permission) - { - if (! (permission instanceof ExecOptionPermission)) - throw new IllegalArgumentException("invalid permission: "+ - permission); - if (isReadOnly()) - throw new SecurityException("attempt to add a Permission to a readonly PermissionCollection"); - - ExecOptionPermission p = (ExecOptionPermission) permission; - - permissions.put(p.getName(), permission); - if (!all_allowed) { - if (p.getName().equals("*")) - all_allowed = true; - } - } - - /** - * Check and see if this set of permissions implies the permissions - * expressed in "permission". - * - * @param p the Permission object to compare - * - * @return true if "permission" is a proper subset of a permission in - * the set, false if not. - */ - public boolean implies(Permission permission) - { - if (! (permission instanceof ExecOptionPermission)) - return false; - - ExecOptionPermission p = (ExecOptionPermission) permission; - - // short circuit if the "*" Permission was added - if (all_allowed) - return true; - - // strategy: - // Check for full match first. Then work our way up the - // name looking for matches on a.b.* - - String pname = p.getName(); - - Permission x = permissions.get(pname); - - if (x != null) - // we have a direct hit! - return x.implies(permission); - - - // work our way up the tree... - int last, offset; - - offset = pname.length() - 1; - - while ((last = pname.lastIndexOf('.', offset)) != -1) { - - pname = pname.substring(0, last+1) + "*"; - x = permissions.get(pname); - - if (x != null) { - return x.implies(permission); - } - offset = last - 1; - } - - // check for "=*" wildcard match - pname = p.getName(); - offset = pname.length() - 1; - - while ((last = pname.lastIndexOf('=', offset)) != -1) { - - pname = pname.substring(0, last+1) + "*"; - x = permissions.get(pname); - - if (x != null) { - return x.implies(permission); - } - offset = last - 1; - } - - // we don't have to check for "*" as it was already checked - // at the top (all_allowed), so we just return false - return false; - } - - /** - * Returns an enumeration of all the ExecOptionPermission objects in the - * container. - * - * @return an enumeration of all the ExecOptionPermission objects. - */ - - public Enumeration elements() - { - return permissions.elements(); - } - } -} diff --git a/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecPermission.java b/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecPermission.java deleted file mode 100644 index aca8e5597a4..00000000000 --- a/src/java.rmi/share/classes/com/sun/rmi/rmid/ExecPermission.java +++ /dev/null @@ -1,302 +0,0 @@ -/* - * Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package com.sun.rmi.rmid; - -import java.security.*; -import java.io.*; -import java.util.*; - -/** - * The ExecPermission class represents permission for rmid to execute - * a specific command to launch an activation group. An ExecPermission - * consists of a pathname of a command to launch an activation group. - *

- * Pathname is the pathname of the file or directory to grant rmid - * execute permission. A pathname that ends in "/*" (where "/" is - * the file separator character, File.separatorChar) indicates - * all the files and directories contained in that directory. A pathname - * that ends with "/-" indicates (recursively) all files - * and subdirectories contained in that directory. A pathname consisting of - * the special token "{@code <>}" matches any file. - *

- * Note: A pathname consisting of a single "*" indicates all the files - * in the current directory, while a pathname consisting of a single "-" - * indicates all the files in the current directory and - * (recursively) all files and subdirectories contained in the current - * directory. - * - * - * @author Ann Wollrath - * - * @serial exclude - * @deprecated See the - * - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -public final class ExecPermission extends Permission -{ - /** - * UID for serialization - */ - private static final long serialVersionUID = -6208470287358147919L; - - private transient FilePermission fp; - - /** - * Creates a new ExecPermission object with the specified path. - * path is the pathname of a file or directory. - * - *

A pathname that ends in "/*" (where "/" is - * the file separator character, File.separatorChar) indicates - * a directory and all the files contained in that directory. A pathname - * that ends with "/-" indicates a directory and (recursively) all files - * and subdirectories contained in that directory. The special pathname - * "{@code <>}" matches all files. - * - *

A pathname consisting of a single "*" indicates all the files - * in the current directory, while a pathname consisting of a single "-" - * indicates all the files in the current directory and - * (recursively) all files and subdirectories contained in the current - * directory. - * - * @param path the pathname of the file/directory. - */ - public ExecPermission(String path) { - super(path); - init(path); - } - - /** - * Creates a new ExecPermission object with the specified path. - * path is the pathname of a file or directory. - * - *

A pathname that ends in "/*" (where "/" is - * the file separator character, File.separatorChar) indicates - * a directory and all the files contained in that directory. A pathname - * that ends with "/-" indicates a directory and (recursively) all files - * and subdirectories contained in that directory. The special pathname - * "{@code <>}" matches all files. - * - *

A pathname consisting of a single "*" indicates all the files - * in the current directory, while a pathname consisting of a single "-" - * indicates all the files in the current directory and - * (recursively) all files and subdirectories contained in the current - * directory. - * - * @param path the pathname of the file/directory. - * @param actions the action string (unused) - */ - public ExecPermission(String path, String actions) { - this(path); - } - - /** - * Checks if this ExecPermission object "implies" the specified permission. - *

- * More specifically, this method returns true if: - *

- * @param p the permission to check against. - * - * @return true if the specified permission is implied by this object, - * false if not. - */ - public boolean implies(Permission p) { - if (!(p instanceof ExecPermission)) - return false; - - ExecPermission that = (ExecPermission) p; - - return fp.implies(that.fp); - } - - /** - * Checks two ExecPermission objects for equality. - * Checks that obj's class is the same as this object's class - * and has the same name as this object. - * - * @param obj the object we are testing for equality with this object. - * @return true if obj is an ExecPermission, and has the same - * pathname as this ExecPermission object, false otherwise. - */ - public boolean equals(Object obj) { - if (obj == this) - return true; - - if (! (obj instanceof ExecPermission)) - return false; - - ExecPermission that = (ExecPermission) obj; - - return fp.equals(that.fp); - } - - /** - * Returns the hash code value for this object. - * - * @return a hash code value for this object. - */ - public int hashCode() { - return this.fp.hashCode(); - } - - /** - * Returns the canonical string representation of the actions. - * - * @return the canonical string representation of the actions. - */ - public String getActions() { - return ""; - } - - /** - * Returns a new PermissionCollection object for storing - * ExecPermission objects. - *

- * A ExecPermissionCollection stores a collection of - * ExecPermission permissions. - * - *

ExecPermission objects must be stored in a manner that allows - * them to be inserted in any order, but that also enables the - * PermissionCollection implies method - * to be implemented in an efficient (and consistent) manner. - * - * @return a new PermissionCollection object suitable for - * storing ExecPermissions. - */ - public PermissionCollection newPermissionCollection() { - return new ExecPermissionCollection(); - } - - /** - * readObject is called to restore the state of the ExecPermission - * from a stream. - */ - private synchronized void readObject(java.io.ObjectInputStream s) - throws IOException, ClassNotFoundException - { - s.defaultReadObject(); - // init is called to initialize the rest of the values. - init(getName()); - } - - /** - * Initialize a ExecPermission object. Common to all constructors. - * Also called during de-serialization. - */ - private void init(String path) { - this.fp = new FilePermission(path, "execute"); - } - - /** - * A ExecPermissionCollection stores a collection - * of ExecPermission permissions. ExecPermission objects - * must be stored in a manner that allows them to be inserted in any - * order, but enable the implies function to evaluate the implies - * method in an efficient (and consistent) manner. - * - * @serial include - */ - private static class ExecPermissionCollection - extends PermissionCollection - implements java.io.Serializable - { - private Vector permissions; - - private static final long serialVersionUID = -3352558508888368273L; - - /** - * Create an empty ExecPermissionCollection. - */ - public ExecPermissionCollection() { - permissions = new Vector<>(); - } - - /** - * Adds a permission to the collection. - * - * @param permission the Permission object to add. - * - * @exception IllegalArgumentException - if the permission is not a - * ExecPermission - * - * @exception SecurityException - if this ExecPermissionCollection - * object has been marked readonly - */ - public void add(Permission permission) - { - if (! (permission instanceof ExecPermission)) - throw new IllegalArgumentException("invalid permission: "+ - permission); - if (isReadOnly()) - throw new SecurityException("attempt to add a Permission to a readonly PermissionCollection"); - - permissions.addElement(permission); - } - - /** - * Check and see if this set of permissions implies the permissions - * expressed in "permission". - * - * @param p the Permission object to compare - * - * @return true if "permission" is a proper subset of a permission in - * the set, false if not. - */ - public boolean implies(Permission permission) - { - if (! (permission instanceof ExecPermission)) - return false; - - Enumeration e = permissions.elements(); - - while (e.hasMoreElements()) { - ExecPermission x = (ExecPermission)e.nextElement(); - if (x.implies(permission)) { - return true; - } - } - return false; - } - - /** - * Returns an enumeration of all the ExecPermission objects in the - * container. - * - * @return an enumeration of all the ExecPermission objects. - */ - public Enumeration elements() - { - return permissions.elements(); - } - } -} diff --git a/src/java.rmi/share/classes/java/rmi/AccessException.java b/src/java.rmi/share/classes/java/rmi/AccessException.java index f6244f2e4d6..4ec935a1f06 100644 --- a/src/java.rmi/share/classes/java/rmi/AccessException.java +++ b/src/java.rmi/share/classes/java/rmi/AccessException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,8 +28,7 @@ package java.rmi; /** * An AccessException is thrown by certain methods of the * java.rmi.Naming class (specifically bind, - * rebind, and unbind) and methods of the - * java.rmi.activation.ActivationSystem interface to + * rebind, and unbind) to * indicate that the caller does not have permission to perform the action * requested by the method call. If the method was invoked from a non-local * host, then an AccessException is thrown. @@ -38,7 +37,6 @@ package java.rmi; * @author Roger Riggs * @since 1.1 * @see java.rmi.Naming - * @see java.rmi.activation.ActivationSystem */ public class AccessException extends java.rmi.RemoteException { diff --git a/src/java.rmi/share/classes/java/rmi/NoSuchObjectException.java b/src/java.rmi/share/classes/java/rmi/NoSuchObjectException.java index 4767c39bb8d..0777eb81c91 100644 --- a/src/java.rmi/share/classes/java/rmi/NoSuchObjectException.java +++ b/src/java.rmi/share/classes/java/rmi/NoSuchObjectException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -35,14 +35,12 @@ package java.rmi; * A NoSuchObjectException is also thrown by the method * java.rmi.server.RemoteObject.toStub and by the * unexportObject methods of - * java.rmi.server.UnicastRemoteObject and - * java.rmi.activation.Activatable and + * java.rmi.server.UnicastRemoteObject. * * @author Ann Wollrath * @since 1.1 * @see java.rmi.server.RemoteObject#toStub(Remote) * @see java.rmi.server.UnicastRemoteObject#unexportObject(Remote,boolean) - * @see java.rmi.activation.Activatable#unexportObject(Remote,boolean) */ public class NoSuchObjectException extends RemoteException { diff --git a/src/java.rmi/share/classes/java/rmi/Remote.java b/src/java.rmi/share/classes/java/rmi/Remote.java index 57814d24c53..2dedfe66f86 100644 --- a/src/java.rmi/share/classes/java/rmi/Remote.java +++ b/src/java.rmi/share/classes/java/rmi/Remote.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,11 +33,10 @@ package java.rmi; * extends java.rmi.Remote are available remotely. * *

Implementation classes can implement any number of remote interfaces and - * can extend other remote implementation classes. RMI provides some - * convenience classes that remote object implementations can extend which - * facilitate remote object creation. These classes are - * java.rmi.server.UnicastRemoteObject and - * java.rmi.activation.Activatable. + * can extend other remote implementation classes. RMI provides a convenience + * class {@link java.rmi.server.UnicastRemoteObject UnicastRemoteObject} + * that remote object implementations can extend and that facilitates remote + * object creation. * *

For complete details on RMI, see the RMI Specification which @@ -45,7 +44,5 @@ package java.rmi; * * @since 1.1 * @author Ann Wollrath - * @see java.rmi.server.UnicastRemoteObject - * @see java.rmi.activation.Activatable */ public interface Remote {} diff --git a/src/java.rmi/share/classes/java/rmi/StubNotFoundException.java b/src/java.rmi/share/classes/java/rmi/StubNotFoundException.java index 1d9c5ec5b9d..1d43f82fd10 100644 --- a/src/java.rmi/share/classes/java/rmi/StubNotFoundException.java +++ b/src/java.rmi/share/classes/java/rmi/StubNotFoundException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,14 +28,10 @@ package java.rmi; /** * A StubNotFoundException is thrown if a valid stub class * could not be found for a remote object when it is exported. - * A StubNotFoundException may also be - * thrown when an activatable object is registered via the - * java.rmi.activation.Activatable.register method. * * @author Roger Riggs * @since 1.1 * @see java.rmi.server.UnicastRemoteObject - * @see java.rmi.activation.Activatable */ public class StubNotFoundException extends RemoteException { diff --git a/src/java.rmi/share/classes/java/rmi/activation/Activatable.java b/src/java.rmi/share/classes/java/rmi/activation/Activatable.java deleted file mode 100644 index 175b469995a..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/Activatable.java +++ /dev/null @@ -1,584 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.MarshalledObject; -import java.rmi.NoSuchObjectException; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.UnknownGroupException; -import java.rmi.activation.UnknownObjectException; -import java.rmi.server.RMIClientSocketFactory; -import java.rmi.server.RMIServerSocketFactory; -import java.rmi.server.RemoteServer; -import sun.rmi.server.ActivatableServerRef; - -/** - * The Activatable class provides support for remote - * objects that require persistent access over time and that - * can be activated by the system. - * - *

For the constructors and static exportObject methods, - * the stub for a remote object being exported is obtained as described in - * {@link java.rmi.server.UnicastRemoteObject}. - * - *

An attempt to serialize explicitly an instance of this class will - * fail. - * - * @author Ann Wollrath - * @since 1.2 - * @serial exclude - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public abstract class Activatable extends RemoteServer { - - private ActivationID id; - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = -3120617863591563455L; - - /** - * Constructs an activatable remote object by registering - * an activation descriptor (with the specified location, data, and - * restart mode) for this object, and exporting the object with the - * specified port. - * - *

Note: Using the Activatable - * constructors that both register and export an activatable remote - * object is strongly discouraged because the actions of registering - * and exporting the remote object are not guaranteed to be - * atomic. Instead, an application should register an activation - * descriptor and export a remote object separately, so that exceptions - * can be handled properly. - * - *

This method invokes the {@link - * #exportObject(Remote,String,MarshalledObject,boolean,int) - * exportObject} method with this object, and the specified location, - * data, restart mode, and port. Subsequent calls to {@link #getID} - * will return the activation identifier returned from the call to - * exportObject. - * - * @param location the location for classes for this object - * @param data the object's initialization data - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @throws ActivationException if object registration fails. - * @throws RemoteException if either of the following fails: - * a) registering the object with the activation system or b) exporting - * the object to the RMI runtime. - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation. - * @since 1.2 - **/ - protected Activatable(String location, - MarshalledObject data, - boolean restart, - int port) - throws ActivationException, RemoteException - { - super(); - id = exportObject(this, location, data, restart, port); - } - - /** - * Constructs an activatable remote object by registering - * an activation descriptor (with the specified location, data, and - * restart mode) for this object, and exporting the object with the - * specified port, and specified client and server socket factories. - * - *

Note: Using the Activatable - * constructors that both register and export an activatable remote - * object is strongly discouraged because the actions of registering - * and exporting the remote object are not guaranteed to be - * atomic. Instead, an application should register an activation - * descriptor and export a remote object separately, so that exceptions - * can be handled properly. - * - *

This method invokes the {@link - * #exportObject(Remote,String,MarshalledObject,boolean,int,RMIClientSocketFactory,RMIServerSocketFactory) - * exportObject} method with this object, and the specified location, - * data, restart mode, port, and client and server socket factories. - * Subsequent calls to {@link #getID} will return the activation - * identifier returned from the call to exportObject. - * - * @param location the location for classes for this object - * @param data the object's initialization data - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @param csf the client-side socket factory for making calls to the - * remote object - * @param ssf the server-side socket factory for receiving remote calls - * @throws ActivationException if object registration fails. - * @throws RemoteException if either of the following fails: - * a) registering the object with the activation system or b) exporting - * the object to the RMI runtime. - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation. - * @since 1.2 - **/ - protected Activatable(String location, - MarshalledObject data, - boolean restart, - int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf) - throws ActivationException, RemoteException - { - super(); - id = exportObject(this, location, data, restart, port, csf, ssf); - } - - /** - * Constructor used to activate/export the object on a specified - * port. An "activatable" remote object must have a constructor that - * takes two arguments:

- * - * A concrete subclass of this class must call this constructor when it is - * activated via the two parameter constructor described above. As - * a side-effect of construction, the remote object is "exported" - * to the RMI runtime (on the specified port) and is - * available to accept incoming calls from clients. - * - * @param id activation identifier for the object - * @param port the port number on which the object is exported - * @throws RemoteException if exporting the object to the RMI - * runtime fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - protected Activatable(ActivationID id, int port) - throws RemoteException - { - super(); - this.id = id; - exportObject(this, id, port); - } - - /** - * Constructor used to activate/export the object on a specified - * port. An "activatable" remote object must have a constructor that - * takes two arguments:

- * - * A concrete subclass of this class must call this constructor when it is - * activated via the two parameter constructor described above. As - * a side-effect of construction, the remote object is "exported" - * to the RMI runtime (on the specified port) and is - * available to accept incoming calls from clients. - * - * @param id activation identifier for the object - * @param port the port number on which the object is exported - * @param csf the client-side socket factory for making calls to the - * remote object - * @param ssf the server-side socket factory for receiving remote calls - * @throws RemoteException if exporting the object to the RMI - * runtime fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - protected Activatable(ActivationID id, int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf) - throws RemoteException - { - super(); - this.id = id; - exportObject(this, id, port, csf, ssf); - } - - /** - * Returns the object's activation identifier. The method is - * protected so that only subclasses can obtain an object's - * identifier. - * @return the object's activation identifier - * @since 1.2 - */ - protected ActivationID getID() { - return id; - } - - /** - * Register an object descriptor for an activatable remote - * object so that is can be activated on demand. - * - * @param desc the object's descriptor - * @return the stub for the activatable remote object - * @throws UnknownGroupException if group id in desc - * is not registered with the activation system - * @throws ActivationException if activation system is not running - * @throws RemoteException if remote call fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static Remote register(ActivationDesc desc) - throws UnknownGroupException, ActivationException, RemoteException - { - // register object with activator. - ActivationID id = - ActivationGroup.getSystem().registerObject(desc); - return sun.rmi.server.ActivatableRef.getStub(desc, id); - } - - /** - * Informs the system that the object with the corresponding activation - * id is currently inactive. If the object is currently - * active, the object is "unexported" from the RMI runtime (only if - * there are no pending or in-progress calls) - * so the that it can no longer receive incoming calls. This call - * informs this VM's ActivationGroup that the object is inactive, - * that, in turn, informs its ActivationMonitor. If this call - * completes successfully, a subsequent activate request to the activator - * will cause the object to reactivate. The operation may still - * succeed if the object is considered active but has already - * unexported itself. - * - * @param id the object's activation identifier - * @return true if the operation succeeds (the operation will - * succeed if the object in currently known to be active and is - * either already unexported or is currently exported and has no - * pending/executing calls); false is returned if the object has - * pending/executing calls in which case it cannot be deactivated - * @throws UnknownObjectException if object is not known (it may - * already be inactive) - * @throws ActivationException if group is not active - * @throws RemoteException if call informing monitor fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static boolean inactive(ActivationID id) - throws UnknownObjectException, ActivationException, RemoteException - { - return ActivationGroup.currentGroup().inactiveObject(id); - } - - /** - * Revokes previous registration for the activation descriptor - * associated with id. An object can no longer be - * activated via that id. - * - * @param id the object's activation identifier - * @throws UnknownObjectException if object (id) is unknown - * @throws ActivationException if activation system is not running - * @throws RemoteException if remote call to activation system fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static void unregister(ActivationID id) - throws UnknownObjectException, ActivationException, RemoteException - { - ActivationGroup.getSystem().unregisterObject(id); - } - - /** - * Registers an activation descriptor (with the specified location, - * data, and restart mode) for the specified object, and exports that - * object with the specified port. - * - *

Note: Using this method (as well as the - * Activatable constructors that both register and export - * an activatable remote object) is strongly discouraged because the - * actions of registering and exporting the remote object are - * not guaranteed to be atomic. Instead, an application should - * register an activation descriptor and export a remote object - * separately, so that exceptions can be handled properly. - * - *

This method invokes the {@link - * #exportObject(Remote,String,MarshalledObject,boolean,int,RMIClientSocketFactory,RMIServerSocketFactory) - * exportObject} method with the specified object, location, data, - * restart mode, and port, and null for both client and - * server socket factories, and then returns the resulting activation - * identifier. - * - * @param obj the object being exported - * @param location the object's code location - * @param data the object's bootstrapping data - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @return the activation identifier obtained from registering the - * descriptor, desc, with the activation system - * the wrong group - * @throws ActivationException if activation group is not active - * @throws RemoteException if object registration or export fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - **/ - public static ActivationID exportObject(Remote obj, - String location, - MarshalledObject data, - boolean restart, - int port) - throws ActivationException, RemoteException - { - return exportObject(obj, location, data, restart, port, null, null); - } - - /** - * Registers an activation descriptor (with the specified location, - * data, and restart mode) for the specified object, and exports that - * object with the specified port, and the specified client and server - * socket factories. - * - *

Note: Using this method (as well as the - * Activatable constructors that both register and export - * an activatable remote object) is strongly discouraged because the - * actions of registering and exporting the remote object are - * not guaranteed to be atomic. Instead, an application should - * register an activation descriptor and export a remote object - * separately, so that exceptions can be handled properly. - * - *

This method first registers an activation descriptor for the - * specified object as follows. It obtains the activation system by - * invoking the method {@link ActivationGroup#getSystem - * ActivationGroup.getSystem}. This method then obtains an {@link - * ActivationID} for the object by invoking the activation system's - * {@link ActivationSystem#registerObject registerObject} method with - * an {@link ActivationDesc} constructed with the specified object's - * class name, and the specified location, data, and restart mode. If - * an exception occurs obtaining the activation system or registering - * the activation descriptor, that exception is thrown to the caller. - * - *

Next, this method exports the object by invoking the {@link - * #exportObject(Remote,ActivationID,int,RMIClientSocketFactory,RMIServerSocketFactory) - * exportObject} method with the specified remote object, the - * activation identifier obtained from registration, the specified - * port, and the specified client and server socket factories. If an - * exception occurs exporting the object, this method attempts to - * unregister the activation identifier (obtained from registration) by - * invoking the activation system's {@link - * ActivationSystem#unregisterObject unregisterObject} method with the - * activation identifier. If an exception occurs unregistering the - * identifier, that exception is ignored, and the original exception - * that occurred exporting the object is thrown to the caller. - * - *

Finally, this method invokes the {@link - * ActivationGroup#activeObject activeObject} method on the activation - * group in this VM with the activation identifier and the specified - * remote object, and returns the activation identifier to the caller. - * - * @param obj the object being exported - * @param location the object's code location - * @param data the object's bootstrapping data - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @param csf the client-side socket factory for making calls to the - * remote object - * @param ssf the server-side socket factory for receiving remote calls - * @return the activation identifier obtained from registering the - * descriptor with the activation system - * @throws ActivationException if activation group is not active - * @throws RemoteException if object registration or export fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - **/ - public static ActivationID exportObject(Remote obj, - String location, - MarshalledObject data, - boolean restart, - int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf) - throws ActivationException, RemoteException - { - ActivationDesc desc = new ActivationDesc(obj.getClass().getName(), - location, data, restart); - /* - * Register descriptor. - */ - ActivationSystem system = ActivationGroup.getSystem(); - ActivationID id = system.registerObject(desc); - - /* - * Export object. - */ - try { - exportObject(obj, id, port, csf, ssf); - } catch (RemoteException e) { - /* - * Attempt to unregister activation descriptor because export - * failed and register/export should be atomic (see 4323621). - */ - try { - system.unregisterObject(id); - } catch (Exception ex) { - } - /* - * Report original exception. - */ - throw e; - } - - /* - * This call can't fail (it is a local call, and the only possible - * exception, thrown if the group is inactive, will not be thrown - * because the group is not inactive). - */ - ActivationGroup.currentGroup().activeObject(id, obj); - - return id; - } - - /** - * Export the activatable remote object to the RMI runtime to make - * the object available to receive incoming calls. The object is - * exported on an anonymous port, if port is zero.

- * - * During activation, this exportObject method should - * be invoked explicitly by an "activatable" object, that does not - * extend the Activatable class. There is no need for objects - * that do extend the Activatable class to invoke this - * method directly because the object is exported during construction. - * - * @return the stub for the activatable remote object - * @param obj the remote object implementation - * @param id the object's activation identifier - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @throws RemoteException if object export fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static Remote exportObject(Remote obj, - ActivationID id, - int port) - throws RemoteException - { - return exportObject(obj, new ActivatableServerRef(id, port)); - } - - /** - * Export the activatable remote object to the RMI runtime to make - * the object available to receive incoming calls. The object is - * exported on an anonymous port, if port is zero.

- * - * During activation, this exportObject method should - * be invoked explicitly by an "activatable" object, that does not - * extend the Activatable class. There is no need for objects - * that do extend the Activatable class to invoke this - * method directly because the object is exported during construction. - * - * @return the stub for the activatable remote object - * @param obj the remote object implementation - * @param id the object's activation identifier - * @param port the port on which the object is exported (an anonymous - * port is used if port=0) - * @param csf the client-side socket factory for making calls to the - * remote object - * @param ssf the server-side socket factory for receiving remote calls - * @throws RemoteException if object export fails - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static Remote exportObject(Remote obj, - ActivationID id, - int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf) - throws RemoteException - { - return exportObject(obj, new ActivatableServerRef(id, port, csf, ssf)); - } - - /** - * Remove the remote object, obj, from the RMI runtime. If - * successful, the object can no longer accept incoming RMI calls. - * If the force parameter is true, the object is forcibly unexported - * even if there are pending calls to the remote object or the - * remote object still has calls in progress. If the force - * parameter is false, the object is only unexported if there are - * no pending or in progress calls to the object. - * - * @param obj the remote object to be unexported - * @param force if true, unexports the object even if there are - * pending or in-progress calls; if false, only unexports the object - * if there are no pending or in-progress calls - * @return true if operation is successful, false otherwise - * @throws NoSuchObjectException if the remote object is not - * currently exported - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public static boolean unexportObject(Remote obj, boolean force) - throws NoSuchObjectException - { - return sun.rmi.transport.ObjectTable.unexportObject(obj, force); - } - - /** - * Exports the specified object using the specified server ref. - */ - private static Remote exportObject(Remote obj, ActivatableServerRef sref) - throws RemoteException - { - // if obj extends Activatable, set its ref. - if (obj instanceof Activatable) { - ((Activatable) obj).ref = sref; - - } - return sref.exportObject(obj, null, false); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivateFailedException.java b/src/java.rmi/share/classes/java/rmi/activation/ActivateFailedException.java deleted file mode 100644 index 654b716265e..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivateFailedException.java +++ /dev/null @@ -1,66 +0,0 @@ -/* - * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -/** - * This exception is thrown by the RMI runtime when activation - * fails during a remote call to an activatable object. - * - * @author Ann Wollrath - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -public class ActivateFailedException extends java.rmi.RemoteException { - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = 4863550261346652506L; - - /** - * Constructs an ActivateFailedException with the specified - * detail message. - * - * @param s the detail message - * @since 1.2 - */ - public ActivateFailedException(String s) { - super(s); - } - - /** - * Constructs an ActivateFailedException with the specified - * detail message and nested exception. - * - * @param s the detail message - * @param ex the nested exception - * @since 1.2 - */ - public ActivateFailedException(String s, Exception ex) { - super(s, ex); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationDesc.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationDesc.java deleted file mode 100644 index d62f4af1fe8..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationDesc.java +++ /dev/null @@ -1,352 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.io.Serializable; -import java.rmi.MarshalledObject; - -/** - * An activation descriptor contains the information necessary to - * activate an object:

- * - *

A descriptor registered with the activation system can be used to - * recreate/activate the object specified by the descriptor. The - * MarshalledObject in the object's descriptor is passed - * as the second argument to the remote object's constructor for - * object to use during reinitialization/activation. - * - * @author Ann Wollrath - * @since 1.2 - * @see java.rmi.activation.Activatable - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public final class ActivationDesc implements Serializable { - - /** - * @serial the group's identifier - */ - private ActivationGroupID groupID; - - /** - * @serial the object's class name - */ - private String className; - - /** - * @serial the object's code location - */ - private String location; - - /** - * @serial the object's initialization data - */ - private MarshalledObject data; - - /** - * @serial indicates whether the object should be restarted - */ - private boolean restart; - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = 7455834104417690957L; - - /** - * Constructs an object descriptor for an object whose class name - * is className, that can be loaded from the - * code location and whose initialization - * information is data. If this form of the constructor - * is used, the groupID defaults to the current id for - * ActivationGroup for this VM. All objects with the - * same ActivationGroupID are activated in the same VM. - * - *

Note that objects specified by a descriptor created with this - * constructor will only be activated on demand (by default, the restart - * mode is false). If an activatable object requires restart - * services, use one of the ActivationDesc constructors that - * takes a boolean parameter, restart. - * - *

This constructor will throw ActivationException if - * there is no current activation group for this VM. To create an - * ActivationGroup use the - * ActivationGroup.createGroup method. - * - * @param className the object's fully package qualified class name - * @param location the object's code location (from where the class is - * loaded) - * @param data the object's initialization (activation) data contained - * in marshalled form. - * @throws ActivationException if the current group is nonexistent - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationDesc(String className, - String location, - MarshalledObject data) - throws ActivationException - { - this(ActivationGroup.internalCurrentGroupID(), - className, location, data, false); - } - - /** - * Constructs an object descriptor for an object whose class name - * is className, that can be loaded from the - * code location and whose initialization - * information is data. If this form of the constructor - * is used, the groupID defaults to the current id for - * ActivationGroup for this VM. All objects with the - * same ActivationGroupID are activated in the same VM. - * - *

This constructor will throw ActivationException if - * there is no current activation group for this VM. To create an - * ActivationGroup use the - * ActivationGroup.createGroup method. - * - * @param className the object's fully package qualified class name - * @param location the object's code location (from where the class is - * loaded) - * @param data the object's initialization (activation) data contained - * in marshalled form. - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @throws ActivationException if the current group is nonexistent - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationDesc(String className, - String location, - MarshalledObject data, - boolean restart) - throws ActivationException - { - this(ActivationGroup.internalCurrentGroupID(), - className, location, data, restart); - } - - /** - * Constructs an object descriptor for an object whose class name - * is className that can be loaded from the - * code location and whose initialization - * information is data. All objects with the same - * groupID are activated in the same Java VM. - * - *

Note that objects specified by a descriptor created with this - * constructor will only be activated on demand (by default, the restart - * mode is false). If an activatable object requires restart - * services, use one of the ActivationDesc constructors that - * takes a boolean parameter, restart. - * - * @param groupID the group's identifier (obtained from registering - * ActivationSystem.registerGroup method). The group - * indicates the VM in which the object should be activated. - * @param className the object's fully package-qualified class name - * @param location the object's code location (from where the class is - * loaded) - * @param data the object's initialization (activation) data contained - * in marshalled form. - * @throws IllegalArgumentException if groupID is null - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationDesc(ActivationGroupID groupID, - String className, - String location, - MarshalledObject data) - { - this(groupID, className, location, data, false); - } - - /** - * Constructs an object descriptor for an object whose class name - * is className that can be loaded from the - * code location and whose initialization - * information is data. All objects with the same - * groupID are activated in the same Java VM. - * - * @param groupID the group's identifier (obtained from registering - * ActivationSystem.registerGroup method). The group - * indicates the VM in which the object should be activated. - * @param className the object's fully package-qualified class name - * @param location the object's code location (from where the class is - * loaded) - * @param data the object's initialization (activation) data contained - * in marshalled form. - * @param restart if true, the object is restarted (reactivated) when - * either the activator is restarted or the object's activation group - * is restarted after an unexpected crash; if false, the object is only - * activated on demand. Specifying restart to be - * true does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @throws IllegalArgumentException if groupID is null - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationDesc(ActivationGroupID groupID, - String className, - String location, - MarshalledObject data, - boolean restart) - { - if (groupID == null) - throw new IllegalArgumentException("groupID can't be null"); - this.groupID = groupID; - this.className = className; - this.location = location; - this.data = data; - this.restart = restart; - } - - /** - * Returns the group identifier for the object specified by this - * descriptor. A group provides a way to aggregate objects into a - * single Java virtual machine. RMI creates/activates objects with - * the same groupID in the same virtual machine. - * - * @return the group identifier - * @since 1.2 - */ - public ActivationGroupID getGroupID() { - return groupID; - } - - /** - * Returns the class name for the object specified by this - * descriptor. - * @return the class name - * @since 1.2 - */ - public String getClassName() { - return className; - } - - /** - * Returns the code location for the object specified by - * this descriptor. - * @return the code location - * @since 1.2 - */ - public String getLocation() { - return location; - } - - /** - * Returns a "marshalled object" containing intialization/activation - * data for the object specified by this descriptor. - * @return the object specific "initialization" data - * @since 1.2 - */ - public MarshalledObject getData() { - return data; - } - - /** - * Returns the "restart" mode of the object associated with - * this activation descriptor. - * - * @return true if the activatable object associated with this - * activation descriptor is restarted via the activation - * daemon when either the daemon comes up or the object's group - * is restarted after an unexpected crash; otherwise it returns false, - * meaning that the object is only activated on demand via a - * method call. Note that if the restart mode is true, the - * activator does not force an initial immediate activation of - * a newly registered object; initial activation is lazy. - * @since 1.2 - */ - public boolean getRestartMode() { - return restart; - } - - /** - * Compares two activation descriptors for content equality. - * - * @param obj the Object to compare with - * @return true if these Objects are equal; false otherwise. - * @see java.util.Hashtable - * @since 1.2 - */ - public boolean equals(Object obj) { - - if (obj instanceof ActivationDesc) { - ActivationDesc desc = (ActivationDesc) obj; - return - ((groupID == null ? desc.groupID == null : - groupID.equals(desc.groupID)) && - (className == null ? desc.className == null : - className.equals(desc.className)) && - (location == null ? desc.location == null: - location.equals(desc.location)) && - (data == null ? desc.data == null : - data.equals(desc.data)) && - (restart == desc.restart)); - - } else { - return false; - } - } - - /** - * Return the same hashCode for similar ActivationDescs. - * @return an integer - * @see java.util.Hashtable - */ - public int hashCode() { - return ((location == null - ? 0 - : location.hashCode() << 24) ^ - (groupID == null - ? 0 - : groupID.hashCode() << 16) ^ - (className == null - ? 0 - : className.hashCode() << 9) ^ - (data == null - ? 0 - : data.hashCode() << 1) ^ - (restart - ? 1 - : 0)); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationException.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationException.java deleted file mode 100644 index 645a5e7bd86..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationException.java +++ /dev/null @@ -1,122 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -/** - * General exception used by the activation interfaces. - * - *

As of release 1.4, this exception has been retrofitted to conform to - * the general purpose exception-chaining mechanism. The "detail exception" - * that may be provided at construction time and accessed via the public - * {@link #detail} field is now known as the cause, and may be - * accessed via the {@link Throwable#getCause()} method, as well as - * the aforementioned "legacy field." - * - *

Invoking the method {@link Throwable#initCause(Throwable)} on an - * instance of {@code ActivationException} always throws {@link - * IllegalStateException}. - * - * @author Ann Wollrath - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -public class ActivationException extends Exception { - - /** - * The cause of the activation exception. - * - *

This field predates the general-purpose exception chaining facility. - * The {@link Throwable#getCause()} method is now the preferred means of - * obtaining this information. - * - * @serial - */ - public Throwable detail; - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = -4320118837291406071L; - - /** - * Constructs an {@code ActivationException}. - */ - public ActivationException() { - initCause(null); // Disallow subsequent initCause - } - - /** - * Constructs an {@code ActivationException} with the specified - * detail message. - * - * @param s the detail message - */ - public ActivationException(String s) { - super(s); - initCause(null); // Disallow subsequent initCause - } - - /** - * Constructs an {@code ActivationException} with the specified - * detail message and cause. This constructor sets the {@link #detail} - * field to the specified {@code Throwable}. - * - * @param s the detail message - * @param cause the cause - */ - public ActivationException(String s, Throwable cause) { - super(s); - initCause(null); // Disallow subsequent initCause - detail = cause; - } - - /** - * Returns the detail message, including the message from the cause, if - * any, of this exception. - * - * @return the detail message - */ - public String getMessage() { - if (detail == null) - return super.getMessage(); - else - return super.getMessage() + - "; nested exception is: \n\t" + - detail.toString(); - } - - /** - * Returns the cause of this exception. This method returns the value - * of the {@link #detail} field. - * - * @return the cause, which may be {@code null}. - * @since 1.4 - */ - public Throwable getCause() { - return detail; - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup.java deleted file mode 100644 index bcfe3e336ad..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup.java +++ /dev/null @@ -1,543 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.lang.reflect.Constructor; -import java.lang.reflect.InvocationTargetException; -import java.rmi.MarshalledObject; -import java.rmi.Naming; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.UnknownGroupException; -import java.rmi.activation.UnknownObjectException; -import java.rmi.server.RMIClassLoader; -import java.rmi.server.UnicastRemoteObject; -import java.security.AccessController; -import java.security.PrivilegedAction; - -/** - * An ActivationGroup is responsible for creating new - * instances of "activatable" objects in its group, informing its - * ActivationMonitor when either: its object's become - * active or inactive, or the group as a whole becomes inactive.

- * - * An ActivationGroup is initially created in one - * of several ways:

- * - * Only the activator can recreate an - * ActivationGroup. The activator spawns, as needed, a - * separate VM (as a child process, for example) for each registered - * activation group and directs activation requests to the appropriate - * group. It is implementation specific how VMs are spawned. An - * activation group is created via the - * ActivationGroup.createGroup static method. The - * createGroup method has two requirements on the group - * to be created: 1) the group must be a concrete subclass of - * ActivationGroup, and 2) the group must have a - * constructor that takes two arguments: - * - *

- * - * When created, the default implementation of - * ActivationGroup will override the system properties - * with the properties requested when its - * ActivationGroupDesc was created, and will set a - * {@link SecurityManager} as the default system - * security manager. If your application requires specific properties - * to be set when objects are activated in the group, the application - * should create a special Properties object containing - * these properties, then create an ActivationGroupDesc - * with the Properties object, and use - * ActivationGroup.createGroup before creating any - * ActivationDescs (before the default - * ActivationGroupDesc is created). If your application - * requires the use of a security manager other than - * {@link SecurityManager}, in the - * ActivativationGroupDescriptor properties list you can set - * java.security.manager property to the name of the security - * manager you would like to install. - * - * @author Ann Wollrath - * @see ActivationInstantiator - * @see ActivationGroupDesc - * @see ActivationGroupID - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public abstract class ActivationGroup - extends UnicastRemoteObject - implements ActivationInstantiator -{ - /** - * @serial the group's identifier - */ - private ActivationGroupID groupID; - - /** - * @serial the group's monitor - */ - @SuppressWarnings("serial") // Not statically typed as Serializable - private ActivationMonitor monitor; - - /** - * @serial the group's incarnation number - */ - private long incarnation; - - /** the current activation group for this VM */ - private static ActivationGroup currGroup; - /** the current group's identifier */ - private static ActivationGroupID currGroupID; - /** the current group's activation system */ - private static ActivationSystem currSystem; - /** used to control a group being created only once */ - private static boolean canCreate = true; - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = -7696947875314805420L; - - /** - * Constructs an activation group with the given activation group - * identifier. The group is exported as a - * java.rmi.server.UnicastRemoteObject. - * - * @param groupID the group's identifier - * @throws RemoteException if this group could not be exported - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - protected ActivationGroup(ActivationGroupID groupID) - throws RemoteException - { - // call super constructor to export the object - super(); - this.groupID = groupID; - } - - /** - * The group's inactiveObject method is called - * indirectly via a call to the Activatable.inactive - * method. A remote object implementation must call - * Activatable's inactive method when - * that object deactivates (the object deems that it is no longer - * active). If the object does not call - * Activatable.inactive when it deactivates, the - * object will never be garbage collected since the group keeps - * strong references to the objects it creates. - * - *

The group's inactiveObject method unexports the - * remote object from the RMI runtime so that the object can no - * longer receive incoming RMI calls. An object will only be unexported - * if the object has no pending or executing calls. - * The subclass of ActivationGroup must override this - * method and unexport the object. - * - *

After removing the object from the RMI runtime, the group - * must inform its ActivationMonitor (via the monitor's - * inactiveObject method) that the remote object is - * not currently active so that the remote object will be - * re-activated by the activator upon a subsequent activation - * request. - * - *

This method simply informs the group's monitor that the object - * is inactive. It is up to the concrete subclass of ActivationGroup - * to fulfill the additional requirement of unexporting the object. - * - * @param id the object's activation identifier - * @return true if the object was successfully deactivated; otherwise - * returns false. - * @throws UnknownObjectException if object is unknown (may already - * be inactive) - * @throws RemoteException if call informing monitor fails - * @throws ActivationException if group is inactive - * @since 1.2 - */ - public boolean inactiveObject(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException - { - getMonitor().inactiveObject(id); - return true; - } - - /** - * The group's activeObject method is called when an - * object is exported (either by Activatable object - * construction or an explicit call to - * Activatable.exportObject. The group must inform its - * ActivationMonitor that the object is active (via - * the monitor's activeObject method) if the group - * hasn't already done so. - * - * @param id the object's identifier - * @param obj the remote object implementation - * @throws UnknownObjectException if object is not registered - * @throws RemoteException if call informing monitor fails - * @throws ActivationException if group is inactive - * @since 1.2 - */ - public abstract void activeObject(ActivationID id, Remote obj) - throws ActivationException, UnknownObjectException, RemoteException; - - /** - * Create and set the activation group for the current VM. The - * activation group can only be set if it is not currently set. - * An activation group is set using the createGroup - * method when the Activator initiates the - * re-creation of an activation group in order to carry out - * incoming activate requests. A group must first be - * registered with the ActivationSystem before it can - * be created via this method. - * - *

The group class specified by the - * ActivationGroupDesc must be a concrete subclass of - * ActivationGroup and have a public constructor that - * takes two arguments: the ActivationGroupID for the - * group and the MarshalledObject containing the - * group's initialization data (obtained from the - * ActivationGroupDesc. - * - *

If the group class name specified in the - * ActivationGroupDesc is null, then - * this method will behave as if the group descriptor contained - * the name of the default activation group implementation class. - * - *

Note that if your application creates its own custom - * activation group, a security manager must be set for that - * group. Otherwise objects cannot be activated in the group. - * {@link SecurityManager} is set by default. - * - *

If a security manager is already set in the group VM, this - * method first calls the security manager's - * checkSetFactory method. This could result in a - * SecurityException. If your application needs to - * set a different security manager, you must ensure that the - * policy file specified by the group's - * ActivationGroupDesc grants the group the necessary - * permissions to set a new security manager. (Note: This will be - * necessary if your group downloads and sets a security manager). - * - *

After the group is created, the - * ActivationSystem is informed that the group is - * active by calling the activeGroup method which - * returns the ActivationMonitor for the group. The - * application need not call activeGroup - * independently since it is taken care of by this method. - * - *

Once a group is created, subsequent calls to the - * currentGroupID method will return the identifier - * for this group until the group becomes inactive. - * - * @param id the activation group's identifier - * @param desc the activation group's descriptor - * @param incarnation the group's incarnation number (zero on group's - * initial creation) - * @return the activation group for the VM - * @throws ActivationException if group already exists or if error - * occurs during group creation - * @throws SecurityException if permission to create group is denied. - * (Note: The default implementation of the security manager - * checkSetFactory - * method requires the RuntimePermission "setFactory") - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @see SecurityManager#checkSetFactory - * @since 1.2 - */ - public static synchronized - ActivationGroup createGroup(ActivationGroupID id, - final ActivationGroupDesc desc, - long incarnation) - throws ActivationException - { - SecurityManager security = System.getSecurityManager(); - if (security != null) - security.checkSetFactory(); - - if (currGroup != null) - throw new ActivationException("group already exists"); - - if (canCreate == false) - throw new ActivationException("group deactivated and " + - "cannot be recreated"); - - try { - // load group's class - String groupClassName = desc.getClassName(); - Class cl; - Class defaultGroupClass = - sun.rmi.server.ActivationGroupImpl.class; - if (groupClassName == null || // see 4252236 - groupClassName.equals(defaultGroupClass.getName())) - { - cl = defaultGroupClass; - } else { - Class cl0; - try { - cl0 = RMIClassLoader.loadClass(desc.getLocation(), - groupClassName); - } catch (Exception ex) { - throw new ActivationException( - "Could not load group implementation class", ex); - } - if (ActivationGroup.class.isAssignableFrom(cl0)) { - cl = cl0.asSubclass(ActivationGroup.class); - } else { - throw new ActivationException("group not correct class: " + - cl0.getName()); - } - } - - // create group - Constructor constructor = - cl.getConstructor(ActivationGroupID.class, - MarshalledObject.class); - ActivationGroup newGroup = - constructor.newInstance(id, desc.getData()); - currSystem = id.getSystem(); - newGroup.incarnation = incarnation; - newGroup.monitor = - currSystem.activeGroup(id, newGroup, incarnation); - currGroup = newGroup; - currGroupID = id; - canCreate = false; - } catch (InvocationTargetException e) { - e.getTargetException().printStackTrace(); - throw new ActivationException("exception in group constructor", - e.getTargetException()); - - } catch (ActivationException e) { - throw e; - - } catch (Exception e) { - throw new ActivationException("exception creating group", e); - } - - return currGroup; - } - - /** - * Returns the current activation group's identifier. Returns null - * if no group is currently active for this VM. - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @return the activation group's identifier - * @since 1.2 - */ - public static synchronized ActivationGroupID currentGroupID() { - return currGroupID; - } - - /** - * Returns the activation group identifier for the VM. If an - * activation group does not exist for this VM, a default - * activation group is created. A group can be created only once, - * so if a group has already become active and deactivated. - * - * @return the activation group identifier - * @throws ActivationException if error occurs during group - * creation, if security manager is not set, or if the group - * has already been created and deactivated. - */ - static synchronized ActivationGroupID internalCurrentGroupID() - throws ActivationException - { - if (currGroupID == null) - throw new ActivationException("nonexistent group"); - - return currGroupID; - } - - /** - * Set the activation system for the VM. The activation system can - * only be set it if no group is currently active. If the activation - * system is not set via this call, then the getSystem - * method attempts to obtain a reference to the - * ActivationSystem by looking up the name - * "java.rmi.activation.ActivationSystem" in the Activator's - * registry. By default, the port number used to look up the - * activation system is defined by - * ActivationSystem.SYSTEM_PORT. This port can be overridden - * by setting the property java.rmi.activation.port. - * - *

If there is a security manager, this method first - * calls the security manager's checkSetFactory method. - * This could result in a SecurityException. - * - * @param system remote reference to the ActivationSystem - * @throws ActivationException if activation system is already set - * @throws SecurityException if permission to set the activation system is denied. - * (Note: The default implementation of the security manager - * checkSetFactory - * method requires the RuntimePermission "setFactory") - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @see #getSystem - * @see SecurityManager#checkSetFactory - * @since 1.2 - */ - public static synchronized void setSystem(ActivationSystem system) - throws ActivationException - { - SecurityManager security = System.getSecurityManager(); - if (security != null) - security.checkSetFactory(); - - if (currSystem != null) - throw new ActivationException("activation system already set"); - - currSystem = system; - } - - /** - * Returns the activation system for the VM. The activation system - * may be set by the setSystem method. If the - * activation system is not set via the setSystem - * method, then the getSystem method attempts to - * obtain a reference to the ActivationSystem by - * looking up the name "java.rmi.activation.ActivationSystem" in - * the Activator's registry. By default, the port number used to - * look up the activation system is defined by - * ActivationSystem.SYSTEM_PORT. This port can be - * overridden by setting the property - * java.rmi.activation.port. - * - * @return the activation system for the VM/group - * @throws ActivationException if activation system cannot be - * obtained or is not bound - * (means that it is not running) - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @see #setSystem - * @since 1.2 - */ - public static synchronized ActivationSystem getSystem() - throws ActivationException - { - if (currSystem == null) { - try { - int port = AccessController.doPrivileged((PrivilegedAction) () -> - Integer.getInteger("java.rmi.activation.port", ActivationSystem.SYSTEM_PORT)); - currSystem = (ActivationSystem) - Naming.lookup("//:" + port + - "/java.rmi.activation.ActivationSystem"); - } catch (Exception e) { - throw new ActivationException( - "unable to obtain ActivationSystem", e); - } - } - return currSystem; - } - - /** - * This protected method is necessary for subclasses to - * make the activeObject callback to the group's - * monitor. The call is simply forwarded to the group's - * ActivationMonitor. - * - * @param id the object's identifier - * @param mobj a marshalled object containing the remote object's stub - * @throws UnknownObjectException if object is not registered - * @throws RemoteException if call informing monitor fails - * @throws ActivationException if an activation error occurs - * @since 1.2 - */ - protected void activeObject(ActivationID id, - MarshalledObject mobj) - throws ActivationException, UnknownObjectException, RemoteException - { - getMonitor().activeObject(id, mobj); - } - - /** - * This protected method is necessary for subclasses to - * make the inactiveGroup callback to the group's - * monitor. The call is simply forwarded to the group's - * ActivationMonitor. Also, the current group - * for the VM is set to null. - * - * @throws UnknownGroupException if group is not registered - * @throws RemoteException if call informing monitor fails - * @since 1.2 - */ - protected void inactiveGroup() - throws UnknownGroupException, RemoteException - { - try { - getMonitor().inactiveGroup(groupID, incarnation); - } finally { - destroyGroup(); - } - } - - /** - * Returns the monitor for the activation group. - */ - private ActivationMonitor getMonitor() throws RemoteException { - synchronized (ActivationGroup.class) { - if (monitor != null) { - return monitor; - } - } - throw new RemoteException("monitor not received"); - } - - /** - * Destroys the current group. - */ - private static synchronized void destroyGroup() { - currGroup = null; - currGroupID = null; - // NOTE: don't set currSystem to null since it may be needed - } - - /** - * Returns the current group for the VM. - * @throws ActivationException if current group is null (not active) - */ - static synchronized ActivationGroup currentGroup() - throws ActivationException - { - if (currGroup == null) { - throw new ActivationException("group is not active"); - } - return currGroup; - } - -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupDesc.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupDesc.java deleted file mode 100644 index 4a40f6054df..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupDesc.java +++ /dev/null @@ -1,381 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.io.IOException; -import java.io.ObjectInputStream; -import java.io.Serializable; -import java.rmi.MarshalledObject; -import java.util.Arrays; -import java.util.Properties; - -/** - * An activation group descriptor contains the information necessary to - * create/recreate an activation group in which to activate objects. - * Such a descriptor contains:

- * - * The group's class must be a concrete subclass of - * ActivationGroup. A subclass of - * ActivationGroup is created/recreated via the - * ActivationGroup.createGroup static method that invokes - * a special constructor that takes two arguments:

- * - * @author Ann Wollrath - * @since 1.2 - * @see ActivationGroup - * @see ActivationGroupID - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -public final class ActivationGroupDesc implements Serializable { - - /** - * @serial The group's fully package qualified class name. - */ - private String className; - - /** - * @serial The location from where to load the group's class. - */ - private String location; - - /** - * @serial The group's initialization data. - */ - private MarshalledObject data; - - /** - * @serial The controlling options for executing the VM in - * another process. - */ - private CommandEnvironment env; - - /** - * @serial A properties map which will override those set - * by default in the subprocess environment. - */ - private Properties props; - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - @java.io.Serial - private static final long serialVersionUID = -4936225423168276595L; - - /** - * Constructs a group descriptor that uses the system defaults for group - * implementation and code location. Properties specify Java - * environment overrides (which will override system properties in - * the group implementation's VM). The command - * environment can control the exact command/options used in - * starting the child VM, or can be null to accept - * rmid's default. - * - *

This constructor will create an ActivationGroupDesc - * with a null group class name, which indicates the system's - * default ActivationGroup implementation. - * - * @param overrides the set of properties to set when the group is - * recreated. - * @param cmd the controlling options for executing the VM in - * another process (or null). - * @since 1.2 - */ - public ActivationGroupDesc(Properties overrides, - CommandEnvironment cmd) - { - this(null, null, null, overrides, cmd); - } - - /** - * Specifies an alternate group implementation and execution - * environment to be used for the group. - * - * @param className the group's package qualified class name or - * null. A null group class name indicates - * the system's default ActivationGroup implementation. - * @param location the location from where to load the group's - * class - * @param data the group's initialization data contained in - * marshalled form (could contain properties, for example) - * @param overrides a properties map which will override those set - * by default in the subprocess environment (will be translated - * into -D options), or null. - * @param cmd the controlling options for executing the VM in - * another process (or null). - * @since 1.2 - */ - public ActivationGroupDesc(String className, - String location, - MarshalledObject data, - Properties overrides, - CommandEnvironment cmd) - { - this.props = overrides; - this.env = cmd; - this.data = data; - this.location = location; - this.className = className; - } - - /** - * Returns the group's class name (possibly null). A - * null group class name indicates the system's default - * ActivationGroup implementation. - * @return the group's class name - * @since 1.2 - */ - public String getClassName() { - return className; - } - - /** - * Returns the group's code location. - * @return the group's code location - * @since 1.2 - */ - public String getLocation() { - return location; - } - - /** - * Returns the group's initialization data. - * @return the group's initialization data - * @since 1.2 - */ - public MarshalledObject getData() { - return data; - } - - /** - * Returns the group's property-override list. - * @return the property-override list, or null - * @since 1.2 - */ - public Properties getPropertyOverrides() { - return (props != null) ? (Properties) props.clone() : null; - } - - /** - * Returns the group's command-environment control object. - * @return the command-environment object, or null - * @since 1.2 - */ - public CommandEnvironment getCommandEnvironment() { - return this.env; - } - - - /** - * Startup options for ActivationGroup implementations. - * - * This class allows overriding default system properties and - * specifying implementation-defined options for ActivationGroups. - * @since 1.2 - */ - public static class CommandEnvironment implements Serializable { - @java.io.Serial - private static final long serialVersionUID = 6165754737887770191L; - - /** - * @serial - */ - private String command; - - /** - * @serial - */ - private String[] options; - - /** - * Create a CommandEnvironment with all the necessary - * information. - * - * @param cmdpath the name of the java executable, including - * the full path, or null, meaning "use rmid's default". - * The named program must be able to accept multiple - * -Dpropname=value options (as documented for the - * "java" tool) - * - * @param argv extra options which will be used in creating the - * ActivationGroup. Null has the same effect as an empty - * list. - * @since 1.2 - */ - public CommandEnvironment(String cmdpath, - String[] argv) - { - this.command = cmdpath; // might be null - - // Hold a safe copy of argv in this.options - if (argv == null) { - this.options = new String[0]; - } else { - this.options = new String[argv.length]; - System.arraycopy(argv, 0, this.options, 0, argv.length); - } - } - - /** - * Fetch the configured path-qualified java command name. - * - * @return the configured name, or null if configured to - * accept the default - * @since 1.2 - */ - public String getCommandPath() { - return (this.command); - } - - /** - * Fetch the configured java command options. - * - * @return An array of the command options which will be passed - * to the new child command by rmid. - * Note that rmid may add other options before or after these - * options, or both. - * Never returns null. - * @since 1.2 - */ - public String[] getCommandOptions() { - return options.clone(); - } - - /** - * Compares two command environments for content equality. - * - * @param obj the Object to compare with - * @return true if these Objects are equal; false otherwise. - * @see java.util.Hashtable - * @since 1.2 - */ - public boolean equals(Object obj) { - - if (obj instanceof CommandEnvironment) { - CommandEnvironment env = (CommandEnvironment) obj; - return - ((command == null ? env.command == null : - command.equals(env.command)) && - Arrays.equals(options, env.options)); - } else { - return false; - } - } - - /** - * Return identical values for similar - * CommandEnvironments. - * @return an integer - * @see java.util.Hashtable - */ - public int hashCode() - { - // hash command and ignore possibly expensive options - return (command == null ? 0 : command.hashCode()); - } - - /** - * readObject for custom serialization. - * - *

This method reads this object's serialized form for this - * class as follows: - *

This method first invokes defaultReadObject on - * the specified object input stream, and if options - * is null, then options is set to a - * zero-length array of String. - * - * @param in the {@code ObjectInputStream} from which data is read - * @throws IOException if an I/O error occurs - * @throws ClassNotFoundException if a serialized class cannot be loaded - * - */ - @java.io.Serial - private void readObject(ObjectInputStream in) - throws IOException, ClassNotFoundException - { - in.defaultReadObject(); - if (options == null) { - options = new String[0]; - } - } - } - - /** - * Compares two activation group descriptors for content equality. - * - * @param obj the Object to compare with - * @return true if these Objects are equal; false otherwise. - * @see java.util.Hashtable - * @since 1.2 - */ - public boolean equals(Object obj) { - - if (obj instanceof ActivationGroupDesc) { - ActivationGroupDesc desc = (ActivationGroupDesc) obj; - return - ((className == null ? desc.className == null : - className.equals(desc.className)) && - (location == null ? desc.location == null : - location.equals(desc.location)) && - (data == null ? desc.data == null : data.equals(desc.data)) && - (env == null ? desc.env == null : env.equals(desc.env)) && - (props == null ? desc.props == null : - props.equals(desc.props))); - } else { - return false; - } - } - - /** - * Produce identical numbers for similar ActivationGroupDescs. - * @return an integer - * @see java.util.Hashtable - */ - public int hashCode() { - // hash location, className, data, and env - // but omit props (may be expensive) - return ((location == null - ? 0 - : location.hashCode() << 24) ^ - (env == null - ? 0 - : env.hashCode() << 16) ^ - (className == null - ? 0 - : className.hashCode() << 8) ^ - (data == null - ? 0 - : data.hashCode())); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupID.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupID.java deleted file mode 100644 index 0ef0fc958c9..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroupID.java +++ /dev/null @@ -1,123 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.server.UID; - -/** - * The identifier for a registered activation group serves several - * purposes:

- * - * The ActivationGroupID is returned from the call to - * ActivationSystem.registerGroup and is used to identify - * the group within the activation system. This group id is passed - * as one of the arguments to the activation group's special constructor - * when an activation group is created/recreated. - * - * @author Ann Wollrath - * @see ActivationGroup - * @see ActivationGroupDesc - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public class ActivationGroupID implements java.io.Serializable { - /** - * @serial The group's activation system. - */ - @SuppressWarnings("serial") // Not statically typed as Serializable - private ActivationSystem system; - - /** - * @serial The group's unique id. - */ - private UID uid = new UID(); - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = -1648432278909740833L; - - /** - * Constructs a unique group id. - * - * @param system the group's activation system - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationGroupID(ActivationSystem system) { - this.system = system; - } - - /** - * Returns the group's activation system. - * @return the group's activation system - * @since 1.2 - */ - public ActivationSystem getSystem() { - return system; - } - - /** - * Returns a hashcode for the group's identifier. Two group - * identifiers that refer to the same remote group will have the - * same hash code. - * - * @see java.util.Hashtable - * @since 1.2 - */ - public int hashCode() { - return uid.hashCode(); - } - - /** - * Compares two group identifiers for content equality. - * Returns true if both of the following conditions are true: - * 1) the unique identifiers are equivalent (by content), and - * 2) the activation system specified in each - * refers to the same remote object. - * - * @param obj the Object to compare with - * @return true if these Objects are equal; false otherwise. - * @see java.util.Hashtable - * @since 1.2 - */ - public boolean equals(Object obj) { - if (this == obj) { - return true; - } else if (obj instanceof ActivationGroupID) { - ActivationGroupID id = (ActivationGroupID)obj; - return (uid.equals(id.uid) && system.equals(id.system)); - } else { - return false; - } - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup_Stub.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup_Stub.java deleted file mode 100644 index f378437b92d..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationGroup_Stub.java +++ /dev/null @@ -1,112 +0,0 @@ -/* - * Copyright (c) 2002, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.lang.reflect.Method; -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.UnexpectedException; -import java.rmi.server.RemoteRef; -import java.rmi.server.RemoteStub; - -/** - * {@code ActivationGroup_Stub} is a stub class for the subclasses of {@code java.rmi.activation.ActivationGroup} - * that are exported as a {@code java.rmi.server.UnicastRemoteObject}. - * - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings({"rawtypes", "removal", "unchecked"}) -public final class ActivationGroup_Stub - extends RemoteStub - implements ActivationInstantiator, Remote { - - @java.io.Serial - private static final long serialVersionUID = 2; - - private static Method $method_newInstance_0; - - static { - try { - $method_newInstance_0 = - ActivationInstantiator.class.getMethod("newInstance", - new Class[] {ActivationID.class, ActivationDesc.class}); - } catch (NoSuchMethodException e) { - throw new NoSuchMethodError( - "stub class initialization failed"); - } - } - - /** - * Constructs a stub for the {@code ActivationGroup} class. - * It invokes the superclass {@code RemoteStub(RemoteRef)} - * constructor with its argument, {@code ref}. - * - * @param ref a remote ref - */ - public ActivationGroup_Stub(RemoteRef ref) { - super(ref); - } - - /** - * Stub method for {@code ActivationGroup.newInstance}. Invokes - * the {@code invoke} method on this instance's - * {@code RemoteObject.ref} field, with {@code this} as the - * first argument, a two-element {@code Object[]} as the second - * argument (with {@code id} as the first element and - * {@code desc} as the second element), and -5274445189091581345L - * as the third argument, and returns the result. If that invocation - * throws a {@code RuntimeException}, {@code RemoteException}, - * or an {@code ActivationException}, then that exception is - * thrown to the caller. If that invocation throws any other - * {@code java.lang.Exception}, then a - * {@code java.rmi.UnexpectedException} is thrown to the caller - * with the original exception as the cause. - * - * @param id an activation identifier - * @param desc an activation descriptor - * @return the result of the invocation - * @throws RemoteException if invocation results in a {@code RemoteException} - * @throws ActivationException if invocation results in an {@code ActivationException} - */ - public MarshalledObject newInstance(ActivationID id, - ActivationDesc desc) - throws RemoteException, ActivationException { - try { - Object $result = ref.invoke(this, $method_newInstance_0, - new Object[]{id, desc}, -5274445189091581345L); - return ((MarshalledObject) $result); - } catch (RuntimeException | RemoteException | ActivationException e) { - throw e; - } catch (Exception e) { - throw new UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationID.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationID.java deleted file mode 100644 index 832c40fbbbf..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationID.java +++ /dev/null @@ -1,328 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.io.IOException; -import java.io.InvalidObjectException; -import java.io.ObjectInputStream; -import java.io.ObjectOutputStream; -import java.io.Serializable; -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.Proxy; -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.UnmarshalException; -import java.rmi.server.RemoteObject; -import java.rmi.server.RemoteObjectInvocationHandler; -import java.rmi.server.RemoteRef; -import java.rmi.server.UID; -import java.security.AccessControlContext; -import java.security.AccessController; -import java.security.Permissions; -import java.security.PrivilegedActionException; -import java.security.PrivilegedExceptionAction; -import java.security.ProtectionDomain; - -/** - * Activation makes use of special identifiers to denote remote - * objects that can be activated over time. An activation identifier - * (an instance of the class ActivationID) contains several - * pieces of information needed for activating an object: - *

- * - * An activation identifier for an object can be obtained by registering - * an object with the activation system. Registration is accomplished - * in a few ways:

- * - * @author Ann Wollrath - * @see Activatable - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public class ActivationID implements Serializable { - /** - * the object's activator - */ - private transient Activator activator; - - /** - * the object's unique id - */ - private transient UID uid = new UID(); - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - @java.io.Serial - private static final long serialVersionUID = -4608673054848209235L; - - /** an AccessControlContext with no permissions */ - private static final AccessControlContext NOPERMS_ACC; - static { - Permissions perms = new Permissions(); - ProtectionDomain[] pd = { new ProtectionDomain(null, perms) }; - NOPERMS_ACC = new AccessControlContext(pd); - } - - /** - * The constructor for ActivationID takes a single - * argument, activator, that specifies a remote reference to the - * activator responsible for activating the object associated with - * this identifier. An instance of ActivationID is globally - * unique. - * - * @param activator reference to the activator responsible for - * activating the object - * @throws UnsupportedOperationException if and only if activation is - * not supported by this implementation - * @since 1.2 - */ - public ActivationID(Activator activator) { - this.activator = activator; - } - - /** - * Activate the object for this id. - * - * @param force if true, forces the activator to contact the group - * when activating the object (instead of returning a cached reference); - * if false, returning a cached value is acceptable. - * @return the reference to the active remote object - * @throws ActivationException if activation fails - * @throws UnknownObjectException if the object is unknown - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public Remote activate(boolean force) - throws ActivationException, UnknownObjectException, RemoteException - { - try { - MarshalledObject mobj = - activator.activate(this, force); - return AccessController.doPrivileged( - new PrivilegedExceptionAction() { - public Remote run() throws IOException, ClassNotFoundException { - return mobj.get(); - } - }, NOPERMS_ACC); - } catch (PrivilegedActionException pae) { - Exception ex = pae.getException(); - if (ex instanceof RemoteException) { - throw (RemoteException) ex; - } else { - throw new UnmarshalException("activation failed", ex); - } - } - - } - - /** - * Returns a hashcode for the activation id. Two identifiers that - * refer to the same remote object will have the same hash code. - * - * @see java.util.Hashtable - * @since 1.2 - */ - public int hashCode() { - return uid.hashCode(); - } - - /** - * Compares two activation ids for content equality. - * Returns true if both of the following conditions are true: - * 1) the unique identifiers equivalent (by content), and - * 2) the activator specified in each identifier - * refers to the same remote object. - * - * @param obj the Object to compare with - * @return true if these Objects are equal; false otherwise. - * @see java.util.Hashtable - * @since 1.2 - */ - public boolean equals(Object obj) { - if (obj instanceof ActivationID) { - ActivationID id = (ActivationID) obj; - return (uid.equals(id.uid) && activator.equals(id.activator)); - } else { - return false; - } - } - - /** - * writeObject for custom serialization. - * - *

This method writes this object's serialized form for - * this class as follows: - * - *

The writeObject method is invoked on - * out passing this object's unique identifier - * (a {@link java.rmi.server.UID UID} instance) as the argument. - * - *

Next, the {@link - * java.rmi.server.RemoteRef#getRefClass(java.io.ObjectOutput) - * getRefClass} method is invoked on the activator's - * RemoteRef instance to obtain its external ref - * type name. Next, the writeUTF method is - * invoked on out with the value returned by - * getRefClass, and then the - * writeExternal method is invoked on the - * RemoteRef instance passing out - * as the argument. - * - * @serialData The serialized data for this class comprises a - * java.rmi.server.UID (written with - * ObjectOutput.writeObject) followed by the - * external ref type name of the activator's - * RemoteRef instance (a string written with - * ObjectOutput.writeUTF), followed by the - * external form of the RemoteRef instance as - * written by its writeExternal method. - * - *

The external ref type name of the - * RemoteRef instance is - * determined using the definitions of external ref type - * names specified in the {@link java.rmi.server.RemoteObject - * RemoteObject} writeObject method - * serialData specification. Similarly, the data - * written by the writeExternal method and read - * by the readExternal method of - * RemoteRef implementation classes - * corresponding to each of the defined external ref type - * names is specified in the {@link - * java.rmi.server.RemoteObject RemoteObject} - * writeObject method serialData - * specification. - * - * @param out the {@code ObjectOutputStream} to which data is written - * @throws IOException if an I/O error occurs - **/ - @java.io.Serial - private void writeObject(ObjectOutputStream out) - throws IOException - { - out.writeObject(uid); - - RemoteRef ref; - if (activator instanceof RemoteObject) { - ref = ((RemoteObject) activator).getRef(); - } else if (Proxy.isProxyClass(activator.getClass())) { - InvocationHandler handler = Proxy.getInvocationHandler(activator); - if (!(handler instanceof RemoteObjectInvocationHandler)) { - throw new InvalidObjectException( - "unexpected invocation handler"); - } - ref = ((RemoteObjectInvocationHandler) handler).getRef(); - - } else { - throw new InvalidObjectException("unexpected activator type"); - } - out.writeUTF(ref.getRefClass(out)); - ref.writeExternal(out); - } - - /** - * readObject for custom serialization. - * - *

This method reads this object's serialized form for this - * class as follows: - * - *

The readObject method is invoked on - * in to read this object's unique identifier - * (a {@link java.rmi.server.UID UID} instance). - * - *

Next, the readUTF method is invoked on - * in to read the external ref type name of the - * RemoteRef instance for this object's - * activator. Next, the RemoteRef - * instance is created of an implementation-specific class - * corresponding to the external ref type name (returned by - * readUTF), and the readExternal - * method is invoked on that RemoteRef instance - * to read the external form corresponding to the external - * ref type name. - * - *

Note: If the external ref type name is - * "UnicastRef", "UnicastServerRef", - * "UnicastRef2", "UnicastServerRef2", - * or "ActivatableRef", a corresponding - * implementation-specific class must be found, and its - * readExternal method must read the serial data - * for that external ref type name as specified to be written - * in the serialData documentation for this class. - * If the external ref type name is any other string (of non-zero - * length), a ClassNotFoundException will be thrown, - * unless the implementation provides an implementation-specific - * class corresponding to that external ref type name, in which - * case the RemoteRef will be an instance of - * that implementation-specific class. - * - * @param in the {@code ObjectInputStream} from which data is read - * @throws IOException if an I/O error occurs - * @throws ClassNotFoundException if a serialized class cannot be loaded - * - */ - @java.io.Serial - private void readObject(ObjectInputStream in) - throws IOException, ClassNotFoundException - { - uid = (UID)in.readObject(); - - try { - Class refClass = - Class.forName(RemoteRef.packagePrefix + "." + in.readUTF()) - .asSubclass(RemoteRef.class); - @SuppressWarnings("deprecation") - RemoteRef ref = refClass.newInstance(); - ref.readExternal(in); - activator = (Activator) - Proxy.newProxyInstance(Activator.class.getClassLoader(), - new Class[] { Activator.class }, - new RemoteObjectInvocationHandler(ref)); - } catch (InstantiationException e) { - throw (IOException) - new InvalidObjectException( - "Unable to create remote reference").initCause(e); - } catch (IllegalAccessException e) { - throw (IOException) - new InvalidObjectException( - "Unable to create remote reference").initCause(e); - } - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationInstantiator.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationInstantiator.java deleted file mode 100644 index 9c2c6f43538..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationInstantiator.java +++ /dev/null @@ -1,94 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; - -/** - * An ActivationInstantiator is responsible for creating - * instances of "activatable" objects. A concrete subclass of - * ActivationGroup implements the newInstance - * method to handle creating objects within the group. - * - * @author Ann Wollrath - * @see ActivationGroup - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public interface ActivationInstantiator extends Remote { - - /** - * The activator calls an instantiator's newInstance - * method in order to recreate in that group an object with the - * activation identifier, id, and descriptor, - * desc. The instantiator is responsible for:

- * - *

In order for activation to be successful, one of the following requirements - * must be met, otherwise {@link ActivationException} is thrown: - * - *

- * - * @param id the object's activation identifier - * @param desc the object's descriptor - * @return a marshalled object containing the serialized - * representation of remote object's stub - * @throws ActivationException if object activation fails - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public MarshalledObject newInstance(ActivationID id, - ActivationDesc desc) - throws ActivationException, RemoteException; -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationMonitor.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationMonitor.java deleted file mode 100644 index f9e8385a2ac..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationMonitor.java +++ /dev/null @@ -1,113 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.UnknownGroupException; -import java.rmi.activation.UnknownObjectException; - -/** - * An ActivationMonitor is specific to an - * ActivationGroup and is obtained when a group is - * reported active via a call to - * ActivationSystem.activeGroup (this is done - * internally). An activation group is responsible for informing its - * ActivationMonitor when either: its objects become active or - * inactive, or the group as a whole becomes inactive. - * - * @author Ann Wollrath - * @see Activator - * @see ActivationSystem - * @see ActivationGroup - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public interface ActivationMonitor extends Remote { - - /** - * An activation group calls its monitor's - * inactiveObject method when an object in its group - * becomes inactive (deactivates). An activation group discovers - * that an object (that it participated in activating) in its VM - * is no longer active, via calls to the activation group's - * inactiveObject method.

- * - * The inactiveObject call informs the - * ActivationMonitor that the remote object reference - * it holds for the object with the activation identifier, - * id, is no longer valid. The monitor considers the - * reference associated with id as a stale reference. - * Since the reference is considered stale, a subsequent - * activate call for the same activation identifier - * results in re-activating the remote object. - * - * @param id the object's activation identifier - * @throws UnknownObjectException if object is unknown - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public void inactiveObject(ActivationID id) - throws UnknownObjectException, RemoteException; - - /** - * Informs that an object is now active. An ActivationGroup - * informs its monitor if an object in its group becomes active by - * other means than being activated directly (i.e., the object - * is registered and "activated" itself). - * - * @param id the active object's id - * @param obj the marshalled form of the object's stub - * @throws UnknownObjectException if object is unknown - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public void activeObject(ActivationID id, - MarshalledObject obj) - throws UnknownObjectException, RemoteException; - - /** - * Informs that the group is now inactive. The group will be - * recreated upon a subsequent request to activate an object - * within the group. A group becomes inactive when all objects - * in the group report that they are inactive. - * - * @param id the group's id - * @param incarnation the group's incarnation number - * @throws UnknownGroupException if group is unknown - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public void inactiveGroup(ActivationGroupID id, - long incarnation) - throws UnknownGroupException, RemoteException; - -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/ActivationSystem.java b/src/java.rmi/share/classes/java/rmi/activation/ActivationSystem.java deleted file mode 100644 index 2a7da67ab3c..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/ActivationSystem.java +++ /dev/null @@ -1,234 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.UnknownGroupException; -import java.rmi.activation.UnknownObjectException; - -/** - * The ActivationSystem provides a means for registering - * groups and "activatable" objects to be activated within those groups. - * The ActivationSystem works closely with the - * Activator, which activates objects registered via the - * ActivationSystem, and the ActivationMonitor, - * which obtains information about active and inactive objects, - * and inactive groups. - * - * @author Ann Wollrath - * @see Activator - * @see ActivationMonitor - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public interface ActivationSystem extends Remote { - - /** The port to lookup the activation system. */ - public static final int SYSTEM_PORT = 1098; - - /** - * The registerObject method is used to register an - * activation descriptor, desc, and obtain an - * activation identifier for a activatable remote object. The - * ActivationSystem creates an - * ActivationID (a activation identifier) for the - * object specified by the descriptor, desc, and - * records, in stable storage, the activation descriptor and its - * associated identifier for later use. When the Activator - * receives an activate request for a specific identifier, it - * looks up the activation descriptor (registered previously) for - * the specified identifier and uses that information to activate - * the object. - * - * @param desc the object's activation descriptor - * @return the activation id that can be used to activate the object - * @throws ActivationException if registration fails (e.g., database - * update failure, etc). - * @throws UnknownGroupException if group referred to in - * desc is not registered with this system - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public ActivationID registerObject(ActivationDesc desc) - throws ActivationException, UnknownGroupException, RemoteException; - - /** - * Remove the activation id and associated descriptor previously - * registered with the ActivationSystem; the object - * can no longer be activated via the object's activation id. - * - * @param id the object's activation id (from previous registration) - * @throws ActivationException if unregister fails (e.g., database - * update failure, etc). - * @throws UnknownObjectException if object is unknown (not registered) - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public void unregisterObject(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException; - - /** - * Register the activation group. An activation group must be - * registered with the ActivationSystem before objects - * can be registered within that group. - * - * @param desc the group's descriptor - * @return an identifier for the group - * @throws ActivationException if group registration fails - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public ActivationGroupID registerGroup(ActivationGroupDesc desc) - throws ActivationException, RemoteException; - - /** - * Callback to inform activation system that group is now - * active. This call is made internally by the - * ActivationGroup.createGroup method to inform - * the ActivationSystem that the group is now - * active. - * - * @param id the activation group's identifier - * @param group the group's instantiator - * @param incarnation the group's incarnation number - * @return monitor for activation group - * @throws UnknownGroupException if group is not registered - * @throws ActivationException if a group for the specified - * id is already active and that group is not equal - * to the specified group or that group has a different - * incarnation than the specified group - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public ActivationMonitor activeGroup(ActivationGroupID id, - ActivationInstantiator group, - long incarnation) - throws UnknownGroupException, ActivationException, RemoteException; - - /** - * Remove the activation group. An activation group makes this call back - * to inform the activator that the group should be removed (destroyed). - * If this call completes successfully, objects can no longer be - * registered or activated within the group. All information of the - * group and its associated objects is removed from the system. - * - * @param id the activation group's identifier - * @throws ActivationException if unregister fails (e.g., database - * update failure, etc). - * @throws UnknownGroupException if group is not registered - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public void unregisterGroup(ActivationGroupID id) - throws ActivationException, UnknownGroupException, RemoteException; - - /** - * Shutdown the activation system. Destroys all groups spawned by - * the activation daemon and exits the activation daemon. - * @throws RemoteException if failed to contact/shutdown the activation - * daemon - * @since 1.2 - */ - public void shutdown() throws RemoteException; - - /** - * Set the activation descriptor, desc for the object with - * the activation identifier, id. The change will take - * effect upon subsequent activation of the object. - * - * @param id the activation identifier for the activatable object - * @param desc the activation descriptor for the activatable object - * @throws UnknownGroupException the group associated with - * desc is not a registered group - * @throws UnknownObjectException the activation id - * is not registered - * @throws ActivationException for general failure (e.g., unable - * to update log) - * @throws RemoteException if remote call fails - * @return the previous value of the activation descriptor - * @see #getActivationDesc - * @since 1.2 - */ - public ActivationDesc setActivationDesc(ActivationID id, - ActivationDesc desc) - throws ActivationException, UnknownObjectException, - UnknownGroupException, RemoteException; - - /** - * Set the activation group descriptor, desc for the object - * with the activation group identifier, id. The change will - * take effect upon subsequent activation of the group. - * - * @param id the activation group identifier for the activation group - * @param desc the activation group descriptor for the activation group - * @throws UnknownGroupException the group associated with - * id is not a registered group - * @throws ActivationException for general failure (e.g., unable - * to update log) - * @throws RemoteException if remote call fails - * @return the previous value of the activation group descriptor - * @see #getActivationGroupDesc - * @since 1.2 - */ - public ActivationGroupDesc setActivationGroupDesc(ActivationGroupID id, - ActivationGroupDesc desc) - throws ActivationException, UnknownGroupException, RemoteException; - - /** - * Returns the activation descriptor, for the object with the activation - * identifier, id. - * - * @param id the activation identifier for the activatable object - * @throws UnknownObjectException if id is not registered - * @throws ActivationException for general failure - * @throws RemoteException if remote call fails - * @return the activation descriptor - * @see #setActivationDesc - * @since 1.2 - */ - public ActivationDesc getActivationDesc(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException; - - /** - * Returns the activation group descriptor, for the group - * with the activation group identifier, id. - * - * @param id the activation group identifier for the group - * @throws UnknownGroupException if id is not registered - * @throws ActivationException for general failure - * @throws RemoteException if remote call fails - * @return the activation group descriptor - * @see #setActivationGroupDesc - * @since 1.2 - */ - public ActivationGroupDesc getActivationGroupDesc(ActivationGroupID id) - throws ActivationException, UnknownGroupException, RemoteException; -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/Activator.java b/src/java.rmi/share/classes/java/rmi/activation/Activator.java deleted file mode 100644 index b80ee6fa7b0..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/Activator.java +++ /dev/null @@ -1,119 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.UnknownObjectException; - -/** - * The Activator facilitates remote object activation. A - * "faulting" remote reference calls the activator's - * activate method to obtain a "live" reference to a - * "activatable" remote object. Upon receiving a request for activation, - * the activator looks up the activation descriptor for the activation - * identifier, id, determines the group in which the - * object should be activated initiates object re-creation via the - * group's ActivationInstantiator (via a call to the - * newInstance method). The activator initiates the - * execution of activation groups as necessary. For example, if an - * activation group for a specific group identifier is not already - * executing, the activator initiates the execution of a VM for the - * group.

- * - * The Activator works closely with - * ActivationSystem, which provides a means for registering - * groups and objects within those groups, and ActivationMonitor, - * which receives information about active and inactive objects and inactive - * groups.

- * - * The activator is responsible for monitoring and detecting when - * activation groups fail so that it can remove stale remote references - * to groups and active object's within those groups. - * - * @author Ann Wollrath - * @see ActivationInstantiator - * @see ActivationGroupDesc - * @see ActivationGroupID - * @since 1.2 - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public interface Activator extends Remote { - /** - * Activate the object associated with the activation identifier, - * id. If the activator knows the object to be active - * already, and force is false , the stub with a - * "live" reference is returned immediately to the caller; - * otherwise, if the activator does not know that corresponding - * the remote object is active, the activator uses the activation - * descriptor information (previously registered) to determine the - * group (VM) in which the object should be activated. If an - * ActivationInstantiator corresponding to the - * object's group descriptor already exists, the activator invokes - * the activation group's newInstance method passing - * it the object's id and descriptor.

- * - * If the activation group for the object's group descriptor does - * not yet exist, the activator starts an - * ActivationInstantiator executing (by spawning a - * child process, for example). When the activator receives the - * activation group's call back (via the - * ActivationSystem's activeGroup - * method) specifying the activation group's reference, the - * activator can then invoke that activation instantiator's - * newInstance method to forward each pending - * activation request to the activation group and return the - * result (a marshalled remote object reference, a stub) to the - * caller.

- * - * Note that the activator receives a "marshalled" object instead of a - * Remote object so that the activator does not need to load the - * code for that object, or participate in distributed garbage - * collection for that object. If the activator kept a strong - * reference to the remote object, the activator would then - * prevent the object from being garbage collected under the - * normal distributed garbage collection mechanism. - * - * @param id the activation identifier for the object being activated - * @param force if true, the activator contacts the group to obtain - * the remote object's reference; if false, returning the cached value - * is allowed. - * @return the remote object (a stub) in a marshalled form - * @throws ActivationException if object activation fails - * @throws UnknownObjectException if object is unknown (not registered) - * @throws RemoteException if remote call fails - * @since 1.2 - */ - public MarshalledObject activate(ActivationID id, - boolean force) - throws ActivationException, UnknownObjectException, RemoteException; - -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/UnknownGroupException.java b/src/java.rmi/share/classes/java/rmi/activation/UnknownGroupException.java deleted file mode 100644 index 09579abcbc9..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/UnknownGroupException.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -/** - * An UnknownGroupException is thrown by methods of classes and - * interfaces in the java.rmi.activation package when the - * ActivationGroupID parameter to the method is determined to be - * invalid, i.e., not known by the ActivationSystem. An - * UnknownGroupException is also thrown if the - * ActivationGroupID in an ActivationDesc refers to - * a group that is not registered with the ActivationSystem - * - * @author Ann Wollrath - * @since 1.2 - * @see java.rmi.activation.Activatable - * @see java.rmi.activation.ActivationGroup - * @see java.rmi.activation.ActivationGroupID - * @see java.rmi.activation.ActivationMonitor - * @see java.rmi.activation.ActivationSystem - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public class UnknownGroupException extends ActivationException { - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = 7056094974750002460L; - - /** - * Constructs an UnknownGroupException with the specified - * detail message. - * - * @param s the detail message - * @since 1.2 - */ - public UnknownGroupException(String s) { - super(s); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/UnknownObjectException.java b/src/java.rmi/share/classes/java/rmi/activation/UnknownObjectException.java deleted file mode 100644 index b3da527259b..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/UnknownObjectException.java +++ /dev/null @@ -1,67 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package java.rmi.activation; - -/** - * An UnknownObjectException is thrown by methods of classes and - * interfaces in the java.rmi.activation package when the - * ActivationID parameter to the method is determined to be - * invalid. An ActivationID is invalid if it is not currently - * known by the ActivationSystem. An ActivationID - * is obtained by the ActivationSystem.registerObject method. - * An ActivationID is also obtained during the - * Activatable.register call. - * - * @author Ann Wollrath - * @since 1.2 - * @see java.rmi.activation.Activatable - * @see java.rmi.activation.ActivationGroup - * @see java.rmi.activation.ActivationID - * @see java.rmi.activation.ActivationMonitor - * @see java.rmi.activation.ActivationSystem - * @see java.rmi.activation.Activator - * @deprecated - * See the - * {@code java.rmi.activation} package specification for further information. - */ -@Deprecated(forRemoval=true, since="15") -@SuppressWarnings("removal") -public class UnknownObjectException extends ActivationException { - - /** indicate compatibility with the Java 2 SDK v1.2 version of class */ - private static final long serialVersionUID = 3425547551622251430L; - - /** - * Constructs an UnknownObjectException with the specified - * detail message. - * - * @param s the detail message - * @since 1.2 - */ - public UnknownObjectException(String s) { - super(s); - } -} diff --git a/src/java.rmi/share/classes/java/rmi/activation/package-info.java b/src/java.rmi/share/classes/java/rmi/activation/package-info.java deleted file mode 100644 index 1c5a862fbf4..00000000000 --- a/src/java.rmi/share/classes/java/rmi/activation/package-info.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * Provides support for RMI Object Activation. A remote - * object's reference can be made ``persistent'' and later activated into a - * ``live'' object using the RMI activation mechanism. - * - *

Implementations are not required to support the activation - * mechanism. If activation is not supported by this implementation, - * several specific activation API methods are all required to throw - * {@code UnsupportedOperationException}. If activation is supported by this - * implementation, these methods must never throw {@code - * UnsupportedOperationException}. These methods are denoted by the - * presence of an entry for {@code UnsupportedOperationException} in the - * Throws section of each method's specification. - * - * @since 1.2 - * @deprecated The RMI Activation mechanism has been deprecated and may - * be removed from a future version of the Java Platform. All of the classes - * and interfaces in this package have been terminally deprecated. The - * {@code rmid} tool has also been terminally deprecated. There is no - * replacement for the RMI Activation mechanism in the Java Platform. Users of - * RMI Activation are advised to migrate their applications to other technologies. - */ -package java.rmi.activation; diff --git a/src/java.rmi/share/classes/java/rmi/server/ExportException.java b/src/java.rmi/share/classes/java/rmi/server/ExportException.java index 6f5714c7f9f..eaa293264fc 100644 --- a/src/java.rmi/share/classes/java/rmi/server/ExportException.java +++ b/src/java.rmi/share/classes/java/rmi/server/ExportException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -29,13 +29,11 @@ package java.rmi.server; * An ExportException is a RemoteException * thrown if an attempt to export a remote object fails. A remote object is * exported via the constructors and exportObject methods of - * java.rmi.server.UnicastRemoteObject and - * java.rmi.activation.Activatable. + * java.rmi.server.UnicastRemoteObject. * * @author Ann Wollrath * @since 1.1 * @see java.rmi.server.UnicastRemoteObject - * @see java.rmi.activation.Activatable */ public class ExportException extends java.rmi.RemoteException { diff --git a/src/java.rmi/share/classes/java/rmi/server/RMIClientSocketFactory.java b/src/java.rmi/share/classes/java/rmi/server/RMIClientSocketFactory.java index 4616fad9eac..576345f74b7 100644 --- a/src/java.rmi/share/classes/java/rmi/server/RMIClientSocketFactory.java +++ b/src/java.rmi/share/classes/java/rmi/server/RMIClientSocketFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,8 +33,7 @@ import java.net.*; * in order to obtain client sockets for RMI calls. A remote object can be * associated with an RMIClientSocketFactory when it is * created/exported via the constructors or exportObject methods - * of java.rmi.server.UnicastRemoteObject and - * java.rmi.activation.Activatable . + * of java.rmi.server.UnicastRemoteObject. * *

An RMIClientSocketFactory instance associated with a remote * object will be downloaded to clients when the remote object's reference is @@ -56,7 +55,6 @@ import java.net.*; * @author Peter Jones * @since 1.2 * @see java.rmi.server.UnicastRemoteObject - * @see java.rmi.activation.Activatable * @see java.rmi.registry.LocateRegistry */ public interface RMIClientSocketFactory { diff --git a/src/java.rmi/share/classes/java/rmi/server/RMIServerSocketFactory.java b/src/java.rmi/share/classes/java/rmi/server/RMIServerSocketFactory.java index 9cadf5501fb..7cda09a5992 100644 --- a/src/java.rmi/share/classes/java/rmi/server/RMIServerSocketFactory.java +++ b/src/java.rmi/share/classes/java/rmi/server/RMIServerSocketFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,8 +33,7 @@ import java.net.*; * in order to obtain server sockets for RMI calls. A remote object can be * associated with an RMIServerSocketFactory when it is * created/exported via the constructors or exportObject methods - * of java.rmi.server.UnicastRemoteObject and - * java.rmi.activation.Activatable . + * of java.rmi.server.UnicastRemoteObject. * *

An RMIServerSocketFactory instance associated with a remote * object is used to obtain the ServerSocket used to accept @@ -55,7 +54,6 @@ import java.net.*; * @author Peter Jones * @since 1.2 * @see java.rmi.server.UnicastRemoteObject - * @see java.rmi.activation.Activatable * @see java.rmi.registry.LocateRegistry */ public interface RMIServerSocketFactory { diff --git a/src/java.rmi/share/classes/java/rmi/server/RemoteObject.java b/src/java.rmi/share/classes/java/rmi/server/RemoteObject.java index 98df3e716c4..4bf8367865e 100644 --- a/src/java.rmi/share/classes/java/rmi/server/RemoteObject.java +++ b/src/java.rmi/share/classes/java/rmi/server/RemoteObject.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -212,12 +212,6 @@ public abstract class RemoteObject implements Remote, java.io.Serializable { * * If this object is an instance of * RemoteStub or RemoteObjectInvocationHandler - * that was returned from any of - * the java.rmi.activation.Activatable.exportObject methods, - * the external ref type name is "ActivatableRef". - * - * If this object is an instance of - * RemoteStub or RemoteObjectInvocationHandler * that was returned from * the RemoteObject.toStub method (and the argument passed * to toStub was not itself a RemoteStub), @@ -318,43 +312,6 @@ public abstract class RemoteObject implements Remote, java.io.Serializable { * * * - *

For "ActivatableRef" with a - * null nested remote reference: - * - *

- * - *

For "ActivatableRef" with a - * non-null nested remote reference: - * - *

- * *

For "UnicastServerRef" and * "UnicastServerRef2", no data is written by the * writeExternal method or read by the @@ -412,8 +369,8 @@ public abstract class RemoteObject implements Remote, java.io.Serializable { * *

If the external ref type name is * "UnicastRef", "UnicastServerRef", - * "UnicastRef2", "UnicastServerRef2", - * or "ActivatableRef", a corresponding + * "UnicastRef2", or "UnicastServerRef2", + * a corresponding * implementation-specific class must be found, and its * readExternal method must read the serial data * for that external ref type name as specified to be written diff --git a/src/java.rmi/share/classes/java/rmi/server/RemoteObjectInvocationHandler.java b/src/java.rmi/share/classes/java/rmi/server/RemoteObjectInvocationHandler.java index e1944f618ac..68d04f10e40 100644 --- a/src/java.rmi/share/classes/java/rmi/server/RemoteObjectInvocationHandler.java +++ b/src/java.rmi/share/classes/java/rmi/server/RemoteObjectInvocationHandler.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -31,7 +31,6 @@ import java.lang.reflect.Proxy; import java.rmi.Remote; import java.rmi.RemoteException; import java.rmi.UnexpectedException; -import java.rmi.activation.Activatable; import java.util.Map; import java.util.WeakHashMap; import sun.rmi.server.Util; @@ -45,8 +44,7 @@ import sun.rmi.server.WeakClassHashMap; * *

Applications are not expected to use this class directly. A remote * object exported to use a dynamic proxy with {@link UnicastRemoteObject} - * or {@link Activatable} has an instance of this class as that proxy's - * invocation handler. + * has an instance of this class as that proxy's invocation handler. * * @author Ann Wollrath * @since 1.5 diff --git a/src/java.rmi/share/classes/module-info.java b/src/java.rmi/share/classes/module-info.java index 99da4f73c5c..96b61a172ff 100644 --- a/src/java.rmi/share/classes/module-info.java +++ b/src/java.rmi/share/classes/module-info.java @@ -28,16 +28,9 @@ * *

The JDK implementation of this module includes * the {@index rmiregistry rmiregistry tool} tool to start a remote - * object registry, and the {@index rmid rmid tool} tool to start - * the activation system daemon. - * - *

Deprecation Notice: The RMI Activation mechanism has been - * deprecated and may be removed from a future version of the Java Platform. See the - * - * {@code java.rmi.activation} package specification for further information. + * object registry. * * @toolGuide rmiregistry - * @toolGuide rmid * * @uses java.rmi.server.RMIClassLoaderSpi * @@ -48,15 +41,11 @@ module java.rmi { requires java.logging; exports java.rmi; - exports java.rmi.activation; exports java.rmi.dgc; exports java.rmi.registry; exports java.rmi.server; exports javax.rmi.ssl; - // com.sun.rmi.rmid contains permissions classes that must be - // accessible to the security manager at initialization time - exports com.sun.rmi.rmid to java.base; exports sun.rmi.registry to jdk.management.agent; exports sun.rmi.server to diff --git a/src/java.rmi/share/classes/sun/rmi/registry/RegistryImpl.java b/src/java.rmi/share/classes/sun/rmi/registry/RegistryImpl.java index 223986f4c27..95f4a9f72c3 100644 --- a/src/java.rmi/share/classes/sun/rmi/registry/RegistryImpl.java +++ b/src/java.rmi/share/classes/sun/rmi/registry/RegistryImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -464,7 +464,6 @@ public class RegistryImpl extends java.rmi.server.RemoteServer || UnicastRef.class.isAssignableFrom(clazz) || RMIClientSocketFactory.class.isAssignableFrom(clazz) || RMIServerSocketFactory.class.isAssignableFrom(clazz) - || java.rmi.activation.ActivationID.class.isAssignableFrom(clazz) || java.rmi.server.UID.class.isAssignableFrom(clazz)) { return ObjectInputFilter.Status.ALLOWED; } else { diff --git a/src/java.rmi/share/classes/sun/rmi/server/ActivatableRef.java b/src/java.rmi/share/classes/sun/rmi/server/ActivatableRef.java deleted file mode 100644 index 14f4c211800..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/ActivatableRef.java +++ /dev/null @@ -1,411 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.io.IOException; -import java.io.ObjectInput; -import java.io.ObjectOutput; -import java.lang.reflect.Proxy; -import java.net.MalformedURLException; -import java.net.URL; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.Operation; -import java.rmi.server.RMIClassLoader; -import java.rmi.server.RemoteCall; -import java.rmi.server.RemoteObject; -import java.rmi.server.RemoteObjectInvocationHandler; -import java.rmi.server.RemoteRef; -import java.rmi.server.RemoteStub; - -@SuppressWarnings({"deprecation", "removal"}) -public class ActivatableRef implements RemoteRef { - - private static final long serialVersionUID = 7579060052569229166L; - - protected ActivationID id; - protected RemoteRef ref; - transient boolean force = false; - - private static final int MAX_RETRIES = 3; - private static final String versionComplaint = - "activation requires 1.2 stubs"; - - /** - * Create a new (empty) ActivatableRef - */ - public ActivatableRef() - {} - - /** - * Create a ActivatableRef with the specified id - */ - public ActivatableRef(ActivationID id, RemoteRef ref) - { - this.id = id; - this.ref = ref; - } - - /** - * Returns the stub for the remote object whose class is - * specified in the activation descriptor. The ActivatableRef - * in the resulting stub has its activation id set to the - * activation id supplied as the second argument. - */ - public static Remote getStub(ActivationDesc desc, ActivationID id) - throws StubNotFoundException - { - String className = desc.getClassName(); - - try { - Class cl = - RMIClassLoader.loadClass(desc.getLocation(), className); - RemoteRef clientRef = new ActivatableRef(id, null); - return Util.createProxy(cl, clientRef, false); - - } catch (IllegalArgumentException e) { - throw new StubNotFoundException( - "class implements an illegal remote interface", e); - - } catch (ClassNotFoundException e) { - throw new StubNotFoundException("unable to load class: " + - className, e); - } catch (MalformedURLException e) { - throw new StubNotFoundException("malformed URL", e); - } - } - - /** - * Invoke method on remote object. This method delegates remote - * method invocation to the underlying ref type. If the - * underlying reference is not known (is null), then the object - * must be activated first. If an attempt at method invocation - * fails, the object should force reactivation. Method invocation - * must preserve "at most once" call semantics. In RMI, "at most - * once" applies to parameter deserialization at the remote site - * and the remote object's method execution. "At most once" does - * not apply to parameter serialization at the client so the - * parameters of a call don't need to be buffered in anticipation - * of call retry. Thus, a method call is only be retried if the - * initial method invocation does not execute at all at the server - * (including parameter deserialization). - */ - public Object invoke(Remote obj, - java.lang.reflect.Method method, - Object[] params, - long opnum) - throws Exception - { - - boolean force = false; - RemoteRef localRef; - Exception exception = null; - - /* - * Attempt object activation if active ref is unknown. - * Throws a RemoteException if object can't be activated. - */ - synchronized (this) { - if (ref == null) { - localRef = activate(force); - force = true; - } else { - localRef = ref; - } - } - - for (int retries = MAX_RETRIES; retries > 0; retries--) { - - try { - return localRef.invoke(obj, method, params, opnum); - } catch (NoSuchObjectException e) { - /* - * Object is not active in VM; retry call - */ - exception = e; - } catch (ConnectException e) { - /* - * Failure during connection setup; retry call - */ - exception = e; - } catch (UnknownHostException e) { - /* - * Failure during connection setup; retry call. - */ - exception = e; - } catch (ConnectIOException e) { - /* - * Failure reusing cached connection; retry call - */ - exception = e; - } catch (MarshalException e) { - /* - * Failure during parameter serialization; call may - * have reached server, so call retry not possible. - */ - throw e; - } catch (ServerError e) { - /* - * Call reached server; propagate remote exception. - */ - throw e; - } catch (ServerException e) { - /* - * Call reached server; propagate remote exception - */ - throw e; - } catch (RemoteException e) { - /* - * This is a catch-all for other RemoteExceptions. - * UnmarshalException being the only one relevant. - * - * StubNotFoundException should never show up because - * it is generally thrown when attempting to locate - * a stub. - * - * UnexpectedException should never show up because - * it is only thrown by a stub and would be wrapped - * in a ServerException if it was propagated by a - * remote call. - */ - synchronized (this) { - if (localRef == ref) { - ref = null; // this may be overly conservative - } - } - - throw e; - } - - if (retries > 1) { - /* - * Activate object, since object could not be reached. - */ - synchronized (this) { - if (localRef.remoteEquals(ref) || ref == null) { - RemoteRef newRef = activate(force); - - if (newRef.remoteEquals(localRef) && - exception instanceof NoSuchObjectException && - force == false) { - /* - * If last exception was NoSuchObjectException, - * then old value of ref is definitely wrong, - * so make sure that it is different. - */ - newRef = activate(true); - } - - localRef = newRef; - force = true; - } else { - localRef = ref; - force = false; - } - } - } - } - - /* - * Retries unsuccessful, so throw last exception - */ - throw exception; - } - - /** - * private method to obtain the ref for a call. - */ - private synchronized RemoteRef getRef() - throws RemoteException - { - if (ref == null) { - ref = activate(false); - } - - return ref; - } - - /** - * private method to activate the remote object. - * - * NOTE: the caller must be synchronized on "this" before - * calling this method. - */ - private RemoteRef activate(boolean force) - throws RemoteException - { - assert Thread.holdsLock(this); - - ref = null; - try { - /* - * Activate the object and retrieve the remote reference - * from inside the stub returned as the result. Then - * set this activatable ref's internal ref to be the - * ref inside the ref of the stub. In more clear terms, - * the stub returned from the activate call contains an - * ActivatableRef. We need to set the ref in *this* - * ActivatableRef to the ref inside the ActivatableRef - * retrieved from the stub. The ref type embedded in the - * ActivatableRef is typically a UnicastRef. - */ - - Remote proxy = id.activate(force); - ActivatableRef newRef = null; - - if (proxy instanceof RemoteStub) { - newRef = (ActivatableRef) ((RemoteStub) proxy).getRef(); - } else { - /* - * Assume that proxy is an instance of a dynamic proxy - * class. If that assumption is not correct, or either of - * the casts below fails, the resulting exception will be - * wrapped in an ActivateFailedException below. - */ - RemoteObjectInvocationHandler handler = - (RemoteObjectInvocationHandler) - Proxy.getInvocationHandler(proxy); - newRef = (ActivatableRef) handler.getRef(); - } - ref = newRef.ref; - return ref; - - } catch (ConnectException e) { - throw new ConnectException("activation failed", e); - } catch (RemoteException e) { - throw new ConnectIOException("activation failed", e); - } catch (UnknownObjectException e) { - throw new NoSuchObjectException("object not registered"); - } catch (ActivationException e) { - throw new ActivateFailedException("activation failed", e); - } - } - - /** - * This call is used by the old 1.1 stub protocol and is - * unsupported since activation requires 1.2 stubs. - */ - public synchronized RemoteCall newCall(RemoteObject obj, - Operation[] ops, - int opnum, - long hash) - throws RemoteException - { - throw new UnsupportedOperationException(versionComplaint); - } - - /** - * This call is used by the old 1.1 stub protocol and is - * unsupported since activation requires 1.2 stubs. - */ - public void invoke(RemoteCall call) throws Exception - { - throw new UnsupportedOperationException(versionComplaint); - } - - /** - * This call is used by the old 1.1 stub protocol and is - * unsupported since activation requires 1.2 stubs. - */ - public void done(RemoteCall call) throws RemoteException { - throw new UnsupportedOperationException(versionComplaint); - } - - /** - * Returns the class of the ref type to be serialized - */ - public String getRefClass(ObjectOutput out) - { - return "ActivatableRef"; - } - - /** - * Write out external representation for remote ref. - */ - public void writeExternal(ObjectOutput out) throws IOException - { - RemoteRef localRef = ref; - - out.writeObject(id); - if (localRef == null) { - out.writeUTF(""); - } else { - out.writeUTF(localRef.getRefClass(out)); - localRef.writeExternal(out); - } - } - - /** - * Read in external representation for remote ref. - * @exception ClassNotFoundException If the class for an object - * being restored cannot be found. - */ - public void readExternal(ObjectInput in) - throws IOException, ClassNotFoundException - { - id = (ActivationID)in.readObject(); - ref = null; - String className = in.readUTF(); - - if (className.isEmpty()) return; - - try { - Class refClass = Class.forName(RemoteRef.packagePrefix + "." + - className); - ref = (RemoteRef)refClass.newInstance(); - ref.readExternal(in); - } catch (InstantiationException e) { - throw new UnmarshalException("Unable to create remote reference", - e); - } catch (IllegalAccessException e) { - throw new UnmarshalException("Illegal access creating remote reference"); - } - } - - //----------------------------------------------------------------------; - /** - * Method from object, forward from RemoteObject - */ - public String remoteToString() { - return Util.getUnqualifiedName(getClass()) + - " [remoteRef: " + ref + "]"; - } - - /** - * default implementation of hashCode for remote objects - */ - public int remoteHashCode() { - return id.hashCode(); - } - - /** default implementation of equals for remote objects - */ - public boolean remoteEquals(RemoteRef ref) { - if (ref instanceof ActivatableRef) - return id.equals(((ActivatableRef)ref).id); - return false; - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/ActivatableServerRef.java b/src/java.rmi/share/classes/sun/rmi/server/ActivatableServerRef.java deleted file mode 100644 index 4640994f0a9..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/ActivatableServerRef.java +++ /dev/null @@ -1,94 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.io.IOException; -import java.io.NotSerializableException; -import java.io.ObjectOutput; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.ActivationID; -import sun.rmi.transport.LiveRef; - -/** - * Server-side ref for a persistent remote impl. - * - * @author Ann Wollrath - */ -@SuppressWarnings({"removal", "serial"}) // Externalizable class w/o no-arg c'tor -public class ActivatableServerRef extends UnicastServerRef2 { - - private static final long serialVersionUID = 2002967993223003793L; - - private ActivationID id; - - /** - * Construct a Unicast server remote reference to be exported - * on the specified port. - */ - public ActivatableServerRef(ActivationID id, int port) - { - this(id, port, null, null); - } - - /** - * Construct a Unicast server remote reference to be exported - * on the specified port. - */ - public ActivatableServerRef(ActivationID id, int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf) - { - super(new LiveRef(port, csf, ssf)); - this.id = id; - } - - /** - * Returns the class of the ref type to be serialized - */ - public String getRefClass(ObjectOutput out) - { - return "ActivatableServerRef"; - } - - /** - * Return the client remote reference for this remoteRef. - * In the case of a client RemoteRef "this" is the answer. - * For a server remote reference, a client side one will have to - * found or created. - */ - protected RemoteRef getClientRef() { - return new ActivatableRef(id, new UnicastRef2(ref)); - } - - /** - * Prevents serialization (because deserializaion is impossible). - */ - public void writeExternal(ObjectOutput out) throws IOException { - throw new NotSerializableException( - "ActivatableServerRef not serializable"); - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/Activation$ActivationSystemImpl_Stub.java b/src/java.rmi/share/classes/sun/rmi/server/Activation$ActivationSystemImpl_Stub.java deleted file mode 100644 index 5b988ee963f..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/Activation$ActivationSystemImpl_Stub.java +++ /dev/null @@ -1,239 +0,0 @@ -/* -* Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. -* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -* -* This code is free software; you can redistribute it and/or modify it -* under the terms of the GNU General Public License version 2 only, as -* published by the Free Software Foundation. Oracle designates this -* particular file as subject to the "Classpath" exception as provided -* by Oracle in the LICENSE file that accompanied this code. -* -* This code is distributed in the hope that it will be useful, but WITHOUT -* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -* version 2 for more details (a copy is included in the LICENSE file that -* accompanied this code). -* -* You should have received a copy of the GNU General Public License version -* 2 along with this work; if not, write to the Free Software Foundation, -* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -* -* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -* or visit www.oracle.com if you need additional information or have any -* questions. -*/ -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -package sun.rmi.server; - -/** - * Activation$ActivationSystemImpl_Stub. - */ -@SuppressWarnings({"deprecation", "rawtypes", "removal", "unchecked"}) -public final class Activation$ActivationSystemImpl_Stub - extends java.rmi.server.RemoteStub - implements java.rmi.activation.ActivationSystem, java.rmi.Remote { - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_activeGroup_0; - private static java.lang.reflect.Method $method_getActivationDesc_1; - private static java.lang.reflect.Method $method_getActivationGroupDesc_2; - private static java.lang.reflect.Method $method_registerGroup_3; - private static java.lang.reflect.Method $method_registerObject_4; - private static java.lang.reflect.Method $method_setActivationDesc_5; - private static java.lang.reflect.Method $method_setActivationGroupDesc_6; - private static java.lang.reflect.Method $method_shutdown_7; - private static java.lang.reflect.Method $method_unregisterGroup_8; - private static java.lang.reflect.Method $method_unregisterObject_9; - - static { - try { - $method_activeGroup_0 = java.rmi.activation.ActivationSystem.class.getMethod("activeGroup", new java.lang.Class[]{java.rmi.activation.ActivationGroupID.class, java.rmi.activation.ActivationInstantiator.class, long.class}); - $method_getActivationDesc_1 = java.rmi.activation.ActivationSystem.class.getMethod("getActivationDesc", new java.lang.Class[]{java.rmi.activation.ActivationID.class}); - $method_getActivationGroupDesc_2 = java.rmi.activation.ActivationSystem.class.getMethod("getActivationGroupDesc", new java.lang.Class[]{java.rmi.activation.ActivationGroupID.class}); - $method_registerGroup_3 = java.rmi.activation.ActivationSystem.class.getMethod("registerGroup", new java.lang.Class[]{java.rmi.activation.ActivationGroupDesc.class}); - $method_registerObject_4 = java.rmi.activation.ActivationSystem.class.getMethod("registerObject", new java.lang.Class[]{java.rmi.activation.ActivationDesc.class}); - $method_setActivationDesc_5 = java.rmi.activation.ActivationSystem.class.getMethod("setActivationDesc", new java.lang.Class[]{java.rmi.activation.ActivationID.class, java.rmi.activation.ActivationDesc.class}); - $method_setActivationGroupDesc_6 = java.rmi.activation.ActivationSystem.class.getMethod("setActivationGroupDesc", new java.lang.Class[]{java.rmi.activation.ActivationGroupID.class, java.rmi.activation.ActivationGroupDesc.class}); - $method_shutdown_7 = java.rmi.activation.ActivationSystem.class.getMethod("shutdown", new java.lang.Class[]{}); - $method_unregisterGroup_8 = java.rmi.activation.ActivationSystem.class.getMethod("unregisterGroup", new java.lang.Class[]{java.rmi.activation.ActivationGroupID.class}); - $method_unregisterObject_9 = java.rmi.activation.ActivationSystem.class.getMethod("unregisterObject", new java.lang.Class[]{java.rmi.activation.ActivationID.class}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public Activation$ActivationSystemImpl_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of activeGroup(ActivationGroupID, ActivationInstantiator, long) - public java.rmi.activation.ActivationMonitor activeGroup(java.rmi.activation.ActivationGroupID $param_ActivationGroupID_1, java.rmi.activation.ActivationInstantiator $param_ActivationInstantiator_2, long $param_long_3) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException { - try { - Object $result = ref.invoke(this, $method_activeGroup_0, new java.lang.Object[]{$param_ActivationGroupID_1, $param_ActivationInstantiator_2, new java.lang.Long($param_long_3)}, -4575843150759415294L); - return ((java.rmi.activation.ActivationMonitor) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of getActivationDesc(ActivationID) - public java.rmi.activation.ActivationDesc getActivationDesc(java.rmi.activation.ActivationID $param_ActivationID_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownObjectException { - try { - Object $result = ref.invoke(this, $method_getActivationDesc_1, new java.lang.Object[]{$param_ActivationID_1}, 4830055440982622087L); - return ((java.rmi.activation.ActivationDesc) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of getActivationGroupDesc(ActivationGroupID) - public java.rmi.activation.ActivationGroupDesc getActivationGroupDesc(java.rmi.activation.ActivationGroupID $param_ActivationGroupID_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException { - try { - Object $result = ref.invoke(this, $method_getActivationGroupDesc_2, new java.lang.Object[]{$param_ActivationGroupID_1}, -8701843806548736528L); - return ((java.rmi.activation.ActivationGroupDesc) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of registerGroup(ActivationGroupDesc) - public java.rmi.activation.ActivationGroupID registerGroup(java.rmi.activation.ActivationGroupDesc $param_ActivationGroupDesc_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException { - try { - Object $result = ref.invoke(this, $method_registerGroup_3, new java.lang.Object[]{$param_ActivationGroupDesc_1}, 6921515268192657754L); - return ((java.rmi.activation.ActivationGroupID) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of registerObject(ActivationDesc) - public java.rmi.activation.ActivationID registerObject(java.rmi.activation.ActivationDesc $param_ActivationDesc_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException { - try { - Object $result = ref.invoke(this, $method_registerObject_4, new java.lang.Object[]{$param_ActivationDesc_1}, -3006759798994351347L); - return ((java.rmi.activation.ActivationID) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of setActivationDesc(ActivationID, ActivationDesc) - public java.rmi.activation.ActivationDesc setActivationDesc(java.rmi.activation.ActivationID $param_ActivationID_1, java.rmi.activation.ActivationDesc $param_ActivationDesc_2) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException, java.rmi.activation.UnknownObjectException { - try { - Object $result = ref.invoke(this, $method_setActivationDesc_5, new java.lang.Object[]{$param_ActivationID_1, $param_ActivationDesc_2}, 7128043237057180796L); - return ((java.rmi.activation.ActivationDesc) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of setActivationGroupDesc(ActivationGroupID, ActivationGroupDesc) - public java.rmi.activation.ActivationGroupDesc setActivationGroupDesc(java.rmi.activation.ActivationGroupID $param_ActivationGroupID_1, java.rmi.activation.ActivationGroupDesc $param_ActivationGroupDesc_2) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException { - try { - Object $result = ref.invoke(this, $method_setActivationGroupDesc_6, new java.lang.Object[]{$param_ActivationGroupID_1, $param_ActivationGroupDesc_2}, 1213918527826541191L); - return ((java.rmi.activation.ActivationGroupDesc) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.rmi.RemoteException { - try { - ref.invoke(this, $method_shutdown_7, null, -7207851917985848402L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of unregisterGroup(ActivationGroupID) - public void unregisterGroup(java.rmi.activation.ActivationGroupID $param_ActivationGroupID_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownGroupException { - try { - ref.invoke(this, $method_unregisterGroup_8, new java.lang.Object[]{$param_ActivationGroupID_1}, 3768097077835970701L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of unregisterObject(ActivationID) - public void unregisterObject(java.rmi.activation.ActivationID $param_ActivationID_1) - throws java.rmi.RemoteException, java.rmi.activation.ActivationException, java.rmi.activation.UnknownObjectException { - try { - ref.invoke(this, $method_unregisterObject_9, new java.lang.Object[]{$param_ActivationID_1}, -6843850585331411084L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.rmi.activation.ActivationException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/Activation.java b/src/java.rmi/share/classes/sun/rmi/server/Activation.java deleted file mode 100644 index 9d615b95576..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/Activation.java +++ /dev/null @@ -1,2605 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.io.ByteArrayOutputStream; -import java.io.File; -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.InputStream; -import java.io.ObjectInput; -import java.io.ObjectInputStream; -import java.io.OutputStream; -import java.io.PrintStream; -import java.io.PrintWriter; -import java.io.Serializable; -import java.lang.Process; -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.net.InetAddress; -import java.net.ServerSocket; -import java.net.Socket; -import java.net.SocketAddress; -import java.net.SocketException; -import java.nio.file.Files; -import java.nio.channels.Channel; -import java.nio.channels.ServerSocketChannel; -import java.rmi.AccessException; -import java.rmi.AlreadyBoundException; -import java.rmi.ConnectException; -import java.rmi.ConnectIOException; -import java.rmi.MarshalledObject; -import java.rmi.NoSuchObjectException; -import java.rmi.NotBoundException; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.ActivationDesc; -import java.rmi.activation.ActivationException; -import java.rmi.activation.ActivationGroupDesc; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationID; -import java.rmi.activation.ActivationInstantiator; -import java.rmi.activation.ActivationMonitor; -import java.rmi.activation.ActivationSystem; -import java.rmi.activation.Activator; -import java.rmi.activation.UnknownGroupException; -import java.rmi.activation.UnknownObjectException; -import java.rmi.registry.Registry; -import java.rmi.server.ObjID; -import java.rmi.server.RMIClassLoader; -import java.rmi.server.RMIClientSocketFactory; -import java.rmi.server.RMIServerSocketFactory; -import java.rmi.server.RemoteObject; -import java.rmi.server.RemoteServer; -import java.rmi.server.UnicastRemoteObject; -import java.security.AccessControlException; -import java.security.AccessController; -import java.security.AllPermission; -import java.security.CodeSource; -import java.security.Permission; -import java.security.PermissionCollection; -import java.security.Permissions; -import java.security.Policy; -import java.security.PrivilegedAction; -import java.security.PrivilegedExceptionAction; -import java.security.cert.Certificate; -import java.text.MessageFormat; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Date; -import java.util.Enumeration; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.MissingResourceException; -import java.util.Properties; -import java.util.ResourceBundle; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import sun.rmi.log.LogHandler; -import sun.rmi.log.ReliableLog; -import sun.rmi.registry.RegistryImpl; -import sun.rmi.runtime.NewThreadAction; -import sun.rmi.transport.LiveRef; -import sun.security.provider.PolicyFile; -import com.sun.rmi.rmid.ExecPermission; -import com.sun.rmi.rmid.ExecOptionPermission; - -/** - * The Activator facilitates remote object activation. A "faulting" - * remote reference calls the activator's activate method - * to obtain a "live" reference to a activatable remote object. Upon - * receiving a request for activation, the activator looks up the - * activation descriptor for the activation identifier, id, determines - * the group in which the object should be activated and invokes the - * activate method on the object's activation group (described by the - * remote interface ActivationInstantiator). The - * activator initiates the execution of activation groups as - * necessary. For example, if an activation group for a specific group - * identifier is not already executing, the activator will spawn a - * child process for the activation group.

- * - * The activator is responsible for monitoring and detecting when - * activation groups fail so that it can remove stale remote references - * from its internal tables.

- * - * @author Ann Wollrath - * @since 1.2 - */ -@SuppressWarnings("removal") -public class Activation implements Serializable { - - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 2921265612698155191L; - private static final byte MAJOR_VERSION = 1; - private static final byte MINOR_VERSION = 0; - - /** exec policy object */ - private static Object execPolicy; - private static Method execPolicyMethod; - private static boolean debugExec; - - /** maps activation id to its respective group id */ - @SuppressWarnings("serial") // Conditionally serializable - private Map idTable = - new ConcurrentHashMap<>(); - /** maps group id to its GroupEntry groups */ - @SuppressWarnings("serial") // Conditionally serializable - private Map groupTable = - new ConcurrentHashMap<>(); - - private byte majorVersion = MAJOR_VERSION; - private byte minorVersion = MINOR_VERSION; - - /** number of simultaneous group exec's */ - private transient int groupSemaphore; - /** counter for numbering groups */ - private transient int groupCounter; - /** reliable log to hold descriptor table */ - private transient ReliableLog log; - /** number of updates since last snapshot */ - private transient int numUpdates; - - /** the java command */ - // accessed by GroupEntry - private transient String[] command; - /** timeout on wait for child process to be created or destroyed */ - private static final long groupTimeout = - getInt("sun.rmi.activation.groupTimeout", 60000); - /** take snapshot after this many updates */ - private static final int snapshotInterval = - getInt("sun.rmi.activation.snapshotInterval", 200); - /** timeout on wait for child process to be created */ - private static final long execTimeout = - getInt("sun.rmi.activation.execTimeout", 30000); - - private static final Object initLock = new Object(); - private static boolean initDone = false; - - // this should be a *private* method since it is privileged - private static int getInt(String name, int def) { - return AccessController.doPrivileged( - (PrivilegedAction) () -> Integer.getInteger(name, def)); - } - - private transient Activator activator; - private transient Activator activatorStub; - private transient ActivationSystem system; - private transient ActivationSystem systemStub; - private transient ActivationMonitor monitor; - private transient Registry registry; - private transient volatile boolean shuttingDown = false; - private transient volatile Object startupLock; - private transient Thread shutdownHook; - - private static ResourceBundle resources = null; - - /** - * Create an uninitialized instance of Activation that can be - * populated with log data. This is only called when the initial - * snapshot is taken during the first incarnation of rmid. - */ - private Activation() {} - - /** - * Recover activation state from the reliable log and initialize - * activation services. - */ - private static void startActivation(int port, - RMIServerSocketFactory ssf, - String logName, - String[] childArgs) - throws Exception - { - ReliableLog log = new ReliableLog(logName, new ActLogHandler()); - Activation state = (Activation) log.recover(); - state.init(port, ssf, log, childArgs); - } - - /** - * Initialize the Activation instantiation; start activation - * services. - */ - private void init(int port, - RMIServerSocketFactory ssf, - ReliableLog log, - String[] childArgs) - throws Exception - { - // initialize - this.log = log; - numUpdates = 0; - shutdownHook = new ShutdownHook(); - groupSemaphore = getInt("sun.rmi.activation.groupThrottle", 3); - groupCounter = 0; - Runtime.getRuntime().addShutdownHook(shutdownHook); - - // Use array size of 0, since the value from calling size() - // may be out of date by the time toArray() is called. - ActivationGroupID[] gids = - groupTable.keySet().toArray(new ActivationGroupID[0]); - - synchronized (startupLock = new Object()) { - // all the remote methods briefly synchronize on startupLock - // (via checkShutdown) to make sure they don't happen in the - // middle of this block. This block must not cause any such - // incoming remote calls to happen, or deadlock would result! - activator = new ActivatorImpl(port, ssf); - activatorStub = (Activator) RemoteObject.toStub(activator); - system = new ActivationSystemImpl(port, ssf); - systemStub = (ActivationSystem) RemoteObject.toStub(system); - monitor = new ActivationMonitorImpl(port, ssf); - initCommand(childArgs); - registry = new SystemRegistryImpl(port, null, ssf, systemStub); - - if (ssf != null) { - synchronized (initLock) { - initDone = true; - initLock.notifyAll(); - } - } - } - startupLock = null; - - // restart services - for (int i = gids.length; --i >= 0; ) { - try { - getGroupEntry(gids[i]).restartServices(); - } catch (UnknownGroupException e) { - System.err.println( - getTextResource("rmid.restart.group.warning")); - e.printStackTrace(); - } - } - } - - /** - * Previous versions used HashMap instead of ConcurrentHashMap. - * Replace any HashMaps found during deserialization with - * ConcurrentHashMaps. - */ - private void readObject(ObjectInputStream ois) - throws IOException, ClassNotFoundException - { - ois.defaultReadObject(); - if (! (groupTable instanceof ConcurrentHashMap)) { - groupTable = new ConcurrentHashMap<>(groupTable); - } - if (! (idTable instanceof ConcurrentHashMap)) { - idTable = new ConcurrentHashMap<>(idTable); - } - } - - private static class SystemRegistryImpl extends RegistryImpl { - - private static final String NAME = ActivationSystem.class.getName(); - private static final long serialVersionUID = 4877330021609408794L; - @SuppressWarnings("serial") // Not statically typed as Serializable - private ActivationSystem systemStub = null; - - SystemRegistryImpl(int port, - RMIClientSocketFactory csf, - RMIServerSocketFactory ssf, - ActivationSystem systemStub) - throws RemoteException - { - super(port, csf, ssf); - assert systemStub != null; - synchronized (this) { - this.systemStub = systemStub; - notifyAll(); - } - } - - /** - * Waits for systemStub to be initialized and returns its - * initialized value. Any remote call that uses systemStub must - * call this method to get it instead of using direct field - * access. This is necessary because the super() call in the - * constructor exports this object before systemStub is initialized - * (see JDK-8023541), allowing remote calls to come in during this - * time. We can't use checkShutdown() like other nested classes - * because this is a static class. - */ - private synchronized ActivationSystem getSystemStub() { - boolean interrupted = false; - - while (systemStub == null) { - try { - wait(); - } catch (InterruptedException ie) { - interrupted = true; - } - } - - if (interrupted) { - Thread.currentThread().interrupt(); - } - - return systemStub; - } - - /** - * Returns the activation system stub if the specified name - * matches the activation system's class name, otherwise - * returns the result of invoking super.lookup with the specified - * name. - */ - public Remote lookup(String name) - throws RemoteException, NotBoundException - { - if (name.equals(NAME)) { - return getSystemStub(); - } else { - return super.lookup(name); - } - } - - public String[] list() throws RemoteException { - String[] list1 = super.list(); - int length = list1.length; - String[] list2 = new String[length + 1]; - if (length > 0) { - System.arraycopy(list1, 0, list2, 0, length); - } - list2[length] = NAME; - return list2; - } - - public void bind(String name, Remote obj) - throws RemoteException, AlreadyBoundException, AccessException - { - if (name.equals(NAME)) { - throw new AccessException( - "binding ActivationSystem is disallowed"); - } else { - RegistryImpl.checkAccess("ActivationSystem.bind"); - super.bind(name, obj); - } - } - - public void unbind(String name) - throws RemoteException, NotBoundException, AccessException - { - if (name.equals(NAME)) { - throw new AccessException( - "unbinding ActivationSystem is disallowed"); - } else { - RegistryImpl.checkAccess("ActivationSystem.unbind"); - super.unbind(name); - } - } - - - public void rebind(String name, Remote obj) - throws RemoteException, AccessException - { - if (name.equals(NAME)) { - throw new AccessException( - "binding ActivationSystem is disallowed"); - } else { - RegistryImpl.checkAccess("ActivationSystem.rebind"); - super.rebind(name, obj); - } - } - } - - - class ActivatorImpl extends RemoteServer implements Activator { - // Because ActivatorImpl has a fixed ObjID, it can be - // called by clients holding stale remote references. Each of - // its remote methods, then, must check startupLock (calling - // checkShutdown() is easiest). - - private static final long serialVersionUID = -3654244726254566136L; - - /** - * Construct a new Activator on a specified port. - */ - ActivatorImpl(int port, RMIServerSocketFactory ssf) - throws RemoteException - { - /* Server ref must be created and assigned before remote object - * 'this' can be exported. - */ - LiveRef lref = - new LiveRef(new ObjID(ObjID.ACTIVATOR_ID), port, null, ssf); - UnicastServerRef uref = new UnicastServerRef(lref); - ref = uref; - uref.exportObject(this, null, false); - } - - public MarshalledObject activate(ActivationID id, - boolean force) - throws ActivationException, UnknownObjectException, RemoteException - { - checkShutdown(); - return getGroupEntry(id).activate(id, force); - } - } - - class ActivationMonitorImpl extends UnicastRemoteObject - implements ActivationMonitor - { - private static final long serialVersionUID = -6214940464757948867L; - - ActivationMonitorImpl(int port, RMIServerSocketFactory ssf) - throws RemoteException - { - super(port, null, ssf); - } - - public void inactiveObject(ActivationID id) - throws UnknownObjectException, RemoteException - { - try { - checkShutdown(); - } catch (ActivationException e) { - return; - } - RegistryImpl.checkAccess("Activator.inactiveObject"); - getGroupEntry(id).inactiveObject(id); - } - - public void activeObject(ActivationID id, - MarshalledObject mobj) - throws UnknownObjectException, RemoteException - { - try { - checkShutdown(); - } catch (ActivationException e) { - return; - } - RegistryImpl.checkAccess("ActivationSystem.activeObject"); - getGroupEntry(id).activeObject(id, mobj); - } - - public void inactiveGroup(ActivationGroupID id, - long incarnation) - throws UnknownGroupException, RemoteException - { - try { - checkShutdown(); - } catch (ActivationException e) { - return; - } - RegistryImpl.checkAccess("ActivationMonitor.inactiveGroup"); - getGroupEntry(id).inactiveGroup(incarnation, false); - } - } - - - /** - * SameHostOnlyServerRef checks that access is from a local client - * before the parameters are deserialized. The unmarshalCustomCallData - * hook is used to check the network address of the caller - * with RegistryImpl.checkAccess(). - * The kind of access is retained for an exception if one is thrown. - */ - @SuppressWarnings("serial") // Externalizable class w/o no-arg c'tor - static class SameHostOnlyServerRef extends UnicastServerRef { - private static final long serialVersionUID = 1234L; - private String accessKind; // an exception message - - /** - * Construct a new SameHostOnlyServerRef from a LiveRef. - * @param lref a LiveRef - */ - SameHostOnlyServerRef(LiveRef lref, String accessKind) { - super(lref); - this.accessKind = accessKind; - } - - @Override - protected void unmarshalCustomCallData(ObjectInput in) throws IOException, ClassNotFoundException { - RegistryImpl.checkAccess(accessKind); - super.unmarshalCustomCallData(in); - } - } - - class ActivationSystemImpl - extends RemoteServer - implements ActivationSystem - { - private static final long serialVersionUID = 9100152600327688967L; - - // Because ActivationSystemImpl has a fixed ObjID, it can be - // called by clients holding stale remote references. Each of - // its remote methods, then, must check startupLock (calling - // checkShutdown() is easiest). - ActivationSystemImpl(int port, RMIServerSocketFactory ssf) - throws RemoteException - { - /* Server ref must be created and assigned before remote object - * 'this' can be exported. - */ - LiveRef lref = new LiveRef(new ObjID(4), port, null, ssf); - UnicastServerRef uref = new SameHostOnlyServerRef(lref, - "ActivationSystem.nonLocalAccess"); - ref = uref; - uref.exportObject(this, null); - } - - public ActivationID registerObject(ActivationDesc desc) - throws ActivationException, UnknownGroupException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - ActivationGroupID groupID = desc.getGroupID(); - ActivationID id = new ActivationID(activatorStub); - getGroupEntry(groupID).registerObject(id, desc, true); - return id; - } - - public void unregisterObject(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - getGroupEntry(id).unregisterObject(id, true); - } - - public ActivationGroupID registerGroup(ActivationGroupDesc desc) - throws ActivationException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - checkArgs(desc, null); - - ActivationGroupID id = new ActivationGroupID(systemStub); - GroupEntry entry = new GroupEntry(id, desc); - // table insertion must take place before log update - groupTable.put(id, entry); - addLogRecord(new LogRegisterGroup(id, desc)); - return id; - } - - public ActivationMonitor activeGroup(ActivationGroupID id, - ActivationInstantiator group, - long incarnation) - throws ActivationException, UnknownGroupException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - getGroupEntry(id).activeGroup(group, incarnation); - return monitor; - } - - public void unregisterGroup(ActivationGroupID id) - throws ActivationException, UnknownGroupException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - // remove entry before unregister so state is updated before - // logged - removeGroupEntry(id).unregisterGroup(true); - } - - public ActivationDesc setActivationDesc(ActivationID id, - ActivationDesc desc) - throws ActivationException, UnknownObjectException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - if (!getGroupID(id).equals(desc.getGroupID())) { - throw new ActivationException( - "ActivationDesc contains wrong group"); - } - return getGroupEntry(id).setActivationDesc(id, desc, true); - } - - public ActivationGroupDesc setActivationGroupDesc(ActivationGroupID id, - ActivationGroupDesc desc) - throws ActivationException, UnknownGroupException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - checkArgs(desc, null); - return getGroupEntry(id).setActivationGroupDesc(id, desc, true); - } - - public ActivationDesc getActivationDesc(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - return getGroupEntry(id).getActivationDesc(id); - } - - public ActivationGroupDesc getActivationGroupDesc(ActivationGroupID id) - throws ActivationException, UnknownGroupException, RemoteException - { - checkShutdown(); - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - return getGroupEntry(id).desc; - } - - /** - * Shutdown the activation system. Destroys all groups spawned by - * the activation daemon and exits the activation daemon. - */ - public void shutdown() throws AccessException { - // RegistryImpl.checkAccess() is done in the SameHostOnlyServerRef - // during unmarshallCustomData and is not applicable to local access. - - Object lock = startupLock; - if (lock != null) { - synchronized (lock) { - // nothing - } - } - - synchronized (Activation.this) { - if (!shuttingDown) { - shuttingDown = true; - (new Shutdown()).start(); - } - } - } - } - - private void checkShutdown() throws ActivationException { - // if the startup critical section is running, wait until it - // completes/fails before continuing with the remote call. - Object lock = startupLock; - if (lock != null) { - synchronized (lock) { - // nothing - } - } - - if (shuttingDown == true) { - throw new ActivationException( - "activation system shutting down"); - } - } - - private static void unexport(Remote obj) { - for (;;) { - try { - if (UnicastRemoteObject.unexportObject(obj, false) == true) { - break; - } else { - Thread.sleep(100); - } - } catch (Exception e) { - continue; - } - } - } - - /** - * Thread to shutdown rmid. - */ - private class Shutdown extends Thread { - Shutdown() { - super("rmid Shutdown"); - } - - public void run() { - try { - /* - * Unexport activation system services - */ - unexport(activator); - unexport(system); - - // destroy all child processes (groups) - for (GroupEntry groupEntry : groupTable.values()) { - groupEntry.shutdown(); - } - - Runtime.getRuntime().removeShutdownHook(shutdownHook); - - /* - * Unexport monitor safely since all processes are destroyed. - */ - unexport(monitor); - - /* - * Close log file, fix for 4243264: rmid shutdown thread - * interferes with remote calls in progress. Make sure - * the log file is only closed when it is impossible for - * its closure to interfere with any pending remote calls. - * We close the log when all objects in the rmid VM are - * unexported. - */ - try { - synchronized (log) { - log.close(); - } - } catch (IOException e) { - } - - } finally { - /* - * Now exit... A System.exit should only be done if - * the RMI activation system daemon was started up - * by the main method below (in which should always - * be the case since the Activation constructor is private). - */ - System.err.println(getTextResource("rmid.daemon.shutdown")); - System.exit(0); - } - } - } - - /** Thread to destroy children in the event of abnormal termination. */ - private class ShutdownHook extends Thread { - ShutdownHook() { - super("rmid ShutdownHook"); - } - - public void run() { - synchronized (Activation.this) { - shuttingDown = true; - } - - // destroy all child processes (groups) quickly - for (GroupEntry groupEntry : groupTable.values()) { - groupEntry.shutdownFast(); - } - } - } - - /** - * Returns the groupID for a given id of an object in the group. - * Throws UnknownObjectException if the object is not registered. - */ - private ActivationGroupID getGroupID(ActivationID id) - throws UnknownObjectException - { - ActivationGroupID groupID = idTable.get(id); - if (groupID != null) { - return groupID; - } - throw new UnknownObjectException("unknown object: " + id); - } - - /** - * Returns the group entry for the group id, optionally removing it. - * Throws UnknownGroupException if the group is not registered. - */ - private GroupEntry getGroupEntry(ActivationGroupID id, boolean rm) - throws UnknownGroupException - { - if (id.getClass() == ActivationGroupID.class) { - GroupEntry entry; - if (rm) { - entry = groupTable.remove(id); - } else { - entry = groupTable.get(id); - } - if (entry != null && !entry.removed) { - return entry; - } - } - throw new UnknownGroupException("group unknown"); - } - - /** - * Returns the group entry for the group id. Throws - * UnknownGroupException if the group is not registered. - */ - private GroupEntry getGroupEntry(ActivationGroupID id) - throws UnknownGroupException - { - return getGroupEntry(id, false); - } - - /** - * Removes and returns the group entry for the group id. Throws - * UnknownGroupException if the group is not registered. - */ - private GroupEntry removeGroupEntry(ActivationGroupID id) - throws UnknownGroupException - { - return getGroupEntry(id, true); - } - - /** - * Returns the group entry for the object's id. Throws - * UnknownObjectException if the object is not registered or the - * object's group is not registered. - */ - private GroupEntry getGroupEntry(ActivationID id) - throws UnknownObjectException - { - ActivationGroupID gid = getGroupID(id); - GroupEntry entry = groupTable.get(gid); - if (entry != null && !entry.removed) { - return entry; - } - throw new UnknownObjectException("object's group removed"); - } - - /** - * Container for group information: group's descriptor, group's - * instantiator, flag to indicate pending group creation, and - * table of the objects that are activated in the group. - * - * WARNING: GroupEntry objects should not be written into log file - * updates. GroupEntrys are inner classes of Activation and they - * can not be serialized independent of this class. If the - * complete Activation system is written out as a log update, the - * point of having updates is nullified. - */ - private class GroupEntry implements Serializable { - - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 7222464070032993304L; - private static final int MAX_TRIES = 2; - private static final int NORMAL = 0; - private static final int CREATING = 1; - private static final int TERMINATE = 2; - private static final int TERMINATING = 3; - - ActivationGroupDesc desc = null; - ActivationGroupID groupID = null; - long incarnation = 0; - @SuppressWarnings("serial") // Conditionally serializable - Map objects = new HashMap<>(); - @SuppressWarnings("serial") // Conditionally serializable - Set restartSet = new HashSet<>(); - - transient ActivationInstantiator group = null; - transient int status = NORMAL; - transient long waitTime = 0; - transient String groupName = null; - transient Process child = null; - transient boolean removed = false; - transient Watchdog watchdog = null; - - GroupEntry(ActivationGroupID groupID, ActivationGroupDesc desc) { - this.groupID = groupID; - this.desc = desc; - } - - void restartServices() { - Iterator iter = null; - - synchronized (this) { - if (restartSet.isEmpty()) { - return; - } - - /* - * Clone the restartSet so the set does not have to be locked - * during iteration. Locking the restartSet could cause - * deadlock if an object we are restarting caused another - * object in this group to be activated. - */ - iter = (new HashSet(restartSet)).iterator(); - } - - while (iter.hasNext()) { - ActivationID id = iter.next(); - try { - activate(id, true); - } catch (Exception e) { - if (shuttingDown) { - return; - } - System.err.println( - getTextResource("rmid.restart.service.warning")); - e.printStackTrace(); - } - } - } - - synchronized void activeGroup(ActivationInstantiator inst, - long instIncarnation) - throws ActivationException, UnknownGroupException - { - if (incarnation != instIncarnation) { - throw new ActivationException("invalid incarnation"); - } - - if (group != null) { - if (group.equals(inst)) { - return; - } else { - throw new ActivationException("group already active"); - } - } - - if (child != null && status != CREATING) { - throw new ActivationException("group not being created"); - } - - group = inst; - status = NORMAL; - notifyAll(); - } - - private void checkRemoved() throws UnknownGroupException { - if (removed) { - throw new UnknownGroupException("group removed"); - } - } - - private ObjectEntry getObjectEntry(ActivationID id) - throws UnknownObjectException - { - if (removed) { - throw new UnknownObjectException("object's group removed"); - } - ObjectEntry objEntry = objects.get(id); - if (objEntry == null) { - throw new UnknownObjectException("object unknown"); - } - return objEntry; - } - - synchronized void registerObject(ActivationID id, - ActivationDesc desc, - boolean addRecord) - throws UnknownGroupException, ActivationException - { - checkRemoved(); - objects.put(id, new ObjectEntry(desc)); - if (desc.getRestartMode() == true) { - restartSet.add(id); - } - - // table insertion must take place before log update - idTable.put(id, groupID); - - if (addRecord) { - addLogRecord(new LogRegisterObject(id, desc)); - } - } - - synchronized void unregisterObject(ActivationID id, boolean addRecord) - throws UnknownGroupException, ActivationException - { - ObjectEntry objEntry = getObjectEntry(id); - objEntry.removed = true; - objects.remove(id); - if (objEntry.desc.getRestartMode() == true) { - restartSet.remove(id); - } - - // table removal must take place before log update - idTable.remove(id); - if (addRecord) { - addLogRecord(new LogUnregisterObject(id)); - } - } - - synchronized void unregisterGroup(boolean addRecord) - throws UnknownGroupException, ActivationException - { - checkRemoved(); - removed = true; - for (Map.Entry entry : - objects.entrySet()) - { - ActivationID id = entry.getKey(); - idTable.remove(id); - ObjectEntry objEntry = entry.getValue(); - objEntry.removed = true; - } - objects.clear(); - restartSet.clear(); - reset(); - childGone(); - - // removal should be recorded before log update - if (addRecord) { - addLogRecord(new LogUnregisterGroup(groupID)); - } - } - - synchronized ActivationDesc setActivationDesc(ActivationID id, - ActivationDesc desc, - boolean addRecord) - throws UnknownObjectException, UnknownGroupException, - ActivationException - { - ObjectEntry objEntry = getObjectEntry(id); - ActivationDesc oldDesc = objEntry.desc; - objEntry.desc = desc; - if (desc.getRestartMode() == true) { - restartSet.add(id); - } else { - restartSet.remove(id); - } - // restart information should be recorded before log update - if (addRecord) { - addLogRecord(new LogUpdateDesc(id, desc)); - } - - return oldDesc; - } - - synchronized ActivationDesc getActivationDesc(ActivationID id) - throws UnknownObjectException, UnknownGroupException - { - return getObjectEntry(id).desc; - } - - synchronized ActivationGroupDesc setActivationGroupDesc( - ActivationGroupID id, - ActivationGroupDesc desc, - boolean addRecord) - throws UnknownGroupException, ActivationException - { - checkRemoved(); - ActivationGroupDesc oldDesc = this.desc; - this.desc = desc; - // state update should occur before log update - if (addRecord) { - addLogRecord(new LogUpdateGroupDesc(id, desc)); - } - return oldDesc; - } - - synchronized void inactiveGroup(long incarnation, boolean failure) - throws UnknownGroupException - { - checkRemoved(); - if (this.incarnation != incarnation) { - throw new UnknownGroupException("invalid incarnation"); - } - - reset(); - if (failure) { - terminate(); - } else if (child != null && status == NORMAL) { - status = TERMINATE; - watchdog.noRestart(); - } - } - - synchronized void activeObject(ActivationID id, - MarshalledObject mobj) - throws UnknownObjectException - { - getObjectEntry(id).stub = mobj; - } - - synchronized void inactiveObject(ActivationID id) - throws UnknownObjectException - { - getObjectEntry(id).reset(); - } - - private synchronized void reset() { - group = null; - for (ObjectEntry objectEntry : objects.values()) { - objectEntry.reset(); - } - } - - private void childGone() { - if (child != null) { - child = null; - watchdog.dispose(); - watchdog = null; - status = NORMAL; - notifyAll(); - } - } - - private void terminate() { - if (child != null && status != TERMINATING) { - child.destroy(); - status = TERMINATING; - waitTime = System.currentTimeMillis() + groupTimeout; - notifyAll(); - } - } - - /* - * Fallthrough from TERMINATE to TERMINATING - * is intentional - */ - @SuppressWarnings("fallthrough") - private void await() { - while (true) { - switch (status) { - case NORMAL: - return; - case TERMINATE: - terminate(); - case TERMINATING: - try { - child.exitValue(); - } catch (IllegalThreadStateException e) { - long now = System.currentTimeMillis(); - if (waitTime > now) { - try { - wait(waitTime - now); - } catch (InterruptedException ee) { - } - continue; - } - // REMIND: print message that group did not terminate? - } - childGone(); - return; - case CREATING: - try { - wait(); - } catch (InterruptedException e) { - } - } - } - } - - // no synchronization to avoid delay wrt getInstantiator - void shutdownFast() { - Process p = child; - if (p != null) { - p.destroy(); - } - } - - synchronized void shutdown() { - reset(); - terminate(); - await(); - } - - MarshalledObject activate(ActivationID id, - boolean force) - throws ActivationException - { - Exception detail = null; - - /* - * Attempt to activate object and reattempt (several times) - * if activation fails due to communication problems. - */ - for (int tries = MAX_TRIES; tries > 0; tries--) { - ActivationInstantiator inst; - long currentIncarnation; - - // look up object to activate - ObjectEntry objEntry; - synchronized (this) { - objEntry = getObjectEntry(id); - // if not forcing activation, return cached stub - if (!force && objEntry.stub != null) { - return objEntry.stub; - } - inst = getInstantiator(groupID); - currentIncarnation = incarnation; - } - - boolean groupInactive = false; - boolean failure = false; - // activate object - try { - return objEntry.activate(id, force, inst); - } catch (NoSuchObjectException e) { - groupInactive = true; - detail = e; - } catch (ConnectException e) { - groupInactive = true; - failure = true; - detail = e; - } catch (ConnectIOException e) { - groupInactive = true; - failure = true; - detail = e; - } catch (InactiveGroupException e) { - groupInactive = true; - detail = e; - } catch (RemoteException e) { - // REMIND: wait some here before continuing? - if (detail == null) { - detail = e; - } - } - - if (groupInactive) { - // group has failed or is inactive; mark inactive - try { - System.err.println( - MessageFormat.format( - getTextResource("rmid.group.inactive"), - detail.toString())); - detail.printStackTrace(); - getGroupEntry(groupID). - inactiveGroup(currentIncarnation, failure); - } catch (UnknownGroupException e) { - // not a problem - } - } - } - - /** - * signal that group activation failed, nested exception - * specifies what exception occurred when the group did not - * activate - */ - throw new ActivationException("object activation failed after " + - MAX_TRIES + " tries", detail); - } - - /** - * Returns the instantiator for the group specified by id and - * entry. If the group is currently inactive, exec some - * bootstrap code to create the group. - */ - private ActivationInstantiator getInstantiator(ActivationGroupID id) - throws ActivationException - { - assert Thread.holdsLock(this); - - await(); - if (group != null) { - return group; - } - checkRemoved(); - boolean acquired = false; - - try { - groupName = Pstartgroup(); - acquired = true; - String[] argv = activationArgs(desc); - checkArgs(desc, argv); - - if (debugExec) { - StringBuilder sb = new StringBuilder(argv[0]); - int j; - for (j = 1; j < argv.length; j++) { - sb.append(' '); - sb.append(argv[j]); - } - System.err.println( - MessageFormat.format( - getTextResource("rmid.exec.command"), - sb.toString())); - } - - try { - child = Runtime.getRuntime().exec(argv); - status = CREATING; - ++incarnation; - watchdog = new Watchdog(); - watchdog.start(); - addLogRecord(new LogGroupIncarnation(id, incarnation)); - - // handle child I/O streams before writing to child - PipeWriter.plugTogetherPair - (child.getInputStream(), System.out, - child.getErrorStream(), System.err); - try (MarshalOutputStream out = - new MarshalOutputStream(child.getOutputStream())) { - out.writeObject(id); - out.writeObject(desc); - out.writeLong(incarnation); - out.flush(); - } - - - } catch (IOException e) { - terminate(); - throw new ActivationException( - "unable to create activation group", e); - } - - try { - long now = System.currentTimeMillis(); - long stop = now + execTimeout; - do { - wait(stop - now); - if (group != null) { - return group; - } - now = System.currentTimeMillis(); - } while (status == CREATING && now < stop); - } catch (InterruptedException e) { - } - - terminate(); - throw new ActivationException( - (removed ? - "activation group unregistered" : - "timeout creating child process")); - } finally { - if (acquired) { - Vstartgroup(); - } - } - } - - /** - * Waits for process termination and then restarts services. - */ - private class Watchdog extends Thread { - private final Process groupProcess = child; - private final long groupIncarnation = incarnation; - private boolean canInterrupt = true; - private boolean shouldQuit = false; - private boolean shouldRestart = true; - - Watchdog() { - super("WatchDog-" + groupName + "-" + incarnation); - setDaemon(true); - } - - public void run() { - - if (shouldQuit) { - return; - } - - /* - * Wait for the group to crash or exit. - */ - try { - groupProcess.waitFor(); - } catch (InterruptedException exit) { - return; - } - - boolean restart = false; - synchronized (GroupEntry.this) { - if (shouldQuit) { - return; - } - canInterrupt = false; - interrupted(); // clear interrupt bit - /* - * Since the group crashed, we should - * reset the entry before activating objects - */ - if (groupIncarnation == incarnation) { - restart = shouldRestart && !shuttingDown; - reset(); - childGone(); - } - } - - /* - * Activate those objects that require restarting - * after a crash. - */ - if (restart) { - restartServices(); - } - } - - /** - * Marks this thread as one that is no longer needed. - * If the thread is in a state in which it can be interrupted, - * then the thread is interrupted. - */ - void dispose() { - shouldQuit = true; - if (canInterrupt) { - interrupt(); - } - } - - /** - * Marks this thread as no longer needing to restart objects. - */ - void noRestart() { - shouldRestart = false; - } - } - } - - private String[] activationArgs(ActivationGroupDesc desc) { - ActivationGroupDesc.CommandEnvironment cmdenv; - cmdenv = desc.getCommandEnvironment(); - - // argv is the literal command to exec - List argv = new ArrayList<>(); - - // Command name/path - argv.add((cmdenv != null && cmdenv.getCommandPath() != null) - ? cmdenv.getCommandPath() - : command[0]); - - // Group-specific command options - if (cmdenv != null && cmdenv.getCommandOptions() != null) { - argv.addAll(Arrays.asList(cmdenv.getCommandOptions())); - } - - // Properties become -D parameters - Properties props = desc.getPropertyOverrides(); - if (props != null) { - for (Enumeration p = props.propertyNames(); - p.hasMoreElements();) - { - String name = (String) p.nextElement(); - /* Note on quoting: it would be wrong - * here, since argv will be passed to - * Runtime.exec, which should not parse - * arguments or split on whitespace. - */ - argv.add("-D" + name + "=" + props.getProperty(name)); - } - } - - /* Finally, rmid-global command options (e.g. -C options) - * and the classname - */ - for (int i = 1; i < command.length; i++) { - argv.add(command[i]); - } - - String[] realArgv = new String[argv.size()]; - System.arraycopy(argv.toArray(), 0, realArgv, 0, realArgv.length); - - return realArgv; - } - - private void checkArgs(ActivationGroupDesc desc, String[] cmd) - throws SecurityException, ActivationException - { - /* - * Check exec command using execPolicy object - */ - if (execPolicyMethod != null) { - if (cmd == null) { - cmd = activationArgs(desc); - } - try { - execPolicyMethod.invoke(execPolicy, desc, cmd); - } catch (InvocationTargetException e) { - Throwable targetException = e.getCause(); - if (targetException instanceof SecurityException) { - throw (SecurityException) targetException; - } else { - throw new ActivationException( - execPolicyMethod.getName() + ": unexpected exception", - e); - } - } catch (Exception e) { - throw new ActivationException( - execPolicyMethod.getName() + ": unexpected exception", e); - } - } - } - - private static class ObjectEntry implements Serializable { - - private static final long serialVersionUID = -5500114225321357856L; - - /** descriptor for object */ - ActivationDesc desc; - /** the stub (if active) */ - volatile transient MarshalledObject stub = null; - volatile transient boolean removed = false; - - ObjectEntry(ActivationDesc desc) { - this.desc = desc; - } - - synchronized MarshalledObject - activate(ActivationID id, - boolean force, - ActivationInstantiator inst) - throws RemoteException, ActivationException - { - MarshalledObject nstub = stub; - if (removed) { - throw new UnknownObjectException("object removed"); - } else if (!force && nstub != null) { - return nstub; - } - - nstub = inst.newInstance(id, desc); - stub = nstub; - /* - * stub could be set to null by a group reset, so return - * the newstub here to prevent returning null. - */ - return nstub; - } - - void reset() { - stub = null; - } - } - - /** - * Add a record to the activation log. If the number of updates - * passes a predetermined threshold, record a snapshot. - */ - private void addLogRecord(LogRecord rec) throws ActivationException { - synchronized (log) { - checkShutdown(); - try { - log.update(rec, true); - } catch (Exception e) { - numUpdates = snapshotInterval; - System.err.println(getTextResource("rmid.log.update.warning")); - e.printStackTrace(); - } - if (++numUpdates < snapshotInterval) { - return; - } - try { - log.snapshot(this); - numUpdates = 0; - } catch (Exception e) { - System.err.println( - getTextResource("rmid.log.snapshot.warning")); - e.printStackTrace(); - try { - // shutdown activation system because snapshot failed - system.shutdown(); - } catch (RemoteException ignore) { - // can't happen - } - // warn the client of the original update problem - throw new ActivationException("log snapshot failed", e); - } - } - } - - /** - * Handler for the log that knows how to take the initial snapshot - * and apply an update (a LogRecord) to the current state. - */ - private static class ActLogHandler extends LogHandler { - - ActLogHandler() { - } - - public Object initialSnapshot() - { - /** - * Return an empty Activation object. Log will update - * this object with recovered state. - */ - return new Activation(); - } - - public Object applyUpdate(Object update, Object state) - throws Exception - { - return ((LogRecord) update).apply(state); - } - - } - - /** - * Abstract class for all log records. The subclass contains - * specific update information and implements the apply method - * that applys the update information contained in the record - * to the current state. - */ - private static abstract class LogRecord implements Serializable { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 8395140512322687529L; - abstract Object apply(Object state) throws Exception; - } - - /** - * Log record for registering an object. - */ - private static class LogRegisterObject extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = -6280336276146085143L; - private ActivationID id; - private ActivationDesc desc; - - LogRegisterObject(ActivationID id, ActivationDesc desc) { - this.id = id; - this.desc = desc; - } - - Object apply(Object state) { - try { - ((Activation) state).getGroupEntry(desc.getGroupID()). - registerObject(id, desc, false); - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogRegisterObject")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Log record for unregistering an object. - */ - private static class LogUnregisterObject extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 6269824097396935501L; - private ActivationID id; - - LogUnregisterObject(ActivationID id) { - this.id = id; - } - - Object apply(Object state) { - try { - ((Activation) state).getGroupEntry(id). - unregisterObject(id, false); - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogUnregisterObject")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Log record for registering a group. - */ - private static class LogRegisterGroup extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = -1966827458515403625L; - private ActivationGroupID id; - private ActivationGroupDesc desc; - - LogRegisterGroup(ActivationGroupID id, ActivationGroupDesc desc) { - this.id = id; - this.desc = desc; - } - - Object apply(Object state) { - // modify state directly; cant ask a nonexistent GroupEntry - // to register itself. - ((Activation) state).groupTable.put(id, ((Activation) state).new - GroupEntry(id, desc)); - return state; - } - } - - /** - * Log record for udpating an activation desc - */ - private static class LogUpdateDesc extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 545511539051179885L; - - private ActivationID id; - private ActivationDesc desc; - - LogUpdateDesc(ActivationID id, ActivationDesc desc) { - this.id = id; - this.desc = desc; - } - - Object apply(Object state) { - try { - ((Activation) state).getGroupEntry(id). - setActivationDesc(id, desc, false); - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogUpdateDesc")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Log record for unregistering a group. - */ - private static class LogUpdateGroupDesc extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = -1271300989218424337L; - private ActivationGroupID id; - private ActivationGroupDesc desc; - - LogUpdateGroupDesc(ActivationGroupID id, ActivationGroupDesc desc) { - this.id = id; - this.desc = desc; - } - - Object apply(Object state) { - try { - ((Activation) state).getGroupEntry(id). - setActivationGroupDesc(id, desc, false); - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogUpdateGroupDesc")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Log record for unregistering a group. - */ - private static class LogUnregisterGroup extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = -3356306586522147344L; - private ActivationGroupID id; - - LogUnregisterGroup(ActivationGroupID id) { - this.id = id; - } - - Object apply(Object state) { - GroupEntry entry = ((Activation) state).groupTable.remove(id); - try { - entry.unregisterGroup(false); - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogUnregisterGroup")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Log record for an active group incarnation - */ - private static class LogGroupIncarnation extends LogRecord { - /** indicate compatibility with JDK 1.2 version of class */ - private static final long serialVersionUID = 4146872747377631897L; - private ActivationGroupID id; - private long inc; - - LogGroupIncarnation(ActivationGroupID id, long inc) { - this.id = id; - this.inc = inc; - } - - Object apply(Object state) { - try { - GroupEntry entry = ((Activation) state).getGroupEntry(id); - entry.incarnation = inc; - } catch (Exception ignore) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.log.recover.warning"), - "LogGroupIncarnation")); - ignore.printStackTrace(); - } - return state; - } - } - - /** - * Initialize command to exec a default group. - */ - private void initCommand(String[] childArgs) { - command = new String[childArgs.length + 2]; - AccessController.doPrivileged(new PrivilegedAction() { - public Void run() { - try { - command[0] = System.getProperty("java.home") + - File.separator + "bin" + File.separator + "java"; - } catch (Exception e) { - System.err.println( - getTextResource("rmid.unfound.java.home.property")); - command[0] = "java"; - } - return null; - } - }); - System.arraycopy(childArgs, 0, command, 1, childArgs.length); - command[command.length-1] = "sun.rmi.server.ActivationGroupInit"; - } - - private static void bomb(String error) { - System.err.println("rmid: " + error); // $NON-NLS$ - System.err.println(MessageFormat.format(getTextResource("rmid.usage"), - "rmid")); - System.exit(1); - } - - /** - * The default policy for checking a command before it is executed - * makes sure the appropriate com.sun.rmi.rmid.ExecPermission and - * set of com.sun.rmi.rmid.ExecOptionPermissions have been granted. - */ - public static class DefaultExecPolicy { - - public void checkExecCommand(ActivationGroupDesc desc, String[] cmd) - throws SecurityException - { - PermissionCollection perms = getExecPermissions(); - - /* - * Check properties overrides. - */ - Properties props = desc.getPropertyOverrides(); - if (props != null) { - Enumeration p = props.propertyNames(); - while (p.hasMoreElements()) { - String name = (String) p.nextElement(); - String value = props.getProperty(name); - String option = "-D" + name + "=" + value; - try { - checkPermission(perms, - new ExecOptionPermission(option)); - } catch (AccessControlException e) { - if (value.isEmpty()) { - checkPermission(perms, - new ExecOptionPermission("-D" + name)); - } else { - throw e; - } - } - } - } - - /* - * Check group class name (allow nothing but the default), - * code location (must be null), and data (must be null). - */ - String groupClassName = desc.getClassName(); - if ((groupClassName != null && - !groupClassName.equals( - ActivationGroupImpl.class.getName())) || - (desc.getLocation() != null) || - (desc.getData() != null)) - { - throw new AccessControlException( - "access denied (custom group implementation not allowed)"); - } - - /* - * If group descriptor has a command environment, check - * command and options. - */ - ActivationGroupDesc.CommandEnvironment cmdenv; - cmdenv = desc.getCommandEnvironment(); - if (cmdenv != null) { - String path = cmdenv.getCommandPath(); - if (path != null) { - checkPermission(perms, new ExecPermission(path)); - } - - String[] options = cmdenv.getCommandOptions(); - if (options != null) { - for (String option : options) { - checkPermission(perms, - new ExecOptionPermission(option)); - } - } - } - } - - /** - * Prints warning message if installed Policy is the default Policy - * implementation and globally granted permissions do not include - * AllPermission or any ExecPermissions/ExecOptionPermissions. - */ - static void checkConfiguration() { - Policy policy = - AccessController.doPrivileged(new PrivilegedAction() { - public Policy run() { - return Policy.getPolicy(); - } - }); - if (!(policy instanceof PolicyFile)) { - return; - } - PermissionCollection perms = getExecPermissions(); - for (Enumeration e = perms.elements(); - e.hasMoreElements();) - { - Permission p = e.nextElement(); - if (p instanceof AllPermission || - p instanceof ExecPermission || - p instanceof ExecOptionPermission) - { - return; - } - } - System.err.println(getTextResource("rmid.exec.perms.inadequate")); - } - - private static PermissionCollection getExecPermissions() { - /* - * The approach used here is taken from the similar method - * getLoaderAccessControlContext() in the class - * sun.rmi.server.LoaderHandler. - */ - - // obtain permissions granted to all code in current policy - PermissionCollection perms = AccessController.doPrivileged( - new PrivilegedAction() { - public PermissionCollection run() { - CodeSource codesource = - new CodeSource(null, (Certificate[]) null); - Policy p = Policy.getPolicy(); - if (p != null) { - return p.getPermissions(codesource); - } else { - return new Permissions(); - } - } - }); - - return perms; - } - - private static void checkPermission(PermissionCollection perms, - Permission p) - throws AccessControlException - { - if (!perms.implies(p)) { - throw new AccessControlException( - "access denied " + p.toString()); - } - } - } - - /** - * Main program to start the activation system.
- * The usage is as follows: rmid [-port num] [-log dir]. - */ - public static void main(String[] args) { - boolean stop = false; - - // Create and install the security manager if one is not installed - // already. - if (System.getSecurityManager() == null) { - System.setSecurityManager(new SecurityManager()); - } - - try { - int port = ActivationSystem.SYSTEM_PORT; - RMIServerSocketFactory ssf = null; - - /* - * If rmid has an inherited channel (meaning that it was - * launched from inetd), set the server socket factory to - * return the inherited server socket. - **/ - Channel inheritedChannel = AccessController.doPrivileged( - new PrivilegedExceptionAction() { - public Channel run() throws IOException { - return System.inheritedChannel(); - } - }); - - if (inheritedChannel != null && - inheritedChannel instanceof ServerSocketChannel) - { - /* - * Redirect System.err output to a file. - */ - AccessController.doPrivileged( - new PrivilegedExceptionAction() { - public Void run() throws IOException { - boolean disable = Boolean.getBoolean( - "sun.rmi.server.activation.disableErrRedirect"); - if (disable) - return null; - - File file = - Files.createTempFile("rmid-err", null).toFile(); - PrintStream errStream = - new PrintStream(new FileOutputStream(file)); - System.setErr(errStream); - return null; - } - }); - - ServerSocket serverSocket = - ((ServerSocketChannel) inheritedChannel).socket(); - port = serverSocket.getLocalPort(); - ssf = new ActivationServerSocketFactory(serverSocket); - - System.err.println(new Date()); - System.err.println(getTextResource( - "rmid.inherited.channel.info") + - ": " + inheritedChannel); - } - - String log = null; - List childArgs = new ArrayList<>(); - - /* - * Parse arguments - */ - for (int i = 0; i < args.length; i++) { - if (args[i].equals("-port")) { - if (ssf != null) { - bomb(getTextResource("rmid.syntax.port.badarg")); - } - if ((i + 1) < args.length) { - try { - port = Integer.parseInt(args[++i]); - } catch (NumberFormatException nfe) { - bomb(getTextResource("rmid.syntax.port.badnumber")); - } - } else { - bomb(getTextResource("rmid.syntax.port.missing")); - } - - } else if (args[i].equals("-log")) { - if ((i + 1) < args.length) { - log = args[++i]; - } else { - bomb(getTextResource("rmid.syntax.log.missing")); - } - - } else if (args[i].equals("-stop")) { - stop = true; - - } else if (args[i].startsWith("-C")) { - childArgs.add(args[i].substring(2)); - - } else { - bomb(MessageFormat.format( - getTextResource("rmid.syntax.illegal.option"), - args[i])); - } - } - - if (log == null) { - if (ssf != null) { - bomb(getTextResource("rmid.syntax.log.required")); - } else { - log = "log"; - } - } - - debugExec = AccessController.doPrivileged( - (PrivilegedAction) () -> Boolean.getBoolean("sun.rmi.server.activation.debugExec")); - - /** - * Determine class name for activation exec policy (if any). - */ - String execPolicyClassName = AccessController.doPrivileged( - (PrivilegedAction) () -> System.getProperty("sun.rmi.activation.execPolicy")); - if (execPolicyClassName == null) { - if (!stop) { - DefaultExecPolicy.checkConfiguration(); - } - execPolicyClassName = "default"; - } - - /** - * Initialize method for activation exec policy. - */ - if (!execPolicyClassName.equals("none")) { - if (execPolicyClassName.isEmpty() || - execPolicyClassName.equals("default")) - { - execPolicyClassName = DefaultExecPolicy.class.getName(); - } - - try { - Class execPolicyClass = getRMIClass(execPolicyClassName); - @SuppressWarnings("deprecation") - Object tmp = execPolicyClass.newInstance(); - execPolicy = tmp; - execPolicyMethod = - execPolicyClass.getMethod("checkExecCommand", - ActivationGroupDesc.class, - String[].class); - } catch (Exception e) { - if (debugExec) { - System.err.println( - getTextResource("rmid.exec.policy.exception")); - e.printStackTrace(); - } - bomb(getTextResource("rmid.exec.policy.invalid")); - } - } - - if (stop == true) { - final int finalPort = port; - AccessController.doPrivileged(new PrivilegedAction() { - public Void run() { - System.setProperty("java.rmi.activation.port", - Integer.toString(finalPort)); - return null; - } - }); - ActivationSystem system = ActivationGroup.getSystem(); - system.shutdown(); - System.exit(0); - } - - System.err.println(getTextResource("rmid.deprecation.warning")); - - /* - * Fix for 4173960: Create and initialize activation using - * a static method, startActivation, which will build the - * Activation state in two ways: if when rmid is run, no - * log file is found, the ActLogHandler.recover(...) - * method will create a new Activation instance. - * Alternatively, if a logfile is available, a serialized - * instance of activation will be read from the log's - * snapshot file. Log updates will be applied to this - * Activation object until rmid's state has been fully - * recovered. In either case, only one instance of - * Activation is created. - */ - startActivation(port, ssf, log, - childArgs.toArray(new String[childArgs.size()])); - - // prevent activator from exiting - while (true) { - try { - Thread.sleep(Long.MAX_VALUE); - } catch (InterruptedException e) { - } - } - } catch (Exception e) { - System.err.println( - MessageFormat.format( - getTextResource("rmid.unexpected.exception"), e)); - e.printStackTrace(); - } - System.exit(1); - } - - /** - * Retrieves text resources from the locale-specific properties file. - */ - private static String getTextResource(String key) { - if (Activation.resources == null) { - try { - Activation.resources = ResourceBundle.getBundle( - "sun.rmi.server.resources.rmid"); - } catch (MissingResourceException mre) { - } - if (Activation.resources == null) { - // throwing an Error is a bit extreme, methinks - return ("[missing resource file: " + key + "]"); - } - } - - String val = null; - try { - val = Activation.resources.getString (key); - } catch (MissingResourceException mre) { - } - - if (val == null) { - return ("[missing resource: " + key + "]"); - } else { - return val; - } - } - - @SuppressWarnings("deprecation") - private static Class getRMIClass(String execPolicyClassName) throws Exception { - return RMIClassLoader.loadClass(execPolicyClassName); - } - /* - * Dijkstra semaphore operations to limit the number of subprocesses - * rmid attempts to make at once. - */ - /** - * Acquire the group semaphore and return a group name. Each - * Pstartgroup must be followed by a Vstartgroup. The calling thread - * will wait until there are fewer than N other threads - * holding the group semaphore. The calling thread will then acquire - * the semaphore and return. - */ - private synchronized String Pstartgroup() throws ActivationException { - while (true) { - checkShutdown(); - // Wait until positive, then decrement. - if (groupSemaphore > 0) { - groupSemaphore--; - return "Group-" + groupCounter++; - } - - try { - wait(); - } catch (InterruptedException e) { - } - } - } - - /** - * Release the group semaphore. Every P operation must be - * followed by a V operation. This may cause another thread to - * wake up and return from its P operation. - */ - private synchronized void Vstartgroup() { - // Increment and notify a waiter (not necessarily FIFO). - groupSemaphore++; - notifyAll(); - } - - /** - * A server socket factory to use when rmid is launched via 'inetd' - * with 'wait' status. This socket factory's 'createServerSocket' - * method returns the server socket specified during construction that - * is specialized to delay accepting requests until the - * 'initDone' flag is 'true'. The server socket supplied to - * the constructor should be the server socket obtained from the - * ServerSocketChannel returned from the 'System.inheritedChannel' - * method. - **/ - private static class ActivationServerSocketFactory - implements RMIServerSocketFactory - { - private final ServerSocket serverSocket; - - /** - * Constructs an 'ActivationServerSocketFactory' with the specified - * 'serverSocket'. - **/ - ActivationServerSocketFactory(ServerSocket serverSocket) { - this.serverSocket = serverSocket; - } - - /** - * Returns the server socket specified during construction wrapped - * in a 'DelayedAcceptServerSocket'. - **/ - public ServerSocket createServerSocket(int port) - throws IOException - { - return new DelayedAcceptServerSocket(serverSocket); - } - - } - - /** - * A server socket that delegates all public methods to the underlying - * server socket specified at construction. The accept method is - * overridden to delay calling accept on the underlying server socket - * until the 'initDone' flag is 'true'. - **/ - private static class DelayedAcceptServerSocket extends ServerSocket { - - private final ServerSocket serverSocket; - - DelayedAcceptServerSocket(ServerSocket serverSocket) - throws IOException - { - this.serverSocket = serverSocket; - } - - public void bind(SocketAddress endpoint) throws IOException { - serverSocket.bind(endpoint); - } - - public void bind(SocketAddress endpoint, int backlog) - throws IOException - { - serverSocket.bind(endpoint, backlog); - } - - public InetAddress getInetAddress() { - return AccessController.doPrivileged( - new PrivilegedAction() { - @Override - public InetAddress run() { - return serverSocket.getInetAddress(); - } - }); - } - - public int getLocalPort() { - return serverSocket.getLocalPort(); - } - - public SocketAddress getLocalSocketAddress() { - return AccessController.doPrivileged( - new PrivilegedAction() { - @Override - public SocketAddress run() { - return serverSocket.getLocalSocketAddress(); - } - }); - } - - /** - * Delays calling accept on the underlying server socket until the - * remote service is bound in the registry. - **/ - public Socket accept() throws IOException { - synchronized (initLock) { - try { - while (!initDone) { - initLock.wait(); - } - } catch (InterruptedException ignore) { - throw new AssertionError(ignore); - } - } - return serverSocket.accept(); - } - - public void close() throws IOException { - serverSocket.close(); - } - - public ServerSocketChannel getChannel() { - return serverSocket.getChannel(); - } - - public boolean isBound() { - return serverSocket.isBound(); - } - - public boolean isClosed() { - return serverSocket.isClosed(); - } - - public void setSoTimeout(int timeout) - throws SocketException - { - serverSocket.setSoTimeout(timeout); - } - - public int getSoTimeout() throws IOException { - return serverSocket.getSoTimeout(); - } - - public void setReuseAddress(boolean on) throws SocketException { - serverSocket.setReuseAddress(on); - } - - public boolean getReuseAddress() throws SocketException { - return serverSocket.getReuseAddress(); - } - - public String toString() { - return serverSocket.toString(); - } - - public void setReceiveBufferSize(int size) - throws SocketException - { - serverSocket.setReceiveBufferSize(size); - } - - public int getReceiveBufferSize() - throws SocketException - { - return serverSocket.getReceiveBufferSize(); - } - } -} - -/** - * PipeWriter plugs together two pairs of input and output streams by - * providing readers for input streams and writing through to - * appropriate output streams. Both output streams are annotated on a - * per-line basis. - * - * @author Laird Dornin, much code borrowed from Peter Jones, Ken - * Arnold and Ann Wollrath. - */ -class PipeWriter implements Runnable { - - /** stream used for buffering lines */ - private ByteArrayOutputStream bufOut; - - /** count since last separator */ - private int cLast; - - /** current chunk of input being compared to lineSeparator.*/ - private byte[] currSep; - - private PrintWriter out; - private InputStream in; - - private String pipeString; - private String execString; - - private static String lineSeparator; - private static int lineSeparatorLength; - - private static int numExecs = 0; - - static { - lineSeparator = AccessController.doPrivileged( - (PrivilegedAction) () -> System.getProperty("line.separator")); - lineSeparatorLength = lineSeparator.length(); - } - - /** - * Create a new PipeWriter object. All methods of PipeWriter, - * except plugTogetherPair, are only accesible to PipeWriter - * itself. Synchronization is unnecessary on functions that will - * only be used internally in PipeWriter. - * - * @param in input stream from which pipe input flows - * @param out output stream to which log messages will be sent - * @param dest String which tags output stream as 'out' or 'err' - * @param nExecs number of execed processes, Activation groups. - */ - private PipeWriter - (InputStream in, OutputStream out, String tag, int nExecs) { - - this.in = in; - this.out = new PrintWriter(out); - - bufOut = new ByteArrayOutputStream(); - currSep = new byte[lineSeparatorLength]; - - /* set unique pipe/pair annotations */ - execString = ":ExecGroup-" + - Integer.toString(nExecs) + ':' + tag + ':'; - } - - /** - * Create a thread to listen and read from input stream, in. buffer - * the data that is read until a marker which equals lineSeparator - * is read. Once such a string has been discovered; write out an - * annotation string followed by the buffered data and a line - * separator. - */ - public void run() { - byte[] buf = new byte[256]; - int count; - - try { - /* read bytes till there are no more. */ - while ((count = in.read(buf)) != -1) { - write(buf, 0, count); - } - - /* flush internal buffer... may not have ended on a line - * separator, we also need a last annotation if - * something was left. - */ - String lastInBuffer = bufOut.toString(); - bufOut.reset(); - if (lastInBuffer.length() > 0) { - out.println (createAnnotation() + lastInBuffer); - out.flush(); // add a line separator - // to make output nicer - } - - } catch (IOException e) { - } - } - - /** - * Write a subarray of bytes. Pass each through write byte method. - */ - private void write(byte b[], int off, int len) throws IOException { - - if (len < 0) { - throw new ArrayIndexOutOfBoundsException(len); - } - for (int i = 0; i < len; ++ i) { - write(b[off + i]); - } - } - - /** - * Write a byte of data to the stream. If we have not matched a - * line separator string, then the byte is appended to the internal - * buffer. If we have matched a line separator, then the currently - * buffered line is sent to the output writer with a prepended - * annotation string. - */ - private void write(byte b) throws IOException { - int i = 0; - - /* shift current to the left */ - for (i = 1 ; i < (currSep.length); i ++) { - currSep[i-1] = currSep[i]; - } - currSep[i-1] = b; - bufOut.write(b); - - /* enough characters for a separator? */ - if ( (cLast >= (lineSeparatorLength - 1)) && - (lineSeparator.equals(new String(currSep))) ) { - - cLast = 0; - - /* write prefix through to underlying byte stream */ - out.print(createAnnotation() + bufOut.toString()); - out.flush(); - bufOut.reset(); - - if (out.checkError()) { - throw new IOException - ("PipeWriter: IO Exception when"+ - " writing to output stream."); - } - - } else { - cLast++; - } - } - - /** - * Create an annotation string to be printed out after - * a new line and end of stream. - */ - private String createAnnotation() { - - /* construct prefix for log messages: - * date/time stamp... - */ - return ((new Date()).toString() + - /* ... print pair # ... */ - (execString)); - } - - /** - * Allow plugging together two pipes at a time, to associate - * output from an execed process. This is the only publicly - * accessible method of this object; this helps ensure that - * synchronization will not be an issue in the annotation - * process. - * - * @param in input stream from which pipe input comes - * @param out output stream to which log messages will be sent - * @param in1 input stream from which pipe input comes - * @param out1 output stream to which log messages will be sent - */ - static void plugTogetherPair(InputStream in, - OutputStream out, - InputStream in1, - OutputStream out1) { - Thread inThread = null; - Thread outThread = null; - - int nExecs = getNumExec(); - - /* start RMI threads to read output from child process */ - inThread = AccessController.doPrivileged( - new NewThreadAction(new PipeWriter(in, out, "out", nExecs), - "out", true)); - outThread = AccessController.doPrivileged( - new NewThreadAction(new PipeWriter(in1, out1, "err", nExecs), - "err", true)); - inThread.start(); - outThread.start(); - } - - private static synchronized int getNumExec() { - return numExecs++; - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupImpl.java b/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupImpl.java deleted file mode 100644 index f1d950e3887..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupImpl.java +++ /dev/null @@ -1,502 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.io.IOException; -import java.lang.reflect.Constructor; -import java.lang.reflect.InvocationTargetException; -import java.net.ServerSocket; -import java.rmi.MarshalledObject; -import java.rmi.NoSuchObjectException; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.Activatable; -import java.rmi.activation.ActivationDesc; -import java.rmi.activation.ActivationException; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationID; -import java.rmi.activation.UnknownObjectException; -import java.rmi.server.RMIClassLoader; -import java.rmi.server.RMIServerSocketFactory; -import java.rmi.server.RMISocketFactory; -import java.rmi.server.UnicastRemoteObject; -import java.security.AccessController; -import java.security.PrivilegedActionException; -import java.security.PrivilegedExceptionAction; -import java.util.ArrayList; -import java.util.Hashtable; -import java.util.List; -import sun.rmi.registry.RegistryImpl; - -/** - * The default activation group implementation. - * - * @author Ann Wollrath - * @since 1.2 - * @see java.rmi.activation.ActivationGroup - */ -@SuppressWarnings("removal") -public class ActivationGroupImpl extends ActivationGroup { - - // use serialVersionUID from JDK 1.2.2 for interoperability - private static final long serialVersionUID = 5758693559430427303L; - - /** maps persistent IDs to activated remote objects */ - private final Hashtable active = - new Hashtable<>(); - private boolean groupInactive = false; - private final ActivationGroupID groupID; - @SuppressWarnings("serial") // Conditionally serializable - private final List lockedIDs = new ArrayList<>(); - - /** - * Creates a default activation group implementation. - * - * @param id the group's identifier - * @param data ignored - */ - public ActivationGroupImpl(ActivationGroupID id, MarshalledObject data) - throws RemoteException - { - super(id); - groupID = id; - - /* - * Unexport activation group impl and attempt to export it on - * an unshared anonymous port. See 4692286. - */ - unexportObject(this, true); - RMIServerSocketFactory ssf = new ServerSocketFactoryImpl(); - UnicastRemoteObject.exportObject(this, 0, null, ssf); - - if (System.getSecurityManager() == null) { - try { - // Provide a default security manager. - System.setSecurityManager(new SecurityManager()); - - } catch (Exception e) { - throw new RemoteException("unable to set security manager", e); - } - } - } - - /** - * Trivial server socket factory used to export the activation group - * impl on an unshared port. - */ - private static class ServerSocketFactoryImpl - implements RMIServerSocketFactory - { - public ServerSocket createServerSocket(int port) throws IOException - { - RMISocketFactory sf = RMISocketFactory.getSocketFactory(); - if (sf == null) { - sf = RMISocketFactory.getDefaultSocketFactory(); - } - return sf.createServerSocket(port); - } - } - - /* - * Obtains a lock on the ActivationID id before returning. Allows only one - * thread at a time to hold a lock on a particular id. If the lock for id - * is in use, all requests for an equivalent (in the Object.equals sense) - * id will wait for the id to be notified and use the supplied id as the - * next lock. The caller of "acquireLock" must execute the "releaseLock" - * method" to release the lock and "notifyAll" waiters for the id lock - * obtained from this method. The typical usage pattern is as follows: - * - * try { - * acquireLock(id); - * // do stuff pertaining to id... - * } finally { - * releaseLock(id); - * checkInactiveGroup(); - * } - */ - private void acquireLock(ActivationID id) { - - ActivationID waitForID; - - for (;;) { - - synchronized (lockedIDs) { - int index = lockedIDs.indexOf(id); - if (index < 0) { - lockedIDs.add(id); - return; - } else { - waitForID = lockedIDs.get(index); - } - } - - synchronized (waitForID) { - synchronized (lockedIDs) { - int index = lockedIDs.indexOf(waitForID); - if (index < 0) continue; - ActivationID actualID = lockedIDs.get(index); - if (actualID != waitForID) - /* - * don't wait on an id that won't be notified. - */ - continue; - } - - try { - waitForID.wait(); - } catch (InterruptedException ignore) { - } - } - } - - } - - /* - * Releases the id lock obtained via the "acquireLock" method and then - * notifies all threads waiting on the lock. - */ - private void releaseLock(ActivationID id) { - synchronized (lockedIDs) { - id = lockedIDs.remove(lockedIDs.indexOf(id)); - } - - synchronized (id) { - id.notifyAll(); - } - } - - /** - * Creates a new instance of an activatable remote object. The - * Activator calls this method to create an activatable - * object in this group. This method should be idempotent; a call to - * activate an already active object should return the previously - * activated object. - * - * Note: this method assumes that the Activator will only invoke - * newInstance for the same object in a serial fashion (i.e., - * the activator will not allow the group to see concurrent requests - * to activate the same object. - * - * @param id the object's activation identifier - * @param desc the object's activation descriptor - * @return a marshalled object containing the activated object's stub - */ - public MarshalledObject - newInstance(final ActivationID id, - final ActivationDesc desc) - throws ActivationException, RemoteException - { - RegistryImpl.checkAccess("ActivationInstantiator.newInstance"); - - if (!groupID.equals(desc.getGroupID())) - throw new ActivationException("newInstance in wrong group"); - - try { - acquireLock(id); - synchronized (this) { - if (groupInactive == true) - throw new InactiveGroupException("group is inactive"); - } - - ActiveEntry entry = active.get(id); - if (entry != null) - return entry.mobj; - - String className = desc.getClassName(); - - final Class cl = - RMIClassLoader.loadClass(desc.getLocation(), className) - .asSubclass(Remote.class); - Remote impl = null; - - final Thread t = Thread.currentThread(); - final ClassLoader savedCcl = t.getContextClassLoader(); - ClassLoader objcl = cl.getClassLoader(); - final ClassLoader ccl = covers(objcl, savedCcl) ? objcl : savedCcl; - - /* - * Fix for 4164971: allow non-public activatable class - * and/or constructor, create the activatable object in a - * privileged block - */ - try { - /* - * The code below is in a doPrivileged block to - * protect against user code which code might have set - * a global socket factory (in which case application - * code would be on the stack). - */ - impl = AccessController.doPrivileged( - new PrivilegedExceptionAction() { - public Remote run() throws InstantiationException, - NoSuchMethodException, IllegalAccessException, - InvocationTargetException - { - Constructor constructor = - cl.getDeclaredConstructor( - ActivationID.class, MarshalledObject.class); - constructor.setAccessible(true); - try { - /* - * Fix for 4289544: make sure to set the - * context class loader to be the class - * loader of the impl class before - * constructing that class. - */ - t.setContextClassLoader(ccl); - return constructor.newInstance(id, - desc.getData()); - } finally { - t.setContextClassLoader(savedCcl); - } - } - }); - } catch (PrivilegedActionException pae) { - Throwable e = pae.getException(); - - // narrow the exception's type and rethrow it - if (e instanceof InstantiationException) { - throw (InstantiationException) e; - } else if (e instanceof NoSuchMethodException) { - throw (NoSuchMethodException) e; - } else if (e instanceof IllegalAccessException) { - throw (IllegalAccessException) e; - } else if (e instanceof InvocationTargetException) { - throw (InvocationTargetException) e; - } else if (e instanceof RuntimeException) { - throw (RuntimeException) e; - } else if (e instanceof Error) { - throw (Error) e; - } - } - - entry = new ActiveEntry(impl); - active.put(id, entry); - return entry.mobj; - - } catch (NoSuchMethodException | NoSuchMethodError e) { - /* user forgot to provide activatable constructor? - * or code recompiled and user forgot to provide - * activatable constructor? - */ - throw new ActivationException - ("Activatable object must provide an activation"+ - " constructor", e ); - - } catch (InvocationTargetException e) { - throw new ActivationException("exception in object constructor", - e.getCause()); - - } catch (Exception e) { - throw new ActivationException("unable to activate object", e); - } finally { - releaseLock(id); - checkInactiveGroup(); - } - } - - - /** - * The group's inactiveObject method is called - * indirectly via a call to the Activatable.inactive - * method. A remote object implementation must call - * Activatable's inactive method when - * that object deactivates (the object deems that it is no longer - * active). If the object does not call - * Activatable.inactive when it deactivates, the - * object will never be garbage collected since the group keeps - * strong references to the objects it creates.

- * - * The group's inactiveObject method - * unexports the remote object from the RMI runtime so that the - * object can no longer receive incoming RMI calls. This call will - * only succeed if the object has no pending/executing calls. If - * the object does have pending/executing RMI calls, then false - * will be returned. - * - * If the object has no pending/executing calls, the object is - * removed from the RMI runtime and the group informs its - * ActivationMonitor (via the monitor's - * inactiveObject method) that the remote object is - * not currently active so that the remote object will be - * re-activated by the activator upon a subsequent activation - * request. - * - * @param id the object's activation identifier - * @return true if the operation succeeds (the operation will - * succeed if the object in currently known to be active and is - * either already unexported or is currently exported and has no - * pending/executing calls); false is returned if the object has - * pending/executing calls in which case it cannot be deactivated - * @exception UnknownObjectException if object is unknown (may already - * be inactive) - * @exception RemoteException if call informing monitor fails - */ - public boolean inactiveObject(ActivationID id) - throws ActivationException, UnknownObjectException, RemoteException - { - - try { - acquireLock(id); - synchronized (this) { - if (groupInactive == true) - throw new ActivationException("group is inactive"); - } - - ActiveEntry entry = active.get(id); - if (entry == null) { - // REMIND: should this be silent? - throw new UnknownObjectException("object not active"); - } - - try { - if (Activatable.unexportObject(entry.impl, false) == false) - return false; - } catch (NoSuchObjectException allowUnexportedObjects) { - } - - try { - super.inactiveObject(id); - } catch (UnknownObjectException allowUnregisteredObjects) { - } - - active.remove(id); - - } finally { - releaseLock(id); - checkInactiveGroup(); - } - - return true; - } - - /* - * Determines if the group has become inactive and - * marks it as such. - */ - private void checkInactiveGroup() { - boolean groupMarkedInactive = false; - synchronized (this) { - if (active.size() == 0 && lockedIDs.size() == 0 && - groupInactive == false) - { - groupInactive = true; - groupMarkedInactive = true; - } - } - - if (groupMarkedInactive) { - try { - super.inactiveGroup(); - } catch (Exception ignoreDeactivateFailure) { - } - - try { - UnicastRemoteObject.unexportObject(this, true); - } catch (NoSuchObjectException allowUnexportedGroup) { - } - } - } - - /** - * The group's activeObject method is called when an - * object is exported (either by Activatable object - * construction or an explicit call to - * Activatable.exportObject. The group must inform its - * ActivationMonitor that the object is active (via - * the monitor's activeObject method) if the group - * hasn't already done so. - * - * @param id the object's identifier - * @param impl the remote object implementation - * @exception UnknownObjectException if object is not registered - * @exception RemoteException if call informing monitor fails - */ - public void activeObject(ActivationID id, Remote impl) - throws ActivationException, UnknownObjectException, RemoteException - { - - try { - acquireLock(id); - synchronized (this) { - if (groupInactive == true) - throw new ActivationException("group is inactive"); - } - if (!active.containsKey(id)) { - ActiveEntry entry = new ActiveEntry(impl); - active.put(id, entry); - // created new entry, so inform monitor of active object - try { - super.activeObject(id, entry.mobj); - } catch (RemoteException e) { - // daemon can still find it by calling newInstance - } - } - } finally { - releaseLock(id); - checkInactiveGroup(); - } - } - - /** - * Entry in table for active object. - */ - private static class ActiveEntry { - Remote impl; - MarshalledObject mobj; - - ActiveEntry(Remote impl) throws ActivationException { - this.impl = impl; - try { - this.mobj = new MarshalledObject(impl); - } catch (IOException e) { - throw new - ActivationException("failed to marshal remote object", e); - } - } - } - - /** - * Returns true if the first argument is either equal to, or is a - * descendant of, the second argument. Null is treated as the root of - * the tree. - */ - private static boolean covers(ClassLoader sub, ClassLoader sup) { - if (sup == null) { - return true; - } else if (sub == null) { - return false; - } - do { - if (sub == sup) { - return true; - } - sub = sub.getParent(); - } while (sub != null); - return false; - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupInit.java b/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupInit.java deleted file mode 100644 index 24257772112..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/ActivationGroupInit.java +++ /dev/null @@ -1,86 +0,0 @@ -/* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.rmi.activation.ActivationGroupDesc; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationGroup; - -/** - * This is the bootstrap code to start a VM executing an activation - * group. - * - * The activator spawns (as a child process) an activation group as needed - * and directs activation requests to the appropriate activation - * group. After spawning the VM, the activator passes some - * information to the bootstrap code via its stdin: - *

- * - * When the bootstrap VM starts executing, it reads group id and - * descriptor from its stdin so that it can create the activation - * group for the VM. - * - * @author Ann Wollrath - */ -@SuppressWarnings("removal") -public abstract class ActivationGroupInit -{ - /** - * Main program to start a VM for an activation group. - */ - public static void main(String args[]) - { - try { - if (System.getSecurityManager() == null) { - System.setSecurityManager(new SecurityManager()); - } - // read group id, descriptor, and incarnation number from stdin - MarshalInputStream in = new MarshalInputStream(System.in); - ActivationGroupID id = (ActivationGroupID)in.readObject(); - ActivationGroupDesc desc = (ActivationGroupDesc)in.readObject(); - long incarnation = in.readLong(); - - // create and set group for the VM - ActivationGroup.createGroup(id, desc, incarnation); - } catch (Exception e) { - System.err.println("Exception in starting ActivationGroupInit:"); - e.printStackTrace(); - } finally { - try { - System.in.close(); - // note: system out/err shouldn't be closed - // since the parent may want to read them. - } catch (Exception ex) { - // ignore exceptions - } - } - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/InactiveGroupException.java b/src/java.rmi/share/classes/sun/rmi/server/InactiveGroupException.java deleted file mode 100644 index 71cd793b92a..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/InactiveGroupException.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2005, 2020, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package sun.rmi.server; - -import java.rmi.activation.ActivationException; - -/** - * Thrown if a local or remote call is made on a group implementation - * instance that is inactive. - * - * @author Sun Microsystems, Inc. - * - * @since 1.6 - */ -@SuppressWarnings("removal") -public class InactiveGroupException extends ActivationException { - - private static final long serialVersionUID = -7491041778450214975L; - - /** - * Constructs an instance with the specified detail message. - * - * @param s the detail message - */ - public InactiveGroupException(String s) { - super(s); - } -} diff --git a/src/java.rmi/share/classes/sun/rmi/server/MarshalInputStream.java b/src/java.rmi/share/classes/sun/rmi/server/MarshalInputStream.java index d04e9292fd5..032ee3c3e3a 100644 --- a/src/java.rmi/share/classes/sun/rmi/server/MarshalInputStream.java +++ b/src/java.rmi/share/classes/sun/rmi/server/MarshalInputStream.java @@ -86,28 +86,13 @@ public class MarshalInputStream extends ObjectInputStream { private boolean useCodebaseOnly = useCodebaseOnlyProperty; /* - * Fix for 4179055: The remote object services inside the - * activation daemon use stubs that are in the package - * sun.rmi.server. Classes for these stubs should be loaded from - * the classpath by RMI system code and not by the normal - * unmarshalling process as applications should not need to have - * permission to access the sun implementation classes. - * - * Note: this fix should be redone when API changes may be - * integrated - * * During parameter unmarshalling RMI needs to explicitly permit - * access to three sun.* stub classes + * access to sun.* stub classes */ static { try { - String system = - "sun.rmi.server.Activation$ActivationSystemImpl_Stub"; String registry = "sun.rmi.registry.RegistryImpl_Stub"; - - permittedSunClasses.put(system, Class.forName(system)); permittedSunClasses.put(registry, Class.forName(registry)); - } catch (ClassNotFoundException e) { throw new NoClassDefFoundError("Missing system class: " + e.getMessage()); diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid.properties deleted file mode 100644 index 54d6fc9a774..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid.properties +++ /dev/null @@ -1,136 +0,0 @@ -# -# -# Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=\ - rmid was launched from inetd with an invalid status (must be wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=\ - port cannot be specified if rmid is launched from inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=\ - port is not a number - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=\ - -port option requires argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=\ - -log option requires argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=\ - -log option required - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=\ - invalid option: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=\ - Activation.main: an exception occurred: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=\ - ActivatorImpl: unable to locate java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=\ - rmid startup with inherited channel - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=\ - Activation.main: invalid exec policy class - -# "rmid" should not be translated -rmid.exec.policy.exception=\ - rmid: attempt to obtain exec policy throws: - -# "rmid" should not be translated -rmid.exec.command=\ - rmid: debugExec: running "{0}" - -# "rmid" should not be translated -rmid.group.inactive=\ - rmid: activation group inactive: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=\ - Activation.main: warning: sun.rmi.activation.execPolicy system\n\ - property unspecified and no ExecPermissions/ExecOptionPermissions\n\ - granted; subsequent activation attempts may fail due to unsuccessful\n\ - ExecPermission/ExecOptionPermission permission checks. \n\ - To configure security, refer to the rmid documentation.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Usage: {0} \ -\n\ -\nwhere include:\ -\n -port Specify port for rmid to use\ -\n -log Specify directory in which rmid writes log\ -\n -stop Stop current invocation of rmid (for specified port)\ -\n -C Pass argument to each child process (activation group)\ -\n -J Pass argument to the java interpreter\ -\n\ - -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=\ - activation daemon shut down - -# "rmid" should not be translated -rmid.restart.group.warning=\ -\nrmid: (WARNING) restart group throws: - -# "rmid" should not be translated -rmid.restart.service.warning=\ -\nrmid: (WARNING) restart service throws: - -# "rmid" should not be translated -rmid.log.update.warning=\ -\nrmid: (WARNING) log update throws: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\ -\nrmid: (SEVERE) log snapshot throws: - -# "rmid" should not be translated -rmid.log.recover.warning=\ -\nrmid: (WARNING) {0}: skipping log record during recovery: - -# "rmid" should not be translated -rmid.deprecation.warning=\ - rmid: (WARNING) The RMI Activation mechanism and the rmid tool\n\ - have been deprecated for removal. They may be removed from a future\n\ - version of the Java Platform. diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_de.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_de.properties deleted file mode 100644 index 757228cc3cb..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_de.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid wurde mit einem ung\u00FCltigen Status (muss "wait" sein) von inetd gestartet - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=Port kann nicht angegeben werden, wenn rmid von inetd gestartet wird - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=Port ist keine Zahl - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=F\u00FCr Option -port ist ein Argument erforderlich - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=F\u00FCr Option -log ist ein Argument erforderlich - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=Option -log ist erforderlich - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=Ung\u00FCltige Option: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: Es ist eine Ausnahme aufgetreten: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: java.home konnte nicht gefunden werden - -# "rmid" should not be translated -rmid.inherited.channel.info=rmid-Start mit \u00FCbernommenem Kanal - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: Ung\u00FCltige exec-Policy-Klasse - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: Versuch, die exec-Policy abzurufen, l\u00F6st Folgendes aus: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: "{0}" wird ausgef\u00FChrt - -# "rmid" should not be translated -rmid.group.inactive=rmid: Aktivierungsgruppe inaktiv: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: Warnung: Es wurde keine Systemeigenschaft sun.rmi.activation.execPolicy\nangegeben und keine ExecPermissions/ExecOptionPermissions\nerteilt. Nachfolgende Aktivierungsversuche scheitern m\u00F6glicherweise aufgrund\nnicht erfolgreicher Berechtigungspr\u00FCfungen ExecPermission/ExecOptionPermission. \nInformationen zur Sicherheitskonfiguration finden Sie in der rmid-Dokumentation.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Verwendung: {0} \n\nwobei folgende m\u00F6glich sind:\n -port Port f\u00FCr rmid angeben\n -log Verzeichnis, in das rmid die Logdatei schreibt, angeben\n -stop Aktuellen Aufruf von rmid stoppen (f\u00FCr den angegebenen Port)\n -C Argument an jeden untergeordneten Prozess (Aktivierungsgruppe) \u00FCbergeben\n -J Argument an den Java-Interpreter \u00FCbergeben\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=Aktivierungsdaemon heruntergefahren - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (WARNUNG) Neustart der Gruppe l\u00F6st Folgendes aus: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (WARNUNG) Neustart des Service l\u00F6st Folgendes aus: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (WARNUNG) Logupdate l\u00F6st Folgendes aus: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (SCHWERWIEGEND) Log-Snapshot l\u00F6st Folgendes aus: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (WARNUNG) {0}: Logdatensatz wird bei Wiederherstellung \u00FCbersprungen: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_es.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_es.properties deleted file mode 100644 index 1cc1b6477b8..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_es.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid se ha iniciado desde inetd con un estado no v\u00E1lido (debe ser wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=no se puede especificar el puerto si rmid se ha iniciado desde inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=el puerto no es un n\u00FAmero - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=la opci\u00F3n -port requiere un argumento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=la opci\u00F3n -log requiere un argumento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=la opci\u00F3n -log es obligatoria - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=opci\u00F3n no permitida: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: se ha producido una excepci\u00F3n: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: no se ha encontrado java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=inicio de rmid con canal heredado - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: clase de pol\u00EDtica de ejecuci\u00F3n no v\u00E1lida - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: el intento de obtener la pol\u00EDtica de ejecuci\u00F3n devuelve: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: en ejecuci\u00F3n "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid: grupo de activaci\u00F3n inactivo: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: advertencia: no se han especificado las propiedades del sistema sun.rmi.activation.execPolicy\ny no se han otorgado ExecPermissions/ExecOptionPermissions;\nlos intentos de activaci\u00F3n posteriores pueden fallar debido a\ncomprobaciones de permiso ExecPermission/ExecOptionPermission incorrectas. \nPara configurar la seguridad, consulte la documentaci\u00F3n sobre rmid.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Sintaxis: {0} \n\ndonde incluye:\n -port Especificar puerto para uso de rmid\n -log Especificar directorio en el que rmid escribir\u00E1 el registro\n -stop Parar la llamada actual de rmid (para el puerto especificado)\n -C Pasar argumento a cada uno de los procesos secundarios (grupo de activaci\u00F3n)\n -J Pasar argumento al int\u00E9rprete de Java\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=daemon de activaci\u00F3n cerrado - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (ADVERTENCIA) el reinicio del grupo devuelve: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (ADVERTENCIA) el reinicio del servicio devuelve: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (ADVERTENCIA) la actualizaci\u00F3n del log indica: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (GRAVE) la instant\u00E1nea del log indica: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (ADVERTENCIA) {0}: se omitir\u00E1 el registro del log durante la recuperaci\u00F3n: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_fr.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_fr.properties deleted file mode 100644 index 807b24a16e4..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_fr.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid a \u00E9t\u00E9 lanc\u00E9 depuis inetd avec un statut non valide (doit \u00EAtre wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=impossible de sp\u00E9cifier port si rmid est lanc\u00E9 depuis inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=port n'est pas un num\u00E9ro - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=l'option -port exige un argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=l'option -log exige un argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=option -log obligatoire - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=option non admise : {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main : une exception s''est produite - {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl : impossible de localiser java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=d\u00E9marrage de rmid avec le canal existant - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main : classe de r\u00E8gle exec incorrecte - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid : tentative d'obtention des basculements de classes exec : - -# "rmid" should not be translated -rmid.exec.command=rmid : debugExec : ex\u00E9cution de "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid : groupe d''activation inactif : {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main : avertissement : propri\u00E9t\u00E9 syst\u00E8me sun.rmi.activation.execPolicy\nnon indiqu\u00E9e et ExecPermissions/ExecOptionPermissions\nnon accord\u00E9s ; les tentatives d'activation suivantes risquent d'\u00E9chouer en raison de la v\u00E9rification des droits\nExecPermission/ExecOptionPermission. \nPour configurer la s\u00E9curit\u00E9, reportez-vous \u00E0 la documentation rmid.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Syntaxe : {0} \n\no\u00F9 comprend :\n -port Port que rmid doit utiliser\n -log R\u00E9pertoire o\u00F9 rmid enregistre le journal\n -stop Arr\u00EAter l''appel en cours de rmid (pour le port sp\u00E9cifi\u00E9)\n -C Transmet l''argument \u00E0 chaque processus enfant (groupe d''activation)\n -J Transmet l''argument \u00E0 l''interpr\u00E9teur Java\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=d\u00E9mon d'activation arr\u00EAt\u00E9 - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid : (AVERTISSEMENT) red\u00E9marrer les basculements de groupes : - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid : (AVERTISSEMENT) red\u00E9marrer les basculements de services : - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid : (AVERTISSEMENT) consigner les basculements de mises \u00E0 jour : - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid : (GRAVE) consigner les basculements de clich\u00E9s : - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid : (AVERTISSEMENT) {0} : enregistrement du journal ignor\u00E9 lors de la r\u00E9cup\u00E9ration : diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_it.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_it.properties deleted file mode 100644 index 21c8b8f35c1..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_it.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid \u00E8 stato avviato da inetd con uno stato non valido (diverso da wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=non \u00E8 possibile specificare la porta se rmid viene avviato da inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=la porta non \u00E8 un numero - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=L'opzione -port richiede un argomento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=L'opzione -log richiede un argomento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=\u00C8 richiesta l'opzione -log - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=opzione non valida: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: si \u00E8 verificata un''eccezione: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: impossibile individuare java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=Avvio di rmid con canale ereditato - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: classe di criteri eseguibili non valida - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: il tentativo di ottenere i criteri di esecuzione ha restituito: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: esecuzione di "{0}" in corso - -# "rmid" should not be translated -rmid.group.inactive=rmid: gruppo attivazione inattivo: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: avvertenza: propriet\u00E0 di sistema sun.rmi.activation.execPolicy\nnon specificata e nessun ExecPermissions/ExecOptionPermissions\nconcesso. I tentativi di attivazione successivi potrebbero fallire a causa di \ncontrolli di autorizzazione ExecPermission/ExecOptionPermission non riusciti.\nPer configurare la sicurezza, fare riferimento alla documentazione rmid.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Uso: {0} \n\ndove include:\n -port Specifica la porta usata da rmid\n -log Specifica la directory in cui rmid scrive il log\n -stop Arresta l''invocazione corrente di rmid (per la porta specificata)\n -C Passa l''argomento a ciascun processo figlio (gruppo di attivazione)\n -J Passa l''argomento all''interprete java\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=daemon di attivazione terminato - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (AVVERTENZA) il riavvio del gruppo ha restituito: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (AVVERTENZA) il riavvio del servizio ha restituito: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (AVVERTENZA) il log dell'aggiornamento ha restituito: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (GRAVE) snapshot log ha restituito: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (AVVERTENZA) {0}: record del log ignorato durante il recupero: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ja.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ja.properties deleted file mode 100644 index 37badc64440..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ja.properties +++ /dev/null @@ -1,99 +0,0 @@ -# -# -# Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid\u304Cinetd\u304B\u3089\u7121\u52B9\u306A\u72B6\u614B\u3067\u8D77\u52D5\u3055\u308C\u307E\u3057\u305F(wait\u3067\u3042\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=rmid\u304Cinetd\u304B\u3089\u8D77\u52D5\u3055\u308C\u305F\u5834\u5408\u3001\u30DD\u30FC\u30C8\u306F\u6307\u5B9A\u3067\u304D\u307E\u305B\u3093 - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=port\u306F\u756A\u53F7\u3067\u306F\u3042\u308A\u307E\u305B\u3093 - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=-port\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u306F\u5F15\u6570\u304C\u5FC5\u8981\u3067\u3059 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=-log\u30AA\u30D7\u30B7\u30E7\u30F3\u306B\u306F\u5F15\u6570\u304C\u5FC5\u8981\u3067\u3059 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=-log\u30AA\u30D7\u30B7\u30E7\u30F3\u304C\u5FC5\u8981\u3067\u3059 - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=\u7121\u52B9\u306A\u30AA\u30D7\u30B7\u30E7\u30F3: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: \u4F8B\u5916\u304C\u767A\u751F\u3057\u307E\u3057\u305F: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: java.home\u3092\u691C\u51FA\u3067\u304D\u307E\u305B\u3093 - -# "rmid" should not be translated -rmid.inherited.channel.info=rmid\u306F\u7D99\u627F\u3055\u308C\u305F\u30C1\u30E3\u30CD\u30EB\u3067\u8D77\u52D5\u3057\u307E\u3059 - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: \u7121\u52B9\u306A\u5B9F\u884C\u30DD\u30EA\u30B7\u30FC\u30FB\u30AF\u30E9\u30B9\u3067\u3059 - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: \u5B9F\u884C\u30DD\u30EA\u30B7\u30FC\u306E\u53D6\u5F97\u3067\u6B21\u304C\u30B9\u30ED\u30FC\u3055\u308C\u307E\u3057\u305F: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: "{0}"\u3092\u5B9F\u884C\u4E2D - -# "rmid" should not be translated -rmid.group.inactive=rmid: \u8D77\u52D5\u30B0\u30EB\u30FC\u30D7\u304C\u505C\u6B62\u3057\u3066\u3044\u307E\u3059: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: \u8B66\u544A:sun.rmi.activation.execPolicy\u30B7\u30B9\u30C6\u30E0\n\u30D7\u30ED\u30D1\u30C6\u30A3\u304C\u6307\u5B9A\u3055\u308C\u3066\u3044\u306A\u3044\u3001\u307E\u305F\u306FExecPermissions/ExecOptionPermissions\u304C\n\u8A31\u53EF\u3055\u308C\u307E\u305B\u3093\u3002ExecPermissions/ExecOptionPermissions\u30A2\u30AF\u30BB\u30B9\u6A29\u691C\u67FB\u3067\u8A31\u53EF\u3055\u308C\n\u306A\u3044\u305F\u3081\u3001\u5F8C\u306B\u7D9A\u304F\u8D77\u52D5\u306F\u5931\u6557\u3059\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002\n\u30BB\u30AD\u30E5\u30EA\u30C6\u30A3\u3092\u78BA\u8A8D\u3059\u308B\u306B\u306F\u3001rmid\u306E\u30C9\u30AD\u30E5\u30E1\u30F3\u30C8\u3092\u53C2\u7167\u3057\u3066\u304F\u3060\u3055\u3044\u3002\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=\u4F7F\u7528\u65B9\u6CD5: {0} \n\n\u306B\u306F\u6B21\u306E\u3082\u306E\u304C\u3042\u308A\u307E\u3059\u3002\n -port rmid\u304C\u4F7F\u7528\u3059\u308B\u30DD\u30FC\u30C8\u3092\u6307\u5B9A\u3059\u308B\n -log rmid\u304C\u30ED\u30B0\u3092\u66F8\u304D\u8FBC\u3080\u30C7\u30A3\u30EC\u30AF\u30C8\u30EA\u3092\u6307\u5B9A\u3059\u308B\n -stop \u6307\u5B9A\u30DD\u30FC\u30C8\u306B\u5BFE\u3059\u308Brmid\u306E\u73FE\u5728\u306E\u547C\u51FA\u3057\u3092\u4E2D\u6B62\u3059\u308B\n -C \u5404\u5B50\u30D7\u30ED\u30BB\u30B9(\u8D77\u52D5\u30B0\u30EB\u30FC\u30D7)\u306B\u5F15\u6570\u3092\u6E21\u3059\n -J java\u30A4\u30F3\u30BF\u30D7\u30EA\u30BF\u306B\u5F15\u6570\u3092\u6E21\u3059\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=\u8D77\u52D5\u30C7\u30FC\u30E2\u30F3\u304C\u505C\u6B62\u3057\u307E\u3057\u305F - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (\u8B66\u544A)\u30B0\u30EB\u30FC\u30D7\u306E\u518D\u8D77\u52D5\u3067\u6B21\u304C\u30B9\u30ED\u30FC\u3055\u308C\u307E\u3057\u305F: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (\u8B66\u544A)\u30B5\u30FC\u30D3\u30B9\u306E\u518D\u8D77\u52D5\u3067\u6B21\u304C\u30B9\u30ED\u30FC\u3055\u308C\u307E\u3057\u305F: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (\u8B66\u544A)\u30ED\u30B0\u66F4\u65B0\u3067\u6B21\u304C\u30B9\u30ED\u30FC\u3055\u308C\u307E\u3057\u305F: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (\u91CD\u5927)\u30ED\u30B0\u30FB\u30B9\u30CA\u30C3\u30D7\u30B7\u30E7\u30C3\u30C8\u3067\u6B21\u304C\u30B9\u30ED\u30FC\u3055\u308C\u307E\u3057\u305F: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (\u8B66\u544A){0}: \u56DE\u5FA9\u4E2D\u306E\u30ED\u30B0\u30FB\u30EC\u30B3\u30FC\u30C9\u306E\u30B9\u30AD\u30C3\u30D7: - -# "rmid" should not be translated -rmid.deprecation.warning=rmid: (\u8B66\u544A) RMI\u8D77\u52D5\u30E1\u30AB\u30CB\u30BA\u30E0\u304A\u3088\u3073rmid\u30C4\u30FC\u30EB\u306F\u524A\u9664\u4E88\u5B9A\u306E\u305F\u3081\n\u975E\u63A8\u5968\u306B\u306A\u308A\u307E\u3057\u305F\u3002\u3053\u308C\u3089\u306F\u3001Java\u30D7\u30E9\u30C3\u30C8\u30D5\u30A9\u30FC\u30E0\u306E\u5C06\u6765\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\n\u304B\u3089\u524A\u9664\u3055\u308C\u308B\u53EF\u80FD\u6027\u304C\u3042\u308A\u307E\u3059\u3002 diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ko.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ko.properties deleted file mode 100644 index da505f2c3d8..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_ko.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid\uAC00 \uBD80\uC801\uD569\uD55C \uC0C1\uD0DC\uC758 inetd\uC5D0\uC11C \uC2DC\uC791\uB418\uC5C8\uC2B5\uB2C8\uB2E4. \uC0C1\uD0DC\uB294 wait\uC5EC\uC57C \uD569\uB2C8\uB2E4. - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=rmid\uAC00 inetd\uC5D0\uC11C \uC2DC\uC791\uB41C \uACBD\uC6B0 \uD3EC\uD2B8\uB97C \uC9C0\uC815\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4. - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=\uD3EC\uD2B8\uB294 \uC22B\uC790\uAC00 \uC544\uB2D9\uB2C8\uB2E4. - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=-port \uC635\uC158\uC744 \uC0AC\uC6A9\uD558\uB824\uBA74 \uC778\uC218\uAC00 \uD544\uC694\uD569\uB2C8\uB2E4. - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=-log \uC635\uC158\uC744 \uC0AC\uC6A9\uD558\uB824\uBA74 \uC778\uC218\uAC00 \uD544\uC694\uD569\uB2C8\uB2E4. - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=-log \uC635\uC158\uC774 \uD544\uC694\uD569\uB2C8\uB2E4. - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=\uC798\uBABB\uB41C \uC635\uC158: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: \uC608\uC678\uC0AC\uD56D \uBC1C\uC0DD: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: java.home\uC744 \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4. - -# "rmid" should not be translated -rmid.inherited.channel.info=\uC0C1\uC18D\uB41C \uCC44\uB110\uC744 \uC0AC\uC6A9\uD558\uC5EC rmid \uC2DC\uC791 - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: \uC2E4\uD589 \uC815\uCC45 \uD074\uB798\uC2A4\uAC00 \uBD80\uC801\uD569\uD569\uB2C8\uB2E4. - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: \uC2E4\uD589 \uC815\uCC45\uC744 \uAC00\uC838\uC624\uB824\uB294 \uC2DC\uB3C4\uB85C \uBC1C\uC0DD\uD55C \uC608\uC678\uC0AC\uD56D: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: "{0}" \uC2E4\uD589 \uC911 - -# "rmid" should not be translated -rmid.group.inactive=rmid: \uD65C\uC131\uD654 \uADF8\uB8F9 \uBE44\uD65C\uC131: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: \uACBD\uACE0: sun.rmi.activation.execPolicy \uC2DC\uC2A4\uD15C \uC18D\uC131\uC774\n\uC9C0\uC815\uB418\uC9C0 \uC54A\uC558\uC73C\uBA70 ExecPermissions/ExecOptionPermissions\uAC00 \uBD80\uC5EC\uB418\uC9C0\n\uC54A\uC558\uC2B5\uB2C8\uB2E4. \uD65C\uC131\uD654\uB97C \uACC4\uC18D \uC2DC\uB3C4\uD558\uBA74 ExecPermission/ExecOptionPermission\n\uAD8C\uD55C \uAC80\uC0AC \uC2E4\uD328\uB85C \uC778\uD574 \uC2E4\uD328\uD560 \uC218 \uC788\uC2B5\uB2C8\uB2E4.\n\uBCF4\uC548\uC744 \uAD6C\uC131\uD558\uB824\uBA74 rmid \uC124\uBA85\uC11C\uB97C \uCC38\uC870\uD558\uC2ED\uC2DC\uC624.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=\uC0AC\uC6A9\uBC95: {0} \n\n\uC5EC\uAE30\uC11C \uB294 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4.\n -port rmid\uAC00 \uC0AC\uC6A9\uD560 \uD3EC\uD2B8\uB97C \uC9C0\uC815\uD569\uB2C8\uB2E4.\n -log rmid\uAC00 \uB85C\uADF8\uB97C \uAE30\uB85D\uD560 \uB514\uB809\uD1A0\uB9AC\uB97C \uC9C0\uC815\uD569\uB2C8\uB2E4.\n -stop \uC9C0\uC815\uB41C \uD3EC\uD2B8\uC5D0 \uB300\uD574 rmid\uC758 \uD604\uC7AC \uD638\uCD9C\uC744 \uC815\uC9C0\uD569\uB2C8\uB2E4.\n -C \uAC01\uAC01\uC758 \uD558\uC704 \uD504\uB85C\uC138\uC2A4(\uD65C\uC131\uD654 \uADF8\uB8F9)\uC5D0 \uC778\uC218\uB97C \uC804\uB2EC\uD569\uB2C8\uB2E4.\n -J Java \uC778\uD130\uD504\uB9AC\uD130\uC5D0 \uC778\uC218\uB97C \uC804\uB2EC\uD569\uB2C8\uB2E4.\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=\uD65C\uC131 \uB370\uBAAC \uC885\uB8CC - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (\uACBD\uACE0) \uADF8\uB8F9 \uC7AC\uC2DC\uC791\uC73C\uB85C \uC778\uD574 \uBC1C\uC0DD\uD55C \uC624\uB958: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (\uACBD\uACE0) \uC11C\uBE44\uC2A4 \uC7AC\uC2DC\uC791\uC73C\uB85C \uC778\uD574 \uBC1C\uC0DD\uD55C \uC624\uB958: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (\uACBD\uACE0) \uB85C\uADF8 \uC5C5\uB370\uC774\uD2B8\uB85C \uC778\uD574 \uBC1C\uC0DD\uD55C \uC624\uB958: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (\uC2EC\uAC01) \uB85C\uADF8 \uC2A4\uB0C5\uC0F7\uC73C\uB85C \uC778\uD574 \uBC1C\uC0DD\uD55C \uC624\uB958: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (\uACBD\uACE0) {0}: \uBCF5\uAD6C\uD558\uB294 \uB3D9\uC548 \uB808\uCF54\uB4DC \uAE30\uB85D\uC744 \uAC74\uB108 \uB6F0\uB294 \uC911: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_pt_BR.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_pt_BR.properties deleted file mode 100644 index a4e6087b3ae..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_pt_BR.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid foi acionado a partir de inetd com um status inv\u00E1lido (deve ser wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=a porta n\u00E3o poder\u00E1 ser especificada se rmid for acionado a partir de inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=a porta n\u00E3o \u00E9 um n\u00FAmero - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=a op\u00E7\u00E3o -port requer um argumento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=a op\u00E7\u00E3o -log requer um argumento - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=op\u00E7\u00E3o -log necess\u00E1ria - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=op\u00E7\u00E3o inv\u00E1lida: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: ocorreu uma exce\u00E7\u00E3o: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: n\u00E3o \u00E9 poss\u00EDvel localizar java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=inicializa\u00E7\u00E3o de rmid com canal herdado - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: classe de pol\u00EDtica de execu\u00E7\u00E3o inv\u00E1lida - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: a tentativa de obter a pol\u00EDtica de execu\u00E7\u00E3o gera: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: executando "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid: grupo de ativa\u00E7\u00E3o inativo: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: warning: sun.rmi.activation.execPolicy system\npropriedade n\u00E3o especificada e nenhuma permiss\u00E3o ExecPermissions/ExecOptionPermissions\nconcedida; as tentativas subsequentes de ativa\u00E7\u00E3o poder\u00E3o falhar por causa das\nverifica\u00E7\u00F5es malsucedidas da permiss\u00E3o ExecPermission/ExecOptionPermission. \nPara configurar a seguran\u00E7a, consulte a documenta\u00E7\u00E3o do rmid.\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Uso: {0} \n\nem que inclui:\n -port especifica a porta que rmid usar\u00E1\n -log especifica o diret\u00F3rio no qual o rmid grava o log\n -stop para a chamada atual de rmid (para a porta especificada)\n -C especifica o argumento para cada processo filho (grupo de ativa\u00E7\u00E3o)\n -J especifica o argumento para o int\u00E9rprete de java\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=shutdown do daemon de ativa\u00E7\u00E3o - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (ADVERT\u00CANCIA) a reinicializa\u00E7\u00E3o do grupo gera: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (ADVERT\u00CANCIA) a reinicializa\u00E7\u00E3o do servi\u00E7o gera: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (ADVERT\u00CANCIA) o registro da atualiza\u00E7\u00E3o gera: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (GRAVE) o registro do snapshot gera: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (ADVERT\u00CANCIA) {0}: ignorando registro de log durante a recupera\u00E7\u00E3o: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_sv.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_sv.properties deleted file mode 100644 index bfa7b84292f..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_sv.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid startades fr\u00E5n inetd med ogiltig status (m\u00E5ste vara wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=port kan inte anges om rmid startas fr\u00E5n inetd - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=port \u00E4r inte ett tal - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=alternativet -port kr\u00E4ver argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=alternativet -log kr\u00E4ver argument - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=alternativet -log kr\u00E4vs - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=otill\u00E5tet alternativ: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: ett undantag uppstod: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: hittar inte java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=start av rmid med \u00E4rvd kanal - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: ogiltig exec policy-klass - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: f\u00F6rs\u00F6k att h\u00E4mta throws f\u00F6r exec-policy: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: k\u00F6r "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid: aktiveringsgruppen \u00E4r inaktiv: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: Varning: Systemegenskapen sun.rmi.activation.execPolicy\nhar inte angetts och inga ExecPermissions/ExecOptionPermissions har\ntilldelats. Efterf\u00F6ljande aktiveringsf\u00F6rs\u00F6k kanske inte utf\u00F6rs p\u00E5 grund\nav ej utf\u00F6rda ExecPermission/ExecOptionPermission-beh\u00F6righetskontroller. \nOm du vill konfigurera s\u00E4kerhet l\u00E4ser du i dokumentationen f\u00F6r rmid. - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=Syntax: {0} \n\nd\u00E4r inkluderar:\n -port Ange porten f\u00F6r rmid\n -log Ange katalogen d\u00E4r rmid ska spara loggen\n -stop Stoppa p\u00E5g\u00E5ende rmid-anrop (f\u00F6r angiven port)\n -C Skicka argumentet till varje underordnad process (aktiveringsgrupp)\n -J Skicka argumentet till Javatolken\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=aktiveringsdemonen avslutas - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (Varning) starta om gruppkast: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (Varning) starta om tj\u00E4nstekast: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (Varning) logga uppdateringskast: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (Allvarligt) logga \u00F6gonblickskast: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (Varning) {0}: hoppar \u00F6ver loggpost under \u00E5terst\u00E4llning: diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_CN.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_CN.properties deleted file mode 100644 index a2d4844d4dd..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_CN.properties +++ /dev/null @@ -1,99 +0,0 @@ -# -# -# Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid \u5DF2\u4ECE inetd \u542F\u52A8, \u4E14\u72B6\u6001\u65E0\u6548 (\u5FC5\u987B\u7B49\u5F85) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=\u5982\u679C rmid \u4ECE inetd \u542F\u52A8, \u5219\u65E0\u6CD5\u6307\u5B9A\u7AEF\u53E3 - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=\u7AEF\u53E3\u4E0D\u662F\u4E00\u4E2A\u6570\u5B57 - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=-port \u9009\u9879\u9700\u8981\u53C2\u6570 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=-log \u9009\u9879\u9700\u8981\u53C2\u6570 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=\u9700\u8981 -log \u9009\u9879 - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=\u65E0\u6548\u7684\u9009\u9879\uFF1A{0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: \u51FA\u73B0\u5F02\u5E38\u9519\u8BEF: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: \u627E\u4E0D\u5230 java.home - -# "rmid" should not be translated -rmid.inherited.channel.info=rmid \u901A\u8FC7\u7EE7\u627F\u7684\u901A\u9053\u542F\u52A8 - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: \u65E0\u6548\u7684\u53EF\u6267\u884C policy \u7C7B - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: \u5C1D\u8BD5\u83B7\u53D6\u6267\u884C\u7B56\u7565\u629B\u51FA: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: \u6B63\u5728\u8FD0\u884C "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid: \u6FC0\u6D3B\u7EC4\u65E0\u6548: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: \u8B66\u544A: \u672A\u6307\u5B9A sun.rmi.activation.execPolicy\n\u7CFB\u7EDF\u5C5E\u6027\u5E76\u4E14\u672A\u6388\u4E88 ExecPermissions/ExecOptionPermissions\u3002\n\u7531\u4E8E\u5BF9 ExecPermission/ExecOptionPermission \u7684\n\u6743\u9650\u68C0\u67E5\u5931\u8D25, \u968F\u540E\u7684\u6FC0\u6D3B\u5C1D\u8BD5\u53EF\u80FD\u4F1A\u5931\u8D25\u3002\n\u8981\u914D\u7F6E\u5B89\u5168\u6027, \u8BF7\u53C2\u9605 rmid \u6587\u6863\u3002\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=\u7528\u6CD5: {0} \n\n\u5176\u4E2D, \u5305\u62EC:\n -port \u6307\u5B9A\u4F9B rmid \u4F7F\u7528\u7684\u7AEF\u53E3\n -log \u6307\u5B9A rmid \u5C06\u65E5\u5FD7\u5199\u5165\u7684\u76EE\u5F55\n -stop \u505C\u6B62\u5F53\u524D\u7684 rmid \u8C03\u7528 (\u5BF9\u6307\u5B9A\u7AEF\u53E3)\n -C \u5411\u6BCF\u4E2A\u5B50\u8FDB\u7A0B\u4F20\u9012\u53C2\u6570 (\u6FC0\u6D3B\u7EC4)\n -J \u5411 java \u89E3\u91CA\u5668\u4F20\u9012\u53C2\u6570\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=\u6FC0\u6D3B\u5B88\u62A4\u7A0B\u5E8F\u5DF2\u5173\u95ED - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (\u8B66\u544A) \u91CD\u65B0\u542F\u52A8\u7EC4\u629B\u51FA: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (\u8B66\u544A) \u91CD\u65B0\u542F\u52A8\u670D\u52A1\u629B\u51FA: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (\u8B66\u544A) \u65E5\u5FD7\u66F4\u65B0\u629B\u51FA: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (\u4E25\u91CD) \u65E5\u5FD7\u5FEB\u7167\u629B\u51FA: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (\u8B66\u544A) {0}: \u6062\u590D\u671F\u95F4\u8DF3\u8FC7\u65E5\u5FD7\u8BB0\u5F55: - -# "rmid" should not be translated -rmid.deprecation.warning=rmid\uFF1A\uFF08\u8B66\u544A\uFF09RMI \u6FC0\u6D3B\u673A\u5236\u548C rmid \u5DE5\u5177\n\u5DF2\u8FC7\u65F6\uFF0C\u5373\u5C06\u5220\u9664\u3002\u5728\u5C06\u6765\u7684\nJava \u5E73\u53F0\u7248\u672C\u4E2D\u53EF\u80FD\u4F1A\u5C06\u5176\u5220\u9664\u3002 diff --git a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_TW.properties b/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_TW.properties deleted file mode 100644 index e7f018d089a..00000000000 --- a/src/java.rmi/share/classes/sun/rmi/server/resources/rmid_zh_TW.properties +++ /dev/null @@ -1,96 +0,0 @@ -# -# -# Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# "rmid", inetd", and "wait" should not be translated. -rmid.syntax.exec.invalid=rmid \u5DF2\u5F9E inetd \u555F\u52D5\uFF0C\u4F46\u72C0\u614B\u7121\u6548 (\u5FC5\u9808\u662F wait) - -# "rmid" and "inetd" should not be translated. -rmid.syntax.port.badarg=\u5982\u679C rmid \u5F9E inetd \u555F\u52D5\uFF0C\u5247\u7121\u6CD5\u6307\u5B9A\u9023\u63A5\u57E0 - -# "port" here refers to a TCP port for the server to listen on. -rmid.syntax.port.badnumber=port \u4E0D\u662F\u4E00\u500B\u6578\u5B57 - -# "-port" should not be translated, because it's part of command syntax. -rmid.syntax.port.missing=-port \u9078\u9805\u9700\u8981\u5F15\u6578 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.missing=-log \u9078\u9805\u9700\u8981\u5F15\u6578 - -# "-log" should not be translated, because it's part of command syntax. -rmid.syntax.log.required=-log \u9078\u9805\u662F\u5FC5\u9700\u7684 - -# {0} = the (string) illegal argument in question -rmid.syntax.illegal.option=\u7121\u6548\u7684\u9078\u9805: {0} - -# {0} = the (string) reason text that came with a thrown exception -# "Activation.main" should not be translated, because it's a codepoint -rmid.unexpected.exception=Activation.main: \u767C\u751F\u7570\u5E38\u72C0\u6CC1: {0} - -# "java.home" should not be translated, because it's a property name -# "ActivatorImpl" should not be translated, because it's a codepoint -rmid.unfound.java.home.property=ActivatorImpl: \u627E\u4E0D\u5230 java.home \u7684\u6240\u5728 - -# "rmid" should not be translated -rmid.inherited.channel.info=rmid \u4F7F\u7528\u7E7C\u627F\u7684\u901A\u9053\u555F\u52D5 - -# "Activation.main" should not be translated, because it's a codepoint -rmid.exec.policy.invalid=Activation.main: \u7121\u6548\u7684\u57F7\u884C\u539F\u5247\u985E\u5225 - -# "rmid" should not be translated -rmid.exec.policy.exception=rmid: \u5617\u8A66\u53D6\u5F97\u57F7\u884C\u539F\u5247\u62CB\u68C4: - -# "rmid" should not be translated -rmid.exec.command=rmid: debugExec: \u57F7\u884C "{0}" - -# "rmid" should not be translated -rmid.group.inactive=rmid: \u555F\u52D5\u7FA4\u7D44\u672A\u5728\u4F7F\u7528\u4E2D: {0} - -# "Activation.main", "sun.rmi.activation.execPolicy", "ExecPermission" and -# "ExecOptionPermission" should not be translated, since they refer to -# class/permission names. -rmid.exec.perms.inadequate=Activation.main: \u8B66\u544A: sun.rmi.activation.execPolicy \u7CFB\u7D71\n\u5C6C\u6027\u672A\u6307\u5B9A\uFF0C\u800C\u4E14\u672A\u6388\u4E88 ExecPermissions/ExecOptionPermissions;\n\u5F8C\u7E8C\u7684\u555F\u52D5\u5617\u8A66\u53EF\u80FD\u6703\u56E0\u70BA\u4E0D\u6210\u529F\u7684\nExecPermission/ExecOptionPermission \u6B0A\u9650\u6AA2\u67E5\u800C\u5931\u6557\u3002\n\u5982\u9700\u8A2D\u5B9A\u5B89\u5168\uFF0C\u8ACB\u53C3\u8003 rmid \u6587\u4EF6\u3002\n - -# "rmid", "-port", "-log", "-stop", "-C" and "-J" should not be translated, -# because they are syntax -rmid.usage=\u7528\u6CD5: {0} \n\n\u5176\u4E2D \u5305\u62EC: \n -port \u6307\u5B9A\u4F9B rmid \u4F7F\u7528\u7684\u9023\u63A5\u57E0\n -log \u6307\u5B9A\u4F9B rmid \u5BEB\u5165\u65E5\u8A8C\u7684\u76EE\u9304\n -stop \u505C\u6B62\u76EE\u524D rmid \u7684\u547C\u53EB (\u91DD\u5C0D\u6307\u5B9A\u7684\u9023\u63A5\u57E0)\n -C \u50B3\u905E\u5F15\u6578\u81F3\u6BCF\u4E00\u5B50\u904E\u7A0B (\u4F5C\u7528\u7FA4\u7D44)\n -J \u50B3\u905E\u5F15\u6578\u81F3 java \u89E3\u8B6F\u7A0B\u5F0F\n -# This means "The currently running activation daemon has been shut down, -# and is about to exit". -rmid.daemon.shutdown=\u95DC\u9589 activation \u5354\u52A9\u7A0B\u5F0F - -# "rmid" should not be translated -rmid.restart.group.warning=\nrmid: (\u8B66\u544A) \u91CD\u65B0\u555F\u52D5\u7FA4\u7D44\u62CB\u68C4: - -# "rmid" should not be translated -rmid.restart.service.warning=\nrmid: (\u8B66\u544A) \u91CD\u65B0\u555F\u52D5\u670D\u52D9\u62CB\u68C4: - -# "rmid" should not be translated -rmid.log.update.warning=\nrmid: (\u8B66\u544A) \u8A18\u9304\u66F4\u65B0\u62CB\u68C4: - -# "rmid" should not be translated -rmid.log.snapshot.warning=\nrmid: (\u56B4\u91CD) \u8A18\u9304\u5FEB\u7167\u62CB\u68C4: - -# "rmid" should not be translated -rmid.log.recover.warning=\nrmid: (\u8B66\u544A) {0}: \u5728\u56DE\u5FA9\u904E\u7A0B\u4E2D\u7565\u904E\u65E5\u8A8C\u8A18\u9304: diff --git a/src/java.rmi/share/man/rmid.1 b/src/java.rmi/share/man/rmid.1 deleted file mode 100644 index 576fba50042..00000000000 --- a/src/java.rmi/share/man/rmid.1 +++ /dev/null @@ -1,413 +0,0 @@ -.\" Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. -.\" DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -.\" -.\" This code is free software; you can redistribute it and/or modify it -.\" under the terms of the GNU General Public License version 2 only, as -.\" published by the Free Software Foundation. -.\" -.\" This code is distributed in the hope that it will be useful, but WITHOUT -.\" ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -.\" FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -.\" version 2 for more details (a copy is included in the LICENSE file that -.\" accompanied this code). -.\" -.\" You should have received a copy of the GNU General Public License version -.\" 2 along with this work; if not, write to the Free Software Foundation, -.\" Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -.\" -.\" Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -.\" or visit www.oracle.com if you need additional information or have any -.\" questions. -.\" -.\" Automatically generated by Pandoc 2.3.1 -.\" -.TH "RMID" "1" "2021" "JDK 17\-ea" "JDK Commands" -.hy -.SH NAME -.PP -rmid \- start the activation system daemon that enables objects to be -registered and activated in a Java Virtual Machine (JVM) -.SH SYNOPSIS -.PP -\f[CB]rmid\f[R] [\f[I]options\f[R]] -.TP -.B \f[I]options\f[R] -This represent the command\-line options for the \f[CB]rmid\f[R] command. -See \f[B]Options for rmid\f[R]. -.RS -.RE -.SH DESCRIPTION -.PP -\f[B]Deprecation Notice:\f[R] The rmid tool and the RMI Activation -mechanism have been deprecated and may be removed from a future version -of the platform. -See \f[B]JEP 385\f[R] [https://openjdk.java.net/jeps/385] for further -information. -.PP -The \f[CB]rmid\f[R] command starts the activation system daemon. -The activation system daemon must be started before objects that can be -activated are either registered with the activation system or activated -in a JVM. -.PP -Start the daemon by executing the \f[CB]rmid\f[R] command and specifying a -security policy file, as follows: -.RS -.PP -\f[CB]rmid\ \-J\-Djava.security.policy=rmid.policy\f[R] -.RE -.PP -When you run Oracle\[aq]s implementation of the \f[CB]rmid\f[R] command, -by default you must specify a security policy file so that the -\f[CB]rmid\f[R] command can verify whether or not the information in each -\f[CB]ActivationGroupDesc\f[R] is allowed to be used to start a JVM for an -activation group. -Specifically, the command and options specified by the -\f[CB]CommandEnvironment\f[R] and any properties passed to an -\f[CB]ActivationGroupDesc\f[R] constructor must now be explicitly allowed -in the security policy file for the \f[CB]rmid\f[R] command. -The value of the \f[CB]sun.rmi.activation.execPolicy\f[R] property -dictates the policy that the \f[CB]rmid\f[R] command uses to determine -whether or not the information in an \f[CB]ActivationGroupDesc\f[R] can be -used to start a JVM for an activation group. -For more information see the description of the -\f[CB]\-J\-Dsun.rmi.activation.execPolicy=policy\f[R] option. -.PP -Executing the \f[CB]rmid\f[R] command starts the \f[CB]Activator\f[R] and an -internal registry on the default port 1098 and binds an -\f[CB]ActivationSystem\f[R] to the name -\f[CB]java.rmi.activation.ActivationSystem\f[R] in this internal registry. -.PP -To specify an alternate port for the registry, you must specify the -\f[CB]\-port\f[R] option when you execute the \f[CB]rmid\f[R] command. -For example, the following command starts the activation system daemon -and a registry on the registry\[aq]s default port, 1099. -.RS -.PP -\f[CB]rmid\ \-J\-Djava.security.policy=rmid.policy\ \-port\ 1099\f[R] -.RE -.SH START RMID ON DEMAND (LINUX ONLY) -.PP -An alternative to starting \f[CB]rmid\f[R] from the command line is to -configure \f[CB]xinetd\f[R] (Linux) to start \f[CB]rmid\f[R] on demand. -.PP -When RMID starts, it attempts to obtain an inherited channel (inherited -from \f[CB]inetd\f[R]/\f[CB]xinetd\f[R]) by calling the -\f[CB]System.inheritedChannel\f[R] method. -If the inherited channel is null or not an instance of -\f[CB]java.nio.channels.ServerSocketChannel\f[R], then RMID assumes that -it wasn\[aq]t started by \f[CB]inetd\f[R]/\f[CB]xinetd\f[R], and it starts -as previously described. -.PP -If the inherited channel is a \f[CB]ServerSocketChannel\f[R] instance, -then RMID uses the \f[CB]java.net.ServerSocket\f[R] obtained from the -\f[CB]ServerSocketChannel\f[R] as the server socket that accepts requests -for the remote objects it exports: The registry in which the -\f[CB]java.rmi.activation.ActivationSystem\f[R] is bound and the -\f[CB]java.rmi.activation.Activator\f[R] remote object. -In this mode, RMID behaves the same as when it is started from the -command line, except in the following cases: -.IP \[bu] 2 -Output printed to \f[CB]System.err\f[R] is redirected to a file. -This file is located in the directory specified by the -\f[CB]java.io.tmpdir\f[R] system property (typically \f[CB]/var/tmp\f[R] or -\f[CB]/tmp\f[R]) with the prefix \f[CB]rmid\-err\f[R] and the suffix -\f[CB]tmp\f[R]. -.IP \[bu] 2 -The \f[CB]\-port\f[R] option isn\[aq]t allowed. -If this option is specified, then RMID exits with an error message. -.IP \[bu] 2 -The \f[CB]\-log\f[R] option is required. -If this option isn\[aq]t specified, then RMID exits with an error -message -.SH OPTIONS FOR RMID -.TP -.B \f[CB]\-C\f[R]\f[I]option\f[R] -Specifies an option that\[aq]s passed as a command\-line argument to -each child process (activation group) of the \f[CB]rmid\f[R] command when -that process is created. -For example, you could pass a property to each virtual machine spawned -by the activation system daemon: -.RS -.RS -.PP -\f[CB]rmid\ \-C\-Dsome.property=value\f[R] -.RE -.PP -This ability to pass command\-line arguments to child processes can be -useful for debugging. -For example, the following command enables server\-call logging in all -child JVMs. -.RS -.PP -\f[CB]rmid\ \-C\-Djava.rmi.server.logCalls=true\f[R] -.RE -.RE -.TP -.B \f[CB]\-J\f[R]\f[I]option\f[R] -Specifies an option that\[aq]s passed to the Java interpreter running -RMID command. -For example, to specify that the \f[CB]rmid\f[R] command use a policy file -named \f[CB]rmid.policy\f[R], the \f[CB]\-J\f[R] option can be used to -define the \f[CB]java.security.policy\f[R] property on the \f[CB]rmid\f[R] -command line, for example: -.RS -.RS -.PP -\f[CB]rmid\ \-J\-Djava.security.policy\-rmid.policy\f[R] -.RE -.RE -.TP -.B \f[CB]\-J\-Dsun.rmi.activation.execPolicy=\f[R]\f[I]policy\f[R] -Specifies the policy that the RMID command employs to check commands and -command\-line options used to start the JVM in which an activation group -runs. -This option exists only in Oracle\[aq]s implementation of the Java RMI -activation daemon. -If this property isn\[aq]t specified on the command line, then the -result is the same as though -\f[CB]\-J\-Dsun.rmi.activation.execPolicy=default\f[R] were specified. -.RS -.PP -The possible values of \f[I]policy\f[R] can be \f[CB]default\f[R], -\f[I]policyClassName\f[R], or \f[CB]none\f[R]. -.IP \[bu] 2 -\f[CB]default\f[R] -.RS 2 -.PP -The \f[CB]default\f[R] or unspecified value \f[CB]execPolicy\f[R] allows the -\f[CB]rmid\f[R] command to execute commands with specific command\-line -options only when the \f[CB]rmid\f[R] command was granted permission to -execute those commands and options in the security policy file that the -\f[CB]rmid\f[R] command uses. -Only the default activation group implementation can be used with the -default execution policy. -.PP -The \f[CB]rmid\f[R] command starts a JVM for an activation group with the -information in the group\[aq]s registered activation group descriptor, -\f[CB]ActivationGroupDesc\f[R]. -The group descriptor specifies an optional -\f[CB]ActivationGroupDesc.CommandEnvironment\f[R] that includes the -command to execute to start the activation group and any command\-line -options to be added to the command line. -By default, the \f[CB]rmid\f[R] command uses the \f[CB]java\f[R] command -found in \f[CB]java.home\f[R]. -The group descriptor also contains properties overrides that are added -to the command line as options defined as: -\f[CB]\-D\f[R]\f[I]property\f[R]\f[CB]=\f[R]\f[I]value\f[R]. -The \f[CB]com.sun.rmi.rmid.ExecPermission\f[R] permission grants the -\f[CB]rmid\f[R] command permission to execute a command that\[aq]s -specified in the group descriptor\[aq]s \f[CB]CommandEnvironment\f[R] to -start an activation group. -The \f[CB]com.sun.rmi.rmid.ExecOptionPermission\f[R] permission enables -the \f[CB]rmid\f[R] command to use command\-line options, specified as -properties overrides in the group descriptor or as options in the -\f[CB]CommandEnvironment\f[R] when starting the activation group. -When granting the \f[CB]rmid\f[R] command permission to execute various -commands and options, the permissions \f[CB]ExecPermission\f[R] and -\f[CB]ExecOptionPermission\f[R] must be granted to all code sources. -.PP -\f[CB]ExecPermission\f[R] class: Represents permission for the -\f[CB]rmid\f[R] command to execute a specific command to start an -activation group. -.PP -\f[CB]ExecPermission\f[R] syntax: The name of \f[CB]ExecPermission\f[R] is -the path name of a command to grant the \f[CB]rmid\f[R] command permission -to execute. -.PP -A path name that ends in a slash (\f[CB]/\f[R]) and an asterisk -(\f[CB]*\f[R]) indicates that all of the files are contained in that -directory where the slash is the file\-separator character, -\f[CB]File.separatorChar\f[R]. -.PP -A path name that ends in a slash (\f[CB]/\f[R]) and a minus sign -(\f[CB]\-\f[R]) indicates that all files and subdirectories are contained -in that directory (recursively). -.PP -A path name that consists of the special token \f[CB]<>\f[R] -matches any file. -.PP -A path name that consists of an asterisk (\f[CB]*\f[R]) indicates that all -the files are in the current directory. -.PP -A path name that consists of a minus sign (\f[CB]\-\f[R]) indicates that -all the files are in the current directory and (recursively) all files -and subdirectories are contained in the current directory. -.PP -\f[CB]ExecOptionPermission\f[R] class: Represents permission for the -\f[CB]rmid\f[R] command to use a specific command\-line option when -starting an activation group. -The name of \f[CB]ExecOptionPermission\f[R] is the value of a -command\-line option. -.PP -\f[CB]ExecOptionPermission\f[R] syntax: Options support a limited wild -card scheme. -An asterisk signifies a wild card match, and it can appear as the option -name itself (matches any option), or an asterisk (*) can appear at the -end of the option name only when the asterisk (\f[CB]*\f[R]) follows a dot -(\f[CB]\&.\f[R]) or an equals sign (\f[CB]=\f[R]). -.PP -For example: \f[CB]*\f[R] or \f[CB]\-Dmydir.*\f[R] or \f[CB]\-Da.b.c=*\f[R] is -valid, but \f[CB]*mydir\f[R] or \f[CB]\-Da*b\f[R] or \f[CB]ab*\f[R] isn\[aq]t -valid. -.PP -\f[B]Policy file for rmid\f[R] -.PP -When you grant the \f[CB]rmid\f[R] command permission to execute various -commands and options, the permissions \f[CB]ExecPermission\f[R] and -\f[CB]ExecOptionPermission\f[R] must be granted to all code sources -(universally). -It is safe to grant these permissions universally because only the -\f[CB]rmid\f[R] command checks these permissions. -.PP -An example policy file that grants various execute permissions to the -\f[CB]rmid\f[R] command is: -.IP \[bu] 2 -\f[B]Linux:\f[R] -.RS 2 -.IP -.nf -\f[CB] -grant\ { -\ \ \ \ permission\ com.sun.rmi.rmid.ExecPermission -\ \ \ \ \ \ \ \ "/files/apps/java/jdk1.7.0/linux/bin/java"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecPermission -\ \ \ \ \ \ \ \ "/files/apps/rmidcmds/*"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Djava.security.policy=/files/policies/group.policy"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Djava.security.debug=*"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Dsun.rmi.*"; -}; -\f[R] -.fi -.RE -.IP \[bu] 2 -\f[B]Windows:\f[R] -.RS 2 -.IP -.nf -\f[CB] -grant\ { -\ \ \ \ permission\ com.sun.rmi.rmid.ExecPermission -\ \ \ \ \ \ \ \ "c:\\\\files\\\\apps\\\\java\\\\jdk1.7.0\\\\win\\\\bin\\\\java"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecPermission -\ \ \ \ \ \ \ \ "c:\\\\files\\\\apps\\\\rmidcmds\\\\*"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Djava.security.policy=c:\\\\files\\\\policies\\\\group.policy"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Djava.security.debug=*"; - -\ \ \ \ permission\ com.sun.rmi.rmid.ExecOptionPermission -\ \ \ \ \ \ \ \ "\-Dsun.rmi.*"; -}; -\f[R] -.fi -.RE -.PP -The first permission granted allows the \f[CB]rmid\f[R] command to execute -the 1.7.0 release of the \f[CB]java\f[R] command, specified by its -explicit path name. -By default, the version of the \f[CB]java\f[R] command found in -\f[CB]java.home\f[R] is used (the same one that the \f[CB]rmid\f[R] command -uses), and doesn\[aq]t need to be specified in the policy file. -The second permission allows the \f[CB]rmid\f[R] command to execute any -command in either the directory \f[CB]/files/apps/rmidcmds\f[R] (Linux and -macOS) or the directory \f[CB]c:\\files\\apps\\rmidcmds\\\f[R] (Windows). -.PP -The third permission granted, \f[CB]ExecOptionPermission\f[R], allows the -\f[CB]rmid\f[R] command to start an activation group that defines the -security policy file to be either \f[CB]/files/policies/group.policy\f[R] -(Linux) or \f[CB]c:\\files\\policies\\group.policy\f[R] (Windows). -The next permission allows the \f[CB]java.security.debug\ property\f[R] to -be used by an activation group. -The last permission allows any property in the -\f[CB]sun.rmi\ property\f[R] name hierarchy to be used by activation -groups. -.PP -To start the \f[CB]rmid\f[R] command with a policy file, the -\f[CB]java.security.policy\f[R] property needs to be specified on the -\f[CB]rmid\f[R] command line, for example: -.PP -\f[CB]rmid\ \-J\-Djava.security.policy=rmid.policy\f[R]. -.RE -.IP \[bu] 2 -\f[I]policyClassName\f[R] -.RS 2 -.PP -If the default behavior isn\[aq]t flexible enough, then an administrator -can provide, when starting the \f[CB]rmid\f[R] command, the name of a -class whose \f[CB]checkExecCommand\f[R] method is executed to check -commands to be executed by the \f[CB]rmid\f[R] command. -.PP -The \f[CB]policyClassName\f[R] specifies a public class with a public, -no\-argument constructor and an implementation of the following -\f[CB]checkExecCommand\f[R] method: -.IP -.nf -\f[CB] -\ public\ void\ checkExecCommand(ActivationGroupDesc\ desc,\ String[]\ command) -\ \ \ \ \ \ \ \ throws\ SecurityException; -\f[R] -.fi -.PP -Before starting an activation group, the \f[CB]rmid\f[R] command calls the -policy\[aq]s \f[CB]checkExecCommand\f[R] method and passes to it the -activation group descriptor and an array that contains the complete -command to start the activation group. -If the \f[CB]checkExecCommand\f[R] throws a \f[CB]SecurityException\f[R], -then the \f[CB]rmid\f[R] command doesn\[aq]t start the activation group -and an \f[CB]ActivationException\f[R] is thrown to the caller attempting -to activate the object. -.RE -.IP \[bu] 2 -\f[CB]none\f[R] -.RS 2 -.PP -If the \f[CB]sun.rmi.activation.execPolicy\f[R] property value is -\f[CB]none\f[R], then the \f[CB]rmid\f[R] command doesn\[aq]t perform any -validation of commands to start activation groups. -.RE -.RE -.TP -.B \f[CB]\-log\f[R] \f[I]dir\f[R] -Specifies the name of the directory that the activation system daemon -uses to write its database and associated information. -The log directory defaults to creating a log, in the directory in which -the \f[CB]rmid\f[R] command was executed. -.RS -.RE -.TP -.B \f[CB]\-port\f[R] \f[I]port\f[R] -Specifies the port that the registry uses. -The activation system daemon binds \f[CB]ActivationSystem\f[R], with the -name \f[CB]java.rmi.activation.ActivationSystem\f[R], in this registry. -The \f[CB]ActivationSystem\f[R] on the local machine can be obtained using -the following \f[CB]Naming.lookup\f[R] method call: -.RS -.IP -.nf -\f[CB] -import\ java.rmi.*; -import\ java.rmi.activation.*; - -ActivationSystem\ system;\ system\ =\ (ActivationSystem) -Naming.lookup("//:port/java.rmi.activation.ActivationSystem"); -\f[R] -.fi -.RE -.TP -.B \f[CB]\-stop\f[R] -Stops the current invocation of the \f[CB]rmid\f[R] command for a port -specified by the \f[CB]\-port\f[R] option. -If no port is specified, then this option stops the \f[CB]rmid\f[R] -invocation running on port 1098. -.RS -.RE diff --git a/test/jdk/ProblemList.txt b/test/jdk/ProblemList.txt index 95c0e8e79f4..7aea0d2eae4 100644 --- a/test/jdk/ProblemList.txt +++ b/test/jdk/ProblemList.txt @@ -635,12 +635,6 @@ java/rmi/transport/rapidExportUnexport/RapidExportUnexport.java 7146541 linux-al java/rmi/transport/checkLeaseInfoLeak/CheckLeaseLeak.java 7191877 generic-all -java/rmi/activation/Activatable/extLoadedImpl/ext.sh 8062724 generic-all - -java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup.java 8169569 windows-all - -java/rmi/activation/rmidViaInheritedChannel/InheritedChannelNotServerSocket.java 8170562 generic-all - java/rmi/registry/readTest/CodebaseTest.java 8173324 windows-all java/rmi/Naming/DefaultRegistryPort.java 8005619 windows-all diff --git a/test/jdk/TEST.groups b/test/jdk/TEST.groups index 127c30be458..bf5ae7e7eb4 100644 --- a/test/jdk/TEST.groups +++ b/test/jdk/TEST.groups @@ -517,7 +517,6 @@ jdk_core_manual_no_input = \ java/net/httpclient/BodyProcessorInputStreamTest.java \ java/net/httpclient/HttpInputStreamTest.java \ java/nio/MappedByteBuffer/PmemTest.java \ - java/rmi/activation/nonLocalActivation/NonLocalActivationTest.java \ java/rmi/registry/nonLocalRegistry/NonLocalRegistryTest.java \ java/util/zip/ZipFile/TestZipFile.java \ javax/net/ssl/compatibility/AlpnTest.java \ diff --git a/test/jdk/java/rmi/RemoteException/chaining/Chaining.java b/test/jdk/java/rmi/RemoteException/chaining/Chaining.java index bb2f7063be6..e20f5825b35 100644 --- a/test/jdk/java/rmi/RemoteException/chaining/Chaining.java +++ b/test/jdk/java/rmi/RemoteException/chaining/Chaining.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,7 +28,6 @@ */ import java.rmi.MarshalledObject; import java.rmi.RemoteException; -import java.rmi.activation.ActivationException; import java.rmi.server.ServerCloneException; public class Chaining { @@ -68,9 +67,6 @@ public class Chaining { test(new RemoteException(), null, null); test(new RemoteException(foo), foo, null); test(new RemoteException(foo, t), fooMsg, t); - test(new ActivationException(), null, null); - test(new ActivationException(foo), foo, null); - test(new ActivationException(foo, t), fooMsg, t); test(new ServerCloneException(foo), foo, null); test(new ServerCloneException(foo, t), fooMsg, t); } diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/ActivateMe.java deleted file mode 100644 index 0e0bd2eb79b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef.java b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef.java deleted file mode 100644 index 9311879886e..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef.java +++ /dev/null @@ -1,275 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4105080 - * @summary Activation retry during a remote method call to an activatable - * object can cause infinite recursion in some situations. The - * RemoteRef contained in the ActivatableRef should never be - * an ActivatableRef, but another type. - * (Needs /othervm to evade JavaTest security manager --aecolley) - * @author Ann Wollrath - * - * @bug 4164971 - * @summary allow non-public activatable class and/or constructor - * Main test class hasa non-public constructor to ensure - * functionality is in place - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server:+open - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivateMe CheckActivateRef_Stub - * @run main/othervm/policy=security.policy/timeout=240 -Djava.rmi.server.ignoreStubClasses=true CheckActivateRef - * @run main/othervm/policy=security.policy/timeout=240 -Djava.rmi.server.ignoreStubClasses=false CheckActivateRef - * @key intermittent - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import sun.rmi.server.ActivatableRef; -import java.lang.reflect.*; -import java.util.Properties; - -public class CheckActivateRef - extends Activatable - implements ActivateMe, Runnable -{ - - private CheckActivateRef(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - } - - public void ping() - {} - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"CheckActivateRef")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - /* - * The following line is required with the JDK 1.2 VM so that the - * VM can exit gracefully when this test completes. Otherwise, the - * conservative garbage collector will find a handle to the server - * object on the native stack and not clear the weak reference to - * it in the RMI runtime's object table. - */ - Object dummy = new Object(); - RMID rmid = null; - ActivateMe obj; - - // test should tolerate certain types of failures - int failures = 0; - int i = 0; - - System.err.println("\nRegression test for bug 4105080\n"); - System.err.println("java.security.policy = " + - System.getProperty("java.security.policy", - "no policy")); - - - String propValue = - System.getProperty("java.rmi.server.useDynamicProxies", "false"); - boolean useDynamicProxies = Boolean.parseBoolean(propValue); - - CheckActivateRef server; - try { - TestLibrary.suggestSecurityManager(TestParams.defaultSecurityManager); - - // start an rmid. - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - p.put("java.rmi.server.useDynamicProxies", propValue); - - /* - * Activate an object by registering its object - * descriptor and invoking a method on the - * stub returned from the register call. - */ - System.err.println("Create activation group in this VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - System.err.println("Creating descriptor"); - ActivationDesc desc = - new ActivationDesc("CheckActivateRef", null, null); - System.err.println("Registering descriptor"); - obj = (ActivateMe) Activatable.register(desc); - - System.err.println("proxy = " + obj); - - if (useDynamicProxies && !Proxy.isProxyClass(obj.getClass())) - { - throw new RuntimeException("proxy is not dynamic proxy"); - } - - /* - * Loop a bunch of times to force activator to - * spawn VMs (groups) - */ - try { - for (; i < 7; i++) { - - System.err.println("Activate object via method call"); - - /* - * Fix for 4277196: if we got an inactive group - * exception, it is likely that we accidentally - * invoked a method on an old activation - * group. Give some time for the group to go away - * and then retry the activation. - */ - try { - obj.ping(); - } catch (RemoteException e) { - Exception detail = (Exception) e.detail; - if ((detail != null) && - (detail instanceof ActivationException) && - (detail.getMessage().equals("group is inactive"))) - { - try { - Thread.sleep(5000); - } catch (InterruptedException ex) { - } - obj.ping(); - - } else { - throw e; - } - } - - System.err.println("proxy = " + obj); - - /* - * Now that object is activated, check to make sure that - * the RemoteRef inside the stub's ActivatableRef - * is *not* an ActivatableRef. - */ - ActivatableRef aref; - if (obj instanceof RemoteStub) { - aref = (ActivatableRef) ((RemoteObject) obj).getRef(); - } else if (Proxy.isProxyClass(obj.getClass())) { - RemoteObjectInvocationHandler handler = - (RemoteObjectInvocationHandler) - Proxy.getInvocationHandler(obj); - aref = (ActivatableRef) handler.getRef(); - } else { - throw new RuntimeException("unknown proxy type"); - } - - final ActivatableRef ref = aref; - Field f = (Field) - java.security.AccessController.doPrivileged - (new java.security.PrivilegedExceptionAction() { - public Object run() throws Exception { - Field ff = ref.getClass().getDeclaredField("ref"); - ff.setAccessible(true); - return ff; - } - }); - Object insideRef = f.get(ref); - System.err.println("insideRef = " + insideRef); - if (insideRef instanceof ActivatableRef) { - TestLibrary.bomb("Embedded ref is an ActivatableRef"); - } else { - System.err.println("ActivatableRef's embedded ref type: " + - insideRef.getClass().getName()); - } - - /* - * Clean up object too. - */ - System.err.println("Deactivate object via method call"); - obj.shutdown(); - - try { - // give activation group time to go away - Thread.sleep(3000); - } catch (InterruptedException e) { - } - } - } catch (java.rmi.UnmarshalException ue) { - // account for test's activation race condition - if (ue.detail instanceof java.io.IOException) { - if ((failures ++) >= 3) { - throw ue; - } - } else { - throw ue; - } - } - - System.err.println("\nsuccess: CheckActivateRef test passed "); - - } catch (java.rmi.activation.ActivationException e) { - // test only needs to pass 3 times in 7 - if (i < 4) { - TestLibrary.bomb(e); - } - } catch (Exception e) { - if (e instanceof java.security.PrivilegedActionException) - e = ((java.security.PrivilegedActionException)e).getException(); - TestLibrary.bomb("\nfailure: unexpected exception " + - e.getClass().getName(), e); - - } finally { - rmid.cleanup(); - obj = null; - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef_Stub.java b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef_Stub.java deleted file mode 100644 index 33ddb0f1344..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/CheckActivateRef_Stub.java +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class CheckActivateRef_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = 10333549859256328L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public CheckActivateRef_Stub() { - super(); - } - public CheckActivateRef_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/group.security.policy b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/group.security.policy deleted file mode 100644 index 02604b7eeb3..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/group.security.policy +++ /dev/null @@ -1,11 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; - - permission java.lang.RuntimePermission "getClassLoader"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/rmid.security.policy deleted file mode 100644 index 4ca2dd3fbbd..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.rmi.server.useDynamicProxies=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/security.policy b/test/jdk/java/rmi/activation/Activatable/checkActivateRef/security.policy deleted file mode 100644 index e36b0a0a19e..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkActivateRef/security.policy +++ /dev/null @@ -1,43 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // test explicitly acccesses sun.rmi.server.ActivatableRef - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; - - // ref to make sure that internal ref is a UnicastRef - permission java.lang.RuntimePermission "accessDeclaredMembers"; - permission java.lang.reflect.ReflectPermission "suppressAccessChecks"; - - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.rmi.server.useDynamicProxies", "read"; - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "getClassLoader"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations.java b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations.java deleted file mode 100644 index 4776f90c3be..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations.java +++ /dev/null @@ -1,280 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4109103 - * @summary rmid should annotate child process output - * - * @author Laird Dornin; code borrowed from Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider MyRMI CheckAnnotations_Stub - * @run main/othervm/policy=security.policy/timeout=480 CheckAnnotations - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import java.security.CodeSource; -import java.util.Properties; -import java.util.StringTokenizer; - - -public class CheckAnnotations - extends Activatable implements MyRMI, Runnable -{ - private static final double TIME_FACTOR = TestLibrary.getTimeoutFactor(); - - private static Object dummy = new Object(); - private static MyRMI myRMI = null; - - // buffers to store rmid output. - private static ByteArrayOutputStream rmidOut = new ByteArrayOutputStream(); - private static ByteArrayOutputStream rmidErr = new ByteArrayOutputStream(); - - public static void main(String args[]) { - /* - * The following line is required with the JDK 1.2 VM so that the - * VM can exit gracefully when this test completes. Otherwise, the - * conservative garbage collector will find a handle to the server - * object on the native stack and not clear the weak reference to - * it in the RMI runtime's object table. - */ - Object dummy1 = new Object(); - RMID rmid = null; - - System.err.println("\nRegression test for bug/rfe 4109103\n"); - - try { - - // Set security manager according to the - // testlibrary. - TestLibrary.suggestSecurityManager(TestParams.defaultSecurityManager); - - // start an rmid. - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(rmidOut, rmidErr, false); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* new desc - we will reuse in order to get multiple vms.*/ - System.err.println("Create activation group in this VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - - ActivationDesc desc = new ActivationDesc - ("CheckAnnotations", null, null); - myRMI = (MyRMI) Activatable.register(desc); - - /* The test- - * Loop a bunch of times to force activator to - * spawn VMs (groups) - */ - for (int i = 0; i < 3; i++) { - - // object activated in annotation check via method call - checkAnnotations(i-1); - - /* - * Clean up object too. - */ - System.err.println - ("Deactivate object via method call"); - myRMI.shutdown(); - } - System.err.println - ("\nsuccess: CheckAnnotations test passed "); - - } catch (Exception e) { - TestLibrary.bomb("\nfailure: unexpected exception ", e); - } finally { - try { - Thread.sleep(4000); - } catch (InterruptedException e) { - } - - myRMI = null; - System.err.println("rmid shut down"); - rmid.cleanup(); - } - } - - /** - * check to make sure that the output from a spawned vm is - * formatted/annotated properly. - */ - public static void checkAnnotations(int iteration) - throws IOException - { - try { - Thread.sleep((long)(5000 * TIME_FACTOR)); - } catch(Exception e) { - System.err.println(e.getMessage()); - } - - final String FAIL_MSG = "Test failed: output improperly annotated."; - final String OUT = "outABC"; - final String ERR = "errXYZ"; - /** - * cause the spawned vm to generate output that will - * be checked for proper annotation. printOut is - * actually being called on an activated implementation. - */ - myRMI.printOut(OUT + iteration); - myRMI.printErr(ERR + iteration); - myRMI.printOut(OUT + iteration); - myRMI.printErr(ERR + iteration); - - /* we have to wait for output to filter down - * from children so we can read it before we - * kill rmid. - */ - - String outString = null; - String errString = null; - - for (int i = 0 ; i < 5 ; i ++ ) { - // have to give output from rmid time to trickle down to - // this process - try { - Thread.sleep((long)(4000 * TIME_FACTOR)); - } catch(InterruptedException e) { - } - - outString = rmidOut.toString(); - errString = rmidErr.toString(); - - if ((!outString.equals("")) && - (!errString.equals(""))) - { - System.err.println("obtained annotations"); - break; - } - System.err.println("rmid output not yet received, retrying..."); - } - - rmidOut.reset(); - rmidErr.reset(); - - // only test when we are annotating..., first run does not annotate - if (iteration >= 0) { - System.err.println("Checking annotations..."); - System.err.println(outString); - System.err.println(errString); - - StringTokenizer stOut = new StringTokenizer(outString, ":"); - StringTokenizer stErr = new StringTokenizer(errString, ":"); - - String execErr = null; - String execOut = null; - String destOut = null; - String destErr = null; - String outTmp = null; - String errTmp = null; - - while (stOut.hasMoreTokens()) { - execOut = outTmp; - outTmp = destOut; - destOut = stOut.nextToken(); - } - while (stErr.hasMoreTokens()) { - execErr = errTmp; - errTmp = destErr; - destErr = stErr.nextToken(); - } - - if ((execErr == null)||(errTmp == null)|| - (destErr == null)) { - TestLibrary.bomb(FAIL_MSG); - } - if ((execOut == null)||(outTmp == null)|| - (destOut == null)) { - TestLibrary.bomb(FAIL_MSG); - } - - - // just make sure that last two strings are what we expect. - if (!execOut.equals("ExecGroup-" + iteration) - || !(new String(destOut.substring(0,OUT.length()+1)).equals(OUT + - iteration)) - || !(execErr.equals("ExecGroup-"+iteration)) - || !(new String(destErr.substring(0,ERR.length()+1)).equals(ERR + - iteration)) ) { - TestLibrary.bomb(FAIL_MSG); - } - } - } - - // implementation of MyRMI, make this object activatable. - public CheckAnnotations - (ActivationID id, MarshalledObject mo) - throws RemoteException { - - // register/export anonymously - super(id,0); - } - - public void printOut(String toPrint) { - System.out.println(toPrint); - } - - public void printErr(String toPrint) { - System.err.println(toPrint); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception { - (new Thread(this,"CheckAnnotations")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations_Stub.java b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations_Stub.java deleted file mode 100644 index 832ecd312d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/CheckAnnotations_Stub.java +++ /dev/null @@ -1,140 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class CheckAnnotations_Stub - extends java.rmi.server.RemoteStub - implements MyRMI, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void printErr(java.lang.String)"), - new java.rmi.server.Operation("void printOut(java.lang.String)"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = -3955951123118841923L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_printErr_0; - private static java.lang.reflect.Method $method_printOut_1; - private static java.lang.reflect.Method $method_shutdown_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_printErr_0 = MyRMI.class.getMethod("printErr", new java.lang.Class[] {java.lang.String.class}); - $method_printOut_1 = MyRMI.class.getMethod("printOut", new java.lang.Class[] {java.lang.String.class}); - $method_shutdown_2 = MyRMI.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public CheckAnnotations_Stub() { - super(); - } - public CheckAnnotations_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of printErr(String) - public void printErr(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_printErr_0, new java.lang.Object[] {$param_String_1}, 1120261287704800747L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeObject($param_String_1); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of printOut(String) - public void printOut(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_printOut_1, new java.lang.Object[] {$param_String_1}, -7517735248176918178L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeObject($param_String_1); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_2, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/MyRMI.java b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/MyRMI.java deleted file mode 100644 index a3ac272a58b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/MyRMI.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface MyRMI extends java.rmi.Remote { - public void printOut(String toPrint) throws RemoteException; - public void printErr(String toPrint) throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/group.security.policy b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/security.policy b/test/jdk/java/rmi/activation/Activatable/checkAnnotations/security.policy deleted file mode 100644 index ef36478e900..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkAnnotations/security.policy +++ /dev/null @@ -1,34 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl.java b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl.java deleted file mode 100644 index 53d3764240b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl.java +++ /dev/null @@ -1,64 +0,0 @@ -/* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * - */ - -import java.rmi.activation.Activatable; -import java.rmi.RemoteException; -import java.rmi.activation.ActivationID; -import java.rmi.MarshalledObject; -import java.net.URL; - -public class ActivatableImpl extends Activatable implements MyRMI { - - private boolean classLoaderOk = false; - - public ActivatableImpl(ActivationID id, MarshalledObject mobj) - throws RemoteException - { - super(id, 0); - - ClassLoader thisLoader = ActivatableImpl.class.getClassLoader(); - ClassLoader ccl = Thread.currentThread().getContextClassLoader(); - - System.err.println("implLoader: " + thisLoader); - System.err.println("ccl: " + ccl); - - /* - * the context class loader is the ccl from when this object - * was exported. If the bug has been fixed, the ccl will be - * the same as the class loader of this class. - */ - classLoaderOk = (thisLoader == ccl); - } - - public boolean classLoaderOk() throws RemoteException { - return classLoaderOk; - } - - public void shutdown() throws Exception { - ActivationLibrary.deactivate(this, getID()); - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl_Stub.java b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl_Stub.java deleted file mode 100644 index 17b8c967922..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/ActivatableImpl_Stub.java +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright (c) 2000, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ActivatableImpl_Stub - extends java.rmi.server.RemoteStub - implements MyRMI, java.rmi.Remote -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_classLoaderOk_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - $method_classLoaderOk_0 = MyRMI.class.getMethod("classLoaderOk", new java.lang.Class[] {}); - $method_shutdown_1 = MyRMI.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public ActivatableImpl_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of classLoaderOk() - public boolean classLoaderOk() - throws java.rmi.RemoteException - { - try { - Object $result = ref.invoke(this, $method_classLoaderOk_0, null, 5226188865994330896L); - return ((java.lang.Boolean) $result).booleanValue(); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/CheckImplClassLoader.java b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/CheckImplClassLoader.java deleted file mode 100644 index f01bcad60b1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/CheckImplClassLoader.java +++ /dev/null @@ -1,124 +0,0 @@ -/* - * Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4289544 - * @summary ActivationGroupImpl.newInstance does not set context classloader for impl - * @author Laird Dornin; code borrowed from Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider - * MyRMI ActivatableImpl ActivatableImpl ActivatableImpl_Stub - * @run main/othervm/policy=security.policy/timeout=150 CheckImplClassLoader - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import java.net.URL; - -/** - * sun.rmi.server.ActivationGroupImpl.newInstance() needs to set the - * context class loader when it constructs the implementation class of - * an Activatable object. It needs to set the ccl to be the class - * loader of the implementation class. - * - * Test creates an Activatable object whose impl is loaded outside of - * CLASSPATH. The impls constructor checks to make sure that the - * correct context class loader has been set when the constructor is - * invoked. - */ -public class CheckImplClassLoader { - - private static Object dummy = new Object(); - private static MyRMI myRMI = null; - private static ActivationGroup group = null; - - public static void main(String args[]) { - /* - * The following line is required with the JDK 1.2 VM because - * of gc hocus pocus that may no longer be needed with an - * exact vm (hotspot). - */ - Object dummy1 = new Object(); - RMID rmid = null; - - System.err.println("\nRegression test for bug/rfe 4289544\n"); - - try { - - URL implcb = TestLibrary.installClassInCodebase("ActivatableImpl", - "implcb"); - TestLibrary.installClassInCodebase("ActivatableImpl_Stub", - "implcb"); - TestLibrary.suggestSecurityManager( - TestParams.defaultSecurityManager); - - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - System.err.println("Create activation group in this VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(null, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - group = ActivationGroup.createGroup(groupID, groupDesc, 0); - - ActivationDesc desc = new ActivationDesc("ActivatableImpl", - implcb.toString(), null); - myRMI = (MyRMI) Activatable.register(desc); - - System.err.println("Checking that impl has correct " + - "context class loader"); - if (!myRMI.classLoaderOk()) { - TestLibrary.bomb("incorrect context class loader for " + - "activation constructor"); - } - - System.err.println("Deactivate object via method call"); - myRMI.shutdown(); - - System.err.println("\nsuccess: CheckImplClassLoader test passed "); - - } catch (Exception e) { - TestLibrary.bomb("\nfailure: unexpected exception ", e); - } finally { - try { - Thread.sleep(4000); - } catch (InterruptedException e) { - } - - myRMI = null; - System.err.println("rmid shut down"); - rmid.cleanup(); - TestLibrary.unexport(group); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/MyRMI.java b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/MyRMI.java deleted file mode 100644 index 3289981725f..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/MyRMI.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2000, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; - -public interface MyRMI extends java.rmi.Remote { - public boolean classLoaderOk() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/security.policy b/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/security.policy deleted file mode 100644 index 82bea323573..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkImplClassLoader/security.policy +++ /dev/null @@ -1,45 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // need to move some classes out of the tests classpath; specific to this test - permission java.io.FilePermission "${test.classes}", "read,write,delete"; - permission java.io.FilePermission "${test.classes}${/}-", "read,write,delete"; - - // need to load custom security manager and activation group from a new codebase - permission java.io.FilePermission ".${/}implcb", "read,write,delete"; - permission java.io.FilePermission ".${/}implcb${/}-", "read,write,delete"; - - // impl class needs to compare context class loader to its own class loader - permission java.lang.RuntimePermission "getClassLoader"; - - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/ActivateMe.java deleted file mode 100644 index 0e0bd2eb79b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog.java b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog.java deleted file mode 100644 index 6053eddec6f..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog.java +++ /dev/null @@ -1,175 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4110548 - * @summary activate fails if rmid is restarted - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * ActivateMe CheckRegisterInLog_Stub - * @run main/othervm/policy=security.policy/timeout=240 CheckRegisterInLog - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import sun.rmi.server.ActivatableRef; -import java.lang.reflect.*; -import java.util.Properties; - -public class CheckRegisterInLog - extends Activatable - implements ActivateMe, Runnable -{ - - public CheckRegisterInLog(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - } - - public void ping() - {} - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"CheckRegisterInLog")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - /* - * The following line is required with the JDK 1.2 VM so that the - * VM can exit gracefully when this test completes. Otherwise, the - * conservative garbage collector will find a handle to the server - * object on the native stack and not clear the weak reference to - * it in the RMI runtime's object table. - */ - Object dummy = new Object(); - RMID rmid = null; - ActivateMe obj; - - System.out.println("\nRegression test for bug 4110548\n"); - - CheckRegisterInLog server; - - try { - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - /* - * Start up activation system daemon "rmid". - */ - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Register an activation group and an object - * in that group. - */ - System.err.println("Creating group descriptor"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - System.err.println("Registering group"); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - - System.err.println("Creating descriptor"); - ActivationDesc desc = - new ActivationDesc(groupID, "CheckRegisterInLog", - null, null); - System.err.println("Registering descriptor"); - obj = (ActivateMe)Activatable.register(desc); - - /* - * Restart rmid to force it to read the log file - */ - rmid.restart(); - - - /* - * 4212096: Give rmid time to go away - we want to make - * sure that an attempt to activate the test object is not made - * on the ActivationSystem that is about to be shutdown. - */ - try { - Thread.sleep(5000); - } catch (InterruptedException ie) { - } - - /* - * Activate the object via a method call. - */ - System.err.println("Activate the object via method call"); - obj.ping(); - - /* - * Clean up object too. - */ - System.err.println("Deactivate object via method call"); - obj.shutdown(); - - System.err.println("\nsuccess: CheckRegisterInLog test passed "); - - } catch (Exception e) { - System.err.println("\nfailure: unexpected exception " + - e.getClass().getName() + ": " + e.getMessage()); - e.printStackTrace(System.err); - throw new RuntimeException("CheckRegisterInLog got exception " + - e.getMessage()); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog_Stub.java b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog_Stub.java deleted file mode 100644 index 6ebcf792034..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/CheckRegisterInLog_Stub.java +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class CheckRegisterInLog_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = 10333549859256328L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public CheckRegisterInLog_Stub() { - super(); - } - public CheckRegisterInLog_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/group.security.policy b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/rmid.security.policy deleted file mode 100644 index ce485f61343..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/security.policy b/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/security.policy deleted file mode 100644 index c8a24a64de1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/checkRegisterInLog/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting object with non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/ActivateMe.java deleted file mode 100644 index 0e0bd2eb79b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/CreatePrivateActivatable.java b/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/CreatePrivateActivatable.java deleted file mode 100644 index 29a662176d4..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/CreatePrivateActivatable.java +++ /dev/null @@ -1,167 +0,0 @@ -/* - * Copyright (c) 1999, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4164971 - * @summary allow non-public activatable class and/or constructor - * @author Laird Dornin - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivateMe - * @run main/othervm/policy=security.policy/timeout=240 CreatePrivateActivatable - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import sun.rmi.server.ActivatableRef; -import java.lang.reflect.*; -import java.util.Properties; - -/** - * Test creates a private inner class Activatable object with a - * private constructor and makes sure that the object can be - * activated. - */ -public class CreatePrivateActivatable -{ - private static class PrivateActivatable extends Activatable - implements ActivateMe, Runnable - { - private PrivateActivatable(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - } - - public void ping() - {} - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this, "CreatePrivateActivatable$PrivateActivatable")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - } - - public static void main(String[] args) { - /* - * The following line is required with the JDK 1.2 VM so that the - * VM can exit gracefully when this test completes. Otherwise, the - * conservative garbage collector will find a handle to the server - * object on the native stack and not clear the weak reference to - * it in the RMI runtime's object table. - */ - Object dummy = new Object(); - RMID rmid = null; - ActivateMe obj; - - System.err.println("\nRegression test for bug 4164971\n"); - System.err.println("java.security.policy = " + - System.getProperty("java.security.policy", "no policy")); - - CreatePrivateActivatable server; - try { - TestLibrary.suggestSecurityManager(TestParams.defaultSecurityManager); - - // start an rmid. - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Activate an object by registering its object - * descriptor and invoking a method on the - * stub returned from the register call. - */ - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - - System.err.println("Creating descriptor"); - ActivationDesc desc = - new ActivationDesc(groupID, - "CreatePrivateActivatable$PrivateActivatable", - null, null); - - System.err.println("Registering descriptor"); - obj = (ActivateMe) Activatable.register(desc); - - /* - * Loop a bunch of times to force activator to - * spawn VMs (groups) - */ - System.err.println("Activate object via method call"); - obj.ping(); - - /* - * Clean up object too. - */ - System.err.println("Deactivate object via method call"); - obj.shutdown(); - - System.err.println("\nsuccess: CreatePrivateActivatable test passed "); - - } catch (Exception e) { - if (e instanceof java.security.PrivilegedActionException) { - e = ((java.security.PrivilegedActionException)e).getException(); - } - TestLibrary.bomb("\nfailure: unexpected exception " + - e.getClass().getName(), e); - - } finally { - rmid.cleanup(); - obj = null; - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/group.security.policy b/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/security.policy b/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/security.policy deleted file mode 100644 index c8a24a64de1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/createPrivateActivable/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting object with non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Bar.java b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Bar.java deleted file mode 100644 index d958d3307a9..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Bar.java +++ /dev/null @@ -1,25 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public class Bar extends Foo { -} diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/DownloadParameterClass.java b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/DownloadParameterClass.java deleted file mode 100644 index b3bafdb1c32..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/DownloadParameterClass.java +++ /dev/null @@ -1,149 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4149366 - * @summary The class loader used to load classes for parameter types sent in - * an RMI call to an activatable object should delegate to the class loader - * that loaded the class of the activatable object itself, to maximize the - * likelihood of type compatibility between downloaded parameter types and - * supertypes shared with the activatable object. - * @author Peter Jones (much code taken from Ann Wollrath's activation tests) - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * Foo FooReceiverImpl FooReceiverImpl_Stub Bar - * @run main/othervm/policy=security.policy/timeout=240 DownloadParameterClass - */ - -import java.io.*; -import java.net.*; -import java.util.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; - -public class DownloadParameterClass { - - public interface FooReceiver extends Remote { - - /* - * The interface can't actually declare that the method takes a - * Foo, because then Foo would have to be in the test's CLASSPATH, - * which might get propagated to the group VM's CLASSPATH, which - * would nullify the test (the Foo supertype must be loaded in the - * group VM only through the class loader that loaded the - * activatable object). - */ - public void receiveFoo(Object obj) throws RemoteException; - } - - public static void main(String[] args) { - - System.err.println("\nRegression test for bug 4149366\n"); - - /* - * Install classes to be seen by the activatable object's class - * loader in the "codebase1" subdirectory of working directory, and - * install the subtype to be downloaded into the activatable object - * into the "codebase2" subdirectory. - */ - URL codebase1 = null; - URL codebase2 = null; - try { - codebase1 = TestLibrary.installClassInCodebase("FooReceiverImpl", "codebase1"); - TestLibrary.installClassInCodebase("FooReceiverImpl_Stub", "codebase1"); - TestLibrary.installClassInCodebase("Foo", "codebase1"); - codebase2 = TestLibrary.installClassInCodebase("Bar", "codebase2"); - } catch (MalformedURLException e) { - TestLibrary.bomb("failed to install test classes", e); - } - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Create and register descriptors for activatable object in a - * group other than this VM's group, so that another VM will be - * spawned with the object is activated. - */ - System.err.println("Creating descriptors"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - ActivationDesc objDesc = - new ActivationDesc(groupID, "FooReceiverImpl", - codebase1.toString(), null, false); - - System.err.println("Registering descriptors"); - FooReceiver obj = (FooReceiver) Activatable.register(objDesc); - - /* - * Create an instance of the subtype to be downloaded by the - * activatable object. The codebase must be a path including - * "codebase1" as well as "codebase2" because the supertype - * must be visible here as well; the supertype cannot be - * installed in both codebases (like it would be in a typical - * setup) because of the trivial installation mechanism used - * below, and see the comment above for why it can't be in - * the test's CLASSPATH. - */ - Class subtype = RMIClassLoader.loadClass( - codebase2 + " " + codebase1, "Bar"); - Object subtypeInstance = subtype.newInstance(); - - obj.receiveFoo(subtypeInstance); - - System.err.println("\nTEST PASSED\n"); - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Foo.java b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Foo.java deleted file mode 100644 index 13f4eb08ff7..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/Foo.java +++ /dev/null @@ -1,25 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public class Foo implements java.io.Serializable { -} diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl.java b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl.java deleted file mode 100644 index bc2986f3160..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * Copyright (c) 1998, 2001, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import java.rmi.activation.*; - -public class FooReceiverImpl implements DownloadParameterClass.FooReceiver { - - private ActivationID id; - - public FooReceiverImpl(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - } - - public void receiveFoo(Object obj) { - /* - * Cast argument to the type "Foo" as resolved from this activatble - * object's class; a ClassCastException will be thrown if the argument - * implements a type "Foo" loaded from a different class loader. - */ - Foo foo = (Foo) obj; - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl_Stub.java b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl_Stub.java deleted file mode 100644 index 1fc32380fc7..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/FooReceiverImpl_Stub.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class FooReceiverImpl_Stub - extends java.rmi.server.RemoteStub - implements DownloadParameterClass. FooReceiver -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_receiveFoo_0; - - static { - try { - $method_receiveFoo_0 = DownloadParameterClass. FooReceiver.class.getMethod("receiveFoo", new java.lang.Class[] {java.lang.Object.class}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public FooReceiverImpl_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of receiveFoo(Object) - public void receiveFoo(java.lang.Object $param_Object_1) - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_receiveFoo_0, new java.lang.Object[] {$param_Object_1}, -1548895758515635945L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/group.security.policy b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/group.security.policy deleted file mode 100644 index 41abd5dd468..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/group.security.policy +++ /dev/null @@ -1,15 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; - - // need to load custom security manager and activation group from a new codebase - permission java.io.FilePermission ".${/}codebase1", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase1${/}-", "read,write"; - permission java.io.FilePermission ".${/}codebase2", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase2${/}-", "read,write,delete"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/manual.security.policy b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/manual.security.policy deleted file mode 100644 index 79d8bb32ce1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/manual.security.policy +++ /dev/null @@ -1,40 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // need to move some classes out of the tests classpath; specific to this test - permission java.io.FilePermission ".", "read,write,delete"; - permission java.io.FilePermission ".${/}-", "read,write,delete"; - - // need to load custom security manager and activation group from a new codebase - permission java.io.FilePermission ".${/}codebase1", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase1${/}-", "read,write"; - permission java.io.FilePermission ".${/}codebase2", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase2${/}-", "read,write,delete"; - - // standard activation permissions - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.classes", "read"; - permission java.util.PropertyPermission "test.src", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/security.policy b/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/security.policy deleted file mode 100644 index f37bf9525a5..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/downloadParameterClass/security.policy +++ /dev/null @@ -1,41 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // need to move some classes out of the tests classpath; specific to this test - permission java.io.FilePermission "${test.classes}", "read,write,delete"; - permission java.io.FilePermission "${test.classes}${/}-", "read,write,delete"; - - // need to load custom security manager and activation group from a new codebase - permission java.io.FilePermission ".${/}codebase1", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase1${/}-", "read,write"; - permission java.io.FilePermission ".${/}codebase2", "read,write,delete"; - permission java.io.FilePermission ".${/}codebase2${/}-", "read,write,delete"; - - // standard activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ActivateMe.java deleted file mode 100644 index 0e0bd2eb79b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod.java b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod.java deleted file mode 100644 index 89f3c90b24c..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod.java +++ /dev/null @@ -1,146 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4128620 - * @summary synopsis: NoSuchMethodError should be elucidated - * @author Laird Dornin - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivateMe ElucidateNoSuchMethod_Stub - * @run main/othervm/policy=security.policy/timeout=240 ElucidateNoSuchMethod - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Properties; - -public class ElucidateNoSuchMethod - extends Activatable - implements ActivateMe, Runnable -{ - - /** - * provide a constructor that alllows this object to be made - * activatable, or at least registered. - */ - ElucidateNoSuchMethod(ActivationID id, int port) - throws RemoteException - { - super(id, port); - } - - /** - * dont provide an activation constructor so that we get a no such - * method error. - */ - - public void ping() {} - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception { - (new Thread(this,"ElucidateNoSuchMethod")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for 4128620 \n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - System.err.println("Create activation group in this VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - - System.err.println("Creating descriptor"); - ActivationDesc desc = - new ActivationDesc("ElucidateNoSuchMethod", null, null); - - System.err.println("Registering descriptor"); - ActivateMe obj = (ActivateMe) Activatable.register(desc); - - System.err.println("Activate object via method call"); - - try { - obj.ping(); - } catch (ActivateFailedException afe) { - ActivationException a = (ActivationException) afe.detail; - - if (((a.detail instanceof NoSuchMethodException) || - (a.detail instanceof NoSuchMethodError)) && - (a.getMessage().indexOf - ("must provide an activation constructor") > -1)) { - System.err.println("\ntest passed for 4128620\n"); - } else { - TestLibrary.bomb("test failed", afe); - } - } - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod_Stub.java b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod_Stub.java deleted file mode 100644 index c0a10df5b2c..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/ElucidateNoSuchMethod_Stub.java +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ElucidateNoSuchMethod_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = 10333549859256328L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public ElucidateNoSuchMethod_Stub() { - super(); - } - public ElucidateNoSuchMethod_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/group.security.policy b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/group.security.policy deleted file mode 100644 index bf7d8c414b9..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/group.security.policy +++ /dev/null @@ -1,13 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; - - // Needed because of bug#: 4182104 - permission java.lang.RuntimePermission "modifyThreadGroup"; - permission java.lang.RuntimePermission "modifyThread"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/rmid.security.policy deleted file mode 100644 index 586dd8efc1b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/security.policy b/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/security.policy deleted file mode 100644 index fd3dd828d23..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/elucidateNoSuchMethod/security.policy +++ /dev/null @@ -1,43 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // Needed because of bug#: 4182104 - permission java.lang.RuntimePermission "modifyThreadGroup"; - permission java.lang.RuntimePermission "modifyThread"; - - // properties are needed because of bug#: 4179055 - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; - permission java.util.PropertyPermission "package.restrict.access.sun", "read"; - permission java.util.PropertyPermission "package.restrict.access.sun.rmi", "read"; - - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/CheckLoader.java b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/CheckLoader.java deleted file mode 100644 index e515eb7a58b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/CheckLoader.java +++ /dev/null @@ -1,26 +0,0 @@ -/* - * Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public interface CheckLoader extends java.rmi.Remote { - boolean isCorrectContextLoader() throws java.rmi.RemoteException; -} diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl.java b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl.java deleted file mode 100644 index 7c2dc413986..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import java.rmi.activation.*; - -public class ExtLoadedImpl implements CheckLoader { - - public ExtLoadedImpl(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - Activatable.exportObject(this, id, 0); - } - - public boolean isCorrectContextLoader() { - ClassLoader contextLoader = - Thread.currentThread().getContextClassLoader(); - ClassLoader implLoader = this.getClass().getClassLoader(); - if (contextLoader == implLoader) { - System.err.println("contextLoader same as implLoader"); - return false; - } else if (contextLoader.getParent() == implLoader) { - System.err.println("contextLoader is child of implLoader"); - return true; - } else { - System.err.println("unknown loader relationship"); - return false; - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImplTest.java b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImplTest.java deleted file mode 100644 index 96b2f7d9421..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImplTest.java +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import java.rmi.activation.*; -import java.util.*; - -public class ExtLoadedImplTest { - - public static void main(String[] args) { - - System.err.println("\nRegression test for bug 4500504\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - Properties p = new Properties(); - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - p.put("java.ext.dirs", "ext"); - - - System.err.println("Creating descriptors"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - ActivationDesc objDesc = - new ActivationDesc(groupID, "ExtLoadedImpl", null, null); - - System.err.println("Registering descriptors"); - CheckLoader obj = (CheckLoader) Activatable.register(objDesc); - - boolean result = obj.isCorrectContextLoader(); - - System.err.println("\nTEST " + - ((result) ? "PASSED" : "FAILED") + "\n"); - - if (!result) { - throw new RuntimeException("TEST FAILED"); - } - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl_Stub.java b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl_Stub.java deleted file mode 100644 index a320f8f9ea6..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ExtLoadedImpl_Stub.java +++ /dev/null @@ -1,66 +0,0 @@ -/* - * Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ExtLoadedImpl_Stub - extends java.rmi.server.RemoteStub - implements CheckLoader -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_isCorrectContextLoader_0; - - static { - try { - $method_isCorrectContextLoader_0 = CheckLoader.class.getMethod("isCorrectContextLoader", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public ExtLoadedImpl_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of isCorrectContextLoader() - public boolean isCorrectContextLoader() - throws java.rmi.RemoteException - { - try { - Object $result = ref.invoke(this, $method_isCorrectContextLoader_0, null, -5210790440944383968L); - return ((java.lang.Boolean) $result).booleanValue(); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ext.sh b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ext.sh deleted file mode 100644 index 2a049fa093b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/ext.sh +++ /dev/null @@ -1,60 +0,0 @@ -# -# Copyright (c) 2002, 2020, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -# @test -# @bug 4500504 -# @summary If the context class loader is a child of the impl's class -# loader, the context class loader should remain unchanged (i.e., not be -# set to the impl's class loader) when the impl is activated. -# @library ../../../testlibrary -# @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary -# @build ExtLoadedImplTest ExtLoadedImpl ExtLoadedImpl_Stub CheckLoader -# @run shell ext.sh - -OS=`uname -s` -case "$OS" in - Linux | Darwin | AIX ) - PS=":" - ;; - Windows* | CYGWIN* ) - PS=";" - ;; - * ) - echo "Unrecognized system!" - exit 1; - ;; -esac - -mkdir -p classes -for dir in `echo ${TESTCLASSPATH:-$TESTCLASSES} | sed -e "s/$PS/ /"` ; do cp $dir/*.class classes ; done -rm classes/ExtLoadedImpl.class classes/ExtLoadedImpl_Stub.class classes/CheckLoader.class -mkdir -p ext -$COMPILEJAVA/bin/jar ${TESTTOOLVMOPTS} cf ext/ext.jar -C $TESTCLASSES ExtLoadedImpl.class -C $TESTCLASSES ExtLoadedImpl_Stub.class -C $TESTCLASSES CheckLoader.class - -TESTVMOPTS="${TESTVMOPTS} \ - --add-exports java.rmi/sun.rmi.registry=ALL-UNNAMED \ - --add-exports java.rmi/sun.rmi.server=ALL-UNNAMED \ - --add-exports java.rmi/sun.rmi.transport=ALL-UNNAMED \ - --add-exports java.rmi/sun.rmi.transport.tcp=ALL-UNNAMED" -$TESTJAVA/bin/java ${TESTVMOPTS} -cp classes -Dtest.src=$TESTSRC -Dtest.classes=$TESTCLASSES -Djava.security.policy=$TESTSRC/security.policy -Djava.ext.dirs=ext ExtLoadedImplTest - diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/group.security.policy b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/rmid.security.policy deleted file mode 100644 index 7d38f7bfa42..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission - "-Djava.security.manager=*"; - permission com.sun.rmi.rmid.ExecOptionPermission - "-Djava.security.policy=*"; - permission com.sun.rmi.rmid.ExecOptionPermission - "-Djava.ext.dirs=*"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/security.policy b/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/security.policy deleted file mode 100644 index 0c9ca1ab750..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/extLoadedImpl/security.policy +++ /dev/null @@ -1,25 +0,0 @@ - -grant { - // standard activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ActivateMe.java deleted file mode 100644 index 79538990c39..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping(int intId, String responder) throws RemoteException; - public void crash() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot.java b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot.java deleted file mode 100644 index 2b97650a599..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot.java +++ /dev/null @@ -1,290 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4173960 - * @summary synopsis: Activatable objects cannot be restarted. - * @author Laird Dornin - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * ActivateMe ForceLogSnapshot_Stub - * @run main/othervm/policy=security.policy/timeout=640 ForceLogSnapshot - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.*; - -public class ForceLogSnapshot - implements ActivateMe -{ - /** how many activatable remote objects to create to test rmid */ - final public static int HOW_MANY = 50; - final public static int NUM_GROUPS = 4; - /** cause RMID to generate a snapshot every 10th activated object */ - final public static int SNAPSHOT_INTERVAL = 10; - - private ActivationID id; - private Vector responders = new Vector(); - - private static final String RESTARTABLE = "restartable"; - private static final String ACTIVATABLE = "activatable"; - - private static Object lock = new Object(); - private static boolean[] restartedObjects = new boolean[HOW_MANY]; - private static boolean[] activatedObjects = new boolean[HOW_MANY]; - - public ForceLogSnapshot(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - int intId = 0; - - Activatable.exportObject(this, id, 0); - ActivateMe obj; - String responder; - try { - Object[] stuff = (Object[]) mobj.get(); - - intId = ((Integer) stuff[0]).intValue(); - responder = (String) stuff[1]; - obj = (ActivateMe) stuff[2]; - - System.err.println(responder + " service started"); - } catch (Exception e) { - System.err.println("unable to obtain stub from marshalled object"); - System.err.println(e.getMessage()); - e.printStackTrace(); - return; - } - - obj.ping(intId, responder); - } - - public ForceLogSnapshot() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - public void ping(int intId, String responder) { - System.err.println("ForceLogSnapshot: received ping from " + - responder); - if (responder.equals(RESTARTABLE)) { - synchronized (lock) { - restartedObjects[intId] = true; - } - } else if (responder.equals(ACTIVATABLE)) { - synchronized (lock) { - activatedObjects[intId] = true; - } - } - } - - public void crash() { - System.exit(0); - } - - public ActivationID getID() { - return id; - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4173960\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - ForceLogSnapshot[] unicastObjs = new ForceLogSnapshot[HOW_MANY]; - - try { - String option = " -Dsun.rmi.activation.snapshotInterval=" + - SNAPSHOT_INTERVAL; - - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.addOptions(new String[] {option, "-Djava.compiler="}); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - Object[][] stuff = new Object[HOW_MANY][]; - MarshalledObject restartMobj = null; - ActivationGroupDesc groupDesc = null; - MarshalledObject activateMobj = null; - ActivationGroupID[] groupIDs = new ActivationGroupID[NUM_GROUPS]; - ActivationDesc restartableDesc = null; - ActivationDesc activatableDesc = null; - ActivateMe[] restartableObj = new ActivateMe[HOW_MANY]; - ActivateMe[] activatableObj = new ActivateMe[HOW_MANY]; - - /* - * Create unicast object to be contacted when service is activated. - */ - int group = 0; - int groupNo = 0; - for (int i = 0 ; i < HOW_MANY ; i ++ ) { - - System.err.println("Creating descriptors and remote objects"); - - unicastObjs[i] = new ForceLogSnapshot(); - - /* - * Create and register descriptors for a restartable and - * non-restartable service (respectively) in a group other than - * this VM's group. - */ - stuff[i] = new Object[] { new Integer(i), - RESTARTABLE, unicastObjs[i] }; - restartMobj = new MarshalledObject(stuff[i]); - - stuff[i][1] = ACTIVATABLE; - activateMobj = new MarshalledObject(stuff[i]); - - groupDesc = - new ActivationGroupDesc(p, null); - - if (i < NUM_GROUPS) { - groupNo = i; - groupIDs[groupNo] = - ActivationGroup.getSystem(). - registerGroup(groupDesc); - } else { - groupNo = (group++)%NUM_GROUPS; - } - - System.err.println("Objects group number: " + groupNo); - - restartableDesc = - new ActivationDesc(groupIDs[groupNo], "ForceLogSnapshot", null, - restartMobj, true); - - activatableDesc = - new ActivationDesc(groupIDs[groupNo], "ForceLogSnapshot", null, - activateMobj, false); - - System.err.println("Registering descriptors"); - restartableObj[i] = - (ActivateMe) Activatable.register(restartableDesc); - - activatableObj[i] = - (ActivateMe) Activatable.register(activatableDesc); - System.err.println("registered activatable #: " + i); - - // start reusing groups if we need to do so. - } - - int repeatOnce = 1; - do { - - /* - * Restart rmid; it should start up the restartable service - */ - rmid.restart(); - - if (howManyRestarted(restartedObjects, 10) < HOW_MANY) { - TestLibrary.bomb("Test1 failed: a service would not " + - "restart"); - } - System.err.println("Test1 passed: rmid " + - "all service(s) restarted. Performing next test."); - - /* - * Make sure no activatable services were automatically - * restarted. - */ - if (howManyRestarted(activatedObjects, 2) != 0) { - TestLibrary.bomb("Test2 failed: activatable service restarted!", - null); - } - System.err.println("Test2 passed: rmid did not " + - "restart activatable service(s)"); - - if (repeatOnce > 0) { - try { - System.err.println("\nCrash restartable object"); - for (int i = 0 ; i < HOW_MANY ; i ++) { - restartableObj[i].crash(); - } - } catch (Exception e) { - } - } - - } while (repeatOnce-- > 0); - - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - for (int i = 0 ; i < HOW_MANY ; i ++) { - TestLibrary.unexport(unicastObjs[i]); - } - } - } - - /** - * Check to see how many services have been automatically - * restarted. - */ - private static int howManyRestarted(boolean[] startedObjects, int retries) { - int succeeded = 0; - int restarted = 0; - int atry = 0; - - while ((restarted < HOW_MANY) && (atry < retries)) { - restarted = 0; - for (int j = 0 ; j < HOW_MANY ; j ++ ) { - synchronized(lock) { - if (startedObjects[j]) { - restarted ++; - } - } - } - System.err.println("not all objects restarted, retrying..."); - try { - Thread.sleep(10000); - } catch (InterruptedException ie) { - } - atry ++; - } - return restarted; - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Skel.java b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Skel.java deleted file mode 100644 index 755ee3f4a50..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Skel.java +++ /dev/null @@ -1,99 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Skeleton class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ForceLogSnapshot_Skel - implements java.rmi.server.Skeleton -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void crash()"), - new java.rmi.server.Operation("void ping(int, java.lang.String)") - }; - - private static final long interfaceHash = -5865767584502007357L; - - public java.rmi.server.Operation[] getOperations() { - return (java.rmi.server.Operation[]) operations.clone(); - } - - public void dispatch(java.rmi.Remote obj, java.rmi.server.RemoteCall call, int opnum, long hash) - throws java.lang.Exception - { - if (opnum < 0) { - if (hash == 8484760490859430950L) { - opnum = 0; - } else if (hash == -1519179153769139224L) { - opnum = 1; - } else { - throw new java.rmi.UnmarshalException("invalid method hash"); - } - } else { - if (hash != interfaceHash) - throw new java.rmi.server.SkeletonMismatchException("interface hash mismatch"); - } - - ForceLogSnapshot server = (ForceLogSnapshot) obj; - switch (opnum) { - case 0: // crash() - { - call.releaseInputStream(); - server.crash(); - try { - call.getResultStream(true); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling return", e); - } - break; - } - - case 1: // ping(int, String) - { - int $param_int_1; - java.lang.String $param_String_2; - try { - java.io.ObjectInput in = call.getInputStream(); - $param_int_1 = in.readInt(); - $param_String_2 = (java.lang.String) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling arguments", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling arguments", e); - } finally { - call.releaseInputStream(); - } - server.ping($param_int_1, $param_String_2); - try { - call.getResultStream(true); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling return", e); - } - break; - } - - default: - throw new java.rmi.UnmarshalException("invalid method number"); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Stub.java b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Stub.java deleted file mode 100644 index 3e6bb0f2b5a..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/ForceLogSnapshot_Stub.java +++ /dev/null @@ -1,111 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ForceLogSnapshot_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void crash()"), - new java.rmi.server.Operation("void ping(int, java.lang.String)") - }; - - private static final long interfaceHash = -5865767584502007357L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_crash_0; - private static java.lang.reflect.Method $method_ping_1; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_crash_0 = ActivateMe.class.getMethod("crash", new java.lang.Class[] {}); - $method_ping_1 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {int.class, java.lang.String.class}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public ForceLogSnapshot_Stub() { - super(); - } - public ForceLogSnapshot_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of crash() - public void crash() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_crash_0, null, 8484760490859430950L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } - - // implementation of ping(int, String) - public void ping(int $param_int_1, java.lang.String $param_String_2) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_1, new java.lang.Object[] {new java.lang.Integer($param_int_1), $param_String_2}, -1519179153769139224L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeInt($param_int_1); - out.writeObject($param_String_2); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/group.security.policy b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/rmid.security.policy deleted file mode 100644 index ce485f61343..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/security.policy b/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/security.policy deleted file mode 100644 index c8a24a64de1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/forceLogSnapshot/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting object with non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/ActivateMe.java deleted file mode 100644 index 4d7d7e5dc8a..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/ActivateMe.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 1999, 2001, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public ActivateMe getUnicastVersion() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup.java b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup.java deleted file mode 100644 index bf5d45d69e9..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup.java +++ /dev/null @@ -1,187 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4116082 - * - * @summary synopsis: rmid should not destroy group when it reports - * inactiveGroup - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary ActivateMe InactiveGroup_Stub - * @run main/othervm/policy=security.policy/timeout=240 InactiveGroup - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Properties; - -public class InactiveGroup - implements ActivateMe, Runnable -{ - - private ActivationID id; - - public InactiveGroup(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - } - - public InactiveGroup() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - public void ping() - {} - - public ActivateMe getUnicastVersion() throws RemoteException { - return new InactiveGroup(); - } - - public ActivationID getID() { - return id; - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"InactiveGroup")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() - { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4116082\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Create descriptor and activate object in a separate VM. - */ - System.err.println("Creating descriptor"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - ActivationDesc desc = - new ActivationDesc(groupID, "InactiveGroup", null, null); - - System.err.println("Registering descriptor"); - ActivateMe activatableObj = (ActivateMe) Activatable.register(desc); - - System.err.println("Activate object via method call"); - activatableObj.ping(); - - /* - * Create a unicast object in the activatable object's VM. - */ - System.err.println("Obtain unicast object"); - ActivateMe unicastObj = activatableObj.getUnicastVersion(); - - /* - * Make activatable object (and therefore group) inactive. - */ - System.err.println("Make activatable object inactive"); - activatableObj.shutdown(); - - /* - * Ping the unicast object a few times to make sure that the - * activation group's process hasn't gone away. - */ - System.err.println("Ping unicast object for existence"); - // set timeout 5 seconds - final long stopTime = System.currentTimeMillis() + 5000; - while (System.currentTimeMillis() < stopTime) { - unicastObj.ping(); - Thread.sleep(500); - } - - /* - * Now, reactivate the activatable object; the unicast object - * should no longer be accessible, since reactivating the - * activatable object should kill the previous group's VM - * and the unicast object along with it. - */ - System.err.println("Reactivate activatable obj"); - activatableObj.ping(); - - try { - System.err.println("Ping unicast object again"); - unicastObj.ping(); - } catch (Exception thisShouldFail) { - System.err.println("Test passed: couldn't reach unicast obj: " + - thisShouldFail.getMessage()); - return; - } - - TestLibrary.bomb("Test failed: unicast obj accessible after group reactivates", - null); - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup_Stub.java b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup_Stub.java deleted file mode 100644 index 5d9fd2ede48..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/InactiveGroup_Stub.java +++ /dev/null @@ -1,140 +0,0 @@ -/* - * Copyright (c) 1998, 2001, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class InactiveGroup_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("ActivateMe getUnicastVersion()"), - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = -23477180812089514L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_getUnicastVersion_0; - private static java.lang.reflect.Method $method_ping_1; - private static java.lang.reflect.Method $method_shutdown_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_getUnicastVersion_0 = ActivateMe.class.getMethod("getUnicastVersion", new java.lang.Class[] {}); - $method_ping_1 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_2 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public InactiveGroup_Stub() { - super(); - } - public InactiveGroup_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of getUnicastVersion() - public ActivateMe getUnicastVersion() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getUnicastVersion_0, null, -4366214672304578894L); - return ((ActivateMe) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ActivateMe $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (ActivateMe) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_1, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_2, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/group.security.policy b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/security.policy b/test/jdk/java/rmi/activation/Activatable/inactiveGroup/security.policy deleted file mode 100644 index c8a24a64de1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/inactiveGroup/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting object with non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/LookupActivationSystem.java b/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/LookupActivationSystem.java deleted file mode 100644 index 8ed9c763b32..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/LookupActivationSystem.java +++ /dev/null @@ -1,129 +0,0 @@ -/* - * Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 6245733 - * @summary synopsis: rmid's registry's list operation doesn't include - * activation system - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * @run main/othervm/timeout=240 LookupActivationSystem - */ - -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.registry.*; -import java.rmi.server.*; -import java.io.Serializable; - -public class LookupActivationSystem implements Remote, Serializable { - - private static final String NAME = ActivationSystem.class.getName(); - - public static void main(String[] args) throws Exception { - - System.out.println("\nRegression test for bug 6245733\n"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - System.err.println("look up activation system"); - Registry rmidRegistry = - LocateRegistry.getRegistry(rmid.getPort()); - ActivationSystem system = (ActivationSystem) - rmidRegistry.lookup(NAME); - - if (system instanceof ActivationSystem) { - System.err.println("test1 passed: lookup succeeded"); - } - - System.err.println("get list of rmid internal registry"); - String[] list = rmidRegistry.list(); - if (list.length == 1 && list[0].equals(NAME)) { - System.err.println( - "test2 passed: activation system found in list"); - } else { - throw new RuntimeException("test2 FAILED"); - } - - try { - rmidRegistry.bind(NAME, new LookupActivationSystem()); - throw new RuntimeException("test3 FAILED: bind succeeded!"); - } catch (ServerException e) { - if (e.getCause() instanceof AccessException) { - System.err.println( - "test3 passed: binding ActivationSystem " + - "failed as expected"); - } else { - throw new RuntimeException( - "test3 FAILED: incorrect cause: " + e.getCause()); - } - - } - - try { - rmidRegistry.rebind(NAME, new LookupActivationSystem()); - throw new RuntimeException("test4 FAILED: rebind succeeded!"); - } catch (ServerException e) { - if (e.getCause() instanceof AccessException) { - System.err.println( - "test4 passed: rebinding ActivationSystem " + - "failed as expected"); - } else { - throw new RuntimeException( - "test4 FAILED: incorrect cause: " + e.getCause()); - } - } - - try { - rmidRegistry.unbind(NAME); - throw new RuntimeException("test4 FAILED: unbind succeeded!"); - } catch (ServerException e) { - if (e.getCause() instanceof AccessException) { - System.err.println( - "test5 passed: unbinding ActivationSystem " + - "failed as expected"); - } else { - throw new RuntimeException( - "test5 FAILED: incorrect cause: " + e.getCause()); - } - } - - - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/rmid.security.policy deleted file mode 100644 index 69c222e3e63..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/lookupActivationSystem/rmid.security.policy +++ /dev/null @@ -1,6 +0,0 @@ -grant { - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/nestedActivate/ActivateMe.java deleted file mode 100644 index a75ba277d3d..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/ActivateMe.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void unregister() throws Exception; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate.java b/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate.java deleted file mode 100644 index b1c841dc256..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate.java +++ /dev/null @@ -1,176 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4138056 - * @summary synopsis: Activating objects from an Activatable constructor causes deadlock - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary ActivateMe NestedActivate_Stub - * @run main/othervm/policy=security.policy/timeout=240 NestedActivate - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Properties; - -public class NestedActivate - extends Activatable - implements ActivateMe, Runnable -{ - - private static Exception exception = null; - private static boolean done = false; - private ActivateMe obj = null; - - public NestedActivate(ActivationID id, MarshalledObject mobj) - throws Exception - { - super(id, 0); - System.err.println("NestedActivate<>: activating object"); - if (mobj != null) { - System.err.println("NestedActivate<>: ping obj to activate"); - obj = (ActivateMe) mobj.get(); - obj.ping(); - System.err.println("NestedActivate<>: ping completed"); - } - } - - public void ping() - {} - - public void unregister() throws Exception { - super.unregister(super.getID()); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"NestedActivate")).start(); - if (obj != null) - obj.shutdown(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.err.println("\nRegression test for bug 4138056\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - final Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - Thread t = new Thread() { - public void run () { - try { - System.err.println("Creating group descriptor"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationGroupID groupID = - ActivationGroup.getSystem(). - registerGroup(groupDesc); - - System.err.println("Creating descriptor: object 1"); - ActivationDesc desc1 = - new ActivationDesc(groupID, "NestedActivate", - null, null); - - System.err.println("Registering descriptor: object 1"); - ActivateMe obj1 = - (ActivateMe) Activatable.register(desc1); - - System.err.println("Creating descriptor: object 2"); - ActivationDesc desc2 = - new ActivationDesc(groupID, "NestedActivate", null, - new MarshalledObject(obj1)); - - System.err.println("Registering descriptor: object 2"); - ActivateMe obj2 = - (ActivateMe) Activatable.register(desc2); - - System.err.println("Activating object 2"); - obj2.ping(); - - System.err.println("Deactivating objects"); - obj2.shutdown(); - } catch (Exception e) { - exception = e; - } - done = true; - } - }; - - t.start(); - t.join(35000); - - if (exception != null) { - TestLibrary.bomb("test failed", exception); - } else if (!done) { - TestLibrary.bomb("test failed: not completed before timeout", null); - } else { - System.err.println("Test passed"); - } - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate_Stub.java b/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate_Stub.java deleted file mode 100644 index 22870a41b0f..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/NestedActivate_Stub.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class NestedActivate_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()"), - new java.rmi.server.Operation("void unregister()") - }; - - private static final long interfaceHash = 4395146122524413703L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - private static java.lang.reflect.Method $method_unregister_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - $method_unregister_2 = ActivateMe.class.getMethod("unregister", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public NestedActivate_Stub() { - super(); - } - public NestedActivate_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } - - // implementation of unregister() - public void unregister() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_unregister_2, null, -5366864281862648102L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/group.security.policy b/test/jdk/java/rmi/activation/Activatable/nestedActivate/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/nestedActivate/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nestedActivate/security.policy b/test/jdk/java/rmi/activation/Activatable/nestedActivate/security.policy deleted file mode 100644 index ac03704a625..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nestedActivate/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting of non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/ActivateMe.java deleted file mode 100644 index a75ba277d3d..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/ActivateMe.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void unregister() throws Exception; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable.java b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable.java deleted file mode 100644 index 5074ac52bc5..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable.java +++ /dev/null @@ -1,150 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4115296 - * @summary synopsis: NoSuchObjectException not thrown for non-existent - * activatable objects - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * ActivateMe NonExistentActivatable_Stub - * @run main/othervm/policy=security.policy/timeout=240 NonExistentActivatable - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Properties; - -public class NonExistentActivatable - extends Activatable - implements ActivateMe, Runnable -{ - - public NonExistentActivatable(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - } - - public void ping() - {} - - public void unregister() throws Exception { - super.unregister(super.getID()); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"NonExistentActivatable")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() - { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4115331\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - System.err.println("Create activation group in this VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - - System.err.println("Creating descriptor"); - ActivationDesc desc = - new ActivationDesc("NonExistentActivatable", null, null); - - System.err.println("Registering descriptor"); - ActivateMe obj = (ActivateMe) Activatable.register(desc); - - System.err.println("Activate object via method call"); - obj.ping(); - - System.err.println("Unregister object"); - obj.unregister(); - - System.err.println("Make object inactive"); - obj.shutdown(); - - System.err.println("Reactivate object"); - try { - obj.ping(); - } catch (NoSuchObjectException e) { - System.err.println("Test succeeded: " + - "NoSuchObjectException caught"); - return; - } catch (Exception e) { - TestLibrary.bomb("Test failed: exception other than NoSuchObjectException", - e); - } - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable_Stub.java b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable_Stub.java deleted file mode 100644 index fa0e2d4b258..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/NonExistentActivatable_Stub.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class NonExistentActivatable_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()"), - new java.rmi.server.Operation("void unregister()") - }; - - private static final long interfaceHash = 4395146122524413703L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - private static java.lang.reflect.Method $method_unregister_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - $method_unregister_2 = ActivateMe.class.getMethod("unregister", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public NonExistentActivatable_Stub() { - super(); - } - public NonExistentActivatable_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } - - // implementation of unregister() - public void unregister() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_unregister_2, null, -5366864281862648102L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/group.security.policy b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/security.policy b/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/security.policy deleted file mode 100644 index c8a24a64de1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/nonExistentActivatable/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // allow exporting object with non-public remote interface - permission java.rmi.RMIPermission "exportRemoteInterface.ActivateMe"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/notSerializable/NotSerializable.java b/test/jdk/java/rmi/activation/Activatable/notSerializable/NotSerializable.java deleted file mode 100644 index 5e45106bfdd..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/notSerializable/NotSerializable.java +++ /dev/null @@ -1,146 +0,0 @@ -/* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4460983 - * @summary This test verifies that an instance of Activatable cannot - * be serialized (without implicit impl-to-stub replacement), because - * it cannot be meaningfully deserialized anyway. - * See also test/java/rmi/server/RemoteObject/unrecognizedRefType. - * @author Peter Jones - * - * @run main/othervm NotSerializable - */ - -import java.io.ByteArrayOutputStream; -import java.io.NotSerializableException; -import java.io.ObjectInput; -import java.io.ObjectOutputStream; -import java.io.ObjectOutput; -import java.lang.reflect.Method; -import java.rmi.MarshalledObject; -import java.rmi.NoSuchObjectException; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.server.Operation; -import java.rmi.server.RemoteCall; -import java.rmi.server.RemoteObject; -import java.rmi.server.RemoteRef; -import java.rmi.server.RemoteStub; -import java.rmi.activation.Activatable; -import java.rmi.activation.ActivationID; -import java.rmi.activation.Activator; - -public class NotSerializable { - - public static void main(String[] args) throws Exception { - System.err.println("\nRegression test for bug 4460983\n"); - - Activatable act = new FakeActivatable(); - try { - ObjectOutputStream out = - new ObjectOutputStream(new ByteArrayOutputStream()); - try { - out.writeObject(act); - throw new RuntimeException("TEST FAILED: " + - "Activatable instance successfully serialized"); - } catch (NotSerializableException e) { - System.err.println("NotSerializableException as expected:"); - e.printStackTrace(); - } // other exceptions cause test failure - - System.err.println("TEST PASSED"); - } finally { - try { - Activatable.unexportObject(act, true); - } catch (NoSuchObjectException e) { - } - } - } - - private static class FakeActivatable extends Activatable { - FakeActivatable() throws RemoteException { - super(new ActivationID(new FakeActivator()), 0); - } - } - - private static class FakeActivator - extends RemoteStub implements Activator - { - FakeActivator() { - super(new FakeRemoteRef("FakeRef")); - } - - public MarshalledObject activate(ActivationID id, boolean force) { - return null; - } - } - - private static class FakeRemoteRef implements RemoteRef { - private final String refType; - - FakeRemoteRef(String refType) { - this.refType = refType; - } - - public Object invoke(Remote obj, - Method method, - Object[] params, - long opnum) - { - throw new UnsupportedOperationException(); - } - - public RemoteCall newCall(RemoteObject obj, - Operation[] op, - int opnum, - long hash) - { - throw new UnsupportedOperationException(); - } - - public void invoke(RemoteCall call) { - throw new UnsupportedOperationException(); - } - - public void done(RemoteCall call) { - throw new UnsupportedOperationException(); - } - - public String getRefClass(java.io.ObjectOutput out) { - return refType; - } - - public int remoteHashCode() { return hashCode(); } - public boolean remoteEquals(RemoteRef obj) { return equals(obj); } - public String remoteToString() { return toString(); } - - public void readExternal(ObjectInput in) { - throw new UnsupportedOperationException(); - } - - public void writeExternal(ObjectOutput out) { - // no data to write - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/ActivateMe.java deleted file mode 100644 index 1f6f5529f0a..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/ActivateMe.java +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright (c) 1999, 2000, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -// TEMPORARY HACK!!! to make interface public until MIS.resolveProxyClass is fixed. -public interface ActivateMe extends Remote { - public void ping(String responder) throws RemoteException; - public ActivateMe getUnicastVersion() throws RemoteException; - public void crash() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService.java b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService.java deleted file mode 100644 index 526d142af71..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService.java +++ /dev/null @@ -1,243 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4095165 - * @bug 4140736 - * @summary synopsis: rmid should waitFor restartable objects that crash and restart them - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivateMe RestartCrashedService_Stub - * @run main/othervm/policy=security.policy/timeout=240 RestartCrashedService - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Vector; -import java.util.Properties; - -public class RestartCrashedService - implements ActivateMe -{ - - private ActivationID id; - private static Object lock = new Object(); - private Vector responders = new Vector(); - - private static final String RESTARTABLE = "restartable"; - private static final String ACTIVATABLE = "activatable"; - - - public RestartCrashedService(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - ActivateMe obj; - String responder; - try { - Object[] stuff = (Object[]) mobj.get(); - responder = (String) stuff[0]; - System.err.println(responder + " service started"); - obj = (ActivateMe) stuff[1]; - } catch (Exception e) { - System.err.println("unable to obtain stub from marshalled object"); - return; - } - - obj.ping(responder); - } - - public RestartCrashedService() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - public void ping(String responder) { - System.err.println("RestartCrashedService: received ping from " + responder); - synchronized (lock) { - responders.add(responder); - lock.notify(); - } - } - - public boolean receivedPing(String responder) { - return responders.contains(responder); - } - - public void resetResponders() { - responders.clear(); - } - - public ActivateMe getUnicastVersion() throws RemoteException { - return new RestartCrashedService(); - } - - public void crash() { - System.exit(0); - } - - public ActivationID getID() { - return id; - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4095165, 4140736\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - RestartCrashedService unicastObj = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - final Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Create unicast object to be contacted when service is activated. - */ - unicastObj = new RestartCrashedService(); - /* - * Create and register descriptors for a restartable and - * non-restartable service (respectively) in a group other than - * this VM's group. - */ - System.err.println("Creating descriptors"); - - Object[] stuff = new Object[] { RESTARTABLE, unicastObj }; - MarshalledObject restartMobj = new MarshalledObject(stuff); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - - stuff[0] = ACTIVATABLE; - MarshalledObject activateMobj = new MarshalledObject(stuff); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - ActivationDesc restartableDesc = - new ActivationDesc(groupID, "RestartCrashedService", null, - restartMobj, true); - - ActivationDesc activatableDesc = - new ActivationDesc(groupID, "RestartCrashedService", null, - activateMobj, false); - - System.err.println("Registering descriptors"); - ActivateMe restartableObj = - (ActivateMe) Activatable.register(restartableDesc); - - ActivateMe activatableObj = - (ActivateMe) Activatable.register(activatableDesc); - - /* - * Restart rmid; it should start up the restartable service - */ - rmid.restart(); - - /* - * Wait for service to be automatically restarted. - */ - int repeat = 1; - - do { - - for (int i = 0; i < 15; i++) { - synchronized (lock) { - if (unicastObj.receivedPing(RESTARTABLE) != true) { - lock.wait(5000); - if (unicastObj.receivedPing(RESTARTABLE) == true) { - System.err.println("Test1 passed: rmid " + - "restarted service"); - break; - } - } else { - break; - } - } - } - - if (unicastObj.receivedPing(RESTARTABLE) != true) - TestLibrary.bomb("Test1 failed: service not restarted by timeout", - null); - - /* - * Make sure activatable services wasn't automatically - * restarted. - */ - synchronized (lock) { - if (unicastObj.receivedPing(ACTIVATABLE) != true) { - lock.wait(5000); - if (unicastObj.receivedPing(ACTIVATABLE) != true) { - System.err.println("Test2 passed: rmid did not " + - "restart activatable service"); - } else { - TestLibrary.bomb("Test2 failed: activatable service restarted", - null); - } - } else { - TestLibrary.bomb("Test2 failed: activatable service restarted!", - null); - } - } - - - if (repeat > 0) { - try { - System.err.println("\nCrash restartable object"); - unicastObj.resetResponders(); - restartableObj.crash(); - } catch (Exception e) { - } - } - - } while (repeat-- > 0); - - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - TestLibrary.unexport(unicastObj); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService_Stub.java b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService_Stub.java deleted file mode 100644 index 9e30d9a3f9b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/RestartCrashedService_Stub.java +++ /dev/null @@ -1,146 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class RestartCrashedService_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void crash()"), - new java.rmi.server.Operation("ActivateMe getUnicastVersion()"), - new java.rmi.server.Operation("void ping(java.lang.String)") - }; - - private static final long interfaceHash = -5511576339806675599L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_crash_0; - private static java.lang.reflect.Method $method_getUnicastVersion_1; - private static java.lang.reflect.Method $method_ping_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_crash_0 = ActivateMe.class.getMethod("crash", new java.lang.Class[] {}); - $method_getUnicastVersion_1 = ActivateMe.class.getMethod("getUnicastVersion", new java.lang.Class[] {}); - $method_ping_2 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {java.lang.String.class}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public RestartCrashedService_Stub() { - super(); - } - public RestartCrashedService_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of crash() - public void crash() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_crash_0, null, 8484760490859430950L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } - - // implementation of getUnicastVersion() - public ActivateMe getUnicastVersion() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getUnicastVersion_1, null, -4366214672304578894L); - return ((ActivateMe) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ActivateMe $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (ActivateMe) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of ping(String) - public void ping(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_2, new java.lang.Object[] {$param_String_1}, 8618968970901024056L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeObject($param_String_1); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/group.security.policy b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/rmid.security.policy deleted file mode 100644 index ce485f61343..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/security.policy b/test/jdk/java/rmi/activation/Activatable/restartCrashedService/security.policy deleted file mode 100644 index 0882def59ad..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartCrashedService/security.policy +++ /dev/null @@ -1,34 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer.java b/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer.java deleted file mode 100644 index 499ef6ce5d9..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer.java +++ /dev/null @@ -1,268 +0,0 @@ -/* - * Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4526514 - * @summary rmid does not handle group restart for latecomer objects - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * RestartLatecomer RestartLatecomer_Stub - * @run main/othervm/policy=security.policy/timeout=240 RestartLatecomer - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Vector; -import java.util.Properties; - -public class RestartLatecomer - implements ActivateMe, Runnable -{ - - private ActivationID id; - private static Object lock = new Object(); - private Vector responders = new Vector(); - - private static final String RESTARTABLE = "restartable"; - private static final String ACTIVATABLE = "activatable"; - - - public RestartLatecomer(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - ActivateMe obj; - String responder; - try { - Object[] stuff = (Object[]) mobj.get(); - responder = (String) stuff[0]; - System.err.println(responder + " service started"); - obj = (ActivateMe) stuff[1]; - } catch (Exception e) { - System.err.println("unable to obtain stub from marshalled object"); - return; - } - - /* - * Call back object in the test VM to notify it that - * this object has been activated or restarted. - */ - obj.callback(responder); - } - - public RestartLatecomer() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - private void waitFor(String responder) throws Exception { - synchronized (lock) { - for (int i = 0; i < 15; i++) { - if (responders.contains(responder) != true) { - lock.wait(5000); - if (responders.contains(responder) == true) { - return; - } - } else { - return; - } - } - } - - throw new RuntimeException( - "TEST FAILED: service not restarted by timeout"); - } - - private void clearResponders() { - synchronized (lock) { - responders.clear(); - } - } - - - /** - * Notifies the receiver that the object denoted by "responder" - * has activated or restarted. - */ - public void callback(String responder) { - System.err.println( - "RestartLatecomer: received callback from " + responder); - /* - * Notify waiter that callback has been received and - * test can proceed. - */ - synchronized (lock) { - responders.add(responder); - lock.notifyAll(); - } - } - - /** - * Pings object (to activate it). - */ - public void ping() { - System.err.println("RestartLatecomer: recevied ping"); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() { - System.err.println("RestartLatecomer: received shutdown request"); - (new Thread(this,"RestartLatecomer")).start(); - } - - public ActivationID getID() { - return id; - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - System.exit(0); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4526514\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - RestartLatecomer callbackObj = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Create unicast object to be contacted when service is activated. - */ - callbackObj = new RestartLatecomer(); - /* - * Create and register descriptors for a restartable and - * non-restartable service (respectively) in a group other than - * this VM's group. - */ - System.err.println("Creating descriptors"); - - Object[] stuff = new Object[] { RESTARTABLE, callbackObj }; - MarshalledObject restartMobj = new MarshalledObject(stuff); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - - stuff[0] = ACTIVATABLE; - MarshalledObject activateMobj = new MarshalledObject(stuff); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - - ActivationDesc activatableDesc = - new ActivationDesc(groupID, "RestartLatecomer", null, - activateMobj, false); - ActivationDesc restartableDesc = - new ActivationDesc(groupID, "RestartLatecomer", null, - restartMobj, true); - - - System.err.println("Register activatable object's descriptor"); - ActivateMe activatableObj = - (ActivateMe) Activatable.register(activatableDesc); - - System.err.println("Activate object (starts group VM)"); - activatableObj.ping(); - - callbackObj.waitFor(ACTIVATABLE); - callbackObj.clearResponders(); - System.err.println("Callback from activatable object received"); - - System.err.println("Register restartable object's descriptor"); - ActivateMe restartableObj = - (ActivateMe) Activatable.register(restartableDesc); - - System.err.println("Shutdown object (exits group VM)"); - try { - activatableObj.shutdown(); - } catch (RemoteException ignore) { - /* - * Since the shutdown method spawns a thread to call - * System.exit, the group's VM may exit, closing all - * connections, before this call had returned. If that - * happens, then a RemoteException will be caught - * here. - */ - } - - System.err.println("Pause for shutdown to happen..."); - Thread.sleep(5000); - - /* - * Wait for "latecomer" restartable service to be - * automatically restarted. - */ - callbackObj.waitFor(RESTARTABLE); - System.err.println( - "TEST PASSED: rmid restarted latecomer service"); - - } catch (Exception e) { - TestLibrary.bomb(e); - } finally { - rmid.cleanup(); - TestLibrary.unexport(callbackObj); - } - } - - -} - - -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void callback(String responder) throws RemoteException; - public void shutdown() throws RemoteException; -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer_Stub.java b/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer_Stub.java deleted file mode 100644 index ba9c71f06db..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/RestartLatecomer_Stub.java +++ /dev/null @@ -1,99 +0,0 @@ -/* - * Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class RestartLatecomer_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_callback_0; - private static java.lang.reflect.Method $method_ping_1; - private static java.lang.reflect.Method $method_shutdown_2; - - static { - try { - $method_callback_0 = ActivateMe.class.getMethod("callback", new java.lang.Class[] {java.lang.String.class}); - $method_ping_1 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_2 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public RestartLatecomer_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of callback(String) - public void callback(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_callback_0, new java.lang.Object[] {$param_String_1}, -1016900954059279373L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_ping_1, null, 5866401369815527589L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_shutdown_2, null, -7207851917985848402L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/group.security.policy b/test/jdk/java/rmi/activation/Activatable/restartLatecomer/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/restartLatecomer/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/security.policy b/test/jdk/java/rmi/activation/Activatable/restartLatecomer/security.policy deleted file mode 100644 index b0aa6518e0f..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartLatecomer/security.policy +++ /dev/null @@ -1,39 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Used in remote impl of Activator.inactive; by the method - // "restartThread.dispose()"when it calls thread.interrupt() - permission java.lang.RuntimePermission "modifyThreadGroup"; - permission java.lang.RuntimePermission "modifyThread"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/restartService/ActivateMe.java deleted file mode 100644 index 06c6d1c5f82..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/ActivateMe.java +++ /dev/null @@ -1,31 +0,0 @@ -/* - * Copyright (c) 1999, 2000, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -public interface ActivateMe extends Remote { - public void ping(String responder) throws RemoteException; -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/RestartService.java b/test/jdk/java/rmi/activation/Activatable/restartService/RestartService.java deleted file mode 100644 index 792c02f208c..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/RestartService.java +++ /dev/null @@ -1,234 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4095165 4321151 - * @key intermittent - * @summary synopsis: activator should restart daemon services - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary ActivateMe RestartService_Stub - * @run main/othervm/policy=security.policy/timeout=240 RestartService - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Vector; -import java.util.Properties; - -public class RestartService - implements ActivateMe, Runnable -{ - - private ActivationID id; - private static Object lock = new Object(); - private Vector responders = new Vector(); - - private static final String RESTARTABLE = "restartable"; - private static final String ACTIVATABLE = "activatable"; - - - public RestartService(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - ActivateMe obj; - String responder; - try { - Object[] stuff = (Object[]) mobj.get(); - responder = (String) stuff[0]; - System.err.println(responder + " service started"); - obj = (ActivateMe) stuff[1]; - } catch (Exception e) { - System.err.println("unable to obtain stub from marshalled object"); - return; - } - - obj.ping(responder); - } - - public RestartService() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - public void ping(String responder) { - System.err.println("RestartService: received ping from " + responder); - synchronized (lock) { - responders.add(responder); - lock.notify(); - } - } - - public boolean receivedPing(String responder) { - return responders.contains(responder); - } - - public ActivateMe getUnicastVersion() throws RemoteException { - return new RestartService(); - } - - public ActivationID getID() { - return id; - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"RestartService")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4095165\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - RestartService unicastObj = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", ""); - - /* - * Create unicast object to be contacted when service is activated. - */ - unicastObj = new RestartService(); - /* - * Create and register descriptors for a restartable and - * non-restartable service (respectively) in a group other than - * this VM's group. - */ - System.err.println("Creating descriptors"); - - Object[] stuff = new Object[] { RESTARTABLE, unicastObj }; - MarshalledObject restartMobj = new MarshalledObject(stuff); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - - stuff[0] = ACTIVATABLE; - MarshalledObject activateMobj = new MarshalledObject(stuff); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - ActivationDesc restartableDesc = - new ActivationDesc(groupID, "RestartService", null, - restartMobj, true); - - ActivationDesc activatableDesc = - new ActivationDesc(groupID, "RestartService", null, - activateMobj, false); - - System.err.println("Registering descriptors"); - ActivateMe restartableObj = - (ActivateMe) Activatable.register(restartableDesc); - - ActivateMe activatableObj = - (ActivateMe) Activatable.register(activatableDesc); - - /* - * Restart rmid; it should start up the restartable service - */ - rmid.restart(); - - /* - * Wait for service to be automatically restarted. - */ - boolean gotPing = false; - for (int i = 0; i < 15; i++) { - synchronized (lock) { - if (unicastObj.receivedPing(RESTARTABLE) != true) { - lock.wait(5000); - if (unicastObj.receivedPing(RESTARTABLE) == true) { - System.err.println("Test1 passed: rmid restarted" + - " service"); - gotPing = true; - break; - } - } else { - gotPing = true; - break; - } - } - } - - if (gotPing == false) - TestLibrary.bomb("Test1 failed: service not restarted by timeout", null); - - /* - * Make sure activatable services wasn't automatically restarted. - */ - synchronized (lock) { - if (unicastObj.receivedPing(ACTIVATABLE) != true) { - lock.wait(5000); - if (unicastObj.receivedPing(ACTIVATABLE) != true) { - System.err.println("Test2 passed: rmid did not " + - "restart activatable service"); - return; - } - } - - TestLibrary.bomb("Test2 failed: activatable service restarted!", null); - } - - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - TestLibrary.unexport(unicastObj); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/RestartService_Stub.java b/test/jdk/java/rmi/activation/Activatable/restartService/RestartService_Stub.java deleted file mode 100644 index a58c603f2cd..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/RestartService_Stub.java +++ /dev/null @@ -1,94 +0,0 @@ -/* - * Copyright (c) 1998, 2001, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class RestartService_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping(java.lang.String)") - }; - - private static final long interfaceHash = -3290104068898408724L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {java.lang.String.class}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public RestartService_Stub() { - super(); - } - public RestartService_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping(String) - public void ping(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, new java.lang.Object[] {$param_String_1}, 8618968970901024056L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeObject($param_String_1); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/group.security.policy b/test/jdk/java/rmi/activation/Activatable/restartService/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/restartService/rmid.security.policy deleted file mode 100644 index 3e6ac7893f0..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/restartService/security.policy b/test/jdk/java/rmi/activation/Activatable/restartService/security.policy deleted file mode 100644 index b0aa6518e0f..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/restartService/security.policy +++ /dev/null @@ -1,39 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Used in remote impl of Activator.inactive; by the method - // "restartThread.dispose()"when it calls thread.interrupt() - permission java.lang.RuntimePermission "modifyThreadGroup"; - permission java.lang.RuntimePermission "modifyThread"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/RegisteringActivatable.java b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/RegisteringActivatable.java deleted file mode 100644 index c627bbbf479..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/RegisteringActivatable.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; - -public interface RegisteringActivatable extends Remote { - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully.java b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully.java deleted file mode 100644 index c45d95674e6..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully.java +++ /dev/null @@ -1,195 +0,0 @@ -/* - * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4183169 8032050 - * @summary Minor problem with the way ReliableLog handles IOExceptions. - * - * @author Laird Dornin; code borrowed from Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider - * TestSecurityManager RegisteringActivatable ShutdownGracefully_Stub - * @run main/othervm/policy=security.policy/timeout=700 ShutdownGracefully - */ - -import java.rmi.activation.*; -import java.rmi.*; -import java.util.Properties; -import java.util.concurrent.TimeoutException; - -/** - * The test creates an rmid with a special security manager. After - * rmid makes two registrations (which is greater than rmid's - * snapshotInterval) the security manager stops allowing rmid to write - * to update and snapshot log files in rmid's log directory. The Test - * registers an Activatable object twice with different group ids. - * The second registration will cause rmid to have to write to a - * LogFile (it causes a snapshot) and the security manager will not - * allow the file write to happen. The test makes sure that rmid - * shuts down in a graceful manner without any explicit request to do - * so. The test will not exit for 400 seconds if rmid does not exit - * (after that time, the test will fail). - */ -public class ShutdownGracefully - extends Activatable implements RegisteringActivatable -{ - private static RegisteringActivatable registering = null; - - private final static long SHUTDOWN_TIMEOUT = 400 * 1000; - - public static void main(String args[]) { - - RMID rmid = null; - - // Save exception if there is a exception or expected behavior - Exception exception = null; - System.err.println("\nRegression test for bug/rfe 4183169\n"); - - try { - TestLibrary.suggestSecurityManager( - "java.rmi.RMISecurityManager"); - - // start an rmid. - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - - // rmid needs to run with a security manager that - // simulates a log problem; rmid should also snapshot - // quickly. - rmid.addOptions(new String[] { - "-Djava.security.manager=TestSecurityManager", - "-Dsun.rmi.activation.snapshotInterval=1"}); - - // rmid.addArguments(new String[] { - // "-C-Djava.rmi.server.logCalls=true"}); - - rmid.start(); - - // Ensure that activation groups run with the correct - // security manager. - // - Properties p = new Properties(); - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - "java.lang.SecurityManager"); - - System.err.println("activation group will be created " + - "in a new VM"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - - System.err.println("registering activatable"); - ActivationDesc desc = new ActivationDesc - (groupID, "ShutdownGracefully", null, null); - registering = (RegisteringActivatable) - Activatable.register(desc); - - System.err.println("activate and deactivate object " + - "via method call"); - registering.shutdown(); - - /* - * the security manager rmid is running with will stop - * rmid from writing to its log files; in 1.2.x this would - * have caused rmid to have thrown a runtime exception and - * continue running in an unstable state. With the fix - * for 4183169, rmid should shutdown gracefully instead. - */ - - /* - * register another activatable with a new group id; rmid - * should not recover from this... I use two - * registrations to more closely simulate the environment - * in which the bug was found. In java versions with out - * the appropriate bug fix, rmid would hide a - * NullPointerException in this circumstance. - */ - p.put("dummyname", "dummyvalue"); - groupDesc = new ActivationGroupDesc(p, null); - ActivationGroupID secondGroupID = - system.registerGroup(groupDesc); - desc = new ActivationDesc(secondGroupID, - "ShutdownGracefully", null, null); - - /* - * registration request is expected to be failed. succeeded case - * should be recorded. And raise error after clean up rmid. - */ - try { - registering = (RegisteringActivatable) - Activatable.register(desc); - System.err.println("The registration request succeeded unexpectedly"); - exception = new RuntimeException("The registration request succeeded unexpectedly"); - } catch (ActivationException e) { - System.err.println("received exception from registration " + - "call that should have failed..."); - // Need wait rmid process terminates. - try { - int exitCode = rmid.waitFor(SHUTDOWN_TIMEOUT); - System.err.println("RMID has exited gracefully with exitcode:" + exitCode); - rmid = null; - } catch (TimeoutException te) { - System.err.println("RMID process has not exited in given time"); - exception = te; - } - } - } catch (Exception e) { - System.err.println("Exception thrown:" + e); - exception = e; - } finally { - if (rmid != null) - rmid.cleanup(); - } - if (exception != null) - TestLibrary.bomb("\nexception thrown in test: ", exception); - } - - /** - * implementation of RegisteringActivatable - */ - public ShutdownGracefully - (ActivationID id, MarshalledObject mo) throws RemoteException - { - // register/export anonymously - super(id, 0); - } - - /** - * Deactivates the object. We need to unexport forcibly because this call - * in-progress on this object, which is the same object that we are trying - * to deactivate. - */ - public void shutdown() throws Exception { - Activatable.unexportObject(this, true); - ActivationLibrary.deactivate(this, getID()); - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully_Stub.java b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully_Stub.java deleted file mode 100644 index f04120d3030..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/ShutdownGracefully_Stub.java +++ /dev/null @@ -1,57 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ShutdownGracefully_Stub - extends java.rmi.server.RemoteStub - implements RegisteringActivatable, java.rmi.Remote -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_shutdown_0; - - static { - try { - $method_shutdown_0 = RegisteringActivatable.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public ShutdownGracefully_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - ref.invoke(this, $method_shutdown_0, null, -7207851917985848402L); - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/TestSecurityManager.java b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/TestSecurityManager.java deleted file mode 100644 index 4ac4b51c1ab..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/TestSecurityManager.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - * - * Security manager which prevents RMID from writing to its logfile - * after it has written out a snapshot. - */ - -import java.io.File; - -public class TestSecurityManager extends SecurityManager { - public TestSecurityManager() { - } - public void checkWrite(String file) { - if (file.endsWith("log" + File.separatorChar + "Snapshot.6")) { - System.out.println("writing file: " + file + " simulating log failure"); - throw new SecurityException("simulating log failure"); - } - } - - public void checkRead(String file) { - if (file.endsWith("log" + File.separatorChar + "Logfile.6")) - { - System.out.println("reading file: " + file + " simulating log failure"); - throw new SecurityException("simulating log failure"); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/group.security.policy b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/rmid.security.policy deleted file mode 100644 index 30b4e537750..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=java.lang.SecurityManager"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Ddummyname=dummyvalue"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/security.policy b/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/security.policy deleted file mode 100644 index b4418a72c3e..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/shutdownGracefully/security.policy +++ /dev/null @@ -1,31 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/ActivateMe.java b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/ActivateMe.java deleted file mode 100644 index 7a7ac2a8ffa..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/ActivateMe.java +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Copyright (c) 1999, 2000, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; - -// TEMPORARY HACK!!! needed to make interface public until MIS is fixed. -public interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void unregister() throws Exception; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive.java b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive.java deleted file mode 100644 index 2ff66718bf4..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive.java +++ /dev/null @@ -1,136 +0,0 @@ -/* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4115331 - * @summary synopsis: activatable object fails to go inactive after - * unregister/inactive sequence. - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary ActivateMe UnregisterInactive_Stub - * @run main/othervm/policy=security.policy/timeout=240 UnregisterInactive - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.Properties; - -public class UnregisterInactive - extends Activatable - implements ActivateMe, Runnable -{ - - public UnregisterInactive(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - } - - public void ping() - {} - - public void unregister() throws Exception { - super.unregister(super.getID()); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"UnregisterInactive")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4115331\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - System.err.println("Creating descriptor"); - - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - - ActivationDesc desc = - new ActivationDesc("UnregisterInactive", null, null); - - System.err.println("Registering descriptor"); - ActivateMe obj = (ActivateMe) Activatable.register(desc); - - System.err.println("Activate object via method call"); - obj.ping(); - - System.err.println("Unregister object"); - obj.unregister(); - - System.err.println("Make object inactive"); - obj.shutdown(); - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive_Stub.java b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive_Stub.java deleted file mode 100644 index 092ad4f4889..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/UnregisterInactive_Stub.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (c) 1998, 1999, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class UnregisterInactive_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("void shutdown()"), - new java.rmi.server.Operation("void unregister()") - }; - - private static final long interfaceHash = 4395146122524413703L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - private static java.lang.reflect.Method $method_unregister_2; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - $method_unregister_2 = ActivateMe.class.getMethod("unregister", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public UnregisterInactive_Stub() { - super(); - } - public UnregisterInactive_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } - - // implementation of unregister() - public void unregister() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_unregister_2, null, -5366864281862648102L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/group.security.policy b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/rmid.security.policy b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/security.policy b/test/jdk/java/rmi/activation/Activatable/unregisterInactive/security.policy deleted file mode 100644 index 63fecad764c..00000000000 --- a/test/jdk/java/rmi/activation/Activatable/unregisterInactive/security.policy +++ /dev/null @@ -1,34 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test rmid uses these properties to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // Needed to create an activation group - permission java.lang.RuntimePermission "setFactory"; - - // allow exporting of remote objects on an arbitrary port. - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails.java b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails.java deleted file mode 100644 index b5787d05735..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails.java +++ /dev/null @@ -1,174 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4097135 - * @summary Need a specific subtype of RemoteException for activation failure. - * If activation fails to happen during a call to a remote object, - * then the call should end in an ActivateFailedException. In this - * test, the actual "activatable" remote object fails to activate - * since its * "activation" constructor throws an exception. - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider ActivationLibrary - * ActivateMe ActivateFails_Stub ShutdownThread - * @run main/othervm/java.security.policy=security.policy/timeout=240 ActivateFails - */ - -import java.rmi.*; -import java.rmi.server.*; -import java.rmi.activation.*; -import java.io.*; -import java.util.Properties; - -public class ActivateFails - extends Activatable - implements ActivateMe -{ - - public ActivateFails(ActivationID id, MarshalledObject obj) - throws ActivationException, RemoteException - { - super(id, 0); - - boolean refuseToActivate = false; - try { - refuseToActivate = ((Boolean)obj.get()).booleanValue(); - } catch (Exception impossible) { - } - - if (refuseToActivate) - throw new RemoteException("object refuses to activate"); - } - - public void ping() - {} - - /** - * Spawns a thread to deactivate the object. - */ - public ShutdownThread shutdown() throws Exception - { - ShutdownThread shutdownThread = new ShutdownThread(this, getID()); - shutdownThread.start(); - return(shutdownThread); - } - - public static void main(String[] args) - { - RMID rmid = null; - ActivateMe obj1, obj2; - ShutdownThread shutdownThread; - - System.err.println("\nRegression test for bug 4097135\n"); - try { - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - /* - * First run "rmid" and wait for it to start up. - */ - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - TestParams.defaultSecurityManager); - - /* - * Create activation descriptor... - */ - System.err.println("creating activation descriptor..."); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - - ActivationDesc desc1 = - new ActivationDesc(groupID, "ActivateFails", - null, - new MarshalledObject(new Boolean(true))); - - ActivationDesc desc2 = - new ActivationDesc(groupID, "ActivateFails", - null, - new MarshalledObject(new Boolean(false))); - /* - * Register activation descriptor and make a call on - * the stub. Activation should fail with an - * ActivateFailedException. If not, report an - * error as a RuntimeException - */ - - System.err.println("registering activation descriptor..."); - obj1 = (ActivateMe)Activatable.register(desc1); - obj2 = (ActivateMe)Activatable.register(desc2); - - System.err.println("invoking method on activatable object..."); - try { - obj1.ping(); - throw new RuntimeException("ActivateFailedException is expected"); - } catch (ActivateFailedException e) { - - /* - * This is what is expected so exit with status 0 - */ - System.err.println("\nsuccess: ActivateFailedException " + - "generated"); - e.getMessage(); - } - - obj2.ping(); - shutdownThread = obj2.shutdown(); - - // wait for shutdown to work - Thread.sleep(2000); - - shutdownThread = null; - - } catch (Exception e) { - /* - * Test failed; unexpected exception generated. - */ - TestLibrary.bomb("\nfailure: unexpected exception " + - e.getClass().getName() + ": " + e.getMessage(), e); - - } finally { - obj1 = obj2 = null; - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails_Stub.java b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails_Stub.java deleted file mode 100644 index b0d2111b943..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateFails_Stub.java +++ /dev/null @@ -1,116 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ActivateFails_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("void ping()"), - new java.rmi.server.Operation("ShutdownThread shutdown()") - }; - - private static final long interfaceHash = -6632667923281093978L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_ping_0 = ActivateMe.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public ActivateFails_Stub() { - super(); - } - public ActivateFails_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public ShutdownThread shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_shutdown_1, null, -3616843253114182719L); - return ((ShutdownThread) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - ShutdownThread $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (ShutdownThread) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateMe.java b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateMe.java deleted file mode 100644 index a778f379b3e..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public ShutdownThread shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ShutdownThread.java b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ShutdownThread.java deleted file mode 100644 index 4657b42ef95..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/ShutdownThread.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright (c) 2001, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import java.rmi.activation.*; -import java.io.*; - -public class ShutdownThread extends Thread implements Serializable { - - Remote remoteObject = null; - ActivationID activationID = null; - - public ShutdownThread(Remote remoteObject, ActivationID activationID) { - remoteObject = remoteObject; - activationID = activationID; - } - - public void run() { - - try { - - Activatable.unexportObject(remoteObject, true); - Activatable.inactive(activationID); - - } catch (Exception e) { - } - - } - -} diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/group.security.policy b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/rmid.security.policy b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/rmid.security.policy deleted file mode 100644 index fd9ccf3da7b..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/rmid.security.policy +++ /dev/null @@ -1,8 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; -}; diff --git a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/security.policy b/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/security.policy deleted file mode 100644 index ef36478e900..00000000000 --- a/test/jdk/java/rmi/activation/ActivateFailedException/activateFails/security.policy +++ /dev/null @@ -1,34 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup.java b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup.java deleted file mode 100644 index e1fbbc34272..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup.java +++ /dev/null @@ -1,186 +0,0 @@ -/* - * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 4510355 - * @summary ActivationGroup implementations cannot be downloaded by default; - * Creates a custom activation group without setting a security manager - * in activation group's descriptor. The custom activation group - * implementation should be downloaded when first object within that group - * is activated. - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary RMIDSelectorProvider - * DownloadActivationGroup MyActivationGroupImpl DownloadActivationGroup_Stub - * @run main/othervm/policy=security.policy/timeout=240 DownloadActivationGroup - */ - -import java.net.URL; -import java.rmi.MarshalledObject; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.Activatable; -import java.rmi.activation.ActivationDesc; -import java.rmi.activation.ActivationException; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationGroupDesc; -import java.rmi.activation.ActivationGroupDesc.CommandEnvironment; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationID; -import java.rmi.server.UnicastRemoteObject; -import java.util.Properties; - -public class DownloadActivationGroup - implements Ping, Runnable -{ - - private ActivationID id; - - public DownloadActivationGroup(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - System.err.println("object activated in group"); - } - - public DownloadActivationGroup() throws RemoteException { - UnicastRemoteObject.exportObject(this, 0); - } - - /** - * Used to activate object. - */ - public void ping() { - System.err.println("received ping"); - } - - /** - * Spawns a thread to deactivate the object (and thus, shuts down the - * activation group). - */ - public void shutdown() throws Exception - { - (new Thread(this,"DownloadActivationGroup")).start(); - } - - /** - * Thread to deactivate object. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public ActivationID getID() { - return id; - } - - - public static void main(String[] args) { - - RMID rmid = null; - - System.out.println("\nRegression test for bug 4510355\n"); - - try { - TestLibrary.suggestSecurityManager("java.lang.SecurityManager"); - - /* - * Install group class file in codebase. - */ - System.err.println("install class file in codebase"); - URL groupURL = TestLibrary.installClassInCodebase( - "MyActivationGroupImpl", "group"); - System.err.println("class file installed"); - - /* - * Start rmid. - */ - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - String execPolicyOption = "-Dsun.rmi.activation.execPolicy=none"; - rmid.addOptions(new String[] { execPolicyOption }); - rmid.addArguments(new String[] { "-C-Djava.security.manager=allow" }); - rmid.start(); - - /* - * Create and register descriptors for custom group and an - * activatable object in that group. - */ - System.err.println("register group"); - - Properties p = new Properties(); - p.put("java.security.policy", TestParams.defaultGroupPolicy); - CommandEnvironment cmd = new ActivationGroupDesc.CommandEnvironment( - null, - new String[] { - "--add-exports=java.rmi/sun.rmi.registry=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.server=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.transport=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.transport.tcp=ALL-UNNAMED" }); - - ActivationGroupDesc groupDesc = - new ActivationGroupDesc("MyActivationGroupImpl", - groupURL.toExternalForm(), - null, p, cmd); - ActivationGroupID groupID = - ActivationGroup.getSystem().registerGroup(groupDesc); - - - System.err.println("register activatable object"); - ActivationDesc desc = - new ActivationDesc(groupID, "DownloadActivationGroup", - null, null); - Ping obj = (Ping) Activatable.register(desc); - - /* - * Start group (by calling ping). - */ - System.err.println( - "ping object (forces download of group's class)"); - obj.ping(); - System.err.println( - "TEST PASSED: group's class downloaded successfully"); - System.err.println("shutdown object"); - obj.shutdown(); - System.err.println("TEST PASSED"); - - } catch (Exception e) { - TestLibrary.bomb(e); - } finally { - rmid.cleanup(); - } - } -} - -interface Ping extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup_Stub.java b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup_Stub.java deleted file mode 100644 index ba7df5a52bc..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/DownloadActivationGroup_Stub.java +++ /dev/null @@ -1,74 +0,0 @@ -/* - * Copyright (c) 2002, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class DownloadActivationGroup_Stub - extends java.rmi.server.RemoteStub - implements Ping -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_ping_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - $method_ping_0 = Ping.class.getMethod("ping", new java.lang.Class[] {}); - $method_shutdown_1 = Ping.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public DownloadActivationGroup_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of ping() - public void ping() - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_ping_0, null, 5866401369815527589L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } -} diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/MyActivationGroupImpl.java b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/MyActivationGroupImpl.java deleted file mode 100644 index 2df6809a4aa..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/MyActivationGroupImpl.java +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Copyright (c) 2002, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import sun.rmi.server.*; -import java.rmi.activation.*; - - -public class MyActivationGroupImpl extends ActivationGroupImpl { - - public MyActivationGroupImpl(ActivationGroupID id, MarshalledObject mobj) - throws RemoteException, ActivationException - { - super(id, mobj); - System.err.println("custom group implementation created"); - } -} diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/group.security.policy b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/group.security.policy deleted file mode 100644 index b290738202a..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/group.security.policy +++ /dev/null @@ -1,11 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; - - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/rmid.security.policy b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/rmid.security.policy deleted file mode 100644 index f2c4f1dbfaa..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/rmid.security.policy +++ /dev/null @@ -1,7 +0,0 @@ -grant { - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/security.policy b/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/security.policy deleted file mode 100644 index 5c829579153..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroup/downloadActivationGroup/security.policy +++ /dev/null @@ -1,7 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - permission java.security.AllPermission; -}; diff --git a/test/jdk/java/rmi/activation/ActivationGroupDesc/checkDefaultGroupName/CheckDefaultGroupName.java b/test/jdk/java/rmi/activation/ActivationGroupDesc/checkDefaultGroupName/CheckDefaultGroupName.java deleted file mode 100644 index b329ea2e14b..00000000000 --- a/test/jdk/java/rmi/activation/ActivationGroupDesc/checkDefaultGroupName/CheckDefaultGroupName.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 4252236 - * @summary ActivationGroupDesc should not do early binding of default classname - * This test doesn't need to run with othervm option as all it does is - * create an ActivationGroupDesc instance, which has no side effects - * @author Laird Dornin - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * @build TestLibrary - * @run main CheckDefaultGroupName - */ - -import java.rmi.activation.*; - -/** - * Test checks the group name for an ActivationGroupDesc which is - * created with no explicit activation group implementation class name - * supplied. - */ -public class CheckDefaultGroupName { - public static void main(String[] args) { - System.out.println("\n\nRegression test for, 4252236\n\n"); - - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(null, null); - - String className = groupDesc.getClassName(); - if (className != null) { - TestLibrary.bomb("ActivationGroupDesc had incorrect default" + - " group implementation class name: " + className); - } else { - System.err.println("test passed, had correct default group" + - " implementation class name: " + className + - "\n\n"); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/IdempotentActiveGroup.java b/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/IdempotentActiveGroup.java deleted file mode 100644 index 9a316e7dac1..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/IdempotentActiveGroup.java +++ /dev/null @@ -1,132 +0,0 @@ -/* - * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4720528 - * @summary synopsis: (spec) ActivationSystem.activeGroup spec should be - * relaxed (duplicate call to activeGroup with same instantiator and - * incarnation should not throw ActivationException; it should succeed) - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary RMIDSelectorProvider - * @run main/othervm/policy=security.policy/timeout=480 IdempotentActiveGroup - */ - -import java.rmi.MarshalledObject; -import java.rmi.NoSuchObjectException; -import java.rmi.RemoteException; -import java.rmi.activation.ActivationDesc; -import java.rmi.activation.ActivationException; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationGroupDesc; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationID; -import java.rmi.activation.ActivationInstantiator; -import java.rmi.activation.ActivationSystem; -import java.rmi.server.UnicastRemoteObject; - -public class IdempotentActiveGroup { - - public static void main(String[] args) { - - System.err.println("\nRegression test for bug 4720528\n"); - - TestLibrary.suggestSecurityManager("java.lang.SecurityManager"); - RMID rmid = null; - ActivationInstantiator inst1 = null; - ActivationInstantiator inst2 = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - System.err.println("Create group descriptor"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(null, null); - ActivationSystem system = ActivationGroup.getSystem(); - System.err.println("Register group descriptor"); - ActivationGroupID groupID = system.registerGroup(groupDesc); - inst1 = new FakeInstantiator(); - inst2 = new FakeInstantiator(); - - System.err.println("Invoke activeGroup with inst1"); - system.activeGroup(groupID, inst1, 0); - - try { - System.err.println("Invoke activeGroup with inst2"); - system.activeGroup(groupID, inst2, 0); - throw new RuntimeException( - "TEST FAILED: activeGroup with unequal groups succeeded!"); - } catch (ActivationException expected) { - System.err.println("Caught expected ActivationException"); - System.err.println("Test 1 (of 2) passed"); - } - - try { - System.err.println("Invoke activeGroup with inst1"); - system.activeGroup(groupID, inst1, 0); - System.err.println("activeGroup call succeeded"); - System.err.println("Test 2 (of 2) passed"); - } catch (ActivationException unexpected) { - throw new RuntimeException( - "TEST FAILED: activeGroup with equal groups failed!", - unexpected); - } - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - try { - if (inst1 != null) { - UnicastRemoteObject.unexportObject(inst1, true); - } - if (inst2 != null) { - UnicastRemoteObject.unexportObject(inst2, true); - } - } catch (NoSuchObjectException unexpected) { - throw new AssertionError(unexpected); - } - rmid.cleanup(); - } - } - - private static class FakeInstantiator - extends UnicastRemoteObject - implements ActivationInstantiator - { - FakeInstantiator() throws RemoteException {} - - public MarshalledObject newInstance(ActivationID id, - ActivationDesc desc) - { - throw new AssertionError(); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/rmid.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/rmid.security.policy deleted file mode 100644 index f2c4f1dbfaa..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/rmid.security.policy +++ /dev/null @@ -1,7 +0,0 @@ -grant { - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/security.policy b/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/security.policy deleted file mode 100644 index a6851ff680e..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/activeGroup/security.policy +++ /dev/null @@ -1,24 +0,0 @@ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ActivateMe.java b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ActivateMe.java deleted file mode 100644 index 4c7b2fff992..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ActivateMe.java +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.activation.ActivationID; -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public String getMessage() throws RemoteException; - public String getProperty(String name) throws RemoteException; - public ActivationID getID() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor.java b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor.java deleted file mode 100644 index 27bb48b60e8..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor.java +++ /dev/null @@ -1,261 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4127754 - * - * @summary synopsis: need to modify registered ActivationDesc and - * ActivationGroupDesc - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary - * ActivateMe ModifyDescriptor_Stub RMIDSelectorProvider - * @run main/othervm/policy=security.policy/timeout=240 ModifyDescriptor - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.rmi.registry.*; -import java.util.*; - -public class ModifyDescriptor - implements ActivateMe, Runnable -{ - - private ActivationID id; - private String message; - - private static final String MESSAGE1 = "hello"; - private static final String MESSAGE2 = "hello, again"; - - - public ModifyDescriptor(ActivationID id, MarshalledObject mobj) - throws ActivationException, RemoteException - { - this.id = id; - Activatable.exportObject(this, id, 0); - - try { - message = (String) mobj.get(); - } catch (Exception e) { - System.err.println("unable to get message from marshalled object"); - } - } - - public String getMessage() { - return message; - } - - public String getProperty(String name) { - return TestLibrary.getProperty(name, null); - } - - public ActivationID getID() { - return id; - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"ModifyDescriptor")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4127754\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* - * Create and register a group and activatable object - */ - - System.err.println("Creating group descriptor"); - Properties props = new Properties(); - props.put("java.security.policy", - TestParams.defaultGroupPolicy); - props.put("java.security.manager", - TestParams.defaultSecurityManager); - props.put("test.message", MESSAGE1); - ActivationGroupDesc initialGroupDesc = - new ActivationGroupDesc(props, null); - System.err.println("Registering group"); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(initialGroupDesc); - - System.err.println("Creating descriptor"); - ActivationDesc initialDesc = - new ActivationDesc(groupID, "ModifyDescriptor", null, - new MarshalledObject(MESSAGE1), false); - - System.err.println("Registering descriptor"); - ActivateMe obj = (ActivateMe) Activatable.register(initialDesc); - - /* - * Ping object and verify that MarshalledObject is okay. - */ - System.err.println("Ping object"); - String message1 = obj.getMessage(); - System.err.println("message = " + message1); - - if (message1.equals(MESSAGE1)) { - System.err.println("Test1a passed: initial MarshalledObject " + - "correct"); - } else { - TestLibrary.bomb("Test1 failed: unexpected MarshalledObject passed to " + - "constructor", null); - } - - /* - * Get property from remote group and make sure it's okay - */ - message1 = obj.getProperty("test.message"); - if (message1.equals(MESSAGE1)) { - System.err.println("Test1b passed: initial group property " + - "correct"); - } else { - TestLibrary.bomb("Test1 failed: unexpected property passed to " + - "group", null); - } - - /* - * Update activation descriptor for object and group - */ - System.err.println("Update activation descriptor"); - ActivationDesc newDesc = - new ActivationDesc(groupID, "ModifyDescriptor", null, - new MarshalledObject(MESSAGE2), false); - ActivationID id = obj.getID(); - ActivationDesc oldDesc = system.setActivationDesc(id, newDesc); - - if (oldDesc.equals(initialDesc)) { - System.err.println("Test2a passed: desc returned from " + - "setActivationDesc is okay"); - } else { - TestLibrary.bomb("Test2a failed: desc returned from setActivationDesc " + - "is not the initial descriptor!", null); - } - - - Properties props2 = new Properties(); - props2.put("test.message", MESSAGE2); - props2.put("java.security.policy", - TestParams.defaultGroupPolicy); - props2.put("java.security.manager", - TestParams.defaultSecurityManager); - ActivationGroupDesc newGroupDesc = - new ActivationGroupDesc(props2, null); - - ActivationGroupDesc oldGroupDesc = - system.setActivationGroupDesc(groupID, newGroupDesc); - - if (oldGroupDesc.equals(initialGroupDesc)) { - System.err.println("Test2b passed: group desc returned from " + - "setActivationGroupDesc is okay"); - } else { - TestLibrary.bomb("Test2b failed: group desc returned from " + - "setActivationGroupDesc is not the initial descriptor!", - null); - } - - /* - * Restart rmid; and ping object to make sure that it has - * new message. - */ - rmid.restart(); - - System.err.println("Ping object after restart"); - String message2 = obj.getMessage(); - - if (message2.equals(MESSAGE2)) { - System.err.println("Test3a passed: setActivationDesc takes " + - "effect after a restart"); - } else { - TestLibrary.bomb("Test3a failed: setActivationDesc did not take effect " + - "after a restart", null); - } - - message2 = obj.getProperty("test.message"); - - if (message2.equals(MESSAGE2)) { - System.err.println("Test3b passed: setActivationGroupDesc " + - "takes effect after a restart"); - } else { - TestLibrary.bomb("Test3b failed: setActivationGroupDesc did not take " + - "effect after a restart", null); - } - - System.err.println("Get activation descriptor"); - ActivationDesc latestDesc = system.getActivationDesc(id); - - if (latestDesc.equals(newDesc)) { - System.err.println("Test4a passed: desc is same as latest"); - } else { - TestLibrary.bomb("Test4a failed: there is no way this would happen", null); - } - - System.err.println("Get activation group descriptor"); - ActivationGroupDesc latestGroupDesc = - system.getActivationGroupDesc(groupID); - - if (latestGroupDesc.equals(newGroupDesc)) { - System.err.println("Test4b passed: group desc is same as " + - "latest"); - } else { - TestLibrary.bomb("Test4b failed: there is no way this would happen", null); - } - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor_Stub.java b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor_Stub.java deleted file mode 100644 index d060da1824b..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/ModifyDescriptor_Stub.java +++ /dev/null @@ -1,194 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class ModifyDescriptor_Stub - extends java.rmi.server.RemoteStub - implements ActivateMe -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("java.rmi.activation.ActivationID getID()"), - new java.rmi.server.Operation("java.lang.String getMessage()"), - new java.rmi.server.Operation("java.lang.String getProperty(java.lang.String)"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = 7998207954486691383L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_getID_0; - private static java.lang.reflect.Method $method_getMessage_1; - private static java.lang.reflect.Method $method_getProperty_2; - private static java.lang.reflect.Method $method_shutdown_3; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_getID_0 = ActivateMe.class.getMethod("getID", new java.lang.Class[] {}); - $method_getMessage_1 = ActivateMe.class.getMethod("getMessage", new java.lang.Class[] {}); - $method_getProperty_2 = ActivateMe.class.getMethod("getProperty", new java.lang.Class[] {java.lang.String.class}); - $method_shutdown_3 = ActivateMe.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public ModifyDescriptor_Stub() { - super(); - } - public ModifyDescriptor_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of getID() - public java.rmi.activation.ActivationID getID() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getID_0, null, -7795865521150345044L); - return ((java.rmi.activation.ActivationID) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - java.rmi.activation.ActivationID $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.rmi.activation.ActivationID) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of getMessage() - public java.lang.String getMessage() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getMessage_1, null, 5353407034680111516L); - return ((java.lang.String) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - java.lang.String $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.lang.String) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of getProperty(String) - public java.lang.String getProperty(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getProperty_2, new java.lang.Object[] {$param_String_1}, 77249282285080913L); - return ((java.lang.String) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - try { - java.io.ObjectOutput out = call.getOutputStream(); - out.writeObject($param_String_1); - } catch (java.io.IOException e) { - throw new java.rmi.MarshalException("error marshalling arguments", e); - } - ref.invoke(call); - java.lang.String $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.lang.String) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_3, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 3, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/group.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/rmid.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/rmid.security.policy deleted file mode 100644 index a352c07a92b..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/rmid.security.policy +++ /dev/null @@ -1,11 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Dtest.message=hello"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Dtest.message=hello, again"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/security.policy b/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/security.policy deleted file mode 100644 index 572e29ce309..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/modifyDescriptor/security.policy +++ /dev/null @@ -1,31 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/CanCreateStubs.java b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/CanCreateStubs.java deleted file mode 100644 index 5b041fa83d1..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/CanCreateStubs.java +++ /dev/null @@ -1,36 +0,0 @@ -/* - * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.activation.ActivationGroupID; -import java.rmi.registry.Registry; -import java.rmi.Remote; -import java.rmi.RemoteException; -interface CanCreateStubs extends java.rmi.Remote { - Registry getRegistry() throws RemoteException; - void shutdown() throws Exception; - Object getForbiddenClass() throws Exception; - ActivationGroupID returnGroupID() throws RemoteException; -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted.java b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted.java deleted file mode 100644 index 43318ce0eb0..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted.java +++ /dev/null @@ -1,264 +0,0 @@ -/* - * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4179055 - * @summary Some java apps need to have access to read "accessClassInPackage.sun.rmi.server" - * @author Laird Dornin - * - * @library ../../../testlibrary - * @modules java.base/sun.security.provider - * java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary RMIDSelectorProvider - * CanCreateStubs StubClassesPermitted_Stub - * @run main/othervm/java.security.policy=security.policy/secure=java.lang.SecurityManager/timeout=240 StubClassesPermitted - */ - -import java.io.ByteArrayOutputStream; -import java.io.PrintStream; -import java.rmi.MarshalledObject; -import java.rmi.RemoteException; -import java.rmi.activation.Activatable; -import java.rmi.activation.ActivationDesc; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationGroupDesc; -import java.rmi.activation.ActivationGroupDesc.CommandEnvironment; -import java.rmi.activation.ActivationGroupID; -import java.rmi.activation.ActivationID; -import java.rmi.activation.ActivationSystem; -import java.rmi.registry.Registry; -import java.util.Properties; - -/** - * The RMI activation system needs to explicitly allow itself to - * create the following sun.* classes on behalf of code that runs with - * user privileges and needs to make use of RMI activation: - * - * sun.rmi.server.Activation$ActivationMonitorImpl_Stub - * sun.rmi.server.Activation$ActivationSystemImpl_Stub - * sun.rmi.registry.RegistryImpl_Stub - * - * The test causes the activation system to need to create each of - * these classes in turn. The test will fail if the activation system - * does not allow these classes to be created. - */ -public class StubClassesPermitted - extends Activatable implements Runnable, CanCreateStubs -{ - public static boolean sameGroup = false; - private static int registryPort = -1; - private static CanCreateStubs canCreateStubs = null; - private static Registry registry = null; - - public static void main(String args[]) { - - sameGroup = true; - - RMID rmid = null; - - System.err.println("\nRegression test for bug/rfe 4179055\n"); - - try { - TestLibrary.suggestSecurityManager("java.lang.SecurityManager"); - - registry = TestLibrary.createRegistryOnEphemeralPort(); - registryPort = TestLibrary.getRegistryPort(registry); - - // must run with java.lang.SecurityManager or the test - // result will be nullified if running with a build where - // 4180392 has not been fixed. - String smClassName = - System.getSecurityManager().getClass().getName(); - if (!smClassName.equals("java.lang.SecurityManager")) { - TestLibrary.bomb("Test must run with java.lang.SecurityManager"); - } - - // start an rmid. - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - //rmid.addOptions(new String[] {"-C-Djava.rmi.server.logCalls=true"}); - - // Ensure that activation groups run with the correct - // security manager. - // - Properties p = new Properties(); - p.put("java.security.policy", - TestParams.defaultGroupPolicy); - p.put("java.security.manager", - "java.lang.SecurityManager"); - - // This action causes the following classes to be created - // in this VM (RMI must permit the creation of these classes): - // - // sun.rmi.server.Activation$ActivationSystemImpl_Stub - // sun.rmi.server.Activation$ActivationMonitorImpl_Stub - // - System.err.println("Create activation group, in a new VM"); - CommandEnvironment cmd = new ActivationGroupDesc.CommandEnvironment(null, - new String[] { - "--add-exports=java.base/sun.security.provider=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.registry=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.server=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.transport=ALL-UNNAMED", - "--add-exports=java.rmi/sun.rmi.transport.tcp=ALL-UNNAMED" }); - - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, cmd); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - - System.err.println("register activatable"); - // Fix for: 4271615: make sure activation group runs in a new VM - ActivationDesc desc = new ActivationDesc - (groupID, "StubClassesPermitted", null, null); - canCreateStubs = (CanCreateStubs) Activatable.register(desc); - - // ensure registry stub can be passed in a remote call - System.err.println("getting the registry"); - registry = canCreateStubs.getRegistry(); - - // make sure a client cant load just any sun.* class, just - // as a sanity check, try to create a class we are not - // allowed to access but which was passed in a remote call - try { - System.err.println("accessing forbidden class"); - Object secureRandom = canCreateStubs.getForbiddenClass(); - - TestLibrary.bomb("test allowed to access forbidden class," + - " sun.security.provider.SecureRandom"); - } catch (java.security.AccessControlException e) { - - // Make sure we received a *local* AccessControlException - ByteArrayOutputStream bout = new ByteArrayOutputStream(); - PrintStream ps = new PrintStream(bout); - e.printStackTrace(ps); - ps.flush(); - String trace = new String(bout.toByteArray()); - if ((trace.indexOf("exceptionReceivedFromServer") >= 0) || - trace.equals("")) - { - throw e; - } - System.err.println("received expected local access control exception"); - } - - // make sure that an ActivationGroupID can be passed in a - // remote call; this is slightly more inclusive than - // just passing a reference to the activation system - System.err.println("returning group desc"); - canCreateStubs.returnGroupID(); - - // Clean up object - System.err.println - ("Deactivate object via method call"); - canCreateStubs.shutdown(); - - System.err.println - ("\nsuccess: StubClassesPermitted test passed "); - - } catch (Exception e) { - TestLibrary.bomb("\nfailure: unexpected exception ", e); - } finally { - try { - Thread.sleep(4000); - } catch (InterruptedException e) { - } - - canCreateStubs = null; - rmid.cleanup(); - System.err.println("rmid shut down"); - } - } - - static ActivationGroupID GroupID = null; - - /** - * implementation of CanCreateStubs - */ - public StubClassesPermitted - (ActivationID id, MarshalledObject mo) throws RemoteException - { - // register/export anonymously - super(id, 0); - - // obtain reference to the test registry - registry = java.rmi.registry.LocateRegistry. - getRegistry(registryPort); - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception { - (new Thread(this,"StubClassesPermitted")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() { - ActivationLibrary.deactivate(this, getID()); - } - - /** - * Return a reference to the RMI registry, to make sure that - * the stub for it can be deserialized in the test client VM. - */ - public Registry getRegistry() throws RemoteException { - if (sameGroup) { - System.out.println("in same group"); - } else { - System.out.println("not in same group"); - } - return registry; - } - - /** - * Remote call to create and return a random serializable sun.* - * class, the test should get a local security exception when - * trying to create the class. Ensure that not all sun.* classes - * can be resolved in a remote call. - */ - public Object getForbiddenClass() throws RemoteException { - System.err.println("creating sun class"); - return new sun.security.provider.SecureRandom(); - } - - /** - * Ensures that an activation group id can be passed in a remote - * call (class may contain a remote reference to the activation - * system implementation). - */ - public ActivationGroupID returnGroupID() throws RemoteException { - return ActivationGroup.currentGroupID(); - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted_Stub.java b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted_Stub.java deleted file mode 100644 index b1b4f9bafc2..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/StubClassesPermitted_Stub.java +++ /dev/null @@ -1,180 +0,0 @@ -/* - * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class StubClassesPermitted_Stub - extends java.rmi.server.RemoteStub - implements CanCreateStubs, java.rmi.Remote -{ - private static final java.rmi.server.Operation[] operations = { - new java.rmi.server.Operation("java.lang.Object getForbiddenClass()"), - new java.rmi.server.Operation("java.rmi.registry.Registry getRegistry()"), - new java.rmi.server.Operation("java.rmi.activation.ActivationGroupID returnGroupID()"), - new java.rmi.server.Operation("void shutdown()") - }; - - private static final long interfaceHash = 1677779850431817575L; - - private static final long serialVersionUID = 2; - - private static boolean useNewInvoke; - private static java.lang.reflect.Method $method_getForbiddenClass_0; - private static java.lang.reflect.Method $method_getRegistry_1; - private static java.lang.reflect.Method $method_returnGroupID_2; - private static java.lang.reflect.Method $method_shutdown_3; - - static { - try { - java.rmi.server.RemoteRef.class.getMethod("invoke", - new java.lang.Class[] { - java.rmi.Remote.class, - java.lang.reflect.Method.class, - java.lang.Object[].class, - long.class - }); - useNewInvoke = true; - $method_getForbiddenClass_0 = CanCreateStubs.class.getMethod("getForbiddenClass", new java.lang.Class[] {}); - $method_getRegistry_1 = CanCreateStubs.class.getMethod("getRegistry", new java.lang.Class[] {}); - $method_returnGroupID_2 = CanCreateStubs.class.getMethod("returnGroupID", new java.lang.Class[] {}); - $method_shutdown_3 = CanCreateStubs.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - useNewInvoke = false; - } - } - - // constructors - public StubClassesPermitted_Stub() { - super(); - } - public StubClassesPermitted_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of getForbiddenClass() - public java.lang.Object getForbiddenClass() - throws java.lang.Exception - { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getForbiddenClass_0, null, -658265783646674294L); - return ((java.lang.Object) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 0, interfaceHash); - ref.invoke(call); - java.lang.Object $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.lang.Object) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } - - // implementation of getRegistry() - public java.rmi.registry.Registry getRegistry() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_getRegistry_1, null, 255311215504696981L); - return ((java.rmi.registry.Registry) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 1, interfaceHash); - ref.invoke(call); - java.rmi.registry.Registry $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.rmi.registry.Registry) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of returnGroupID() - public java.rmi.activation.ActivationGroupID returnGroupID() - throws java.rmi.RemoteException - { - try { - if (useNewInvoke) { - Object $result = ref.invoke(this, $method_returnGroupID_2, null, 6267304638191237098L); - return ((java.rmi.activation.ActivationGroupID) $result); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 2, interfaceHash); - ref.invoke(call); - java.rmi.activation.ActivationGroupID $result; - try { - java.io.ObjectInput in = call.getInputStream(); - $result = (java.rmi.activation.ActivationGroupID) in.readObject(); - } catch (java.io.IOException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } catch (java.lang.ClassNotFoundException e) { - throw new java.rmi.UnmarshalException("error unmarshalling return", e); - } finally { - ref.done(call); - } - return $result; - } - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - if (useNewInvoke) { - ref.invoke(this, $method_shutdown_3, null, -7207851917985848402L); - } else { - java.rmi.server.RemoteCall call = ref.newCall((java.rmi.server.RemoteObject) this, operations, 3, interfaceHash); - ref.invoke(call); - ref.done(call); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/group.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/group.security.policy deleted file mode 100644 index c99d2e288a2..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/group.security.policy +++ /dev/null @@ -1,11 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; - - permission java.lang.RuntimePermission "accessClassInPackage.sun.security.provider"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/rmid.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/rmid.security.policy deleted file mode 100644 index 640fb78d7bd..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/rmid.security.policy +++ /dev/null @@ -1,12 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=java.lang.SecurityManager"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - - // test needs to export a set of internal APIs to access them from unamed module - permission com.sun.rmi.rmid.ExecOptionPermission "*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/security.policy b/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/security.policy deleted file mode 100644 index 9287c5130c9..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/stubClassesPermitted/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // required for test to get the registry port - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.registry"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.tcp"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/ActivateMe.java b/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/ActivateMe.java deleted file mode 100644 index c0230a97226..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/ActivateMe.java +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ -import java.rmi.Remote; -import java.rmi.RemoteException; -interface ActivateMe extends Remote { - public void ping() throws RemoteException; - public void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/UnregisterGroup.java b/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/UnregisterGroup.java deleted file mode 100644 index fcd21614e6e..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/UnregisterGroup.java +++ /dev/null @@ -1,167 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4134233 - * @bug 4213186 - * @summary synopsis: ActivationSystem.unregisterGroup should unregister objects in group - * @author Ann Wollrath - * - * @library ../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary ActivateMe RMIDSelectorProvider - * @run main/othervm/policy=security.policy UnregisterGroup - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.util.Properties; - -public class UnregisterGroup extends Activatable implements ActivateMe -{ - private static volatile Exception exception = null; - private static volatile String error = null; - private static volatile boolean done = false; - private static final int NUM_OBJECTS = 10; - - public UnregisterGroup(ActivationID id, MarshalledObject mobj) - throws Exception - { - super(id, 0); - } - - /** - * Does nothing, but serves to activate this object. - */ - public void ping() { } - - /** - * Deactivates the object. We need to unexport forcibly because - * this call is in-progress on this object, which is the same object - * that we are trying to deactivate. - */ - public void shutdown() throws Exception { - Activatable.unexportObject(this, true); - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) throws RemoteException { - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - RMID rmid = null; - - try { - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.start(); - - /* Cause activation groups to have a security policy that will - * allow security managers to be downloaded and installed - */ - final Properties p = new Properties(); - // this test must always set policies/managers in its - // activation groups - p.put("java.security.policy", TestParams.defaultGroupPolicy); - p.put("java.security.manager", TestParams.defaultSecurityManager); - - Thread t = new Thread() { - public void run () { - try { - System.err.println("Creating group descriptor"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(p, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = - system.registerGroup(groupDesc); - - ActivateMe[] obj = new ActivateMe[NUM_OBJECTS]; - - for (int i = 0; i < NUM_OBJECTS; i++) { - System.err.println("Creating descriptor: " + i); - ActivationDesc desc = - new ActivationDesc(groupID, "UnregisterGroup", - null, null); - System.err.println("Registering descriptor: " + i); - obj[i] = (ActivateMe) Activatable.register(desc); - System.err.println("Activating object: " + i); - obj[i].ping(); - } - - System.err.println("Unregistering group"); - system.unregisterGroup(groupID); - - try { - System.err.println("Get the group descriptor"); - system.getActivationGroupDesc(groupID); - error = "test failed: group still registered"; - } catch (UnknownGroupException e) { - System.err.println("Test passed: " + - "group unregistered"); - } - - /* - * Deactivate objects so group VM will exit. - */ - for (int i = 0; i < NUM_OBJECTS; i++) { - System.err.println("Deactivating object: " + i); - obj[i].shutdown(); - obj[i] = null; - } - System.err.println("Successfully deactivated all objects."); - - } catch (Exception e) { - exception = e; - } - - done = true; - } - }; - - t.start(); - - // Default jtreg timeout is two minutes. - // Timeout ourselves after one minute so that - // we can clean up. - t.join(60000); - - if (exception != null) { - TestLibrary.bomb("test failed", exception); - } else if (error != null) { - TestLibrary.bomb(error, null); - } else if (!done) { - TestLibrary.bomb("test failed: not completed before timeout", null); - } else { - System.err.println("Test passed"); - } - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - } finally { - rmid.cleanup(); - } - } -} diff --git a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/group.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/rmid.security.policy b/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/rmid.security.policy deleted file mode 100644 index ce485f61343..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/rmid.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/security.policy b/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/security.policy deleted file mode 100644 index 4fc5934ff33..00000000000 --- a/test/jdk/java/rmi/activation/ActivationSystem/unregisterGroup/security.policy +++ /dev/null @@ -1,37 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - - // required for test to get the registry port - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.registry"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.tcp"; -}; diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/Doctor.java b/test/jdk/java/rmi/activation/CommandEnvironment/Doctor.java deleted file mode 100644 index 77f9495cb4e..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/Doctor.java +++ /dev/null @@ -1,91 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.rmi.*; -import java.rmi.activation.*; - -public class Doctor - extends Activatable - implements Eliza, Retireable -{ - // reanimation constructor - public Doctor(ActivationID id, MarshalledObject blah) - throws RemoteException - { - super(id, 0); // export self on port 0 (== assign randomly) - System.out.println("Doctor constructed and exported"); - } - - private boolean asked = false; - - // implement Eliza.complain() - public String complain(String plaint) - { - System.out.println("Doctor will see you now"); - if (this.asked) { - return ("DO GO ON?"); - } else { - this.asked = true; - return ("TELL ME ABOUT YOUR MOTHER"); - } - } - - // implement Retireable.retire() - public void retire() - { - System.out.println("Doctor retiring"); - try { - Activatable.inactive(this.getID()); - ActivationGroup.getSystem().unregisterObject(this.getID()); - (new HaraKiri()).start(); - - } catch (UnknownObjectException uoe) { - System.err.println("Exception in Activatable.inactive:"); - uoe.printStackTrace(); - - } catch (ActivationException ae) { - System.err.println("Exception in Activatable.inactive:"); - ae.printStackTrace(); - - } catch (RemoteException re) { - System.err.println("Exception in Activatable.inactive:"); - re.printStackTrace(); - } - } - - private static class HaraKiri extends Thread - { - public HaraKiri() { - super("Thread-of-Death"); - } - - public void run() - { - try { - Thread.sleep(5000); - } catch (Exception foo) { - } - System.exit(0); - } - } -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/Doctor_Stub.java b/test/jdk/java/rmi/activation/CommandEnvironment/Doctor_Stub.java deleted file mode 100644 index 63b7134dd6d..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/Doctor_Stub.java +++ /dev/null @@ -1,83 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class Doctor_Stub - extends java.rmi.server.RemoteStub - implements Eliza, Retireable, java.rmi.Remote -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_complain_0; - private static java.lang.reflect.Method $method_retire_1; - - static { - try { - $method_complain_0 = Eliza.class.getMethod("complain", new java.lang.Class[] {java.lang.String.class}); - $method_retire_1 = Retireable.class.getMethod("retire", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public Doctor_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of complain(String) - public java.lang.String complain(java.lang.String $param_String_1) - throws java.rmi.RemoteException - { - try { - Object $result = ref.invoke(this, $method_complain_0, new java.lang.Object[] {$param_String_1}, -6341882871094951445L); - return ((java.lang.String) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of retire() - public void retire() - throws java.rmi.RemoteException - { - try { - ref.invoke(this, $method_retire_1, null, 1748571935738034018L); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/Eliza.java b/test/jdk/java/rmi/activation/CommandEnvironment/Eliza.java deleted file mode 100644 index baa3ca11db5..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/Eliza.java +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public interface Eliza - extends java.rmi.Remote -{ - public String complain(String plaint) - throws java.rmi.RemoteException; -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/NullOptions.java b/test/jdk/java/rmi/activation/CommandEnvironment/NullOptions.java deleted file mode 100644 index b15ce40c9c3..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/NullOptions.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 6236643 - * @summary null doesn't have the same effect as empty list for - * ActivationGroupDesc.CommandEnvironment - * @author Ann Wollrath - * - * @run main/othervm/timeout=240 NullOptions - */ - -import java.rmi.activation.ActivationGroupDesc.CommandEnvironment; - -public class NullOptions { - - public static void main(String[] args) throws Exception { - - CommandEnvironment env1 = - new CommandEnvironment(null, null); - CommandEnvironment env2 = - new CommandEnvironment(null, new String[0]); - - if (env1.equals(env2)) { - System.err.println("TEST PASSED: environments are equal"); - } else { - System.err.println("TEST FAILED: environments not equal!"); - throw new RuntimeException("TEST FAILED"); - } - } -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/Retireable.java b/test/jdk/java/rmi/activation/CommandEnvironment/Retireable.java deleted file mode 100644 index 56bde68bc06..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/Retireable.java +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -public interface Retireable - extends java.rmi.Remote -{ - public void retire() - throws java.rmi.RemoteException; -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/SetChildEnv.java b/test/jdk/java/rmi/activation/CommandEnvironment/SetChildEnv.java deleted file mode 100644 index 1b7b8f6a7f5..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/SetChildEnv.java +++ /dev/null @@ -1,253 +0,0 @@ -/* - * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * - * @bug 4105043 - * @summary cannot set java.rmi.server.hostname on children of rmid in time - * - * @bug 4097357 - * @summary activation group should not overwrite system properties - * - * @bug 4107184 - * @summary activation groups should be able to control their JVM properties - * - * @author Adrian Colley - * - * @library ../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary RMID ActivationLibrary RMIDSelectorProvider - * Eliza Retireable Doctor Doctor_Stub - * @run main/othervm/timeout=240/policy=security.policy SetChildEnv 0 0 - * @run main/othervm/timeout=240/policy=security.policy SetChildEnv 1 -verbosegc - * 2 foo.bar=SetChildEnvTest sun.rmi.server.doSomething=true - * @run main/othervm/timeout=240/policy=security.policy SetChildEnv 0 1 parameter.count=zero - * @run main/othervm/timeout=240/policy=security.policy SetChildEnv 1 -Xmx32m 0 - */ -import java.rmi.*; -import java.util.Properties; -import java.io.*; -import java.util.StringTokenizer; -import java.util.Set; -import java.util.HashSet; -import java.util.Arrays; -import java.rmi.activation.*; - -public class SetChildEnv -{ - public static void main(String argv[]) throws Exception { - RMID rmid = null; - try { - System.out.println("java.compiler=" + System.getProperty("java.compiler")); - int paramCount = Integer.valueOf(argv[0]); - String[] params = paramCount == 0 ? - new String[0] : Arrays.copyOfRange(argv, 1, paramCount+1); - int propCount = Integer.valueOf(argv[paramCount+1]); - String[] props = propCount == 0 ? - new String[0] : - Arrays.copyOfRange(argv, paramCount+2, paramCount+propCount+2); - - TestLibrary.suggestSecurityManager(TestParams.defaultSecurityManager); - - // make a "watcher" which listens on a pipe and searches for - // the debugExec line while teeing to System.err - DebugExecWatcher watcher = DebugExecWatcher.makeWithPipe(); - - RMID.removeLog(); - rmid = RMID.createRMIDOnEphemeralPort(watcher.otherEnd(), - watcher.otherEnd(), true); - - rmid.start(); - - // compile props - Properties p = new Properties(); - p.put("java.security.policy", TestParams.defaultGroupPolicy); - p.put("java.security.manager", TestParams.defaultSecurityManager); - //p.put("java.rmi.server.logCalls", "true"); - int i; - for (i = 0; i < props.length; i++) { - p.put(props[i].substring(0, props[i].indexOf('=')), - props[i].substring(props[i].indexOf('=')+1)); - } - - // create CommandEnvironment and ActivationGroupDesc - ActivationGroupDesc.CommandEnvironment cmdenv = - new ActivationGroupDesc.CommandEnvironment( - null, - params); - - ActivationGroupDesc gdesc = new ActivationGroupDesc( - p, cmdenv); - - // register group - ActivationSystem actsys = ActivationGroup.getSystem(); - ActivationGroupID gid = actsys.registerGroup(gdesc); - - // create ActivationDesc - ActivationDesc odesc = new ActivationDesc(gid, // group - "Doctor", // class - null, // codesource - null); // closure data - - // register activatable object - Eliza doctor = (Eliza)Activatable.register(odesc); - - // invoke a call with oh-so-humorous sample text - System.out.println ("Invoking complain()..."); - String complaint = - "HELP ME, DOCTOR. I FEEL VIOLENT TOWARDS PEOPLE " + - "WHO INQUIRE ABOUT MY PARENTS."; - - System.out.println(complaint); - String res = doctor.complain(complaint); - System.out.println (" => " + res); - - // Get debugExec line, allowing 15 seconds for it to flush - // through the buffers and pipes. - String found = watcher.found; - if (found == null) { - int fudge = 15; - while (found == null && --fudge > 0) { - Thread.sleep(1000); - found = watcher.found; - } - if (found == null) { - TestLibrary.bomb("rmid subprocess produced no " + - "recognizable debugExec line"); - } - } - - System.err.println("debugExec found: <<" + found + ">>"); - // q: first double-quote after debugExec - int q = found.indexOf('"', found.indexOf("rmid: debugExec")); - // qe: last double-quote on debugExec line - int qe = found.lastIndexOf('"'); - if (q <= 1 || qe <= q) { - TestLibrary.bomb("rmid subprocess produced " + - "mangled debugExec line"); - } - - // split args by whitespace - StringTokenizer tk = new StringTokenizer(found.substring(q+1, qe)); - tk.nextToken(); // skip command path/name - - // Now check off the requested args. Order isn't important, and - // any extra args are ignored, even if they're inconsistent or - // bargage, or duplicates. - - Set argset = new HashSet(tk.countTokens()); - while (tk.hasMoreTokens()) { - argset.add(tk.nextToken()); - } - - int m; - for (m = 0; m < params.length; m++) { - if(!argset.contains(params[m])) - TestLibrary.bomb("Parameter \"" + params[m] + "\" not set"); - } - - for (m = 0; m < props.length; m++) { - if (!argset.contains("-D" + props[m])) { - TestLibrary.bomb("Property binding \"" + props[m] + - "\" not set"); - } - } - - // End doctor - if (doctor instanceof Retireable) - ((Retireable)doctor).retire(); - actsys.unregisterGroup(gid); - } finally { - Thread.sleep(5000); - if (rmid != null) { - rmid.cleanup(); - } - } - } - - public static class DebugExecWatcher - extends Thread - { - public String found; - private BufferedReader str; - private OutputStream otherEnd; - - private DebugExecWatcher(InputStream readStream, OutputStream wrStream) - { - super("DebugExecWatcher"); - found = null; - str = new BufferedReader(new InputStreamReader(readStream)); - otherEnd = wrStream; - } - - static public DebugExecWatcher makeWithPipe() - throws IOException - { - PipedOutputStream wr = new PipedOutputStream(); - PipedInputStream rd = new PipedInputStream(wr); - DebugExecWatcher embryo = new DebugExecWatcher(rd, wr); - embryo.start(); - return embryo; - } - - public OutputStream otherEnd() - { - return otherEnd; - } - - public synchronized void notifyLine(String s) - { - if (s != null && s.indexOf("rmid: debugExec") != -1) - found = s; - } - - public void run() - { - try { - String line; - while ((line = str.readLine()) != null) { - this.notifyLine(line); - System.err.println(line); - } - } catch (IOException e) { - /* During termination of distant rmid, StreamPipes will be broken when - * distant vm terminates. A "Pipe broken" exception is expected because - * DebugExecWatcher points to the same streams as StreamPipes used by RMID. - * If we get this exception. We just terminate the thread. - */ - if (e.getMessage().equals("Pipe broken")) { - try { - str.close(); - } catch (IOException ioe) {} - } - else { - e.printStackTrace(); - } - } - } - } -} diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/group.security.policy b/test/jdk/java/rmi/activation/CommandEnvironment/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/rmid.security.policy b/test/jdk/java/rmi/activation/CommandEnvironment/rmid.security.policy deleted file mode 100644 index 1f861467197..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/rmid.security.policy +++ /dev/null @@ -1,14 +0,0 @@ -grant { - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.manager=default"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Djava.security.policy=*"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Dsun.rmi.server.doSomething=true"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Dfoo.bar=SetChildEnvTest"; - permission com.sun.rmi.rmid.ExecOptionPermission "-verbosegc"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Dparameter.count=zero"; - permission com.sun.rmi.rmid.ExecOptionPermission "-Xmx32m"; - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/activation/CommandEnvironment/security.policy b/test/jdk/java/rmi/activation/CommandEnvironment/security.policy deleted file mode 100644 index de4eaa17834..00000000000 --- a/test/jdk/java/rmi/activation/CommandEnvironment/security.policy +++ /dev/null @@ -1,32 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - permission java.util.PropertyPermission "java.compiler", "read"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; -}; diff --git a/test/jdk/java/rmi/activation/log/LogTest.java b/test/jdk/java/rmi/activation/log/LogTest.java deleted file mode 100644 index 91d4726754b..00000000000 --- a/test/jdk/java/rmi/activation/log/LogTest.java +++ /dev/null @@ -1,196 +0,0 @@ -/* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - * @test - * @bug 4652922 - * - * @summary synopsis: ReliableLog.update should pad records to 4-byte - * boundaries - * @author Ann Wollrath - * - * @modules java.rmi/sun.rmi.log - * @run main/othervm/timeout=240 LogTest - */ - -import sun.rmi.log.LogHandler; -import sun.rmi.log.ReliableLog; -import java.io.FileDescriptor; -import java.io.FileNotFoundException; -import java.io.IOException; -import java.io.Serializable; - -public class LogTest { - - private static int crashPoint = 0; - private static boolean spansBoundary = false; - private static ReliableLog log = null; - private static Counter counter = new Counter(); - - public static void main(String[] args) throws Exception { - - System.err.println("\nRegression test for bug 4652922\n"); - - System.setProperty("sun.rmi.log.class", MyLogFile.class.getName()); - //System.setProperty("sun.rmi.log.debug", "true"); - - log = new ReliableLog(".", new TestLogHandler(counter), false); - - writeUpdatesCrashAndRecover(10, 1, false, 10); - writeUpdatesCrashAndRecover(10, 1, true, 20); - writeUpdatesCrashAndRecover(10, 2, true, 30); - writeUpdatesCrashAndRecover(9, 2, false, 40); - writeUpdatesCrashAndRecover(9, 3, true, 50); - log.close(); - } - - private static void writeUpdatesCrashAndRecover(int updates, - int crashValue, - boolean spans, - int expectedCount) - throws IOException - { - /* - * Write updates - */ - System.err.println("\nwrite updates: " + updates); - for (int i = 0; i < updates; i++) { - counter.increment(); - log.update(counter); - } - - /* - * Crash - */ - crashPoint = crashValue; - spansBoundary = spans; - System.err.println("crash during next update on sync #" + - crashPoint + - " (spansBoundary = " + spansBoundary + ")"); - try { - System.err.println( - "write one update (update record should " + - ((counter.value() + 1 == expectedCount) ? "" : "not ") + - "be complete)"); - counter.increment(); - log.update(counter); - throw new RuntimeException("failed to reach crashpoint " + - crashPoint); - } catch (IOException e) { - System.err.println("caught IOException; message: " + - e.getMessage()); - log.close(); - } - - /* - * Recover - */ - log = new ReliableLog(".", new TestLogHandler(null), false); - try { - System.err.println("recover log"); - counter = (Counter) log.recover(); - System.err.println("recovered counter value: " + counter.value()); - if (counter.value() != expectedCount) { - throw new RuntimeException("unexpected counter value " + - counter.value()); - } - System.err.println("log recovery successful"); - - } catch (IOException e) { - System.err.println("log should recover after crash point"); - e.printStackTrace(); - throw new RuntimeException( - "log should recover after crash point"); - } - - } - - private static class Counter implements Serializable { - private static long serialVersionUID = 1; - private int count = 0; - - Counter() {} - - int increment() { - return ++count; - } - - int value() { - return count; - } - - void update(Counter value) { - if (value.value() < count) { - throw new IllegalStateException( - "bad update (count = " + count + ", value = " + value + ")"); - } else { - count = value.value(); - } - } - } - - static class TestLogHandler extends LogHandler { - - private final Counter initialState; - - TestLogHandler(Counter initialState) { - this.initialState = initialState; - } - - public Object initialSnapshot() { - if (initialState == null) { - throw new IllegalStateException( - "attempting initialSnapshot with null"); - } - return initialState; - } - - public Object applyUpdate(Object update, Object state) { - ((Counter) state).update((Counter) update); - return state; - } - } - - public static class MyLogFile extends ReliableLog.LogFile { - - public MyLogFile(String name, String mode) - throws FileNotFoundException, IOException - { - super(name, mode); - } - - protected void sync() throws IOException { - if (crashPoint != 0) { - if (--crashPoint == 0) { - throw new IOException("crash point reached"); - } - } - super.sync(); - } - - protected boolean checkSpansBoundary(long fp) { - return - crashPoint > 0 ? spansBoundary : super.checkSpansBoundary(fp); - } - } -} diff --git a/test/jdk/java/rmi/activation/nonLocalActivation/NonLocalActivationTest.java b/test/jdk/java/rmi/activation/nonLocalActivation/NonLocalActivationTest.java deleted file mode 100644 index 55cea96a0d2..00000000000 --- a/test/jdk/java/rmi/activation/nonLocalActivation/NonLocalActivationTest.java +++ /dev/null @@ -1,181 +0,0 @@ -/* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.net.InetAddress; -import java.rmi.AccessException; -import java.rmi.activation.ActivationSystem; -import java.rmi.registry.LocateRegistry; -import java.rmi.registry.Registry; -import java.util.Set; - -/* - * @test - * @bug 8174770 - * @summary Verify that ActivationSystem rejects non-local access. - * The test is manual because the (non-local) host running rmid must be supplied as a property. - * @run main/manual/othervm -Dactivation.host=rmid-host NonLocalActivationTest - */ - -/** - * Lookup the ActivationSystem on a different host and invoke its remote interface methods. - * They should all throw an exception, non-local access is prohibited. - * - * This test is a manual test and uses rmid running on a *different* host. - * The default port (1098) for the Activation System is ok and expected. - * Login or ssh to the different host and invoke {@code $JDK_HOME/bin/rmid}. - * It will not show any output. - * - * On the first host modify the @run command above to replace "rmid-host" - * with the hostname or IP address of the different host and run the test with jtreg. - */ -public class NonLocalActivationTest -{ - public static void main(String[] args) throws Exception { - - String host = System.getProperty("activation.host"); - if (host == null || host.isEmpty()) { - throw new RuntimeException("Specify host with system property: -Dactivation.host="); - } - - // Check if running the test on a local system; it only applies to remote - String myHostName = InetAddress.getLocalHost().getHostName(); - Set myAddrs = Set.of(InetAddress.getAllByName(myHostName)); - Set hostAddrs = Set.of(InetAddress.getAllByName(host)); - if (hostAddrs.stream().anyMatch(i -> myAddrs.contains(i)) - || hostAddrs.stream().anyMatch(h -> h.isLoopbackAddress())) { - throw new RuntimeException("Error: property 'activation.host' must not be the local host%n"); - } - - // Locate the registry operated by the ActivationSystem - // Test SystemRegistryImpl - Registry registry = LocateRegistry.getRegistry(host, ActivationSystem.SYSTEM_PORT); - try { - // Verify it is an ActivationSystem registry - registry.lookup("java.rmi.activation.ActivationSystem"); - } catch (Exception nf) { - throw new RuntimeException("Not a ActivationSystem registry, does not contain java.rmi.activation.ActivationSystem", nf); - } - - try { - registry.bind("foo", null); - throw new RuntimeException("Remote access should not succeed for method: bind"); - } catch (Exception e) { - assertIsAccessException(e, "Registry.bind"); - } - - try { - registry.rebind("foo", null); - throw new RuntimeException("Remote access should not succeed for method: rebind"); - } catch (Exception e) { - assertIsAccessException(e, "Registry.rebind"); - } - - try { - registry.unbind("foo"); - throw new RuntimeException("Remote access should not succeed for method: unbind"); - } catch (Exception e) { - assertIsAccessException(e, "Registry.unbind"); - } - - - // Locate the ActivationSystem on the specified host and default port. - // Test each of the ActivationSystem methods - ActivationSystem as = (ActivationSystem) registry.lookup("java.rmi.activation.ActivationSystem"); - - // Argument is not material, access check is before arg processing - - try { - as.registerGroup(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.getActivationDesc(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.getActivationGroupDesc(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.registerObject(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.unregisterGroup(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.unregisterObject(null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.setActivationDesc(null, null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - - try { - as.setActivationGroupDesc(null, null); - } catch (Exception aex) { - assertIsAccessException(aex, "ActivationSystem.nonLocalAccess"); - } - } - - /** - * Check the exception chain for the expected AccessException and message. - * @param ex the exception from the remote invocation. - */ - private static void assertIsAccessException(Exception ex, String msg1) { - Throwable t = ex; - System.out.println(); - while (!(t instanceof AccessException) && t.getCause() != null) { - t = t.getCause(); - } - if (t instanceof AccessException) { - String msg = t.getMessage(); - int asIndex = msg.indexOf(msg1); - int disallowIndex = msg.indexOf("disallowed"); - int nonLocalHostIndex = msg.indexOf("non-local host"); - if (asIndex < 0 || - disallowIndex < 0 || - nonLocalHostIndex < 0 ) { - throw new RuntimeException("exception message is malformed", t); - } - System.out.printf("Found expected AccessException: %s%n", t); - } else { - throw new RuntimeException("AccessException did not occur", ex); - } - } -} diff --git a/test/jdk/java/rmi/activation/rmidViaInheritedChannel/InheritedChannelNotServerSocket.java b/test/jdk/java/rmi/activation/rmidViaInheritedChannel/InheritedChannelNotServerSocket.java deleted file mode 100644 index e7a7f1da8c4..00000000000 --- a/test/jdk/java/rmi/activation/rmidViaInheritedChannel/InheritedChannelNotServerSocket.java +++ /dev/null @@ -1,198 +0,0 @@ -/* - * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 6261402 6824141 - * @summary If rmid has an inherited channel that is not a server - * socket (such as it if was started using rsh/rcmd), then it should - * function normally. - * @author Peter Jones - * - * @library ../../testlibrary - * @modules java.base/sun.nio.ch - * java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * @build TestLibrary RMID ActivationLibrary - * @run main/othervm/timeout=240 InheritedChannelNotServerSocket - * @key intermittent - */ - -import java.io.IOException; -import java.net.Socket; -import java.net.ProtocolFamily; -import java.nio.channels.Channel; -import java.nio.channels.DatagramChannel; -import java.nio.channels.Pipe; -import java.nio.channels.ServerSocketChannel; -import java.nio.channels.SocketChannel; -import java.nio.channels.spi.AbstractSelector; -import java.nio.channels.spi.SelectorProvider; -import java.rmi.NotBoundException; -import java.rmi.Remote; -import java.rmi.RemoteException; -import java.rmi.activation.ActivationGroup; -import java.rmi.activation.ActivationSystem; -import java.rmi.registry.LocateRegistry; -import java.rmi.registry.Registry; -import java.rmi.server.UnicastRemoteObject; - -public class InheritedChannelNotServerSocket { - private static final Object lock = new Object(); - private static boolean notified = false; - - private InheritedChannelNotServerSocket() { } - - public interface Callback extends Remote { - void notifyTest() throws RemoteException; - } - - public static class CallbackImpl implements Callback { - CallbackImpl() { } - public void notifyTest() { - synchronized (lock) { - notified = true; - System.err.println("notification received."); - lock.notifyAll(); - } - } - } - - public static void main(String[] args) throws Exception { - System.err.println("\nRegression test for bug 6261402\n"); - System.setProperty("java.rmi.activation.port", - Integer.toString(TestLibrary.INHERITEDCHANNELNOTSERVERSOCKET_ACTIVATION_PORT)); - RMID rmid = null; - Callback obj = null; - try { - /* - * Export callback object and bind in registry. - */ - System.err.println("export callback object and bind in registry"); - obj = new CallbackImpl(); - Callback proxy = - (Callback) UnicastRemoteObject.exportObject(obj, 0); - Registry registry = TestLibrary.createRegistryOnEphemeralPort(); - int registryPort = TestLibrary.getRegistryPort(registry); - registry.bind("Callback", proxy); - - /* - * Start rmid. - */ - System.err.println("start rmid with inherited channel"); - RMID.removeLog(); - rmid = RMID.createRMID(System.out, System.err, true, true, - TestLibrary.INHERITEDCHANNELNOTSERVERSOCKET_ACTIVATION_PORT); - rmid.addOptions( - "--add-exports=java.base/sun.nio.ch=ALL-UNNAMED", - "-Djava.nio.channels.spi.SelectorProvider=InheritedChannelNotServerSocket$SP", - "-Dtest.java.rmi.rmidViaInheritedChannel.registry.port=" + registryPort); - rmid.start(); - - /* - * Get activation system and wait to be notified via callback - * from rmid's selector provider. - */ - System.err.println("get activation system"); - ActivationSystem system = ActivationGroup.getSystem(); - System.err.println("ActivationSystem = " + system); - synchronized (lock) { - while (!notified) { - lock.wait(); - } - } - System.err.println("TEST PASSED"); - } finally { - if (obj != null) { - UnicastRemoteObject.unexportObject(obj, true); - } - if (rmid != null) { - rmid.cleanup(); - } - } - } - - public static class SP extends SelectorProvider { - private final SelectorProvider provider; - private volatile SocketChannel channel = null; - - public SP() { - provider = sun.nio.ch.DefaultSelectorProvider.get(); - } - - public DatagramChannel openDatagramChannel() throws IOException { - return provider.openDatagramChannel(); - } - - public DatagramChannel openDatagramChannel(ProtocolFamily family) - throws IOException - { - return provider.openDatagramChannel(family); - } - - public Pipe openPipe() throws IOException { - return provider.openPipe(); - } - - public AbstractSelector openSelector() throws IOException { - return provider.openSelector(); - } - - public ServerSocketChannel openServerSocketChannel() - throws IOException - { - return provider.openServerSocketChannel(); - } - - public SocketChannel openSocketChannel() throws IOException { - return provider.openSocketChannel(); - } - - public synchronized Channel inheritedChannel() throws IOException { - System.err.println("SP.inheritedChannel"); - if (channel == null) { - channel = SocketChannel.open(); - Socket socket = channel.socket(); - System.err.println("socket = " + socket); - - /* - * Notify test that inherited channel was created. - */ - try { - System.err.println("notify test..."); - int registryPort = Integer.getInteger( - "test.java.rmi.rmidViaInheritedChannel.registry.port", 0); - Registry registry = LocateRegistry.getRegistry(registryPort); - Callback obj = (Callback) registry.lookup("Callback"); - obj.notifyTest(); - } catch (NotBoundException nbe) { - throw (IOException) - new IOException("callback object not bound"). - initCause(nbe); - } - } - return channel; - } - } -} diff --git a/test/jdk/java/rmi/activation/rmidViaInheritedChannel/rmid.security.policy b/test/jdk/java/rmi/activation/rmidViaInheritedChannel/rmid.security.policy deleted file mode 100644 index 1d94a375522..00000000000 --- a/test/jdk/java/rmi/activation/rmidViaInheritedChannel/rmid.security.policy +++ /dev/null @@ -1,7 +0,0 @@ -grant { - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.net.SocketPermission "*", "connect,accept"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - permission java.util.PropertyPermission "test.java.rmi.rmidViaInheritedChannel.registry.port", "read"; -}; diff --git a/test/jdk/java/rmi/registry/altSecurityManager/AltSecurityManager.java b/test/jdk/java/rmi/registry/altSecurityManager/AltSecurityManager.java index 4f29e0519b4..0a542c2d036 100644 --- a/test/jdk/java/rmi/registry/altSecurityManager/AltSecurityManager.java +++ b/test/jdk/java/rmi/registry/altSecurityManager/AltSecurityManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ /* @test * @bug 4183202 - * @summary rmid and rmiregistry could allow alternate security manager + * @summary rmiregistry could allow alternate security manager * @author Laird Dornin * * @library ../../testlibrary @@ -32,27 +32,25 @@ * java.rmi/sun.rmi.transport * java.rmi/sun.rmi.transport.tcp * java.base/sun.nio.ch - * @build TestLibrary RMID RMIDSelectorProvider RegistryVM RMIRegistryRunner - * TestSecurityManager + * @build TestLibrary RegistryVM RMIRegistryRunner TestSecurityManager * @run main/othervm AltSecurityManager */ /** * Ensure that a user is able to specify alternate security managers to - * be used in rmiregistry and rmid. Test specifies a security manager + * be used in rmiregistry. Test specifies a security manager * that throws a runtime exception in its checkListen method, this - * will cause rmiregistry and rmid to exit early because those + * will cause rmiregistry to exit early because those * utilities will be unable to export any remote objects; test fails - * if registry and rmid take too long to exit. + * if registry takes too long to exit. */ public class AltSecurityManager implements Runnable { - // variable to hold registry and rmid children + // variable to hold registry child static JavaVM vm = null; // names of utilities static String utilityToStart = null; static final String REGISTRY_IMPL = "sun.rmi.registry.RegistryImpl"; - static final String ACTIVATION = "sun.rmi.server.Activation"; // children should exit in at least this time. private static final long TIME_OUT = @@ -64,12 +62,8 @@ public class AltSecurityManager implements Runnable { vm = RegistryVM.createRegistryVMWithRunner( "RMIRegistryRunner", "-Djava.security.manager=TestSecurityManager"); - } else if (utilityToStart.contains(ACTIVATION)) { - vm = RMID.createRMIDOnEphemeralPortWithOptions( - "-Djava.security.manager=TestSecurityManager"); } else { - TestLibrary.bomb("Utility to start must be " + REGISTRY_IMPL + - " or " + ACTIVATION); + TestLibrary.bomb("Utility to start must be " + REGISTRY_IMPL); } System.err.println("starting " + utilityToStart); @@ -93,7 +87,7 @@ public class AltSecurityManager implements Runnable { } /** - * Wait to make sure that the registry and rmid exit after + * Wait to make sure that the registry exits after * their security manager is set. */ public static void ensureExit(String utility) throws Exception { @@ -131,15 +125,10 @@ public class AltSecurityManager implements Runnable { // make sure the registry exits early. ensureExit(REGISTRY_IMPL); - // make sure rmid exits early - ensureExit(ACTIVATION); - System.err.println("test passed"); } catch (Exception e) { TestLibrary.bomb(e); - } finally { - RMID.removeLog(); } } } diff --git a/test/jdk/java/rmi/registry/altSecurityManager/TestSecurityManager.java b/test/jdk/java/rmi/registry/altSecurityManager/TestSecurityManager.java index ea291919ad3..42e370fa3d8 100644 --- a/test/jdk/java/rmi/registry/altSecurityManager/TestSecurityManager.java +++ b/test/jdk/java/rmi/registry/altSecurityManager/TestSecurityManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,10 +30,9 @@ public class TestSecurityManager extends SecurityManager { } public void checkListen(int port) { - // 4269910: ok, now rmid and the regsitry will *really* go - // away... + // 4269910: ok, now the registry will *really* go away... // - // rmid and the registry need to listen on sockets so they + // the registry needs to listen on sockets so they // will exit when they try to do so... this is used as a sign // by the main test process to detect that the proper security // manager has been installed in the relevant VMs. diff --git a/test/jdk/java/rmi/registry/altSecurityManager/rmid.security.policy b/test/jdk/java/rmi/registry/altSecurityManager/rmid.security.policy index 5307f72ce64..81c0c85c188 100644 --- a/test/jdk/java/rmi/registry/altSecurityManager/rmid.security.policy +++ b/test/jdk/java/rmi/registry/altSecurityManager/rmid.security.policy @@ -1,7 +1,5 @@ grant { permission java.lang.RuntimePermission "selectorProvider"; permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; }; diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressConstants.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressConstants.java deleted file mode 100644 index 909e1d4eb84..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressConstants.java +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ - -interface CompressConstants { - - // constants for 6-bit code values - static final int NOP = 0; // no operation: used to pad words on flush() - static final int RAW = 1; // introduces raw byte format - static final int BASE = 2; // base for codes found in lookup table - static final String codeTable = - "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ ,.!?\"'()"; -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressInputStream.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressInputStream.java deleted file mode 100644 index 73c3d8db863..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressInputStream.java +++ /dev/null @@ -1,110 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ - -import java.io.*; - -class CompressInputStream extends FilterInputStream - implements CompressConstants -{ - - public CompressInputStream(InputStream in) { - super(in); - } - - // buffer of unpacked 6-bit codes from last 32-word read - int buf[] = new int[5]; - - // position of next code to read in buffer (5 == end of buffer) - int bufPos = 5; - - public int read() throws IOException { - try { - int code; - do { - code = readCode(); - } while (code == NOP); // ignore NOP codes - - if (code >= BASE) - return codeTable.charAt(code - BASE); - else if (code == RAW) { - int high = readCode(); - int low = readCode(); - return (high << 4) | low; - } else - throw new IOException("unknown compression code: " + code); - } catch (EOFException e) { - return -1; - } - } - - public int read(byte b[], int off, int len) throws IOException { - if (len <= 0) { - return 0; - } - - int c = read(); - if (c == -1) { - return -1; - } - b[off] = (byte)c; - - int i = 1; -/***** - try { - for (; i < len ; i++) { - c = read(); - if (c == -1) { - break; - } - if (b != null) { - b[off + i] = (byte)c; - } - } - } catch (IOException ee) { - } - *****/ - return i; - } - - private int readCode() throws IOException { - if (bufPos == 5) { - int b1 = in.read(); - int b2 = in.read(); - int b3 = in.read(); - int b4 = in.read(); - if ((b1 | b2 | b3 | b4) < 0) - throw new EOFException(); - int pack = (b1 << 24) | (b2 << 16) | (b3 << 8) | b4; - buf[0] = (pack >>> 24) & 0x3F; - buf[1] = (pack >>> 18) & 0x3F; - buf[2] = (pack >>> 12) & 0x3F; - buf[3] = (pack >>> 6) & 0x3F; - buf[4] = (pack >>> 0) & 0x3F; - bufPos = 0; - } - return buf[bufPos++]; - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressOutputStream.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressOutputStream.java deleted file mode 100644 index 883a4a8e8ae..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/CompressOutputStream.java +++ /dev/null @@ -1,84 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ - -import java.io.*; - -class CompressOutputStream extends FilterOutputStream - implements CompressConstants -{ - - public CompressOutputStream(OutputStream out) { - super(out); - } - - // buffer of 6-bit codes to pack into next 32-bit word - int buf[] = new int[5]; - - // number of valid codes pending in buffer - int bufPos = 0; - - public void write(int b) throws IOException { - b &= 0xFF; // force argument to a byte - - int pos = codeTable.indexOf((char)b); - if (pos != -1) - writeCode(BASE + pos); - else { - writeCode(RAW); - writeCode(b >> 4); - writeCode(b & 0xF); - } - } - - public void write(byte b[], int off, int len) throws IOException { - /* - * This is quite an inefficient implementation, because it has to - * call the other write method for every byte in the array. It - * could be optimized for performance by doing all the processing - * in this method. - */ - for (int i = 0; i < len; i++) - write(b[off + i]); - } - - public void flush() throws IOException { - while (bufPos > 0) - writeCode(NOP); - } - - private void writeCode(int c) throws IOException { - buf[bufPos++] = c; - if (bufPos == 5) { // write next word when we have 5 codes - int pack = (buf[0] << 24) | (buf[1] << 18) | (buf[2] << 12) | - (buf[3] << 6) | buf[4]; - out.write((pack >>> 24) & 0xFF); - out.write((pack >>> 16) & 0xFF); - out.write((pack >>> 8) & 0xFF); - out.write((pack >>> 0) & 0xFF); - bufPos = 0; - } - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/Echo.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/Echo.java deleted file mode 100644 index 05f3075cb48..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/Echo.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ - -import java.rmi.*; - -public interface Echo extends Remote { - - byte[] echoNot(byte[] data) throws RemoteException; - void shutdown() throws Exception; -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl.java deleted file mode 100644 index 209be45911b..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl.java +++ /dev/null @@ -1,141 +0,0 @@ -/* - * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.server.*; -import java.security.CodeSource; -import java.net.URL; - -public class EchoImpl - extends Activatable - implements Echo, Runnable -{ - private static final byte[] pattern = { (byte) 'A' }; - - /** - * Initialization constructor. - */ - public EchoImpl(String protocol) - throws ActivationException, RemoteException - { - super(null, makeMarshalledObject(protocol), false, 0, - new MultiSocketFactory.ClientFactory(protocol, pattern), - new MultiSocketFactory.ServerFactory(protocol, pattern)); - } - - /** - * Activation constructor. - */ - public EchoImpl(ActivationID id, MarshalledObject obj) - throws RemoteException - { - super(id, 0, - new MultiSocketFactory.ClientFactory(getProtocol(obj), pattern), - new MultiSocketFactory.ServerFactory(getProtocol(obj), pattern)); - } - - private static MarshalledObject makeMarshalledObject(String protocol) { - MarshalledObject obj = null; - try { - obj = new MarshalledObject(protocol); - } catch (Exception willNotHappen) { - } - - return obj; - } - - private static String getProtocol(MarshalledObject obj) { - String protocol = ""; - try { - protocol = (String) obj.get(); - } catch (Exception willNotHappen) { - } - - return protocol; - } - - public byte[] echoNot(byte[] data) { - byte[] result = new byte[data.length]; - for (int i = 0; i < data.length; i++) - result[i] = (byte) ~data[i]; - return result; - } - - /** - * Spawns a thread to deactivate the object. - */ - public void shutdown() throws Exception - { - (new Thread(this,"Echo.shutdown")).start(); - } - - /** - * Thread to deactivate object. First attempts to make object - * inactive (via the inactive method). If that fails (the - * object may still have pending/executing calls), then - * unexport the object forcibly. - */ - public void run() - { - ActivationLibrary.deactivate(this, getID()); - } - - public static void main(String[] args) { - /* - * The following line is required with the JDK 1.2 VM so that the - * VM can exit gracefully when this test completes. Otherwise, the - * conservative garbage collector will find a handle to the server - * object on the native stack and not clear the weak reference to - * it in the RMI runtime's object table. - */ - Object dummy = new Object(); - - System.setSecurityManager(new RMISecurityManager()); - - try { - String protocol = ""; - if (args.length >= 1) - protocol = args[0]; - - System.out.println("EchoServer: creating remote object"); - ActivationGroupDesc groupDesc = - new ActivationGroupDesc(null, null); - ActivationSystem system = ActivationGroup.getSystem(); - ActivationGroupID groupID = system.registerGroup(groupDesc); - ActivationGroup.createGroup(groupID, groupDesc, 0); - - EchoImpl impl = new EchoImpl(protocol); - int registryPort = Integer.parseInt(System.getProperty("rmi.registry.port")); - System.out.println("EchoServer: binding in registry on port:" + registryPort); - Naming.rebind("//:" + registryPort + - "/EchoServer", impl); - System.out.println("EchoServer ready."); - } catch (Exception e) { - System.err.println("EXCEPTION OCCURRED:"); - e.printStackTrace(); - } - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl_Stub.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl_Stub.java deleted file mode 100644 index 6331dd875ae..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/EchoImpl_Stub.java +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -// Stub class generated by rmic, do not edit. -// Contents subject to change without notice. - -public final class EchoImpl_Stub - extends java.rmi.server.RemoteStub - implements Echo, java.rmi.Remote -{ - private static final long serialVersionUID = 2; - - private static java.lang.reflect.Method $method_echoNot_0; - private static java.lang.reflect.Method $method_shutdown_1; - - static { - try { - $method_echoNot_0 = Echo.class.getMethod("echoNot", new java.lang.Class[] {byte[].class}); - $method_shutdown_1 = Echo.class.getMethod("shutdown", new java.lang.Class[] {}); - } catch (java.lang.NoSuchMethodException e) { - throw new java.lang.NoSuchMethodError( - "stub class initialization failed"); - } - } - - // constructors - public EchoImpl_Stub(java.rmi.server.RemoteRef ref) { - super(ref); - } - - // methods from remote interfaces - - // implementation of echoNot(byte[]) - public byte[] echoNot(byte[] $param_arrayOf_byte_1) - throws java.rmi.RemoteException - { - try { - Object $result = ref.invoke(this, $method_echoNot_0, new java.lang.Object[] {$param_arrayOf_byte_1}, -4295721514897591756L); - return ((byte[]) $result); - } catch (java.lang.RuntimeException e) { - throw e; - } catch (java.rmi.RemoteException e) { - throw e; - } catch (java.lang.Exception e) { - throw new java.rmi.UnexpectedException("undeclared checked exception", e); - } - } - - // implementation of shutdown() - public void shutdown() - throws java.lang.Exception - { - ref.invoke(this, $method_shutdown_1, null, -7207851917985848402L); - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/MultiSocketFactory.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/MultiSocketFactory.java deleted file mode 100644 index 4af99832bb0..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/MultiSocketFactory.java +++ /dev/null @@ -1,226 +0,0 @@ -/* - * Copyright (c) 1998, 2008, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* - */ - -import java.io.*; -import java.net.*; -import java.rmi.*; -import java.rmi.server.*; -import java.util.zip.*; - - -public class MultiSocketFactory { - - private static RMISocketFactory def = - RMISocketFactory.getDefaultSocketFactory(); - - - public static class ServerFactory - implements RMIServerSocketFactory, Serializable - { - - private String protocol; - private byte[] data; - - public ServerFactory(String protocol, byte[] data) { - this.protocol = protocol; - this.data = data; - } - - public ServerSocket createServerSocket(int port) throws IOException - { - if (protocol.equals("compress")) { - return new CompressServerSocket(port); - - } else if (protocol.equals("xor")) { - if (data == null || data.length != 1) - throw new IOException("invalid argument for XOR protocol"); - return new XorServerSocket(port, data[0]); - - } - - return def.createServerSocket(port); - } - } - - public static class ClientFactory - implements RMIClientSocketFactory, Serializable - { - - private String protocol; - private byte[] data; - - public ClientFactory(String protocol, byte[] data) { - this.protocol = protocol; - this.data = data; - } - - public Socket createSocket(String host, int port) - throws IOException - { - if (protocol.equals("compress")) { - return new CompressSocket(host, port); - - } else if (protocol.equals("xor")) { - if (data == null || data.length != 1) - throw new IOException("invalid argument for XOR protocol"); - return new XorSocket(host, port, data[0]); - - } - - return def.createSocket(host, port); - } - } - - static class CompressSocket extends Socket { - private InputStream in; - private OutputStream out; - public CompressSocket() { super(); } - public CompressSocket(String host, int port) throws IOException { - super(host, port); - } - public InputStream getInputStream() throws IOException { - if (in == null) { - in = new CompressInputStream(super.getInputStream()); - } - return in; - } - public OutputStream getOutputStream() throws IOException { - if (out == null) { - out = new CompressOutputStream(super.getOutputStream()); - } - return out; - } - } - - static class CompressServerSocket extends ServerSocket { - public CompressServerSocket(int port) throws IOException { - super(port); - } - public Socket accept() throws IOException { - Socket s = new CompressSocket(); - implAccept(s); - return s; - } - } - - static class XorSocket extends Socket { - private byte pattern; - private InputStream in; - private OutputStream out; - public XorSocket(byte pattern) { super(); this.pattern = pattern; } - public XorSocket(String host, int port, byte pattern) - throws IOException - { - super(host, port); - this.pattern = pattern; - } - public InputStream getInputStream() throws IOException { - if (in == null) { - in = new XorInputStream(super.getInputStream(), pattern); - } - return in; - } - public OutputStream getOutputStream() throws IOException { - if (out == null) { - out = new XorOutputStream(super.getOutputStream(), pattern); - } - return out; - } - } - - static class XorServerSocket extends ServerSocket { - private byte pattern; - public XorServerSocket(int port, byte pattern) throws IOException { - super(port); - this.pattern = pattern; - } - public Socket accept() throws IOException { - Socket s = new XorSocket(pattern); - implAccept(s); - return s; - } - } - - static class XorOutputStream extends FilterOutputStream { - private byte pattern; - public XorOutputStream(OutputStream out, byte pattern) { - super(out); - this.pattern = pattern; - } - public void write(int b) throws IOException { - out.write(b ^ pattern); - out.flush(); - } - public void write(byte b[], int off, int len) throws IOException { - for (int i = 0; i < len; i++) - write(b[off + i]); - } - } - - static class XorInputStream extends FilterInputStream { - private byte pattern; - public XorInputStream(InputStream in, byte pattern) { - super(in); - this.pattern = pattern; - } - public int read() throws IOException { - int b = in.read(); -// System.out.print("BEFORE: " + Integer.toHexString(b)); - if (b != -1) - b = (b ^ pattern) & 0xFF; -// System.out.println("\tAFTER: " + Integer.toHexString(b)); - return b; - } - public int read(byte b[], int off, int len) throws IOException { - if (len <= 0) { - return 0; - } - - int c = read(); - if (c == -1) { - return -1; - } - b[off] = (byte)c; - - int i = 1; -/***** - try { - for (; i < len ; i++) { - c = read(); - if (c == -1) { - break; - } - if (b != null) { - b[off + i] = (byte)c; - } - } - } catch (IOException ee) { - } -*****/ - return i; - } - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/UseCustomSocketFactory.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/UseCustomSocketFactory.java deleted file mode 100644 index 68eaf8ee955..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/UseCustomSocketFactory.java +++ /dev/null @@ -1,173 +0,0 @@ -/* - * Copyright (c) 1998, 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/* @test - * @bug 4115696 - * @key intermittent - * @summary synopsis: cannot use socket factories with Activatable objects - * @author Ann Wollrath - * - * @library ../../../../testlibrary - * @modules java.rmi/sun.rmi.registry - * java.rmi/sun.rmi.server - * java.rmi/sun.rmi.transport - * java.rmi/sun.rmi.transport.tcp - * java.base/sun.nio.ch - * @build TestLibrary Echo EchoImpl EchoImpl_Stub RMIDSelectorProvider - * @run main/othervm/policy=security.policy/timeout=360 UseCustomSocketFactory - */ - -import java.io.*; -import java.net.MalformedURLException; -import java.rmi.*; -import java.rmi.registry.*; - -public class UseCustomSocketFactory { - static int registryPort = -1; - - static String[] protocol = new String[] { "", "compress", "xor" }; - - public static void main(String[] args) { - - System.out.println("\nRegression test for bug 4115696\n"); - - TestLibrary.suggestSecurityManager("java.rmi.RMISecurityManager"); - - try { - Registry reg = LocateRegistry.createRegistry(0); - registryPort = TestLibrary.getRegistryPort(reg); - } catch (RemoteException e) { - TestLibrary.bomb("creating registry", e); - } - - RMID rmid = null; - - try { - rmid = RMID.createRMIDOnEphemeralPort(); - rmid.addArguments(new String[] { - "-C-Djava.security.policy=" + - TestParams.defaultGroupPolicy + - " -C-Djava.security.manager=java.rmi.RMISecurityManager "}); - rmid.start(); - - Echo[] echo = spawnAndTest(rmid.getPort()); - reactivateAndTest(echo); - } catch (IOException e) { - TestLibrary.bomb("creating rmid", e); - } finally { - if (rmid != null) - rmid.destroy(); - } - } - - private static Echo[] spawnAndTest(int rmidPort) { - - System.err.println("\nCreate Test-->"); - - Echo[] echo = new Echo[protocol.length]; - - for (int i = 0; i < protocol.length; i++) { - JavaVM serverVM = new JavaVM("EchoImpl", - "-Djava.security.manager=allow" + - " -Djava.security.policy=" + - TestParams.defaultPolicy + - " -Drmi.registry.port=" + - registryPort + - " -Djava.rmi.activation.port=" + - rmidPort, - protocol[i]); - - System.err.println("\nusing protocol: " + - ("".equals(protocol[i]) ? "none" : protocol[i])); - - try { - /* spawn VM for EchoServer */ - serverVM.start(); - - /* lookup server */ - echo[i] = null; - // 24 seconds timeout - long stopTime = System.currentTimeMillis() + 24000; - do { - try { - echo[i] = (Echo) Naming.lookup("//:" + registryPort + - "/EchoServer"); - break; - } catch (NotBoundException e) { - try { - Thread.sleep(200); - } catch (InterruptedException ignore) { - } - } - } while (System.currentTimeMillis() < stopTime); - - if (echo[i] == null) - TestLibrary.bomb("server not bound in 120 tries", null); - - /* invoke remote method and print result*/ - System.err.println("Bound to " + echo[i]); - byte[] data = ("Greetings, citizen " + - System.getProperty("user.name") + "!"). getBytes(); - byte[] result = echo[i].echoNot(data); - for (int j = 0; j < result.length; j++) - result[j] = (byte) ~result[j]; - System.err.println("Result: " + new String(result)); - echo[i].shutdown(); - - } catch (Exception e) { - TestLibrary.bomb("test failed", e); - - } finally { - serverVM.destroy(); - try { - Naming.unbind("//:" + registryPort + "/EchoServer"); - } catch (RemoteException | NotBoundException | MalformedURLException e) { - TestLibrary.bomb("unbinding EchoServer", e); - } - } - } - return echo; - } - - - private static void reactivateAndTest(Echo[] echo) { - - System.err.println("\nReactivate Test-->"); - - for (int i = 0; i < echo.length; i++) { - try { - System.err.println("\nusing protocol: " + - ("".equals(protocol[i]) ? "none" : protocol[i])); - byte[] data = ("Greetings, citizen " + - System.getProperty("user.name") + "!").getBytes(); - byte[] result = echo[i].echoNot(data); - for (int j = 0; j < result.length; j++) - result[j] = (byte) ~result[j]; - System.err.println("Result: " + new String(result)); - echo[i].shutdown(); - } catch (Exception e) { - TestLibrary.bomb("activating EchoServer for protocol " + protocol[i], e); - } - } - } -} diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/group.security.policy b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/group.security.policy deleted file mode 100644 index 276768a15d1..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/group.security.policy +++ /dev/null @@ -1,9 +0,0 @@ -/* - * security policy used by activation groups - */ - -grant { - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; - permission java.util.PropertyPermission "test.*", "read"; -}; diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/rmid.security.policy b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/rmid.security.policy deleted file mode 100644 index f2c4f1dbfaa..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/rmid.security.policy +++ /dev/null @@ -1,7 +0,0 @@ -grant { - permission java.lang.RuntimePermission "selectorProvider"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.nio.ch"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.port", "read"; - permission java.util.PropertyPermission "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", "read"; - permission java.net.SocketPermission "*:1024-", "listen,resolve,connect,accept"; -}; diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/security.policy b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/security.policy deleted file mode 100644 index 324624d5bc7..00000000000 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/activatable/security.policy +++ /dev/null @@ -1,43 +0,0 @@ -/* - * security policy used by the test process - */ - -grant { - // property specifically accessed by this test - permission java.util.PropertyPermission "user.name", "read"; - - // standard test activation permissions - permission java.io.FilePermission "..${/}..${/}test.props", "read"; - - // test needs to cleanup rmid's log. - permission java.io.FilePermission ".${/}log", "read,write,delete"; - permission java.io.FilePermission ".${/}log${/}-", "read,write,delete"; - - // test needs to use java to exec an rmid - permission java.io.FilePermission "${java.home}${/}bin${/}java", "execute"; - - // test uses these permissions to propagate security values to rmid - permission java.util.PropertyPermission "java.security.policy", "read"; - permission java.util.PropertyPermission "java.security.manager", "read"; - - // used by TestLibrary to get the RMI Registry port - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.registry"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.server"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.proxy"; - permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.tcp"; - - // used by TestLibrary to determine test environment - permission java.util.PropertyPermission "test.*", "read"; - permission java.util.PropertyPermission "user.dir", "read"; - permission java.util.PropertyPermission "java.home", "read"; - - permission java.util.PropertyPermission "rmi.registry.port", "read"; - permission java.util.PropertyPermission "java.rmi.activation.port", "write"; - - // required for test to create an ActivationGroup - permission java.lang.RuntimePermission "setFactory"; - - // test needs to export rmid and communicate with objects on arbitrary ports - permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; -}; diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/registry/security.policy b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/registry/security.policy index 70bf79ac69e..e35814e04b1 100644 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/registry/security.policy +++ b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/registry/security.policy @@ -29,6 +29,6 @@ grant { permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.proxy"; permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.tcp"; - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; }; diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/UseCustomSocketFactory.java b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/UseCustomSocketFactory.java index e3c02f2e725..945111b8a92 100644 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/UseCustomSocketFactory.java +++ b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/UseCustomSocketFactory.java @@ -33,7 +33,7 @@ * java.rmi/sun.rmi.server * java.rmi/sun.rmi.transport * java.rmi/sun.rmi.transport.tcp - * @build TestLibrary RMID JavaVM Echo EchoImpl EchoImpl_Stub + * @build TestLibrary JavaVM Echo EchoImpl EchoImpl_Stub * @run main/othervm/policy=security.policy/timeout=120 UseCustomSocketFactory */ diff --git a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/security.policy b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/security.policy index 70bf79ac69e..e35814e04b1 100644 --- a/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/security.policy +++ b/test/jdk/java/rmi/server/RMISocketFactory/useSocketFactory/unicast/security.policy @@ -29,6 +29,6 @@ grant { permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.proxy"; permission java.lang.RuntimePermission "accessClassInPackage.sun.rmi.transport.tcp"; - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; }; diff --git a/test/jdk/java/rmi/server/RemoteObject/unrecognizedRefType/UnrecognizedRefType.java b/test/jdk/java/rmi/server/RemoteObject/unrecognizedRefType/UnrecognizedRefType.java index 86f46397459..57b60756b72 100644 --- a/test/jdk/java/rmi/server/RemoteObject/unrecognizedRefType/UnrecognizedRefType.java +++ b/test/jdk/java/rmi/server/RemoteObject/unrecognizedRefType/UnrecognizedRefType.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -32,7 +32,6 @@ * longer a supported "external ref type name", and the names of * other classes in the internal package sun.rmi.server should * produce the same result. - * See also test/java/rmi/activation/Activatable/notSerializable. * @author Peter Jones * * @run main/othervm UnrecognizedRefType diff --git a/test/jdk/java/rmi/server/clientStackTrace/security.policy b/test/jdk/java/rmi/server/clientStackTrace/security.policy index 2913666a0ee..0585c072708 100644 --- a/test/jdk/java/rmi/server/clientStackTrace/security.policy +++ b/test/jdk/java/rmi/server/clientStackTrace/security.policy @@ -3,6 +3,6 @@ */ grant { - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; }; diff --git a/test/jdk/java/rmi/testlibrary/ActivationLibrary.java b/test/jdk/java/rmi/testlibrary/ActivationLibrary.java deleted file mode 100644 index 75531a97017..00000000000 --- a/test/jdk/java/rmi/testlibrary/ActivationLibrary.java +++ /dev/null @@ -1,92 +0,0 @@ -/* - * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -/** - * - */ - -import java.io.File; -import java.rmi.Naming; -import java.rmi.NoSuchObjectException; -import java.rmi.NotBoundException; -import java.rmi.Remote; -import java.rmi.activation.Activatable; -import java.rmi.activation.ActivationID; -import java.rmi.activation.ActivationSystem; -import java.rmi.registry.LocateRegistry; - -/** - * Class of test utility/library methods related to Activatable - * objects. - */ -public class ActivationLibrary { - private static void mesg(Object mesg) { - System.err.println("ACTIVATION_LIBRARY: " + mesg.toString()); - } - - /** - * Deactivate an activated Activatable - */ - public static void deactivate(Remote remote, - ActivationID id) { - final long POLLTIME_MS = 100L; - final long DEACTIVATE_TIME_MS = 30_000L; - - long startTime = System.currentTimeMillis(); - long deadline = TestLibrary.computeDeadline(startTime, DEACTIVATE_TIME_MS); - - while (System.currentTimeMillis() < deadline) { - try { - if (Activatable.inactive(id) == true) { - mesg("inactive successful"); - return; - } else { - Thread.sleep(POLLTIME_MS); - } - } catch (InterruptedException e) { - Thread.currentThread().interrupt(); - mesg("Thread interrupted while trying to deactivate activatable. Exiting deactivation"); - return; - } catch (Exception e) { - try { - // forcibly unexport the object - mesg("Unexpected exception. Have to forcibly unexport the object." + - " Exception was :"); - e.printStackTrace(); - Activatable.unexportObject(remote, true); - } catch (NoSuchObjectException ex) { - } - return; - } - } - - mesg("unable to inactivate after " + - (System.currentTimeMillis() - startTime) + "ms."); - mesg("unexporting object forcibly instead"); - - try { - Activatable.unexportObject(remote, true); - } catch (NoSuchObjectException e) { - } - } -} diff --git a/test/jdk/java/rmi/testlibrary/JavaVM.java b/test/jdk/java/rmi/testlibrary/JavaVM.java index c2abd8be7e9..a37f04f81cd 100644 --- a/test/jdk/java/rmi/testlibrary/JavaVM.java +++ b/test/jdk/java/rmi/testlibrary/JavaVM.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -188,40 +188,6 @@ public class JavaVM { errPipe = StreamPipe.plugTogether(vm.getErrorStream(), this.errorStream); } - public int startAndGetPort() throws IOException { - start0(); - - int port = -1; - if (options.contains("java.nio.channels.spi.SelectorProvider=RMIDSelectorProvider")) { - // Obtain the server socket channel's ephemeral port number of the - // child rmid process. - BufferedReader reader = new BufferedReader( - new InputStreamReader(vm.getInputStream())); - String s; - while ((s = reader.readLine()) != null) { - System.out.println(s); - int i = s.indexOf(RMID.EPHEMERAL_MSG); - if (i != -1) { - String v = s.substring(RMID.EPHEMERAL_MSG.length()); - port = Integer.valueOf(v); - break; - } - } - if (port == -1) { - // something failed - reader = new BufferedReader(new InputStreamReader(vm.getErrorStream())); - while ((s = reader.readLine()) != null) - System.err.println(s); - } - } - - /* output from the exec'ed process may optionally be captured. */ - outPipe = StreamPipe.plugTogether(vm.getInputStream(), this.outputStream); - errPipe = StreamPipe.plugTogether(vm.getErrorStream(), this.errorStream); - - return port; - } - public void destroy() { if (vm != null) { vm.destroyForcibly(); diff --git a/test/jdk/java/rmi/testlibrary/README.jcov b/test/jdk/java/rmi/testlibrary/README.jcov index d27b8a9114a..d47c5d95ec7 100644 --- a/test/jdk/java/rmi/testlibrary/README.jcov +++ b/test/jdk/java/rmi/testlibrary/README.jcov @@ -2,14 +2,14 @@ # This file contains example scripts and property files for collecting # code coverage data of the RMI regression suite. # -# Since many RMI regression tests spawn child VMs (either directly -# or through activation), special support is required for setting +# Since many RMI regression tests spawn child VMs, +# special support is required for setting # command line options and arguments needed by jcov - the code coverage # instrumentation and collection tool. This special support is provided # by properties in the test.props file. If a file named ../../test.props # exists (assuming the working directory is "/JTwork/scratch", this # will find "/test.props"), then it will be used by test library -# code that spawns VMs or instances of rmid. See the example test.props +# code that spawns VMs. See the example test.props # file below for the properties that may be defined. @@ -32,18 +32,12 @@ ${JT_HOME}/solaris/bin/jtreg -Xrunjcov:file=/files/rmi.jcov ${OPTS} -va -w:/tmp/ # are currently supported: # jcov.options are the jcov options that should be added to VMs # system properties -# rmid.jcov.args are the jcov options that should be added as -# arguments to rmid command line; effectively, these -# are identical to jcov.options but each option is -# prefaced with '-C' # jcov.sleep.multiplier is an integer that will be multiplied by # various wait times in the test library; the # default value used is '1' jcov.options=-Xrunjcov:file=/files/rmi.jcov -Xms256m -Xmx256m -XX:+UseUnsupportedDeprecatedJVMPI -XX:+EnableJVMPIInstructionStartEvent -XX:-UseFastEmptyMethods -XX:-UseFastAccessorMethods -rmid.jcov.args=-C-Xrunjcov:file=/files/rmi.jcov -C-Xms256m -C-Xmx256m -C-XX:+UseUnsupportedDeprecatedJVMPI -C-XX:+EnableJVMPIInstructionStartEvent -C-XX:-UseFastEmptyMethods -C-XX:-UseFastAccessorMethods - jcov.sleep.multiplier=3 @@ -59,7 +53,6 @@ export SRCS= java com.sun.tdk.jcov.MergerMain template_a.jcov /files/rmi.jcov java -Xms256m -Xmx512m com.sun.tdk.jcov.RepGenMain -fmt=html_ns -src_root=${SRCS} \ -include=java.rmi.* \ - -include=java.rmi.activation.* \ -include=java.rmi.dgc.* \ -include=java.rmi.registry.* \ -include=java.rmi.server.* \ @@ -72,7 +65,6 @@ java -Xms256m -Xmx512m com.sun.tdk.jcov.RepGenMain -fmt=html_ns -src_root=${SRCS -include=sun.rmi.transport.tcp.* \ -include=java.lang.reflect.Proxy \ -include=sun.misc.ProxyGenerator \ - -exclude=com.sun.rmi.rmid.* \ -exclude=javax.rmi.ssl.* \ java.jcov diff --git a/test/jdk/java/rmi/testlibrary/RMID.java b/test/jdk/java/rmi/testlibrary/RMID.java deleted file mode 100644 index c87d25bc234..00000000000 --- a/test/jdk/java/rmi/testlibrary/RMID.java +++ /dev/null @@ -1,506 +0,0 @@ -/* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.io.*; -import java.rmi.*; -import java.rmi.activation.*; -import java.rmi.registry.*; -import java.time.LocalTime; -import java.util.concurrent.TimeoutException; - -/** - * Utility class that creates an instance of rmid with a policy - * file of name TestParams.defaultPolicy. - * - * Activation groups should run with the same security manager as the - * test. - */ -public class RMID extends JavaVM { - - // TODO: adjust these based on the timeout factor - // such as jcov.sleep.multiplier; see start(long) method. - // Also consider the test.timeout.factor property (a float). - private static final long TIMEOUT_SHUTDOWN_MS = 60_000L; - private static final long TIMEOUT_DESTROY_MS = 10_000L; - private static final long STARTTIME_MS = 15_000L; - private static final long POLLTIME_MS = 100L; - private static final long TIMEOUT_BASE = 240_000L; - - // when restart rmid, it may take more time than usual because of - // "port in use" by a possible interloper (check JDK-8168975), - // so need to set a longer timeout than STARTTIME_MS for restart. - private static final long RESTART_TIMEOUT = (long)(TIMEOUT_BASE * 0.9); - // Same reason to inheritedChannel in RMIDSelectorProvider. - // Put it here rather than in RMIDSelectorProvider to adjust - // both timeout values together. - private static long inheritedChannelTimeout; - - private static final String SYSTEM_NAME = ActivationSystem.class.getName(); - // "java.rmi.activation.ActivationSystem" - - public static String MANAGER_OPTION="-Djava.security.manager="; - - /** - * Test port for rmid. - * - * May initially be 0, which means that the child rmid process will choose - * an ephemeral port and report it back to the parent process. This field - * will then be set to the child rmid's ephemeral port value. - */ - private volatile int port; - //private final boolean ephemeralPort - - /** Initial log name */ - protected static String log = "log"; - /** rmid's logfile directory; currently must be "." */ - protected static String LOGDIR = "."; - - /** The output message from the child rmid process that directly precedes - * the ephemeral port number.*/ - public static final String EPHEMERAL_MSG = "RmidSelectorProvider-listening-On:"; - - private static void mesg(Object mesg) { - System.err.println("RMID: " + mesg.toString()); - } - - /** make test options and arguments */ - private static String makeOptions(int port, boolean debugExec, - boolean enableSelectorProvider) { - - String options = " -Dsun.rmi.server.activation.debugExec=" + - debugExec; - // + - //" -Djava.compiler= "; - - // if test params set, want to propagate them - if (!TestParams.testSrc.equals("")) { - options += " -Dtest.src=" + TestParams.testSrc + " "; - } - //if (!TestParams.testClasses.equals("")) { - // options += " -Dtest.classes=" + TestParams.testClasses + " "; - //} - options += " -Dtest.classes=" + TestParams.testClasses //; - + - " -Djava.rmi.server.logLevel=v "; - - // + - // " -Djava.security.debug=all "; - - // Set execTimeout to 60 sec (default is 30 sec) - // to avoid spurious timeouts on slow machines. - options += " -Dsun.rmi.activation.execTimeout=60000"; - - // It's important to set handshakeTimeout to small value, for example - // 5 sec (default is 60 sec) to avoid wasting too much time when - // calling lookupSystem(port) in restart(), because - // 1. If use default value of this option, it will take about 2 minutes - // to finish lookupSystem(port) in 2 loops in restart(); - // 2. If set this option as 5 sec then lookupSystem(port) will return - // very quickly. - options += " -Dsun.rmi.transport.tcp.handshakeTimeout=5000"; - - if (port == 0 || enableSelectorProvider) { - // Ephemeral port, so have the rmid child process create the - // server socket channel and report its port number, over stdin. - options += " -classpath " + TestParams.testClassPath; - options += " --add-exports=java.base/sun.nio.ch=ALL-UNNAMED"; - options += " -Djava.nio.channels.spi.SelectorProvider=RMIDSelectorProvider"; - options += " -Dtest.java.rmi.testlibrary.RMIDSelectorProvider.port=" + port; - options += " -Dtest.java.rmi.testlibrary.RMIDSelectorProvider.timeout=" - + inheritedChannelTimeout; - - // Disable redirection of System.err to /tmp - options += " -Dsun.rmi.server.activation.disableErrRedirect=true"; - } - - return options; - } - - private static String makeArgs() { - return makeArgs(false, 0); - } - - private static String makeArgs(boolean includePortArg, int port) { - // getAbsolutePath requires permission to read user.dir - String args = - " -log " + (new File(LOGDIR, log)).getAbsolutePath(); - - // 0 = ephemeral port, do not include an explicit port number - if (includePortArg && port != 0) { - args += " -port " + port; - } - - // + - // " -C-Djava.compiler= "; - - // if test params set, want to propagate them - if (!TestParams.testSrc.equals("")) { - args += " -C-Dtest.src=" + TestParams.testSrc; - } - if (!TestParams.testClasses.equals("")) { - args += " -C-Dtest.classes=" + TestParams.testClasses; - } - - if (!TestParams.testJavaOpts.equals("")) { - for (String a : TestParams.testJavaOpts.split(" +")) { - args += " -C" + a; - } - } - - if (!TestParams.testVmOpts.equals("")) { - for (String a : TestParams.testVmOpts.split(" +")) { - args += " -C" + a; - } - } - - args += " -C-Djava.rmi.server.useCodebaseOnly=false "; - - args += " " + getCodeCoverageArgs(); - return args; - } - - /** - * Routine that creates an rmid that will run with or without a - * policy file. - */ - public static RMID createRMID() { - return createRMID(System.out, System.err, true, true, - TestLibrary.getUnusedRandomPort()); - } - - public static RMID createRMID(OutputStream out, OutputStream err, - boolean debugExec) - { - return createRMID(out, err, debugExec, true, - TestLibrary.getUnusedRandomPort()); - } - - public static RMID createRMID(OutputStream out, OutputStream err, - boolean debugExec, boolean includePortArg, - int port) - { - return createRMIDWithOptions(out, err, debugExec, includePortArg, port, ""); - } - - /** - * Create a RMID on a specified port capturing stdout and stderr - * with additional command line options and whether to print out - * debugging information that is used for spawning activation groups. - * - * @param out the OutputStream where the normal output of the - * rmid subprocess goes - * @param err the OutputStream where the error output of the - * rmid subprocess goes - * @param debugExec whether to print out debugging information - * @param includePortArg whether to include port argument - * @param port the port on which rmid accepts requests - * @param additionalOptions additional command line options - * @return a RMID instance - */ - public static RMID createRMIDWithOptions(OutputStream out, OutputStream err, - boolean debugExec, boolean includePortArg, - int port, String additionalOptions) - { - String options = makeOptions(port, debugExec, false); - options += " " + additionalOptions; - String args = makeArgs(includePortArg, port); - RMID rmid = new RMID("sun.rmi.server.Activation", options, args, - out, err, port); - rmid.setPolicyFile(TestParams.defaultRmidPolicy); - - return rmid; - } - - public static RMID createRMIDOnEphemeralPort() { - return createRMID(System.out, System.err, true, false, 0); - } - - /** - * Create a RMID on an ephemeral port capturing stdout and stderr - * with additional command line options. - * - * @param additionalOptions additional command line options - * @return a RMID instance - */ - public static RMID createRMIDOnEphemeralPortWithOptions( - String additionalOptions) { - return createRMIDWithOptions(System.out, System.err, - true, false, 0, additionalOptions); - } - - public static RMID createRMIDOnEphemeralPort(OutputStream out, - OutputStream err, - boolean debugExec) - { - return createRMID(out, err, debugExec, false, 0); - } - - - /** - * Private constructor. RMID instances should be created - * using the static factory methods. - */ - private RMID(String classname, String options, String args, - OutputStream out, OutputStream err, int port) - { - super(classname, options, args, out, err); - this.port = port; - long waitTime = (long)(TIMEOUT_BASE * TestLibrary.getTimeoutFactor()); - inheritedChannelTimeout = (long)(waitTime * 0.8); - } - - /** - * Removes rmid's log file directory. - */ - public static void removeLog() { - File f = new File(LOGDIR, log); - - if (f.exists()) { - mesg("Removing rmid's old log file."); - String[] files = f.list(); - - if (files != null) { - for (int i=0; i deadline) { - TestLibrary.bomb("Failed to start rmid, giving up after " + - (System.currentTimeMillis() - startTime) + "ms.", null); - } - } - } - - /** - * Destroys rmid and restarts it. Note that this does NOT clean up - * the log file, because it stores information about restartable - * and activatable objects that must be carried over to the new - * rmid instance. - */ - public void restart() throws IOException { - destroy(); - options = makeOptions(port, true, true); - args = makeArgs(); - - start(RESTART_TIMEOUT); - } - - /** - * Ask rmid to shutdown gracefully using a remote method call. - * catch any errors that might occur from rmid not being present - * at time of shutdown invocation. If the remote call is - * successful, wait for the process to terminate. Return true - * if the process terminated, otherwise return false. - */ - private boolean shutdown() throws InterruptedException { - mesg("shutdown()"); - long startTime = System.currentTimeMillis(); - ActivationSystem system = lookupSystem(port); - if (system == null) { - mesg("lookupSystem() returned null after " + - (System.currentTimeMillis() - startTime) + "ms."); - return false; - } - - try { - mesg("ActivationSystem.shutdown()"); - system.shutdown(); - } catch (Exception e) { - mesg("Caught exception from ActivationSystem.shutdown():"); - e.printStackTrace(); - } - - try { - waitFor(TIMEOUT_SHUTDOWN_MS); - mesg("Shutdown successful after " + - (System.currentTimeMillis() - startTime) + "ms."); - return true; - } catch (TimeoutException ex) { - mesg("Shutdown timed out after " + - (System.currentTimeMillis() - startTime) + "ms:"); - ex.printStackTrace(); - return false; - } - } - - /** - * Ask rmid to shutdown gracefully but then destroy the rmid - * process if it does not exit by itself. This method only works - * if rmid is a child process of the current VM. - */ - public void destroy() { - if (vm == null) { - throw new IllegalStateException("can't wait for RMID that isn't running"); - } - - long startTime = System.currentTimeMillis(); - - // First, attempt graceful shutdown of the activation system. - try { - if (! shutdown()) { - // Graceful shutdown failed, use Process.destroy(). - mesg("Destroying RMID process."); - vm.destroy(); - try { - waitFor(TIMEOUT_DESTROY_MS); - mesg("Destroy successful after " + - (System.currentTimeMillis() - startTime) + "ms."); - } catch (TimeoutException ex) { - mesg("Destroy timed out, giving up after " + - (System.currentTimeMillis() - startTime) + "ms:"); - ex.printStackTrace(); - } - } - } catch (InterruptedException ie) { - mesg("Shutdown/destroy interrupted, giving up at " + - (System.currentTimeMillis() - startTime) + "ms."); - ie.printStackTrace(); - Thread.currentThread().interrupt(); - return; - } - - vm = null; - } - - /** - * Shuts down rmid and then removes its log file. - */ - public void cleanup() { - destroy(); - RMID.removeLog(); - } - - /** - * Gets the port on which this rmid is listening. - */ - public int getPort() { - return port; - } -} diff --git a/test/jdk/java/rmi/testlibrary/RMIDSelectorProvider.java b/test/jdk/java/rmi/testlibrary/RMIDSelectorProvider.java deleted file mode 100644 index 5726bf0b125..00000000000 --- a/test/jdk/java/rmi/testlibrary/RMIDSelectorProvider.java +++ /dev/null @@ -1,139 +0,0 @@ -/* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -import java.io.*; -import java.net.BindException; -import java.net.InetSocketAddress; -import java.net.ProtocolFamily; -import java.nio.channels.Channel; -import java.nio.channels.DatagramChannel; -import java.nio.channels.Pipe; -import java.nio.channels.ServerSocketChannel; -import java.nio.channels.SocketChannel; -import java.nio.channels.spi.AbstractSelector; -import java.nio.channels.spi.SelectorProvider; -import java.time.LocalTime; -import static java.net.StandardSocketOptions.SO_REUSEADDR; -import static java.net.StandardSocketOptions.SO_REUSEPORT; - -/** - * A SelectorProvider, that can be loaded by the child rmid process, whose - * inheritedChannel method will create a new server socket channel and report - * it back to the parent process, over stdout. - */ -public class RMIDSelectorProvider extends SelectorProvider { - - private final SelectorProvider provider; - private ServerSocketChannel channel; - - public RMIDSelectorProvider() { - provider = sun.nio.ch.DefaultSelectorProvider.get(); - } - - public DatagramChannel openDatagramChannel() - throws IOException - { - return provider.openDatagramChannel(); - } - - public DatagramChannel openDatagramChannel(ProtocolFamily family) - throws IOException - { - return provider.openDatagramChannel(family); - } - - public Pipe openPipe() - throws IOException - { - return provider.openPipe(); - } - - public AbstractSelector openSelector() - throws IOException - { - return provider.openSelector(); - } - - public ServerSocketChannel openServerSocketChannel() - throws IOException - { - return provider.openServerSocketChannel(); - } - - public SocketChannel openSocketChannel() - throws IOException - { - return provider.openSocketChannel(); - } - - public synchronized Channel inheritedChannel() throws IOException { - System.out.println("RMIDSelectorProvider.inheritedChannel"); - if (channel == null) { - // Create and bind a new server socket channel - channel = ServerSocketChannel.open(); - - // Enable SO_REUSEADDR before binding - channel.setOption(SO_REUSEADDR, true); - - // Enable SO_REUSEPORT, if supported, before binding - if (channel.supportedOptions().contains(SO_REUSEPORT)) { - channel.setOption(SO_REUSEPORT, true); - } - - // when it comes here, these properties should have been set with - // a valid value, but assign a default value anyway. - long timeout = Long.getLong( - "test.java.rmi.testlibrary.RMIDSelectorProvider.timeout", - 200_000); - long deadline = System.currentTimeMillis() + timeout; - int port = Integer.getInteger( - "test.java.rmi.testlibrary.RMIDSelectorProvider.port", 0); - while (true) { - try { - channel.bind(new InetSocketAddress(port)); - break; - } catch (BindException ex) { - System.out.format("RMIDSelectorProvider: " - + "failed to bind to port %d due to \"%s\", at %s%n", - port, ex.getMessage(), LocalTime.now()); - } - if (System.currentTimeMillis() > deadline) { - System.out.format("RMIDSelectorProvider: " - + "fail to bind to port %d after trying for " - + "%d seconds, exiting rmid process, at %s%n", - port, timeout/1000, LocalTime.now()); - channel.close(); - // can not start rmid on specific port, - // there is no need to continue run rmid. - System.exit(1); - } - try { - Thread.sleep(1000); - } catch(InterruptedException ignore) { } - } - - System.out.println(RMID.EPHEMERAL_MSG + channel.socket().getLocalPort()); - } - return channel; - } -} diff --git a/test/jdk/java/rmi/testlibrary/TestLibrary.java b/test/jdk/java/rmi/testlibrary/TestLibrary.java index 43bab34ad74..cb2d2644660 100644 --- a/test/jdk/java/rmi/testlibrary/TestLibrary.java +++ b/test/jdk/java/rmi/testlibrary/TestLibrary.java @@ -88,8 +88,6 @@ public class TestLibrary { */ public final static int FIXED_PORT_MIN = 60001; public final static int FIXED_PORT_MAX = 60010; - public final static int RMIDVIAINHERITEDCHANNEL_ACTIVATION_PORT = 60001; - public final static int RMIDVIAINHERITEDCHANNEL_REGISTRY_PORT = 60002; public final static int INHERITEDCHANNELNOTSERVERSOCKET_ACTIVATION_PORT = 60003; public final static int INHERITEDCHANNELNOTSERVERSOCKET_REGISTRY_PORT = 60004; public final static int READTEST_REGISTRY_PORT = 60005; diff --git a/test/jdk/java/rmi/testlibrary/TestParams.java b/test/jdk/java/rmi/testlibrary/TestParams.java index 07baf57e5d3..9feba1f7636 100644 --- a/test/jdk/java/rmi/testlibrary/TestParams.java +++ b/test/jdk/java/rmi/testlibrary/TestParams.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,15 +39,9 @@ public class TestParams { /** name of default security policy for test JVM */ public static final String defaultPolicy; - /** name of default security policy for RMID */ - public static final String defaultRmidPolicy; - /** name of default security policy for RegistryVM */ public static final String defaultRegistryPolicy; - /** name of default security policy for activation groups */ - public static final String defaultGroupPolicy; - /** name of default security manager */ public static final String defaultSecurityManager; @@ -69,15 +63,9 @@ public class TestParams { } defaultPolicy = dp; - defaultRmidPolicy = - testSrc + File.separatorChar + "rmid.security.policy"; - defaultRegistryPolicy = testSrc + File.separatorChar + "registry.security.policy"; - defaultGroupPolicy = - testSrc + File.separatorChar + "group.security.policy"; - String tmp = TestLibrary.getProperty("java.security.manager", null); if (tmp == null || tmp.equals("allow")) { tmp = "java.lang.SecurityManager"; diff --git a/test/jdk/java/rmi/transport/checkLeaseInfoLeak/security.policy b/test/jdk/java/rmi/transport/checkLeaseInfoLeak/security.policy index 2ae9c27386d..7b62c9d6f41 100644 --- a/test/jdk/java/rmi/transport/checkLeaseInfoLeak/security.policy +++ b/test/jdk/java/rmi/transport/checkLeaseInfoLeak/security.policy @@ -18,6 +18,6 @@ grant { permission java.util.PropertyPermission "java.security.policy", "read"; permission java.util.PropertyPermission "java.security.manager", "read"; - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept"; }; diff --git a/test/jdk/java/rmi/transport/dgcDeadLock/registry.security.policy b/test/jdk/java/rmi/transport/dgcDeadLock/registry.security.policy index 926d8787fd9..bd6ca55df35 100644 --- a/test/jdk/java/rmi/transport/dgcDeadLock/registry.security.policy +++ b/test/jdk/java/rmi/transport/dgcDeadLock/registry.security.policy @@ -22,6 +22,6 @@ grant { permission java.util.PropertyPermission "java.security.policy", "read"; permission java.util.PropertyPermission "java.security.manager", "read"; - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; }; diff --git a/test/jdk/java/rmi/transport/dgcDeadLock/security.policy b/test/jdk/java/rmi/transport/dgcDeadLock/security.policy index b1caaba7e00..df76916420c 100644 --- a/test/jdk/java/rmi/transport/dgcDeadLock/security.policy +++ b/test/jdk/java/rmi/transport/dgcDeadLock/security.policy @@ -22,6 +22,6 @@ grant { permission java.util.PropertyPermission "java.security.policy", "read"; permission java.util.PropertyPermission "java.security.manager", "read"; - // test needs to export rmid and communicate with objects on arbitrary ports + // test needs to communicate with objects on arbitrary ports permission java.net.SocketPermission "*:1024-", "connect,accept,listen"; }; diff --git a/test/jdk/java/security/PermissionCollection/Concurrent.java b/test/jdk/java/security/PermissionCollection/Concurrent.java index 1b77d4dc77a..f6c97e166ce 100644 --- a/test/jdk/java/security/PermissionCollection/Concurrent.java +++ b/test/jdk/java/security/PermissionCollection/Concurrent.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,7 +25,6 @@ * @test * @bug 4671598 * @summary PermissionCollection is not properly synchronized - * @modules java.rmi/com.sun.rmi.rmid */ import java.security.*; // AllPermission, BasicPermission, Permissions @@ -37,8 +36,6 @@ import javax.security.auth.AuthPermission; import javax.security.auth.kerberos.DelegationPermission; import javax.security.auth.kerberos.ServicePermission; import javax.management.MBeanServerPermission; -import com.sun.rmi.rmid.ExecPermission; -import com.sun.rmi.rmid.ExecOptionPermission; import java.util.*; diff --git a/test/jdk/tools/launcher/HelpFlagsTest.java b/test/jdk/tools/launcher/HelpFlagsTest.java index 6c8c0ccf294..1c1bf98b804 100644 --- a/test/jdk/tools/launcher/HelpFlagsTest.java +++ b/test/jdk/tools/launcher/HelpFlagsTest.java @@ -146,7 +146,6 @@ public class HelpFlagsTest extends TestHelper { new ToolHelpSpec("jstat", 1, 1, 1, 0, 1, 1, 1), // -?, -h, --help -help, Documents -help new ToolHelpSpec("jstatd", 1, 1, 1, 0, 0, 0, 1), // -?, -h, --help new ToolHelpSpec("keytool", 1, 1, 1, 0, 1, 0, 1), // none, prints help message anyways. - new ToolHelpSpec("rmid", 0, 0, 0, 0, 0, 0, 1), // none, prints help message anyways. new ToolHelpSpec("rmiregistry", 0, 0, 0, 0, 0, 0, 1), // none, prints help message anyways. new ToolHelpSpec("serialver", 0, 0, 0, 0, 0, 0, 1), // none, prints help message anyways. new ToolHelpSpec("jpackage", 0, 1, 1, 0, 0, 1, 1), // -h, --help, diff --git a/test/jdk/tools/launcher/VersionCheck.java b/test/jdk/tools/launcher/VersionCheck.java index 1146b33a71f..38a61b54198 100644 --- a/test/jdk/tools/launcher/VersionCheck.java +++ b/test/jdk/tools/launcher/VersionCheck.java @@ -104,7 +104,6 @@ public class VersionCheck extends TestHelper { "klist", "ktab", "jpackage", - "rmid", "rmiregistry", "serialver", "servertool",