summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorValery Sizov <vsv2711@gmail.com>2015-09-14 16:48:33 +0300
committerValery Sizov <vsv2711@gmail.com>2015-09-14 16:48:33 +0300
commit2c4daf1a68a23e6d4f17340b03415cfd715d5afc (patch)
treec7f937c25d813e628d0305229850c21906589994
parent4c53cc0ebac36560d806732ff1fefba9206c75f3 (diff)
downloadgitlab-ce-2c4daf1a68a23e6d4f17340b03415cfd715d5afc.tar.gz
fix part of specs
-rw-r--r--spec/requests/ci/builds_spec.rb2
-rw-r--r--spec/requests/ci/commits_spec.rb2
-rw-r--r--spec/services/ci/create_commit_service_spec.rb194
3 files changed, 100 insertions, 98 deletions
diff --git a/spec/requests/ci/builds_spec.rb b/spec/requests/ci/builds_spec.rb
index 0d7650ef582..998c386ead4 100644
--- a/spec/requests/ci/builds_spec.rb
+++ b/spec/requests/ci/builds_spec.rb
@@ -9,7 +9,7 @@ describe "Builds" do
describe "GET /:project/builds/:id/status.json" do
before do
- get status_project_build_path(@project, @build), format: :json
+ get status_ci_project_build_path(@project, @build), format: :json
end
it { expect(response.status).to eq(200) }
diff --git a/spec/requests/ci/commits_spec.rb b/spec/requests/ci/commits_spec.rb
index fe7bd2de3e7..fb317670339 100644
--- a/spec/requests/ci/commits_spec.rb
+++ b/spec/requests/ci/commits_spec.rb
@@ -8,7 +8,7 @@ describe "Commits" do
describe "GET /:project/refs/:ref_name/commits/:id/status.json" do
before do
- get status_project_ref_commit_path(@project, @commit.ref, @commit.sha), format: :json
+ get status_ci_project_ref_commits_path(@project, @commit.ref, @commit.sha), format: :json
end
it { expect(response.status).to eq(200) }
diff --git a/spec/services/ci/create_commit_service_spec.rb b/spec/services/ci/create_commit_service_spec.rb
index 2bb8c5acb65..38d9943765a 100644
--- a/spec/services/ci/create_commit_service_spec.rb
+++ b/spec/services/ci/create_commit_service_spec.rb
@@ -1,84 +1,121 @@
require 'spec_helper'
-describe Ci::CreateCommitService do
- let(:service) { CreateCommitService.new }
- let(:project) { FactoryGirl.create(:project) }
-
- describe :execute do
- context 'valid params' do
- let(:commit) do
- service.execute(project,
- ref: 'refs/heads/master',
- before: '00000000',
- after: '31das312',
- ci_yaml_file: gitlab_ci_yaml,
- commits: [ { message: "Message" } ]
- )
+module Ci
+ describe CreateCommitService do
+ let(:service) { CreateCommitService.new }
+ let(:project) { FactoryGirl.create(:ci_project) }
+
+ describe :execute do
+ context 'valid params' do
+ let(:commit) do
+ service.execute(project,
+ ref: 'refs/heads/master',
+ before: '00000000',
+ after: '31das312',
+ ci_yaml_file: gitlab_ci_yaml,
+ commits: [ { message: "Message" } ]
+ )
+ end
+
+ it { expect(commit).to be_kind_of(Commit) }
+ it { expect(commit).to be_valid }
+ it { expect(commit).to be_persisted }
+ it { expect(commit).to eq(project.commits.last) }
+ it { expect(commit.builds.first).to be_kind_of(Build) }
end
- it { commit.should be_kind_of(Commit) }
- it { commit.should be_valid }
- it { commit.should be_persisted }
- it { commit.should == project.commits.last }
- it { commit.builds.first.should be_kind_of(Build) }
- end
-
- context "skip tag if there is no build for it" do
- it "creates commit if there is appropriate job" do
- result = service.execute(project,
- ref: 'refs/tags/0_1',
- before: '00000000',
- after: '31das312',
- ci_yaml_file: gitlab_ci_yaml,
- commits: [ { message: "Message" } ]
- )
- result.should be_persisted
+ context "skip tag if there is no build for it" do
+ it "creates commit if there is appropriate job" do
+ result = service.execute(project,
+ ref: 'refs/tags/0_1',
+ before: '00000000',
+ after: '31das312',
+ ci_yaml_file: gitlab_ci_yaml,
+ commits: [ { message: "Message" } ]
+ )
+ expect(result).to be_persisted
+ end
+
+ it "creates commit if there is no appropriate job but deploy job has right ref setting" do
+ config = YAML.dump({ deploy: { deploy: "ls", only: ["0_1"] } })
+
+ result = service.execute(project,
+ ref: 'refs/heads/0_1',
+ before: '00000000',
+ after: '31das312',
+ ci_yaml_file: config,
+ commits: [ { message: "Message" } ]
+ )
+ expect(result).to be_persisted
+ end
end
- it "creates commit if there is no appropriate job but deploy job has right ref setting" do
- config = YAML.dump({ deploy: { deploy: "ls", only: ["0_1"] } })
-
- result = service.execute(project,
- ref: 'refs/heads/0_1',
- before: '00000000',
- after: '31das312',
- ci_yaml_file: config,
- commits: [ { message: "Message" } ]
- )
- result.should be_persisted
+ describe :ci_skip? do
+ it "skips builds creation if there is [ci skip] tag in commit message" do
+ commits = [{ message: "some message[ci skip]" }]
+ commit = service.execute(project,
+ ref: 'refs/tags/0_1',
+ before: '00000000',
+ after: '31das312',
+ commits: commits,
+ ci_yaml_file: gitlab_ci_yaml
+ )
+ expect(commit.builds.any?).to be false
+ expect(commit.status).to eq("skipped")
+ end
+
+ it "does not skips builds creation if there is no [ci skip] tag in commit message" do
+ commits = [{ message: "some message" }]
+
+ commit = service.execute(project,
+ ref: 'refs/tags/0_1',
+ before: '00000000',
+ after: '31das312',
+ commits: commits,
+ ci_yaml_file: gitlab_ci_yaml
+ )
+
+ expect(commit.builds.first.name).to eq("staging")
+ end
+
+ it "skips builds creation if there is [ci skip] tag in commit message and yaml is invalid" do
+ commits = [{ message: "some message[ci skip]" }]
+ commit = service.execute(project,
+ ref: 'refs/tags/0_1',
+ before: '00000000',
+ after: '31das312',
+ commits: commits,
+ ci_yaml_file: "invalid: file"
+ )
+ expect(commit.builds.any?).to be false
+ expect(commit.status).to eq("skipped")
+ end
end
- end
- describe :ci_skip? do
- it "skips builds creation if there is [ci skip] tag in commit message" do
- commits = [{ message: "some message[ci skip]" }]
+ it "skips build creation if there are already builds" do
+ commits = [{ message: "message" }]
commit = service.execute(project,
- ref: 'refs/tags/0_1',
+ ref: 'refs/heads/master',
before: '00000000',
after: '31das312',
commits: commits,
ci_yaml_file: gitlab_ci_yaml
)
- commit.builds.any?.should be_false
- commit.status.should == "skipped"
- end
-
- it "does not skips builds creation if there is no [ci skip] tag in commit message" do
- commits = [{ message: "some message" }]
+ expect(commit.builds.count(:all)).to eq(2)
commit = service.execute(project,
- ref: 'refs/tags/0_1',
+ ref: 'refs/heads/master',
before: '00000000',
after: '31das312',
commits: commits,
ci_yaml_file: gitlab_ci_yaml
)
-
- commit.builds.first.name.should == "staging"
+ expect(commit.builds.count(:all)).to eq(2)
end
- it "skips builds creation if there is [ci skip] tag in commit message and yaml is invalid" do
- commits = [{ message: "some message[ci skip]" }]
+ it "creates commit with failed status if yaml is invalid" do
+ commits = [{ message: "some message" }]
+
commit = service.execute(project,
ref: 'refs/tags/0_1',
before: '00000000',
@@ -86,45 +123,10 @@ describe Ci::CreateCommitService do
commits: commits,
ci_yaml_file: "invalid: file"
)
- commit.builds.any?.should be_false
- commit.status.should == "skipped"
- end
- end
-
- it "skips build creation if there are already builds" do
- commits = [{ message: "message" }]
- commit = service.execute(project,
- ref: 'refs/heads/master',
- before: '00000000',
- after: '31das312',
- commits: commits,
- ci_yaml_file: gitlab_ci_yaml
- )
- commit.builds.count(:all).should == 2
-
- commit = service.execute(project,
- ref: 'refs/heads/master',
- before: '00000000',
- after: '31das312',
- commits: commits,
- ci_yaml_file: gitlab_ci_yaml
- )
- commit.builds.count(:all).should == 2
- end
- it "creates commit with failed status if yaml is invalid" do
- commits = [{ message: "some message" }]
-
- commit = service.execute(project,
- ref: 'refs/tags/0_1',
- before: '00000000',
- after: '31das312',
- commits: commits,
- ci_yaml_file: "invalid: file"
- )
-
- commit.status.should == "failed"
- commit.builds.any?.should be_false
+ expect(commit.status).to eq("failed")
+ expect(commit.builds.any?).to be false
+ end
end
end
end