Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
LinuxSuRen
jenkins
提交
4e9443d4
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,发现更多精彩内容 >>
提交
4e9443d4
编写于
8月 23, 2012
作者:
J
Jesse Glick
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' into Behaviour-specify-14495
上级
20a5daa3
d5e513e6
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
170 addition
and
42 deletion
+170
-42
core/src/main/java/hudson/cli/BuildCommand.java
core/src/main/java/hudson/cli/BuildCommand.java
+27
-1
core/src/main/java/hudson/cli/CreateJobCommand.java
core/src/main/java/hudson/cli/CreateJobCommand.java
+22
-2
core/src/main/java/hudson/init/InitStrategy.java
core/src/main/java/hudson/init/InitStrategy.java
+19
-5
core/src/main/java/jenkins/model/Jenkins.java
core/src/main/java/jenkins/model/Jenkins.java
+4
-29
core/src/main/java/jenkins/model/ModifiableTopLevelItemGroup.java
.../main/java/jenkins/model/ModifiableTopLevelItemGroup.java
+75
-0
test/pom.xml
test/pom.xml
+2
-0
test/src/main/java/org/jvnet/hudson/test/JellyTestSuiteBuilder.java
...ain/java/org/jvnet/hudson/test/JellyTestSuiteBuilder.java
+4
-4
test/src/test/groovy/hudson/cli/BuildCommandTest.groovy
test/src/test/groovy/hudson/cli/BuildCommandTest.groovy
+16
-0
war/pom.xml
war/pom.xml
+1
-1
未找到文件。
core/src/main/java/hudson/cli/BuildCommand.java
浏览文件 @
4e9443d4
...
...
@@ -48,6 +48,7 @@ import java.util.HashMap;
import
java.util.List
;
import
java.util.ArrayList
;
import
java.util.Map.Entry
;
import
java.io.FileNotFoundException
;
import
java.io.PrintStream
;
import
jenkins.model.Jenkins
;
...
...
@@ -82,6 +83,12 @@ public class BuildCommand extends CLICommand {
@Option
(
name
=
"-v"
,
usage
=
"Prints out the console output of the build. Use with -s"
)
public
boolean
consoleOutput
=
false
;
@Option
(
name
=
"-r"
,
usage
=
"Number of times to retry reading of the output log if it does not exists on first attempt. Defaults to 0. Use with -v."
)
public
String
retryCntStr
=
"0"
;
// hold parsed retryCnt;
private
int
retryCnt
=
0
;
protected
int
run
()
throws
Exception
{
job
.
checkPermission
(
Item
.
BUILD
);
...
...
@@ -114,6 +121,8 @@ public class BuildCommand extends CLICommand {
a
=
new
ParametersAction
(
values
);
}
retryCnt
=
Integer
.
parseInt
(
retryCntStr
);
if
(
checkSCM
)
{
if
(
job
.
poll
(
new
StreamTaskListener
(
stdout
,
getClientCharset
())).
change
==
Change
.
NONE
)
{
return
0
;
...
...
@@ -128,7 +137,24 @@ public class BuildCommand extends CLICommand {
if
(
sync
)
{
if
(
consoleOutput
)
{
b
.
writeWholeLogTo
(
stdout
);
// read output in a retry loop, by default try only once
// writeWholeLogTo may fail with FileNotFound
// exception on a slow/busy machine, if it takes
// longish to create the log file
int
retryInterval
=
100
;
for
(
int
i
=
0
;
i
<=
retryCnt
;)
{
try
{
b
.
writeWholeLogTo
(
stdout
);
break
;
}
catch
(
FileNotFoundException
e
)
{
if
(
i
==
retryCnt
)
{
throw
e
;
}
i
++;
Thread
.
sleep
(
retryInterval
);
}
}
}
// TODO: should we abort the build if the CLI is cancelled?
f
.
get
();
// wait for the completion
...
...
core/src/main/java/hudson/cli/CreateJobCommand.java
浏览文件 @
4e9443d4
...
...
@@ -23,9 +23,12 @@
*/
package
hudson.cli
;
import
hudson.model.ModifiableItemGroup
;
import
hudson.model.TopLevelItem
;
import
jenkins.model.Jenkins
;
import
hudson.Extension
;
import
hudson.model.Item
;
import
jenkins.model.ModifiableTopLevelItemGroup
;
import
org.kohsuke.args4j.Argument
;
/**
...
...
@@ -47,12 +50,29 @@ public class CreateJobCommand extends CLICommand {
Jenkins
h
=
Jenkins
.
getInstance
();
h
.
checkPermission
(
Item
.
CREATE
);
if
(
h
.
getItem
(
name
)!=
null
)
{
if
(
h
.
getItem
ByFullName
(
name
)!=
null
)
{
stderr
.
println
(
"Job '"
+
name
+
"' already exists"
);
return
-
1
;
}
h
.
createProjectFromXML
(
name
,
stdin
);
ModifiableTopLevelItemGroup
ig
=
h
;
int
i
=
name
.
lastIndexOf
(
'/'
);
if
(
i
>
0
)
{
String
group
=
name
.
substring
(
0
,
i
);
Item
item
=
h
.
getItemByFullName
(
group
);
if
(
item
==
null
)
{
throw
new
IllegalArgumentException
(
"Unknown ItemGroup "
+
group
);
}
if
(
item
instanceof
ModifiableTopLevelItemGroup
)
{
ig
=
(
ModifiableTopLevelItemGroup
)
item
;
}
else
{
throw
new
IllegalArgumentException
(
"Can't create job from CLI in "
+
group
);
}
name
=
name
.
substring
(
i
+
1
);
}
ig
.
createProjectFromXML
(
name
,
stdin
);
return
0
;
}
}
...
...
core/src/main/java/hudson/init/InitStrategy.java
浏览文件 @
4e9443d4
...
...
@@ -10,9 +10,12 @@ import java.util.Collection;
import
java.util.List
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.logging.Level
;
import
java.util.logging.Logger
;
import
hudson.PluginManager
;
import
hudson.util.DirScanner
;
import
hudson.util.FileVisitor
;
import
hudson.util.Service
;
/**
...
...
@@ -65,20 +68,31 @@ public class InitStrategy {
}
/**
* Lists up additional bundled plugins from the system property.
*
* Lists up additional bundled plugins from the system property
{@code hudson.bundled.plugins}
.
*
Since 1.480 glob syntax is supported.
* For use in the "mvn hudson-dev:run".
* TODO: maven-hpi-plugin should inject its own InitStrategy instead of having this in the core.
*/
protected
void
getBundledPluginsFromProperty
(
List
<
File
>
r
)
{
protected
void
getBundledPluginsFromProperty
(
final
List
<
File
>
r
)
{
String
hplProperty
=
System
.
getProperty
(
"hudson.bundled.plugins"
);
if
(
hplProperty
!=
null
)
{
for
(
String
hplLocation
:
hplProperty
.
split
(
","
))
{
File
hpl
=
new
File
(
hplLocation
.
trim
());
if
(
hpl
.
exists
())
if
(
hpl
.
exists
())
{
r
.
add
(
hpl
);
else
}
else
if
(
hpl
.
getName
().
contains
(
"*"
))
{
try
{
new
DirScanner
.
Glob
(
hpl
.
getName
(),
null
).
scan
(
hpl
.
getParentFile
(),
new
FileVisitor
()
{
@Override
public
void
visit
(
File
f
,
String
relativePath
)
throws
IOException
{
r
.
add
(
f
);
}
});
}
catch
(
IOException
x
)
{
LOGGER
.
log
(
Level
.
WARNING
,
"could not expand "
+
hplLocation
,
x
);
}
}
else
{
LOGGER
.
warning
(
"bundled plugin "
+
hplLocation
+
" does not exist"
);
}
}
}
}
...
...
core/src/main/java/jenkins/model/Jenkins.java
浏览文件 @
4e9443d4
...
...
@@ -306,7 +306,7 @@ import javax.annotation.CheckForNull;
* @author Kohsuke Kawaguchi
*/
@ExportedBean
public
class
Jenkins
extends
AbstractCIBase
implements
Modifiable
ItemGroup
<
TopLevelItem
>
,
StaplerProxy
,
StaplerFallback
,
ViewGroup
,
AccessControlled
,
DescriptorByNameOwner
,
ModelObjectWithContextMenu
{
public
class
Jenkins
extends
AbstractCIBase
implements
Modifiable
TopLevelItemGroup
,
StaplerProxy
,
StaplerFallback
,
ViewGroup
,
AccessControlled
,
DescriptorByNameOwner
,
ModelObjectWithContextMenu
{
private
transient
final
Queue
queue
;
/**
...
...
@@ -2259,7 +2259,7 @@ public class Jenkins extends AbstractCIBase implements ModifiableItemGroup<TopLe
* null if either such {@link Item} doesn't exist under the given full name,
* or it exists but it's no an instance of the given type.
*/
public
<
T
extends
Item
>
T
getItemByFullName
(
String
fullName
,
Class
<
T
>
type
)
{
public
@CheckForNull
<
T
extends
Item
>
T
getItemByFullName
(
String
fullName
,
Class
<
T
>
type
)
{
StringTokenizer
tokens
=
new
StringTokenizer
(
fullName
,
"/"
);
ItemGroup
parent
=
this
;
...
...
@@ -2284,7 +2284,7 @@ public class Jenkins extends AbstractCIBase implements ModifiableItemGroup<TopLe
}
}
public
Item
getItemByFullName
(
String
fullName
)
{
public
@CheckForNull
Item
getItemByFullName
(
String
fullName
)
{
return
getItemByFullName
(
fullName
,
Item
.
class
);
}
...
...
@@ -2298,24 +2298,10 @@ public class Jenkins extends AbstractCIBase implements ModifiableItemGroup<TopLe
return
User
.
get
(
name
,
hasPermission
(
ADMINISTER
));
}
/**
* Creates a new job.
*
* @throws IllegalArgumentException
* if the project of the given name already exists.
*/
public
synchronized
TopLevelItem
createProject
(
TopLevelItemDescriptor
type
,
String
name
)
throws
IOException
{
return
createProject
(
type
,
name
,
true
);
}
/**
* Creates a new job.
* @param type Descriptor for job type
* @param name Name for job
* @param notify Whether to fire onCreated method for all ItemListeners
* @throws IllegalArgumentException
* if a project of the give name already exists.
*/
public
synchronized
TopLevelItem
createProject
(
TopLevelItemDescriptor
type
,
String
name
,
boolean
notify
)
throws
IOException
{
return
itemGroupMixIn
.
createProject
(
type
,
name
,
notify
);
}
...
...
@@ -2805,24 +2791,13 @@ public class Jenkins extends AbstractCIBase implements ModifiableItemGroup<TopLe
}
/**
* Creates a new job from its configuration XML. The type of the job created will be determined by
* what's in this XML.
* @since 1.319
*/
public
TopLevelItem
createProjectFromXML
(
String
name
,
InputStream
xml
)
throws
IOException
{
return
itemGroupMixIn
.
createProjectFromXML
(
name
,
xml
);
}
/**
* Copys a job.
*
* @param src
* A {@link TopLevelItem} to be copied.
* @param name
* Name of the newly created project.
* @return
* Newly created {@link TopLevelItem}.
*/
@SuppressWarnings
({
"unchecked"
})
public
<
T
extends
TopLevelItem
>
T
copy
(
T
src
,
String
name
)
throws
IOException
{
return
itemGroupMixIn
.
copy
(
src
,
name
);
...
...
core/src/main/java/jenkins/model/ModifiableTopLevelItemGroup.java
0 → 100644
浏览文件 @
4e9443d4
/*
* The MIT License
*
* Copyright (c) 2011, CloudBees, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package
jenkins.model
;
import
hudson.model.ModifiableItemGroup
;
import
hudson.model.TopLevelItem
;
import
hudson.model.TopLevelItemDescriptor
;
import
java.io.IOException
;
import
java.io.InputStream
;
/**
* A {@link hudson.model.ModifiableItemGroup} to manage {@link hudson.model.TopLevelItem},
* including copying, creating from descriptor and from XML.
*
* @author <a href="mailto:nicolas.deloof@gmail.com">Nicolas De Loof</a>
*/
public
interface
ModifiableTopLevelItemGroup
extends
ModifiableItemGroup
<
TopLevelItem
>
{
/**
* Copys a job.
*
* @param src
* A {@link TopLevelItem} to be copied.
* @param name
* Name of the newly created project.
* @return
* Newly created {@link TopLevelItem}.
*/
<
T
extends
TopLevelItem
>
T
copy
(
T
src
,
String
name
)
throws
IOException
;
/**
* /**
* Creates a new job from its configuration XML. The type of the job created will be determined by
* what's in this XML.
* @param name
* Name of the newly created project.
* @param xml
* Item configuration as xml
* @return
* Newly created {@link TopLevelItem}.
*/
TopLevelItem
createProjectFromXML
(
String
name
,
InputStream
xml
)
throws
IOException
;
/**
* Creates a new job.
* @param type Descriptor for job type
* @param name Name for job
* @param notify Whether to fire onCreated method for all ItemListeners
* @throws IllegalArgumentException
* if a project of the give name already exists.
*/
TopLevelItem
createProject
(
TopLevelItemDescriptor
type
,
String
name
,
boolean
notify
)
throws
IOException
;
}
test/pom.xml
浏览文件 @
4e9443d4
...
...
@@ -234,6 +234,7 @@ THE SOFTWARE.
<skip>
false
</skip>
<includes>
<include>
**/UseRecipesWithJenkinsRuleTest.java
</include>
<include>
hudson/model/CauseTest.java
</include>
</includes>
</configuration>
</plugin>
...
...
@@ -277,6 +278,7 @@ THE SOFTWARE.
</systemProperties>
<excludes>
<exclude>
org/jvnet/hudson/main/UseRecipesWithJenkinsRuleTest.class
</exclude>
<exclude>
hudson/model/CauseTest.java
</exclude>
</excludes>
</configuration>
</execution>
...
...
test/src/main/java/org/jvnet/hudson/test/JellyTestSuiteBuilder.java
浏览文件 @
4e9443d4
...
...
@@ -59,7 +59,7 @@ public class JellyTestSuiteBuilder {
if
(
res
.
isDirectory
())
{
for
(
final
File
jelly
:
(
Collection
<
File
>)
FileUtils
.
listFiles
(
res
,
new
String
[]{
"jelly"
},
true
))
ts
.
addTest
(
new
JellyCheck
(
jelly
.
toURI
().
toURL
(),
jct
,
requirePI
));
ts
.
addTest
(
new
JellyCheck
(
jelly
.
toURI
().
toURL
(),
j
elly
.
getAbsolutePath
().
substring
(
0
,
(
res
.
getAbsolutePath
()
+
File
.
separator
).
length
()),
j
ct
,
requirePI
));
}
if
(
res
.
getName
().
endsWith
(
".jar"
))
{
String
jarUrl
=
res
.
toURI
().
toURL
().
toExternalForm
();
...
...
@@ -68,7 +68,7 @@ public class JellyTestSuiteBuilder {
while
(
e
.
hasMoreElements
())
{
JarEntry
ent
=
e
.
nextElement
();
if
(
ent
.
getName
().
endsWith
(
".jelly"
))
ts
.
addTest
(
new
JellyCheck
(
new
URL
(
"jar:"
+
jarUrl
+
"!/"
+
ent
.
getName
()),
jct
,
requirePI
));
ts
.
addTest
(
new
JellyCheck
(
new
URL
(
"jar:"
+
jarUrl
+
"!/"
+
ent
.
getName
()),
ent
.
getName
(),
jct
,
requirePI
));
}
jf
.
close
();
}
...
...
@@ -80,8 +80,8 @@ public class JellyTestSuiteBuilder {
private
final
JellyClassLoaderTearOff
jct
;
private
final
boolean
requirePI
;
public
JellyCheck
(
URL
jelly
,
JellyClassLoaderTearOff
jct
,
boolean
requirePI
)
{
super
(
jelly
.
getPath
()
);
JellyCheck
(
URL
jelly
,
String
name
,
JellyClassLoaderTearOff
jct
,
boolean
requirePI
)
{
super
(
name
);
this
.
jelly
=
jelly
;
this
.
jct
=
jct
;
this
.
requirePI
=
requirePI
;
...
...
test/src/test/groovy/hudson/cli/BuildCommandTest.groovy
浏览文件 @
4e9443d4
...
...
@@ -84,6 +84,22 @@ public class BuildCommandTest extends HudsonTestCase {
}
/**
* Tests synchronous execution with retried verbose output
*/
void
testSyncWOutputStreaming
()
{
def
p
=
createFreeStyleProject
();
p
.
buildersList
.
add
(
new
Shell
(
"sleep 3"
));
def
cli
=
new
CLI
(
getURL
())
try
{
cli
.
execute
([
"build"
,
"-s"
,
"-v"
,
"-r"
,
"5"
,
p
.
name
])
assertFalse
(
p
.
getBuildByNumber
(
1
).
isBuilding
())
}
finally
{
cli
.
close
();
}
}
void
testParameters
()
{
def
p
=
createFreeStyleProject
();
p
.
addProperty
(
new
ParametersDefinitionProperty
([
new
StringParameterDefinition
(
"key"
,
null
)]));
...
...
war/pom.xml
浏览文件 @
4e9443d4
...
...
@@ -420,7 +420,7 @@ THE SOFTWARE.
<value>
<!-- run "mvn install" once will generate the.hpl -->
${basedir}/../maven-plugin/target/test-classes/the.hpl,
${basedir}/../ui-samples-plugin/target/test-classes/the.hpl,
${project.build.directory}/${project.build.finalName}/WEB-INF/plugins/
javadoc
.hpi
${project.build.directory}/${project.build.finalName}/WEB-INF/plugins/
*
.hpi
</value>
</systemProperty>
<systemProperty>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录