Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
LinuxSuRen
jenkins
提交
4378e878
J
jenkins
项目概览
LinuxSuRen
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4378e878
编写于
2月 09, 2012
作者:
K
Kohsuke Kawaguchi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[FIXED JENKINS-12680] the onOffline method wasn't called for abrupt client termination
上级
482b4333
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
26 addition
and
5 deletion
+26
-5
changelog.html
changelog.html
+4
-1
core/src/main/java/hudson/slaves/SlaveComputer.java
core/src/main/java/hudson/slaves/SlaveComputer.java
+4
-4
test/src/test/java/hudson/slaves/JNLPLauncherTest.java
test/src/test/java/hudson/slaves/JNLPLauncherTest.java
+18
-0
未找到文件。
changelog.html
浏览文件 @
4378e878
...
...
@@ -93,7 +93,10 @@ Upcoming changes</a>
<li
class=
bug
>
Fixed a bug in LDAP default root DN inference.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-8152"
>
issue 8152
</a>
)
<li
class=
rfe
>
<li
class=
bug
>
<tt>
ComputerListener.onOffline
</tt>
was not called when the client was terminated abruptly.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-12680"
>
issue 12680
</a>
)
<li
class=
ref
>
CLI now supports also encrypted key file
<li
class=
rfe
>
Recognize test results from eviware:maven-soapui-plugin.
...
...
core/src/main/java/hudson/slaves/SlaveComputer.java
浏览文件 @
4378e878
...
...
@@ -329,14 +329,14 @@ public class SlaveComputer extends Computer {
channel
.
addListener
(
new
Channel
.
Listener
()
{
@Override
public
void
onClosed
(
Channel
c
,
IOException
cause
)
{
SlaveComputer
.
this
.
channel
=
null
;
// Orderly shutdown will have null exception
if
(
cause
!=
null
)
{
offlineCause
=
new
ChannelTermination
(
cause
);
cause
.
printStackTrace
(
taskListener
.
error
(
"Connection terminated"
));
cause
.
printStackTrace
(
taskListener
.
error
(
"Connection terminated"
));
}
else
{
taskListener
.
getLogger
().
println
(
"Connection terminated"
);
}
closeChannel
();
launcher
.
afterDisconnect
(
SlaveComputer
.
this
,
taskListener
);
}
});
...
...
@@ -501,9 +501,9 @@ public class SlaveComputer extends Computer {
}
catch
(
IOException
e
)
{
logger
.
log
(
Level
.
SEVERE
,
"Failed to terminate channel to "
+
getDisplayName
(),
e
);
}
for
(
ComputerListener
cl
:
ComputerListener
.
all
())
cl
.
onOffline
(
this
);
}
for
(
ComputerListener
cl
:
ComputerListener
.
all
())
cl
.
onOffline
(
this
);
}
@Override
...
...
test/src/test/java/hudson/slaves/JNLPLauncherTest.java
浏览文件 @
4378e878
...
...
@@ -31,13 +31,17 @@ import hudson.model.Computer;
import
hudson.model.Node
;
import
hudson.model.Node.Mode
;
import
hudson.model.Slave
;
import
hudson.model.TaskListener
;
import
hudson.remoting.Callable
;
import
hudson.remoting.Which
;
import
hudson.util.ArgumentListBuilder
;
import
org.jvnet.hudson.test.HudsonTestCase
;
import
org.jvnet.hudson.test.TestExtension
;
import
javax.inject.Inject
;
import
java.io.File
;
import
java.io.IOException
;
import
java.net.URL
;
import
java.util.ArrayList
;
import
java.util.List
;
...
...
@@ -69,8 +73,22 @@ public class JNLPLauncherTest extends HudsonTestCase {
public
void
testHeadlessLaunch
()
throws
Exception
{
Computer
c
=
addTestSlave
();
launchJnlpAndVerify
(
c
,
buildJnlpArgs
(
c
).
add
(
"-arg"
,
"-headless"
));
// make sure that onOffline gets called just the right number of times
assertEquals
(
1
,
ComputerListener
.
all
().
get
(
ListenerImpl
.
class
).
offlined
);
}
@TestExtension
public
static
class
ListenerImpl
extends
ComputerListener
{
int
offlined
=
0
;
@Override
public
void
onOffline
(
Computer
c
)
{
offlined
++;
assertTrue
(
c
.
isOffline
());
}
}
private
ArgumentListBuilder
buildJnlpArgs
(
Computer
c
)
throws
Exception
{
ArgumentListBuilder
args
=
new
ArgumentListBuilder
();
args
.
add
(
new
File
(
new
File
(
System
.
getProperty
(
"java.home"
)),
"bin/java"
).
getPath
(),
"-jar"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录