Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
jenkins
提交
d506b32f
J
jenkins
项目概览
xxadev
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
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,发现更多精彩内容 >>
提交
d506b32f
编写于
1月 31, 2013
作者:
J
Jesse Glick
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[FIXED JENKINS-15747] Avoid recording too many upstream causes at any depth.
上级
9e58d944
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
41 addition
and
3 deletion
+41
-3
changelog.html
changelog.html
+3
-0
core/src/main/java/hudson/model/Cause.java
core/src/main/java/hudson/model/Cause.java
+13
-3
test/src/test/java/hudson/model/CauseTest.java
test/src/test/java/hudson/model/CauseTest.java
+25
-0
未找到文件。
changelog.html
浏览文件 @
d506b32f
...
...
@@ -67,6 +67,9 @@ Upcoming changes</a>
<li
class=
bug
>
Plugin icons in the sidebar were not being properly cached.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-16530"
>
issue 16530
</a>
)
<li
class=
'major bug'
>
Broadly as well as deeply nested build causes overwhelmed the UI after 1.482.
(
<a
href=
"https://issues.jenkins-ci.org/browse/JENKINS-15747"
>
issue 15747
</a>
)
<li
class=
bug
>
API typo
<code>
DependecyDeclarer
</code>
corrected.
<li
class=
bug
>
...
...
core/src/main/java/hudson/model/Cause.java
浏览文件 @
d506b32f
...
...
@@ -34,6 +34,7 @@ import jenkins.model.Jenkins;
import
org.kohsuke.stapler.export.Exported
;
import
org.kohsuke.stapler.export.ExportedBean
;
import
com.thoughtworks.xstream.converters.UnmarshallingContext
;
import
java.util.concurrent.atomic.AtomicInteger
;
import
javax.annotation.Nonnull
;
/**
...
...
@@ -106,6 +107,10 @@ public abstract class Cause {
* Maximum depth of transitive upstream causes we want to record.
*/
private
static
final
int
MAX_DEPTH
=
10
;
/**
* Maximum number of transitive upstream causes we want to record.
*/
private
static
final
int
MAX_LEAF
=
25
;
private
String
upstreamProject
,
upstreamUrl
;
private
int
upstreamBuild
;
/**
...
...
@@ -128,8 +133,9 @@ public abstract class Cause {
upstreamProject
=
up
.
getParent
().
getFullName
();
upstreamUrl
=
up
.
getParent
().
getUrl
();
upstreamCauses
=
new
ArrayList
<
Cause
>();
AtomicInteger
leaf
=
new
AtomicInteger
(
MAX_LEAF
);
for
(
Cause
c
:
up
.
getCauses
())
{
upstreamCauses
.
add
(
trim
(
c
,
MAX_DEPTH
));
upstreamCauses
.
add
(
trim
(
c
,
MAX_DEPTH
,
leaf
));
}
}
...
...
@@ -140,7 +146,7 @@ public abstract class Cause {
this
.
upstreamCauses
=
upstreamCauses
;
}
private
@Nonnull
Cause
trim
(
@Nonnull
Cause
c
,
int
depth
)
{
private
@Nonnull
Cause
trim
(
@Nonnull
Cause
c
,
int
depth
,
AtomicInteger
leaf
)
{
if
(!(
c
instanceof
UpstreamCause
))
{
return
c
;
}
...
...
@@ -148,7 +154,11 @@ public abstract class Cause {
List
<
Cause
>
cs
=
new
ArrayList
<
Cause
>();
if
(
depth
>
0
)
{
for
(
Cause
c2
:
uc
.
upstreamCauses
)
{
cs
.
add
(
trim
(
c2
,
depth
-
1
));
if
(
leaf
.
decrementAndGet
()
>
0
)
{
cs
.
add
(
trim
(
c2
,
depth
-
1
,
leaf
));
}
else
{
cs
.
add
(
new
DeeplyNestedUpstreamCause
());
}
}
}
else
{
cs
.
add
(
new
DeeplyNestedUpstreamCause
());
...
...
test/src/test/java/hudson/model/CauseTest.java
浏览文件 @
d506b32f
...
...
@@ -26,6 +26,8 @@ package hudson.model;
import
hudson.XmlFile
;
import
java.io.File
;
import
java.util.concurrent.Future
;
import
java.util.regex.Pattern
;
import
static
org
.
junit
.
Assert
.*;
import
org.junit.Rule
;
import
org.junit.Test
;
...
...
@@ -54,4 +56,27 @@ public class CauseTest {
assertFalse
(
"too big:\n"
+
buildXml
,
buildXml
.
contains
(
"<upstreamBuild>1</upstreamBuild>"
));
}
@Bug
(
15747
)
@Test
public
void
broadlyNestedCauses
()
throws
Exception
{
FreeStyleProject
a
=
j
.
createFreeStyleProject
(
"a"
);
FreeStyleProject
b
=
j
.
createFreeStyleProject
(
"b"
);
FreeStyleProject
c
=
j
.
createFreeStyleProject
(
"c"
);
Run
<?,?>
last
=
null
;
for
(
int
i
=
1
;
i
<=
10
;
i
++)
{
Cause
cause
=
last
==
null
?
null
:
new
Cause
.
UpstreamCause
(
last
);
Future
<?
extends
Run
<?,?>>
next1
=
a
.
scheduleBuild2
(
0
,
cause
);
a
.
scheduleBuild2
(
0
,
cause
);
cause
=
new
Cause
.
UpstreamCause
(
next1
.
get
());
Future
<?
extends
Run
<?,?>>
next2
=
b
.
scheduleBuild2
(
0
,
cause
);
b
.
scheduleBuild2
(
0
,
cause
);
cause
=
new
Cause
.
UpstreamCause
(
next2
.
get
());
Future
<?
extends
Run
<?,?>>
next3
=
c
.
scheduleBuild2
(
0
,
cause
);
c
.
scheduleBuild2
(
0
,
cause
);
last
=
next3
.
get
();
}
int
count
=
new
XmlFile
(
Run
.
XSTREAM
,
new
File
(
last
.
getRootDir
(),
"build.xml"
)).
asString
().
split
(
Pattern
.
quote
(
"<hudson.model.Cause_-UpstreamCause"
)).
length
;
assertFalse
(
"too big at "
+
count
,
count
>
100
);
//j.interactiveBreak();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录