Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
jenkinsci
Jenkins Cli
提交
68cd99df
J
Jenkins Cli
项目概览
jenkinsci
/
Jenkins Cli
通知
0
Star
1
Fork
0
代码
文件
提交
分支
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 搜索 >>
未验证
提交
68cd99df
编写于
7月 21, 2020
作者:
JenkinsInChina
提交者:
GitHub
7月 21, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Improve the version upgrade of jcli (#435)
上级
6c65096b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
37 addition
and
8 deletion
+37
-8
app/cmd/version/upgrade.go
app/cmd/version/upgrade.go
+37
-8
未找到文件。
app/cmd/version/upgrade.go
浏览文件 @
68cd99df
...
...
@@ -13,6 +13,7 @@ import (
"github.com/spf13/cobra"
"github.com/spf13/pflag"
"io"
"io/ioutil"
"os"
"os/exec"
"path/filepath"
...
...
@@ -50,6 +51,17 @@ func (o *SelfUpgradeOption) RunE(cmd *cobra.Command, args []string) (err error)
version
=
args
[
0
]
}
// copy binary file into system path
var
targetPath
string
if
targetPath
,
err
=
exec
.
LookPath
(
"jcli"
);
err
!=
nil
{
err
=
fmt
.
Errorf
(
"cannot find Jenkins CLI from system path, error: %v"
,
err
)
return
}
var
targetF
*
os
.
File
if
targetF
,
err
=
os
.
OpenFile
(
targetPath
,
os
.
O_CREATE
|
os
.
O_RDWR
,
0644
);
err
!=
nil
{
return
}
// try to understand the version from user input
switch
version
{
case
"dev"
:
...
...
@@ -84,6 +96,11 @@ func (o *SelfUpgradeOption) RunE(cmd *cobra.Command, args []string) (err error)
_
=
os
.
RemoveAll
(
output
)
}()
// make sure we count the download action
go
func
()
{
o
.
downloadCount
(
version
,
runtime
.
GOOS
)
}()
downloader
:=
util
.
HTTPDownloader
{
RoundTripper
:
o
.
RoundTripper
,
TargetFilePath
:
output
,
...
...
@@ -95,16 +112,8 @@ func (o *SelfUpgradeOption) RunE(cmd *cobra.Command, args []string) (err error)
return
}
// copy binary file into system path
var
targetPath
string
if
targetPath
,
err
=
exec
.
LookPath
(
"jcli"
);
err
!=
nil
{
err
=
fmt
.
Errorf
(
"cannot find Jenkins CLI from system path, error: %v"
,
err
)
return
}
if
err
=
o
.
extractFiles
(
output
);
err
==
nil
{
sourceFile
:=
fmt
.
Sprintf
(
"%s/jcli"
,
filepath
.
Dir
(
output
))
targetF
,
_
:=
os
.
OpenFile
(
targetPath
,
os
.
O_CREATE
|
os
.
O_RDWR
,
0644
)
sourceF
,
_
:=
os
.
Open
(
sourceFile
)
if
_
,
err
=
io
.
Copy
(
targetF
,
sourceF
);
err
!=
nil
{
err
=
fmt
.
Errorf
(
"cannot copy Jenkins CLI from %s to %s, error: %v"
,
sourceFile
,
targetPath
,
err
)
...
...
@@ -115,6 +124,26 @@ func (o *SelfUpgradeOption) RunE(cmd *cobra.Command, args []string) (err error)
return
}
func
(
o
*
SelfUpgradeOption
)
downloadCount
(
version
string
,
arch
string
)
{
countURL
:=
fmt
.
Sprintf
(
"https: //github.com/jenkins-zh/jenkins-cli/releases/download/v%s/jcli-%s-amd64.tar.gz"
,
version
,
arch
)
if
tempDir
,
err
:=
ioutil
.
TempDir
(
"."
,
"download-count"
);
err
==
nil
{
tempFile
:=
tempDir
+
"/jcli.tar.gz"
defer
func
()
{
_
=
os
.
RemoveAll
(
tempDir
)
}()
downloader
:=
util
.
HTTPDownloader
{
RoundTripper
:
o
.
RoundTripper
,
TargetFilePath
:
tempFile
,
URL
:
countURL
,
}
// we don't care about the result, just for counting
_
=
downloader
.
DownloadFile
()
}
}
func
(
o
*
SelfUpgradeOption
)
extractFiles
(
tarFile
string
)
(
err
error
)
{
var
f
*
os
.
File
var
gzf
*
gzip
.
Reader
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录