Commit 59bffe6b authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Merge pull request #162 from asedge/annotated_tags

Adding support+tests for annotated tags.
parents f959bd4d df90f59c
...@@ -58,9 +58,10 @@ Remove branch ...@@ -58,9 +58,10 @@ Remove branch
./bin/gitlab-projects rm-branch gitlab/gitlab-ci.git 3-0-stable ./bin/gitlab-projects rm-branch gitlab/gitlab-ci.git 3-0-stable
Create tag Create tag (lightweight & annotated)
./bin/gitlab-projects create-tag gitlab/gitlab-ci.git v3.0.0 3-0-stable ./bin/gitlab-projects create-tag gitlab/gitlab-ci.git v3.0.0 3-0-stable
./bin/gitlab-projects create-tag gitlab/gitlab-ci.git v3.0.0 3-0-stable 'annotated message goes here'
Remove tag Remove tag
......
...@@ -67,7 +67,12 @@ class GitlabProjects ...@@ -67,7 +67,12 @@ class GitlabProjects
def create_tag def create_tag
tag_name = ARGV.shift tag_name = ARGV.shift
ref = ARGV.shift || "HEAD" ref = ARGV.shift || "HEAD"
cmd = %W(git --git-dir=#{full_path} tag -- #{tag_name} #{ref}) cmd = %W(git --git-dir=#{full_path} tag)
if ARGV.size > 0
msg = ARGV.shift
cmd += %W(-a -m #{msg})
end
cmd += %W(-- #{tag_name} #{ref})
system(*cmd) system(*cmd)
end end
......
...@@ -60,14 +60,36 @@ describe GitlabProjects do ...@@ -60,14 +60,36 @@ describe GitlabProjects do
let(:gl_projects_create) { let(:gl_projects_create) {
build_gitlab_projects('import-project', repo_name, 'https://github.com/randx/six.git') build_gitlab_projects('import-project', repo_name, 'https://github.com/randx/six.git')
} }
let(:gl_projects) { build_gitlab_projects('create-tag', repo_name, 'test_tag', 'master') } context "lightweight tag" do
let(:gl_projects) { build_gitlab_projects('create-tag', repo_name, 'test_tag', 'master') }
it "should create a tag" do it "should create a tag" do
gl_projects_create.exec gl_projects_create.exec
gl_projects.exec gl_projects.exec
tag_ref = capture_in_tmp_repo(%W(git rev-parse test_tag)) tag_ref = capture_in_tmp_repo(%W(git rev-parse test_tag))
master_ref = capture_in_tmp_repo(%W(git rev-parse master)) master_ref = capture_in_tmp_repo(%W(git rev-parse master))
tag_ref.should == master_ref tag_ref.should == master_ref
end
end
context "annotated tag" do
msg = 'some message'
tag_name = 'test_annotated_tag'
let(:gl_projects) { build_gitlab_projects('create-tag', repo_name, tag_name, 'master', msg) }
it "should create an annotated tag" do
gl_projects_create.exec
system(*%W(git --git-dir=#{tmp_repo_path} config user.name Joe))
system(*%W(git --git-dir=#{tmp_repo_path} config user.email joe@smith.com))
gl_projects.exec
tag_ref = capture_in_tmp_repo(%W(git rev-parse #{tag_name}^{}))
master_ref = capture_in_tmp_repo(%W(git rev-parse master))
tag_msg = capture_in_tmp_repo(%W(git tag -l -n1 #{tag_name}))
tag_ref.should == master_ref
tag_msg.should == tag_name + ' ' + msg
end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment