Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
jenkins
提交
98ad8e4d
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,发现更多精彩内容 >>
提交
98ad8e4d
编写于
4月 08, 2017
作者:
D
Daniel Beck
提交者:
GitHub
4月 08, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2824 from daniel-beck/JENKINS-43228
[FIX JENKINS-43228] Consider time zone for cron validation
上级
72901698
a34479c4
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
38 addition
and
2 deletion
+38
-2
core/src/main/java/hudson/scheduler/CronTab.java
core/src/main/java/hudson/scheduler/CronTab.java
+13
-0
core/src/main/java/hudson/scheduler/CronTabList.java
core/src/main/java/hudson/scheduler/CronTabList.java
+2
-2
core/src/test/java/hudson/triggers/TimerTriggerTest.java
core/src/test/java/hudson/triggers/TimerTriggerTest.java
+23
-0
未找到文件。
core/src/main/java/hudson/scheduler/CronTab.java
浏览文件 @
98ad8e4d
...
...
@@ -532,4 +532,17 @@ public final class CronTab {
return
null
;
}
}
/**
* Returns the configured time zone, or null if none is configured
*
* @return the configured time zone, or null if none is configured
* @since TODO
*/
@CheckForNull
public
TimeZone
getTimeZone
()
{
if
(
this
.
specTimezone
==
null
)
{
return
null
;
}
return
TimeZone
.
getTimeZone
(
this
.
specTimezone
);
}
}
core/src/main/java/hudson/scheduler/CronTabList.java
浏览文件 @
98ad8e4d
...
...
@@ -131,7 +131,7 @@ public final class CronTabList {
public
@CheckForNull
Calendar
previous
()
{
Calendar
nearest
=
null
;
for
(
CronTab
tab
:
tabs
)
{
Calendar
scheduled
=
tab
.
floor
(
Calendar
.
getInstance
(
));
Calendar
scheduled
=
tab
.
floor
(
tab
.
getTimeZone
()
==
null
?
Calendar
.
getInstance
()
:
Calendar
.
getInstance
(
tab
.
getTimeZone
()
));
if
(
nearest
==
null
||
nearest
.
before
(
scheduled
))
{
nearest
=
scheduled
;
}
...
...
@@ -143,7 +143,7 @@ public final class CronTabList {
public
@CheckForNull
Calendar
next
()
{
Calendar
nearest
=
null
;
for
(
CronTab
tab
:
tabs
)
{
Calendar
scheduled
=
tab
.
ceil
(
Calendar
.
getInstance
(
));
Calendar
scheduled
=
tab
.
ceil
(
tab
.
getTimeZone
()
==
null
?
Calendar
.
getInstance
()
:
Calendar
.
getInstance
(
tab
.
getTimeZone
()
));
if
(
nearest
==
null
||
nearest
.
after
(
scheduled
))
{
nearest
=
scheduled
;
}
...
...
core/src/test/java/hudson/triggers/TimerTriggerTest.java
浏览文件 @
98ad8e4d
...
...
@@ -24,9 +24,14 @@
package
hudson.triggers
;
import
antlr.ANTLRException
;
import
hudson.scheduler.CronTabList
;
import
hudson.scheduler.Hash
;
import
org.junit.Assert
;
import
org.junit.Test
;
import
org.jvnet.hudson.test.Issue
;
import
java.util.TimeZone
;
/**
* @author Kanstantsin Shautsou
*/
...
...
@@ -36,4 +41,22 @@ public class TimerTriggerTest {
public
void
testNoNPE
()
throws
ANTLRException
{
new
TimerTrigger
(
""
).
run
();
}
@Issue
(
"JENKINS-43328"
)
@Test
public
void
testTimeZoneOffset
()
throws
Exception
{
TimeZone
defaultTz
=
TimeZone
.
getDefault
();
TimeZone
.
setDefault
(
TimeZone
.
getTimeZone
(
"Europe/Berlin"
));
try
{
String
cron
=
"TZ=GMT\nH 0 * * *"
;
CronTabList
ctl
=
CronTabList
.
create
(
cron
,
Hash
.
from
(
"whatever"
));
Assert
.
assertEquals
(
"previous occurrence is in GMT"
,
"GMT"
,
ctl
.
previous
().
getTimeZone
().
getID
());
cron
=
"TZ=America/Denver\nH 0 * * *"
;
ctl
=
CronTabList
.
create
(
cron
,
Hash
.
from
(
"whatever"
));
Assert
.
assertEquals
(
"next occurrence is in America/Denver"
,
"America/Denver"
,
ctl
.
next
().
getTimeZone
().
getID
());
}
finally
{
TimeZone
.
setDefault
(
defaultTz
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录