summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKamil Trzcinski <ayufan@ayufan.eu>2016-08-12 11:53:27 +0200
committerKamil Trzcinski <ayufan@ayufan.eu>2016-08-12 11:53:27 +0200
commitad3e1edcfce1e24fb9889d5d73852680cf4facf9 (patch)
treee8054ae4ad1b0d6882971cbeda3ff4c6fa59187e
parente1f05b932de5553462793fb88fdea2ca54072d40 (diff)
downloadgitlab-ce-ad3e1edcfce1e24fb9889d5d73852680cf4facf9.tar.gz
Added specs for started_at and finished_at
-rw-r--r--app/models/ci/pipeline.rb15
-rw-r--r--spec/models/ci/pipeline_spec.rb46
2 files changed, 46 insertions, 15 deletions
diff --git a/app/models/ci/pipeline.rb b/app/models/ci/pipeline.rb
index 6aef91804a2..92fae78fe4e 100644
--- a/app/models/ci/pipeline.rb
+++ b/app/models/ci/pipeline.rb
@@ -22,10 +22,11 @@ module Ci
state_machine :status, initial: :created do
event :queue do
transition :created => :pending
+ transition any - [:created, :pending] => :running
end
event :run do
- transition [:pending, :success, :failed, :canceled, :skipped] => :running
+ transition any => :running
end
event :skip do
@@ -44,15 +45,15 @@ module Ci
transition any => :canceled
end
- after_transition [:created, :pending] => :running do |pipeline|
- pipeline.update(started_at: Time.now)
+ before_transition [:created, :pending] => :running do |pipeline|
+ pipeline.started_at = Time.now
end
- after_transition any => [:success, :failed, :canceled] do |pipeline|
- pipeline.update(finished_at: Time.now)
+ before_transition any => [:success, :failed, :canceled] do |pipeline|
+ pipeline.finished_at = Time.now
end
- after_transition do |pipeline|
+ before_transition do |pipeline|
pipeline.update_duration
end
end
@@ -245,7 +246,7 @@ module Ci
end
def update_duration
- update(duration: statuses.latest.duration)
+ self.duration = statuses.latest.duration
end
private
diff --git a/spec/models/ci/pipeline_spec.rb b/spec/models/ci/pipeline_spec.rb
index adfe4bdd0c8..28d07f67b26 100644
--- a/spec/models/ci/pipeline_spec.rb
+++ b/spec/models/ci/pipeline_spec.rb
@@ -120,18 +120,48 @@ describe Ci::Pipeline, models: true do
end
end
- describe '#duration' do
+ describe 'state machine' do
let(:current) { Time.now.change(usec: 0) }
- let!(:build) { create :ci_build, name: 'build1', pipeline: pipeline, started_at: current - 60, finished_at: current }
- let!(:build2) { create :ci_build, name: 'build2', pipeline: pipeline, started_at: current - 60, finished_at: current }
+ let(:build) { create :ci_build, name: 'build1', pipeline: pipeline, started_at: current - 60, finished_at: current }
+ let(:build2) { create :ci_build, name: 'build2', pipeline: pipeline, started_at: current - 60, finished_at: current }
- before do
- build.skip
- build2.skip
+ describe '#duration' do
+ before do
+ build.skip
+ build2.skip
+ end
+
+ it 'matches sum of builds duration' do
+ expect(pipeline.reload.duration).to eq(build.duration + build2.duration)
+ end
end
- it 'matches sum of builds duration' do
- expect(pipeline.reload.duration).to eq(build.duration + build2.duration)
+ describe '#started_at' do
+ it 'updates on transitioning to running' do
+ build.run
+
+ expect(pipeline.reload.started_at).not_to be_nil
+ end
+
+ it 'do not update on transitioning to success' do
+ build.success
+
+ expect(pipeline.reload.started_at).to be_nil
+ end
+ end
+
+ describe '#finished_at' do
+ it 'updates on transitioning to success' do
+ build.success
+
+ expect(pipeline.reload.finished_at).not_to be_nil
+ end
+
+ it 'do not update on transitioning to running' do
+ build.run
+
+ expect(pipeline.reload.finished_at).to be_nil
+ end
end
end