Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShinya Maeda <shinya@gitlab.com>2018-09-26 09:13:39 +0300
committerAlessio Caiazza <acaiazza@gitlab.com>2018-10-02 18:08:11 +0300
commit6eee8d2d53a327051515ec18953726fd5606c000 (patch)
treeeaa41f674dda46bf1407869645b1994198485f35 /spec/services/ci/process_build_service_spec.rb
parentaf4b85cef57c00f4cccdac7fde15d4c69d9e94fb (diff)
Fix process build service spec
Diffstat (limited to 'spec/services/ci/process_build_service_spec.rb')
-rw-r--r--spec/services/ci/process_build_service_spec.rb61
1 files changed, 61 insertions, 0 deletions
diff --git a/spec/services/ci/process_build_service_spec.rb b/spec/services/ci/process_build_service_spec.rb
new file mode 100644
index 00000000000..74a81af75f2
--- /dev/null
+++ b/spec/services/ci/process_build_service_spec.rb
@@ -0,0 +1,61 @@
+# frozen_string_literal: true
+require 'spec_helper'
+
+describe Ci::ProcessBuildService, '#execute' do
+ let(:user) { create(:user) }
+ let(:project) { create(:project) }
+
+ subject { described_class.new(project, user).execute(build) }
+
+ before do
+ project.add_maintainer(user)
+ end
+
+ context 'when build is schedulable' do
+ let(:build) { create(:ci_build, :created, :schedulable, user: user, project: project) }
+
+ context 'when ci_enable_scheduled_build feature flag is enabled' do
+ before do
+ stub_feature_flags(ci_enable_scheduled_build: true)
+ end
+
+ it 'schedules the build' do
+ subject
+
+ expect(build).to be_scheduled
+ end
+ end
+
+ context 'when ci_enable_scheduled_build feature flag is disabled' do
+ before do
+ stub_feature_flags(ci_enable_scheduled_build: false)
+ end
+
+ it 'enqueues the build' do
+ subject
+
+ expect(build).to be_pending
+ end
+ end
+ end
+
+ context 'when build is actionable' do
+ let(:build) { create(:ci_build, :created, :actionable, user: user, project: project) }
+
+ it 'actionizes the build' do
+ subject
+
+ expect(build).to be_manual
+ end
+ end
+
+ context 'when build does not have any actions' do
+ let(:build) { create(:ci_build, :created, user: user, project: project) }
+
+ it 'enqueues the build' do
+ subject
+
+ expect(build).to be_pending
+ end
+ end
+end