Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
LinuxSuRen
jenkins
提交
bdfbf251
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,发现更多精彩内容 >>
提交
bdfbf251
编写于
4月 19, 2014
作者:
K
Kohsuke Kawaguchi
浏览文件
操作
浏览文件
下载
差异文件
[FIXED JENKINS-20857] Merged pull request 1060
上级
f1c70147
d8b72b09
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
40 addition
and
7 deletion
+40
-7
changelog.html
changelog.html
+3
-0
core/src/main/java/hudson/model/RunParameterValue.java
core/src/main/java/hudson/model/RunParameterValue.java
+13
-7
test/src/test/java/hudson/model/RunParameterDefinitionTest.java
...rc/test/java/hudson/model/RunParameterDefinitionTest.java
+24
-0
未找到文件。
changelog.html
浏览文件 @
bdfbf251
...
...
@@ -55,6 +55,9 @@ Upcoming changes</a>
<!-- Record your changes in the trunk here. -->
<div
id=
"trunk"
style=
"display:none"
>
<!--=TRUNK-BEGIN=-->
<ul
class=
image
>
<li
class=
bug
>
Fixed NPE if
<tt>
RunParameterValue
</tt>
points to a stable build.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-20857"
>
issue 20857
</a>
)
<li
class=
bug
>
Fixed a JavaScript problem in sortable table with IE8.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-21729"
>
issue 21729
</a>
)
...
...
core/src/main/java/hudson/model/RunParameterValue.java
浏览文件 @
bdfbf251
...
...
@@ -23,13 +23,14 @@
*/
package
hudson.model
;
import
java.util.Locale
;
import
hudson.EnvVars
;
import
jenkins.model.Jenkins
;
import
org.kohsuke.stapler.DataBoundConstructor
;
import
org.kohsuke.stapler.export.Exported
;
import
javax.annotation.CheckForNull
;
import
java.util.Locale
;
public
class
RunParameterValue
extends
ParameterValue
{
private
final
String
runId
;
...
...
@@ -45,7 +46,10 @@ public class RunParameterValue extends ParameterValue {
this
.
runId
=
runId
;
}
public
Run
getRun
()
{
/**
* Can be null if the {@link Run} that this was pointing to no longer exists.
*/
public
@CheckForNull
Run
getRun
()
{
return
Run
.
fromExternalizableId
(
runId
);
}
...
...
@@ -71,7 +75,7 @@ public class RunParameterValue extends ParameterValue {
public
void
buildEnvironment
(
Run
<?,?>
build
,
EnvVars
env
)
{
Run
run
=
getRun
();
String
value
=
Jenkins
.
getInstance
().
getRootUrl
()
+
run
.
getUrl
();
String
value
=
(
null
==
run
)
?
"UNKNOWN"
:
Jenkins
.
getInstance
().
getRootUrl
()
+
run
.
getUrl
();
env
.
put
(
name
,
value
);
env
.
put
(
name
+
".jobName"
,
getJobName
());
// undocumented, left for backward compatibility
...
...
@@ -80,9 +84,10 @@ public class RunParameterValue extends ParameterValue {
env
.
put
(
name
+
".number"
,
getNumber
());
// same as above
env
.
put
(
name
+
"_NUMBER"
,
getNumber
());
env
.
put
(
name
+
"_NAME"
,
run
.
getDisplayName
());
// since 1.504
// if run is null, default to the standard '#1' display name format
env
.
put
(
name
+
"_NAME"
,
(
null
==
run
)
?
"#"
+
getNumber
()
:
run
.
getDisplayName
());
// since 1.504
String
buildResult
=
(
null
==
run
.
getResult
())
?
"UNKNOWN"
:
run
.
getResult
().
toString
();
String
buildResult
=
(
null
==
run
||
null
==
run
.
getResult
())
?
"UNKNOWN"
:
run
.
getResult
().
toString
();
env
.
put
(
name
+
"_RESULT"
,
buildResult
);
// since 1.517
env
.
put
(
name
.
toUpperCase
(
Locale
.
ENGLISH
),
value
);
// backward compatibility pre 1.345
...
...
@@ -95,7 +100,8 @@ public class RunParameterValue extends ParameterValue {
}
@Override
public
String
getShortDescription
()
{
return
name
+
"="
+
getRun
().
getFullDisplayName
();
Run
run
=
getRun
();
return
name
+
"="
+
((
null
==
run
)
?
getJobName
()
+
" #"
+
getNumber
()
:
run
.
getFullDisplayName
());
}
}
test/src/test/java/hudson/model/RunParameterDefinitionTest.java
浏览文件 @
bdfbf251
...
...
@@ -236,6 +236,30 @@ public class RunParameterDefinitionTest {
}
@Test
public
void
testLoadEnvironmentVariablesWhenRunParameterJobHasBeenDeleted
()
throws
Exception
{
FreeStyleProject
project
=
j
.
createFreeStyleProject
(
"project"
);
FreeStyleBuild
successfulBuild
=
project
.
scheduleBuild2
(
0
).
get
();
FreeStyleProject
paramProject
=
j
.
createFreeStyleProject
(
"paramProject"
);
ParametersDefinitionProperty
pdp
=
new
ParametersDefinitionProperty
(
new
RunParameterDefinition
(
"RUN"
,
project
.
getName
(),
"run description"
,
RunParameterFilter
.
ALL
));
paramProject
.
addProperty
(
pdp
);
FreeStyleBuild
build
=
paramProject
.
scheduleBuild2
(
0
).
get
();
assertEquals
(
Integer
.
toString
(
project
.
getLastBuild
().
getNumber
()),
build
.
getEnvironment
(
new
LogTaskListener
(
LOGGER
,
Level
.
INFO
)).
get
(
"RUN_NUMBER"
));
successfulBuild
.
delete
();
// We should still be able to retrieve non RunParameter environment variables for the parameterized build
// even when the selected RunParameter build has been deleted.
assertEquals
(
"paramProject"
,
build
.
getEnvironment
(
new
LogTaskListener
(
LOGGER
,
Level
.
INFO
)).
get
(
"JOB_NAME"
));
}
static
class
ResultPublisher
extends
Publisher
{
private
final
Result
result
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录