Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Jenkins 中文社区
jenkins-cli
提交
21db67a3
J
jenkins-cli
项目概览
Jenkins 中文社区
/
jenkins-cli
通知
49
Star
8
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins-cli
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
21db67a3
编写于
11月 06, 2019
作者:
LinuxSuRen
提交者:
GitHub
11月 06, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #228 from LinuxSuRen/job-history-test
Add test cases for job history
上级
9603a61f
bf4d5173
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
183 addition
and
82 deletion
+183
-82
app/cmd/job_history.go
app/cmd/job_history.go
+22
-22
app/cmd/job_history_test.go
app/cmd/job_history_test.go
+76
-0
app/cmd/job_param.go
app/cmd/job_param.go
+1
-5
app/cmd/user_delete.go
app/cmd/user_delete.go
+3
-3
client/job.go
client/job.go
+9
-29
client/job_test.go
client/job_test.go
+16
-12
client/job_test_common.go
client/job_test_common.go
+56
-11
未找到文件。
app/cmd/job_history.go
浏览文件 @
21db67a3
package
cmd
import
(
"bytes"
"fmt"
"log"
"os"
"github.com/jenkins-zh/jenkins-cli/app/helper"
"github.com/jenkins-zh/jenkins-cli/client"
"github.com/jenkins-zh/jenkins-cli/util"
"github.com/spf13/cobra"
"net/http"
)
// JobHistoryOption is the job history option
type
JobHistoryOption
struct
{
OutputOption
RoundTripper
http
.
RoundTripper
}
var
jobHistoryOption
JobHistoryOption
...
...
@@ -30,41 +32,39 @@ var jobHistoryCmd = &cobra.Command{
Run
:
func
(
cmd
*
cobra
.
Command
,
args
[]
string
)
{
jobName
:=
args
[
0
]
jenkins
:=
getCurrentJenkinsFromOptionsOrDie
()
jclient
:=
&
client
.
JobClient
{}
jclient
.
URL
=
jenkins
.
URL
jclient
.
UserName
=
jenkins
.
UserName
jclient
.
Token
=
jenkins
.
Token
jclient
.
Proxy
=
jenkins
.
Proxy
jclient
.
ProxyAuth
=
jenkins
.
ProxyAuth
jClient
:=
&
client
.
JobClient
{
JenkinsCore
:
client
.
JenkinsCore
{
RoundTripper
:
jobHistoryOption
.
RoundTripper
,
},
}
getCurrentJenkinsAndClient
(
&
(
jClient
.
JenkinsCore
))
if
builds
,
err
:=
jclient
.
GetHistory
(
jobName
);
err
==
nil
{
if
data
,
err
:=
jobHistoryOption
.
Output
(
builds
);
err
==
nil
{
if
len
(
data
)
>
0
{
fmt
.
Println
(
string
(
data
))
}
}
else
{
log
.
Fatal
(
err
)
builds
,
err
:=
jClient
.
GetHistory
(
jobName
)
if
err
==
nil
{
var
data
[]
byte
data
,
err
=
jobHistoryOption
.
Output
(
builds
)
if
err
==
nil
&&
len
(
data
)
>
0
{
cmd
.
Print
(
string
(
data
))
}
}
else
{
log
.
Fatal
(
err
)
}
helper
.
CheckErr
(
cmd
,
err
)
},
}
// Output print the output
func
(
o
*
JobHistoryOption
)
Output
(
obj
interface
{})
(
data
[]
byte
,
err
error
)
{
if
data
,
err
=
o
.
OutputOption
.
Output
(
obj
);
err
!=
nil
{
buildList
:=
obj
.
([]
client
.
JobBuild
)
table
:=
util
.
CreateTable
(
os
.
Stdout
)
buildList
:=
obj
.
([]
*
client
.
JobBuild
)
buf
:=
new
(
bytes
.
Buffer
)
table
:=
util
.
CreateTable
(
buf
)
table
.
AddRow
(
"number"
,
"displayname"
,
"building"
,
"result"
)
for
i
,
build
:=
range
buildList
{
table
.
AddRow
(
fmt
.
Sprintf
(
"%d"
,
i
),
build
.
DisplayName
,
fmt
.
Sprintf
(
"%v"
,
build
.
Building
),
build
.
Result
)
}
table
.
Render
()
data
=
buf
.
Bytes
()
err
=
nil
data
=
[]
byte
{}
}
return
}
app/cmd/job_history_test.go
0 → 100644
浏览文件 @
21db67a3
package
cmd
import
(
"bytes"
"github.com/jenkins-zh/jenkins-cli/client"
"io/ioutil"
"os"
"github.com/golang/mock/gomock"
.
"github.com/onsi/ginkgo"
.
"github.com/onsi/gomega"
"github.com/jenkins-zh/jenkins-cli/mock/mhttp"
)
var
_
=
Describe
(
"job history command"
,
func
()
{
var
(
ctrl
*
gomock
.
Controller
roundTripper
*
mhttp
.
MockRoundTripper
err
error
jenkinsRoot
string
username
string
token
string
)
BeforeEach
(
func
()
{
ctrl
=
gomock
.
NewController
(
GinkgoT
())
roundTripper
=
mhttp
.
NewMockRoundTripper
(
ctrl
)
jobHistoryOption
.
RoundTripper
=
roundTripper
rootCmd
.
SetArgs
([]
string
{})
rootOptions
.
Jenkins
=
""
rootOptions
.
ConfigFile
=
"test.yaml"
jenkinsRoot
=
"http://localhost:8080/jenkins"
username
=
"admin"
token
=
"111e3a2f0231198855dceaff96f20540a9"
})
AfterEach
(
func
()
{
rootCmd
.
SetArgs
([]
string
{})
err
=
os
.
Remove
(
rootOptions
.
ConfigFile
)
rootOptions
.
ConfigFile
=
""
ctrl
.
Finish
()
})
Context
(
"basic cases"
,
func
()
{
It
(
"should not error"
,
func
()
{
Expect
(
err
)
.
NotTo
(
HaveOccurred
())
})
It
(
"should success"
,
func
()
{
data
,
err
:=
generateSampleConfig
()
Expect
(
err
)
.
To
(
BeNil
())
err
=
ioutil
.
WriteFile
(
rootOptions
.
ConfigFile
,
data
,
0664
)
Expect
(
err
)
.
To
(
BeNil
())
jobName
:=
"fakeJob"
client
.
PrepareForGetJob
(
roundTripper
,
jenkinsRoot
,
jobName
,
username
,
token
)
client
.
PrepareForGetBuild
(
roundTripper
,
jenkinsRoot
,
jobName
,
1
,
username
,
token
)
client
.
PrepareForGetBuild
(
roundTripper
,
jenkinsRoot
,
jobName
,
2
,
username
,
token
)
rootCmd
.
SetArgs
([]
string
{
"job"
,
"history"
,
jobName
})
buf
:=
new
(
bytes
.
Buffer
)
rootCmd
.
SetOutput
(
buf
)
_
,
err
=
rootCmd
.
ExecuteC
()
Expect
(
err
)
.
To
(
BeNil
())
Expect
(
buf
.
String
())
.
To
(
Equal
(
`number displayname building result
0 fake false
1 fake false
`
))
})
})
})
app/cmd/job_param.go
浏览文件 @
21db67a3
...
...
@@ -28,12 +28,8 @@ var jobParamCmd = &cobra.Command{
Use
:
"param <jobName>"
,
Short
:
"Get param of the job of your Jenkins"
,
Long
:
`Get param of the job of your Jenkins`
,
Args
:
cobra
.
MinimumNArgs
(
1
),
Run
:
func
(
cmd
*
cobra
.
Command
,
args
[]
string
)
{
if
len
(
args
)
==
0
{
cmd
.
Help
()
return
}
name
:=
args
[
0
]
jenkins
:=
getCurrentJenkinsFromOptionsOrDie
()
jclient
:=
&
client
.
JobClient
{}
...
...
app/cmd/user_delete.go
浏览文件 @
21db67a3
...
...
@@ -2,6 +2,7 @@ package cmd
import
(
"fmt"
"github.com/jenkins-zh/jenkins-cli/app/helper"
"net/http"
"github.com/jenkins-zh/jenkins-cli/client"
...
...
@@ -42,8 +43,7 @@ var userDeleteCmd = &cobra.Command{
}
getCurrentJenkinsAndClient
(
&
(
jclient
.
JenkinsCore
))
if
err
:=
jclient
.
Delete
(
username
);
err
!=
nil
{
cmd
.
PrintErrln
(
err
)
}
err
:=
jclient
.
Delete
(
username
)
helper
.
CheckErr
(
cmd
,
err
)
},
}
client/job.go
浏览文件 @
21db67a3
...
...
@@ -131,38 +131,18 @@ func (q *JobClient) UpdatePipeline(name, script string) (err error) {
}
// GetHistory returns the build history of a job
func
(
q
*
JobClient
)
GetHistory
(
name
string
)
(
builds
[]
JobBuild
,
err
error
)
{
func
(
q
*
JobClient
)
GetHistory
(
name
string
)
(
builds
[]
*
JobBuild
,
err
error
)
{
var
job
*
Job
if
job
,
err
=
q
.
GetJob
(
name
);
err
==
nil
{
builds
=
job
.
Builds
for
i
,
build
:=
range
builds
{
api
:=
fmt
.
Sprintf
(
"%sapi/json"
,
build
.
URL
)
var
(
req
*
http
.
Request
response
*
http
.
Response
)
req
,
err
=
http
.
NewRequest
(
"GET"
,
api
,
nil
)
if
err
==
nil
{
q
.
AuthHandle
(
req
)
}
else
{
return
}
client
:=
q
.
GetClient
()
if
response
,
err
=
client
.
Do
(
req
);
err
==
nil
{
code
:=
response
.
StatusCode
var
data
[]
byte
data
,
err
=
ioutil
.
ReadAll
(
response
.
Body
)
if
code
==
200
{
err
=
json
.
Unmarshal
(
data
,
&
build
)
builds
[
i
]
=
build
}
else
{
log
.
Fatal
(
string
(
data
))
}
}
else
{
log
.
Fatal
(
err
)
buildList
:=
job
.
Builds
// only contains basic info
var
build
*
JobBuild
for
_
,
buildItem
:=
range
buildList
{
build
,
err
=
q
.
GetBuild
(
name
,
buildItem
.
Number
)
if
err
!=
nil
{
break
}
builds
=
append
(
builds
,
build
)
}
}
return
...
...
client/job_test.go
浏览文件 @
21db67a3
...
...
@@ -158,18 +158,7 @@ var _ = Describe("job test", func() {
It
(
"basic case with one build"
,
func
()
{
jobName
:=
"fake"
buildID
:=
2
request
,
_
:=
http
.
NewRequest
(
"GET"
,
fmt
.
Sprintf
(
"%s/job/%s/%d/api/json"
,
jobClient
.
URL
,
jobName
,
buildID
),
nil
)
response
:=
&
http
.
Response
{
StatusCode
:
200
,
Proto
:
"HTTP/1.1"
,
Request
:
request
,
Body
:
ioutil
.
NopCloser
(
bytes
.
NewBufferString
(
`
{"displayName":"fake"}
`
)),
}
roundTripper
.
EXPECT
()
.
RoundTrip
(
request
)
.
Return
(
response
,
nil
)
PrepareForGetBuild
(
roundTripper
,
jobClient
.
URL
,
jobName
,
2
,
""
,
""
)
result
,
err
:=
jobClient
.
GetBuild
(
jobName
,
buildID
)
Expect
(
err
)
.
To
(
BeNil
())
...
...
@@ -365,4 +354,19 @@ var _ = Describe("job test", func() {
Expect
(
err
)
.
To
(
BeNil
())
})
})
Context
(
"GetHistory"
,
func
()
{
It
(
"simple case, should success"
,
func
()
{
jobName
:=
"fakeJob"
PrepareForGetJob
(
roundTripper
,
jobClient
.
URL
,
jobName
,
""
,
""
)
PrepareForGetBuild
(
roundTripper
,
jobClient
.
URL
,
jobName
,
1
,
""
,
""
)
PrepareForGetBuild
(
roundTripper
,
jobClient
.
URL
,
jobName
,
2
,
""
,
""
)
builds
,
err
:=
jobClient
.
GetHistory
(
jobName
)
Expect
(
err
)
.
To
(
BeNil
())
Expect
(
builds
)
.
NotTo
(
BeNil
())
Expect
(
len
(
builds
))
.
To
(
Equal
(
2
))
})
})
})
client/job_test_common.go
浏览文件 @
21db67a3
...
...
@@ -13,7 +13,7 @@ import (
)
// PrepareForGetJobInputActions only for test
func
PrepareForGetJobInputActions
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
user
,
passwd
,
jobName
string
,
buildID
int
)
(
func
PrepareForGetJobInputActions
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
user
,
passw
or
d
,
jobName
string
,
buildID
int
)
(
request
*
http
.
Request
,
response
*
http
.
Response
)
{
request
,
_
=
http
.
NewRequest
(
"GET"
,
fmt
.
Sprintf
(
"%s/job/%s/%d/wfapi/pendingInputActions"
,
rootURL
,
jobName
,
buildID
),
nil
)
response
=
&
http
.
Response
{
...
...
@@ -27,48 +27,93 @@ func PrepareForGetJobInputActions(roundTripper *mhttp.MockRoundTripper, rootURL,
roundTripper
.
EXPECT
()
.
RoundTrip
(
request
)
.
Return
(
response
,
nil
)
if
user
!=
""
&&
passwd
!=
""
{
request
.
SetBasicAuth
(
user
,
passwd
)
if
user
!=
""
&&
passw
or
d
!=
""
{
request
.
SetBasicAuth
(
user
,
passw
or
d
)
}
return
}
// PrepareForSubmitInput only for test
func
PrepareForSubmitInput
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobPath
,
user
,
passwd
string
)
(
func
PrepareForSubmitInput
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobPath
,
user
,
passw
or
d
string
)
(
request
*
http
.
Request
,
response
*
http
.
Response
)
{
request
,
_
=
http
.
NewRequest
(
"POST"
,
fmt
.
Sprintf
(
"%s%s/%d/input/%s/abort?json={
\"
parameter
\"
:[]}"
,
rootURL
,
jobPath
,
1
,
"Eff7d5dba32b4da32d9a67a519434d3f"
),
nil
)
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passwd
,
rootURL
)
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passw
or
d
,
rootURL
)
return
}
// PrepareForSubmitProcessInput only for test
func
PrepareForSubmitProcessInput
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobPath
,
user
,
passwd
string
)
(
func
PrepareForSubmitProcessInput
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobPath
,
user
,
passw
or
d
string
)
(
request
*
http
.
Request
,
response
*
http
.
Response
)
{
request
,
_
=
http
.
NewRequest
(
"POST"
,
fmt
.
Sprintf
(
"%s%s/%d/input/%s/proceed?json={
\"
parameter
\"
:[]}"
,
rootURL
,
jobPath
,
1
,
"Eff7d5dba32b4da32d9a67a519434d3f"
),
nil
)
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passwd
,
rootURL
)
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passw
or
d
,
rootURL
)
return
}
// PrepareForBuildWithNoParams only for test
func
PrepareForBuildWithNoParams
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
,
user
,
passwd
string
)
(
func
PrepareForBuildWithNoParams
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
,
user
,
passw
or
d
string
)
(
request
*
http
.
Request
,
response
*
http
.
Response
)
{
formData
:=
url
.
Values
{
"json"
:
{
`{"parameter": []}`
}}
payload
:=
strings
.
NewReader
(
formData
.
Encode
())
request
,
_
=
http
.
NewRequest
(
"POST"
,
fmt
.
Sprintf
(
"%s/job/%s/build"
,
rootURL
,
jobName
),
payload
)
request
.
Header
.
Add
(
util
.
ContentType
,
util
.
ApplicationForm
)
response
=
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passwd
,
rootURL
)
response
=
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passw
or
d
,
rootURL
)
response
.
StatusCode
=
201
return
}
// PrepareForBuildWithParams only for test
func
PrepareForBuildWithParams
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
,
user
,
passwd
string
)
(
func
PrepareForBuildWithParams
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
,
user
,
passw
or
d
string
)
(
request
*
http
.
Request
,
response
*
http
.
Response
)
{
formData
:=
url
.
Values
{
"json"
:
{
`{"parameter": {"Description":"","name":"name","Type":"","value":"value","DefaultParameterValue":{"Description":"","Value":null}}}`
}}
payload
:=
strings
.
NewReader
(
formData
.
Encode
())
request
,
_
=
http
.
NewRequest
(
"POST"
,
fmt
.
Sprintf
(
"%s/job/%s/build"
,
rootURL
,
jobName
),
payload
)
request
.
Header
.
Add
(
util
.
ContentType
,
util
.
ApplicationForm
)
response
=
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passwd
,
rootURL
)
response
=
PrepareCommonPost
(
request
,
""
,
roundTripper
,
user
,
passw
or
d
,
rootURL
)
response
.
StatusCode
=
201
return
}
// PrepareForGetJob only for test
func
PrepareForGetJob
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
,
user
,
password
string
)
{
request
,
_
:=
http
.
NewRequest
(
"GET"
,
fmt
.
Sprintf
(
"%s/job/%s/api/json"
,
rootURL
,
jobName
),
nil
)
response
:=
&
http
.
Response
{
StatusCode
:
200
,
Proto
:
"HTTP/1.1"
,
Request
:
request
,
Body
:
ioutil
.
NopCloser
(
bytes
.
NewBufferString
(
fmt
.
Sprintf
(
`{
"name" : "%s",
"builds" : [
{
"number" : 1,
"url" : "http://localhost:8080/job/we/1/"
},
{
"number" : 2,
"url" : "http://localhost:8080/job/we/2/"
}]
}`
,
jobName
))),
}
roundTripper
.
EXPECT
()
.
RoundTrip
(
request
)
.
Return
(
response
,
nil
)
if
user
!=
""
&&
password
!=
""
{
request
.
SetBasicAuth
(
user
,
password
)
}
}
// PrepareForGetBuild only for test
func
PrepareForGetBuild
(
roundTripper
*
mhttp
.
MockRoundTripper
,
rootURL
,
jobName
string
,
buildID
int
,
user
,
password
string
)
{
request
,
_
:=
http
.
NewRequest
(
"GET"
,
fmt
.
Sprintf
(
"%s/job/%s/%d/api/json"
,
rootURL
,
jobName
,
buildID
),
nil
)
response
:=
&
http
.
Response
{
StatusCode
:
200
,
Proto
:
"HTTP/1.1"
,
Request
:
request
,
Body
:
ioutil
.
NopCloser
(
bytes
.
NewBufferString
(
`
{"displayName":"fake"}
`
)),
}
roundTripper
.
EXPECT
()
.
RoundTrip
(
request
)
.
Return
(
response
,
nil
)
if
user
!=
""
&&
password
!=
""
{
request
.
SetBasicAuth
(
user
,
password
)
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录