Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
s920243400
Rocketmq
提交
52e49dd0
R
Rocketmq
项目概览
s920243400
/
Rocketmq
与 Fork 源项目一致
Fork自
Apache RocketMQ / Rocketmq
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rocketmq
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
52e49dd0
编写于
12月 11, 2017
作者:
Y
yukon
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Pass TLS unit tests
上级
43c300f4
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
130 addition
and
152 deletion
+130
-152
remoting/src/main/java/org/apache/rocketmq/remoting/netty/TlsHelper.java
...in/java/org/apache/rocketmq/remoting/netty/TlsHelper.java
+1
-0
remoting/src/test/java/org/apache/rocketmq/remoting/TlsConfigTest.java
...test/java/org/apache/rocketmq/remoting/TlsConfigTest.java
+0
-108
remoting/src/test/java/org/apache/rocketmq/remoting/TlsTest.java
...g/src/test/java/org/apache/rocketmq/remoting/TlsTest.java
+129
-44
未找到文件。
remoting/src/main/java/org/apache/rocketmq/remoting/netty/TlsHelper.java
浏览文件 @
52e49dd0
...
@@ -160,6 +160,7 @@ public class TlsHelper {
...
@@ -160,6 +160,7 @@ public class TlsHelper {
private
static
void
extractTlsConfigFromFile
(
final
File
configFile
)
{
private
static
void
extractTlsConfigFromFile
(
final
File
configFile
)
{
if
(!(
configFile
.
exists
()
&&
configFile
.
isFile
()
&&
configFile
.
canRead
()))
{
if
(!(
configFile
.
exists
()
&&
configFile
.
isFile
()
&&
configFile
.
canRead
()))
{
LOGGER
.
info
(
"Tls config file doesn't exist, skip it"
);
LOGGER
.
info
(
"Tls config file doesn't exist, skip it"
);
return
;
}
}
Properties
properties
;
Properties
properties
;
...
...
remoting/src/test/java/org/apache/rocketmq/remoting/TlsConfigTest.java
已删除
100644 → 0
浏览文件 @
43c300f4
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
org.apache.rocketmq.remoting
;
import
java.io.BufferedWriter
;
import
java.io.File
;
import
java.io.FileWriter
;
import
java.io.IOException
;
import
java.io.PrintWriter
;
import
org.apache.rocketmq.remoting.netty.TlsHelper
;
import
org.junit.Rule
;
import
org.junit.Test
;
import
org.junit.rules.TemporaryFolder
;
import
org.junit.runner.RunWith
;
import
org.mockito.junit.MockitoJUnitRunner
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_AUTHSERVER
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_CERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_KEYPASSWORD
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_KEYPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CONFIG_FILE
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_AUTHCLIENT
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_CERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_KEYPASSWORD
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_KEYPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_NEED_CLIENT_AUTH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientAuthServer
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientKeyPassword
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientKeyPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientTrustCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerAuthClient
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerKeyPassword
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerKeyPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerNeedClientAuth
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerTrustCertPath
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
@RunWith
(
MockitoJUnitRunner
.
class
)
public
class
TlsConfigTest
{
@Rule
public
TemporaryFolder
tempFolder
=
new
TemporaryFolder
();
@Test
public
void
testTlsConfigThroughFile
()
throws
Exception
{
File
file
=
tempFolder
.
newFile
(
"tls.config"
);
System
.
setProperty
(
TLS_CONFIG_FILE
,
file
.
getAbsolutePath
());
StringBuilder
sb
=
new
StringBuilder
();
sb
.
append
(
TLS_SERVER_NEED_CLIENT_AUTH
+
"=require\n"
);
sb
.
append
(
TLS_SERVER_KEYPATH
+
"=/server.key\n"
);
sb
.
append
(
TLS_SERVER_CERTPATH
+
"=/server.pem\n"
);
sb
.
append
(
TLS_SERVER_KEYPASSWORD
+
"=2345\n"
);
sb
.
append
(
TLS_SERVER_AUTHCLIENT
+
"=true\n"
);
sb
.
append
(
TLS_SERVER_TRUSTCERTPATH
+
"=/ca.pem\n"
);
sb
.
append
(
TLS_CLIENT_KEYPATH
+
"=/client.key\n"
);
sb
.
append
(
TLS_CLIENT_KEYPASSWORD
+
"=1234\n"
);
sb
.
append
(
TLS_CLIENT_CERTPATH
+
"=/client.pem\n"
);
sb
.
append
(
TLS_CLIENT_KEYPASSWORD
+
"=1234\n"
);
sb
.
append
(
TLS_CLIENT_AUTHSERVER
+
"=false\n"
);
sb
.
append
(
TLS_CLIENT_TRUSTCERTPATH
+
"=/ca.pem\n"
);
writeStringToFile
(
file
.
getAbsolutePath
(),
sb
.
toString
());
TlsHelper
.
buildSslContext
(
false
);
assertThat
(
tlsServerNeedClientAuth
).
isEqualTo
(
"require"
);
assertThat
(
tlsServerKeyPath
).
isEqualTo
(
"/server.key"
);
assertThat
(
tlsServerCertPath
).
isEqualTo
(
"/server.pem"
);
assertThat
(
tlsServerKeyPassword
).
isEqualTo
(
"2345"
);
assertThat
(
tlsServerAuthClient
).
isEqualTo
(
true
);
assertThat
(
tlsServerTrustCertPath
).
isEqualTo
(
"/ca.pem"
);
assertThat
(
tlsClientKeyPath
).
isEqualTo
(
"/client.key"
);
assertThat
(
tlsClientKeyPassword
).
isEqualTo
(
"1234"
);
assertThat
(
tlsClientCertPath
).
isEqualTo
(
"/client.pem"
);
assertThat
(
tlsClientAuthServer
).
isEqualTo
(
false
);
assertThat
(
tlsClientTrustCertPath
).
isEqualTo
(
"/ca.pem"
);
}
private
static
void
writeStringToFile
(
String
path
,
String
content
)
{
try
{
PrintWriter
out
=
new
PrintWriter
(
new
BufferedWriter
(
new
FileWriter
(
path
,
true
)));
out
.
println
(
content
);
out
.
close
();
}
catch
(
IOException
ignore
)
{
}
}
}
remoting/src/test/java/org/apache/rocketmq/remoting/TlsTest.java
浏览文件 @
52e49dd0
...
@@ -17,18 +17,22 @@
...
@@ -17,18 +17,22 @@
package
org.apache.rocketmq.remoting
;
package
org.apache.rocketmq.remoting
;
import
java.io.BufferedWriter
;
import
java.io.File
;
import
java.io.File
;
import
java.security.SignatureException
;
import
java.io.FileWriter
;
import
javax.net.ssl.SSLException
;
import
java.io.IOException
;
import
java.io.PrintWriter
;
import
org.apache.rocketmq.remoting.common.TlsMode
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.netty.NettyClientConfig
;
import
org.apache.rocketmq.remoting.netty.NettyClientConfig
;
import
org.apache.rocketmq.remoting.netty.TlsHelper
;
import
org.apache.rocketmq.remoting.protocol.LanguageCode
;
import
org.apache.rocketmq.remoting.protocol.LanguageCode
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.assertj.core.util.Throwables
;
import
org.junit.After
;
import
org.junit.After
;
import
org.junit.Before
;
import
org.junit.Before
;
import
org.junit.Rule
;
import
org.junit.Rule
;
import
org.junit.Test
;
import
org.junit.Test
;
import
org.junit.rules.TemporaryFolder
;
import
org.junit.rules.TestName
;
import
org.junit.rules.TestName
;
import
org.junit.runner.RunWith
;
import
org.junit.runner.RunWith
;
import
org.mockito.junit.MockitoJUnitRunner
;
import
org.mockito.junit.MockitoJUnitRunner
;
...
@@ -40,11 +44,24 @@ import static org.apache.rocketmq.remoting.netty.TlsSystemConfig.TLS_CLIENT_KEYP
...
@@ -40,11 +44,24 @@ import static org.apache.rocketmq.remoting.netty.TlsSystemConfig.TLS_CLIENT_KEYP
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_CLIENT_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_AUTHCLIENT
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_AUTHCLIENT
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_CERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_CERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_KEYPASSWORD
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_KEYPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_KEYPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_MODE
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_NEED_CLIENT_AUTH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_NEED_CLIENT_AUTH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_SERVER_TRUSTCERTPATH
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
TLS_TEST_MODE_ENABLE
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientAuthServer
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientKeyPassword
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientKeyPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsClientTrustCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsConfigFile
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsMode
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerAuthClient
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerKeyPassword
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerKeyPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerNeedClientAuth
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsServerTrustCertPath
;
import
static
org
.
apache
.
rocketmq
.
remoting
.
netty
.
TlsSystemConfig
.
tlsTestModeEnable
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
failBecauseExceptionWasNotThrown
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
failBecauseExceptionWasNotThrown
;
import
static
org
.
junit
.
Assert
.
assertTrue
;
import
static
org
.
junit
.
Assert
.
assertTrue
;
...
@@ -57,22 +74,24 @@ public class TlsTest {
...
@@ -57,22 +74,24 @@ public class TlsTest {
@Rule
@Rule
public
TestName
name
=
new
TestName
();
public
TestName
name
=
new
TestName
();
@Rule
public
TemporaryFolder
tempFolder
=
new
TemporaryFolder
();
@Before
@Before
public
void
setUp
()
throws
InterruptedException
{
public
void
setUp
()
throws
InterruptedException
{
System
.
setProperty
(
TLS_SERVER_MODE
,
"enforcing"
);
tlsMode
=
TlsMode
.
ENFORCING
;
System
.
setProperty
(
TLS_TEST_MODE_ENABLE
,
"false"
);
tlsTestModeEnable
=
false
;
tlsServerNeedClientAuth
=
"require"
;
System
.
setProperty
(
TLS_SERVER_NEED_CLIENT_AUTH
,
"require"
);
tlsServerKeyPath
=
getCertsPath
(
"server.key"
);
System
.
setProperty
(
TLS_SERVER_KEYPATH
,
getCertsPath
(
"server.key"
));
tlsServerCertPath
=
getCertsPath
(
"server.pem"
);
System
.
setProperty
(
TLS_SERVER_CERTPATH
,
getCertsPath
(
"server.pem"
));
tlsServerAuthClient
=
true
;
System
.
setProperty
(
TLS_SERVER_AUTHCLIENT
,
"true"
);
tlsServerTrustCertPath
=
getCertsPath
(
"ca.pem"
);
System
.
setProperty
(
TLS_SERVER_TRUSTCERTPATH
,
getCertsPath
(
"ca.pem"
));
tlsClientKeyPath
=
getCertsPath
(
"client.key"
);
tlsClientCertPath
=
getCertsPath
(
"client.pem"
);
System
.
setProperty
(
TLS_CLIENT_KEYPATH
,
getCertsPath
(
"client.key"
));
tlsClientAuthServer
=
true
;
System
.
setProperty
(
TLS_CLIENT_CERTPATH
,
getCertsPath
(
"client.pem"
));
tlsClientTrustCertPath
=
getCertsPath
(
"ca.pem"
);
System
.
setProperty
(
TLS_CLIENT_AUTHSERVER
,
"true"
);
tlsClientKeyPassword
=
"1234"
;
System
.
setProperty
(
TLS_CLIENT_TRUSTCERTPATH
,
getCertsPath
(
"ca.pem"
));
tlsServerKeyPassword
=
""
;
System
.
setProperty
(
TLS_CLIENT_KEYPASSWORD
,
"1234"
);
NettyClientConfig
clientConfig
=
new
NettyClientConfig
();
NettyClientConfig
clientConfig
=
new
NettyClientConfig
();
clientConfig
.
setUseTLS
(
true
);
clientConfig
.
setUseTLS
(
true
);
...
@@ -80,34 +99,41 @@ public class TlsTest {
...
@@ -80,34 +99,41 @@ public class TlsTest {
if
(
"serverRejectsUntrustedClientCert"
.
equals
(
name
.
getMethodName
()))
{
if
(
"serverRejectsUntrustedClientCert"
.
equals
(
name
.
getMethodName
()))
{
// Create a client. Its credentials come from a CA that the server does not trust. The client
// Create a client. Its credentials come from a CA that the server does not trust. The client
// trusts both test CAs to ensure the handshake failure is due to the server rejecting the client's cert.
// trusts both test CAs to ensure the handshake failure is due to the server rejecting the client's cert.
System
.
setProperty
(
TLS_CLIENT_KEYPATH
,
getCertsPath
(
"badClient.key"
)
);
tlsClientKeyPath
=
getCertsPath
(
"badClient.key"
);
System
.
setProperty
(
TLS_CLIENT_CERTPATH
,
getCertsPath
(
"badClient.pem"
)
);
tlsClientCertPath
=
getCertsPath
(
"badClient.pem"
);
}
else
if
(
"serverAcceptsUntrustedClientCert"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"serverAcceptsUntrustedClientCert"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_CLIENT_KEYPATH
,
getCertsPath
(
"badClient.key"
)
);
tlsClientKeyPath
=
getCertsPath
(
"badClient.key"
);
System
.
setProperty
(
TLS_CLIENT_CERTPATH
,
getCertsPath
(
"badClient.pem"
)
);
tlsClientCertPath
=
getCertsPath
(
"badClient.pem"
);
System
.
setProperty
(
TLS_SERVER_AUTHCLIENT
,
"false"
)
;
tlsServerAuthClient
=
false
;
}
}
else
if
(
"noClientAuthFailure"
.
equals
(
name
.
getMethodName
()))
{
else
if
(
"noClientAuthFailure"
.
equals
(
name
.
getMethodName
()))
{
//Clear the client cert config to ensure produce the handshake error
//Clear the client cert config to ensure produce the handshake error
System
.
setProperty
(
TLS_CLIENT_KEYPATH
,
""
)
;
tlsClientKeyPath
=
""
;
System
.
setProperty
(
TLS_CLIENT_CERTPATH
,
""
)
;
tlsClientCertPath
=
""
;
}
else
if
(
"clientRejectsUntrustedServerCert"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"clientRejectsUntrustedServerCert"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_SERVER_KEYPATH
,
getCertsPath
(
"badServer.key"
)
);
tlsServerKeyPath
=
getCertsPath
(
"badServer.key"
);
System
.
setProperty
(
TLS_SERVER_CERTPATH
,
getCertsPath
(
"badServer.pem"
)
);
tlsServerCertPath
=
getCertsPath
(
"badServer.pem"
);
}
else
if
(
"clientAcceptsUntrustedServerCert"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"clientAcceptsUntrustedServerCert"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_SERVER_KEYPATH
,
getCertsPath
(
"badServer.key"
)
);
tlsServerKeyPath
=
getCertsPath
(
"badServer.key"
);
System
.
setProperty
(
TLS_SERVER_CERTPATH
,
getCertsPath
(
"badServer.pem"
)
);
tlsServerCertPath
=
getCertsPath
(
"badServer.pem"
);
System
.
setProperty
(
TLS_CLIENT_AUTHSERVER
,
"false"
)
;
tlsClientAuthServer
=
false
;
}
else
if
(
"serverNotNeedClientAuth"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"serverNotNeedClientAuth"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_SERVER_NEED_CLIENT_AUTH
,
"none"
)
;
tlsServerNeedClientAuth
=
"none"
;
System
.
clearProperty
(
TLS_CLIENT_KEYPATH
)
;
tlsClientKeyPath
=
""
;
System
.
clearProperty
(
TLS_CLIENT_CERTPATH
)
;
tlsClientCertPath
=
""
;
}
else
if
(
"serverWantClientAuth"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"serverWantClientAuth"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_SERVER_NEED_CLIENT_AUTH
,
"optional"
)
;
tlsServerNeedClientAuth
=
"optional"
;
}
else
if
(
"serverWantClientAuth_ButClientNoCert"
.
equals
(
name
.
getMethodName
()))
{
}
else
if
(
"serverWantClientAuth_ButClientNoCert"
.
equals
(
name
.
getMethodName
()))
{
System
.
setProperty
(
TLS_SERVER_NEED_CLIENT_AUTH
,
"optional"
);
tlsServerNeedClientAuth
=
"optional"
;
System
.
clearProperty
(
TLS_CLIENT_KEYPATH
);
tlsClientKeyPath
=
""
;
System
.
clearProperty
(
TLS_CLIENT_CERTPATH
);
tlsClientCertPath
=
""
;
}
else
if
(
"serverAcceptsUnAuthClient"
.
equals
(
name
.
getMethodName
()))
{
tlsMode
=
TlsMode
.
PERMISSIVE
;
tlsClientKeyPath
=
""
;
tlsClientCertPath
=
""
;
clientConfig
.
setUseTLS
(
false
);
}
else
if
(
"serverRejectsSSLClient"
.
equals
(
name
.
getMethodName
()))
{
tlsMode
=
TlsMode
.
DISABLED
;
}
}
remotingServer
=
RemotingServerTest
.
createRemotingServer
();
remotingServer
=
RemotingServerTest
.
createRemotingServer
();
...
@@ -118,6 +144,7 @@ public class TlsTest {
...
@@ -118,6 +144,7 @@ public class TlsTest {
public
void
tearDown
()
{
public
void
tearDown
()
{
remotingClient
.
shutdown
();
remotingClient
.
shutdown
();
remotingServer
.
shutdown
();
remotingServer
.
shutdown
();
tlsMode
=
TlsMode
.
PERMISSIVE
;
}
}
/**
/**
...
@@ -139,6 +166,20 @@ public class TlsTest {
...
@@ -139,6 +166,20 @@ public class TlsTest {
requestThenAssertResponse
();
requestThenAssertResponse
();
}
}
@Test
public
void
serverAcceptsUnAuthClient
()
throws
Exception
{
requestThenAssertResponse
();
}
@Test
public
void
serverRejectsSSLClient
()
throws
Exception
{
try
{
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
5
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
}
catch
(
RemotingSendRequestException
ignore
)
{
}
}
/**
/**
* Tests that a server configured to require client authentication refuses to accept connections
* Tests that a server configured to require client authentication refuses to accept connections
* from a client that has an untrusted certificate.
* from a client that has an untrusted certificate.
...
@@ -148,8 +189,7 @@ public class TlsTest {
...
@@ -148,8 +189,7 @@ public class TlsTest {
try
{
try
{
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
5
);
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
5
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
}
catch
(
RemotingSendRequestException
exception
)
{
}
catch
(
RemotingSendRequestException
ignore
)
{
assertThat
(
Throwables
.
getRootCause
(
exception
)).
isInstanceOf
(
SSLException
.
class
);
}
}
}
}
...
@@ -167,8 +207,7 @@ public class TlsTest {
...
@@ -167,8 +207,7 @@ public class TlsTest {
try
{
try
{
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
3
);
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
3
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
}
catch
(
RemotingSendRequestException
exception
)
{
}
catch
(
RemotingSendRequestException
ignore
)
{
assertThat
(
Throwables
.
getRootCause
(
exception
)).
isInstanceOf
(
SSLException
.
class
);
}
}
}
}
...
@@ -181,8 +220,7 @@ public class TlsTest {
...
@@ -181,8 +220,7 @@ public class TlsTest {
try
{
try
{
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
3
);
RemotingCommand
response
=
remotingClient
.
invokeSync
(
"localhost:8888"
,
createRequest
(),
1000
*
3
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
failBecauseExceptionWasNotThrown
(
RemotingSendRequestException
.
class
);
}
catch
(
RemotingSendRequestException
exception
)
{
}
catch
(
RemotingSendRequestException
ignore
)
{
assertThat
(
Throwables
.
getRootCause
(
exception
)).
isInstanceOf
(
SignatureException
.
class
);
}
}
}
}
...
@@ -191,6 +229,53 @@ public class TlsTest {
...
@@ -191,6 +229,53 @@ public class TlsTest {
requestThenAssertResponse
();
requestThenAssertResponse
();
}
}
@Test
public
void
testTlsConfigThroughFile
()
throws
Exception
{
File
file
=
tempFolder
.
newFile
(
"tls.config"
);
tlsTestModeEnable
=
true
;
tlsConfigFile
=
file
.
getAbsolutePath
();
StringBuilder
sb
=
new
StringBuilder
();
sb
.
append
(
TLS_SERVER_NEED_CLIENT_AUTH
+
"=require\n"
);
sb
.
append
(
TLS_SERVER_KEYPATH
+
"=/server.key\n"
);
sb
.
append
(
TLS_SERVER_CERTPATH
+
"=/server.pem\n"
);
sb
.
append
(
TLS_SERVER_KEYPASSWORD
+
"=2345\n"
);
sb
.
append
(
TLS_SERVER_AUTHCLIENT
+
"=true\n"
);
sb
.
append
(
TLS_SERVER_TRUSTCERTPATH
+
"=/ca.pem\n"
);
sb
.
append
(
TLS_CLIENT_KEYPATH
+
"=/client.key\n"
);
sb
.
append
(
TLS_CLIENT_KEYPASSWORD
+
"=1234\n"
);
sb
.
append
(
TLS_CLIENT_CERTPATH
+
"=/client.pem\n"
);
sb
.
append
(
TLS_CLIENT_AUTHSERVER
+
"=false\n"
);
sb
.
append
(
TLS_CLIENT_TRUSTCERTPATH
+
"=/ca.pem\n"
);
writeStringToFile
(
file
.
getAbsolutePath
(),
sb
.
toString
());
TlsHelper
.
buildSslContext
(
false
);
assertThat
(
tlsServerNeedClientAuth
).
isEqualTo
(
"require"
);
assertThat
(
tlsServerKeyPath
).
isEqualTo
(
"/server.key"
);
assertThat
(
tlsServerCertPath
).
isEqualTo
(
"/server.pem"
);
assertThat
(
tlsServerKeyPassword
).
isEqualTo
(
"2345"
);
assertThat
(
tlsServerAuthClient
).
isEqualTo
(
true
);
assertThat
(
tlsServerTrustCertPath
).
isEqualTo
(
"/ca.pem"
);
assertThat
(
tlsClientKeyPath
).
isEqualTo
(
"/client.key"
);
assertThat
(
tlsClientKeyPassword
).
isEqualTo
(
"1234"
);
assertThat
(
tlsClientCertPath
).
isEqualTo
(
"/client.pem"
);
assertThat
(
tlsClientAuthServer
).
isEqualTo
(
false
);
assertThat
(
tlsClientTrustCertPath
).
isEqualTo
(
"/ca.pem"
);
tlsConfigFile
=
"/notFound"
;
}
private
static
void
writeStringToFile
(
String
path
,
String
content
)
{
try
{
PrintWriter
out
=
new
PrintWriter
(
new
BufferedWriter
(
new
FileWriter
(
path
,
true
)));
out
.
println
(
content
);
out
.
close
();
}
catch
(
IOException
ignore
)
{
}
}
private
static
String
getCertsPath
(
String
fileName
)
{
private
static
String
getCertsPath
(
String
fileName
)
{
File
resourcesDirectory
=
new
File
(
"src/test/resources/certs"
);
File
resourcesDirectory
=
new
File
(
"src/test/resources/certs"
);
return
resourcesDirectory
.
getAbsolutePath
()
+
"/"
+
fileName
;
return
resourcesDirectory
.
getAbsolutePath
()
+
"/"
+
fileName
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录