Commit 1cec47ec authored by João Cunha's avatar João Cunha Committed by Jan Provaznik

DRY check progress services

Extract duplicated code from two similar classes into a parent one.
parent 2d31e3cb
...@@ -2,24 +2,7 @@ ...@@ -2,24 +2,7 @@
module Clusters module Clusters
module Applications module Applications
class CheckInstallationProgressService < BaseHelmService class CheckInstallationProgressService < CheckProgressService
def execute
return unless operation_in_progress?
case installation_phase
when Gitlab::Kubernetes::Pod::SUCCEEDED
on_success
when Gitlab::Kubernetes::Pod::FAILED
on_failed
else
check_timeout
end
rescue Kubeclient::HttpError => e
log_error(e)
app.make_errored!("Kubernetes error: #{e.error_code}")
end
private private
def operation_in_progress? def operation_in_progress?
...@@ -32,10 +15,6 @@ module Clusters ...@@ -32,10 +15,6 @@ module Clusters
remove_installation_pod remove_installation_pod
end end
def on_failed
app.make_errored!("Operation failed. Check pod logs for #{pod_name} for more details.")
end
def check_timeout def check_timeout
if timed_out? if timed_out?
begin begin
...@@ -54,18 +33,6 @@ module Clusters ...@@ -54,18 +33,6 @@ module Clusters
def timed_out? def timed_out?
Time.now.utc - app.updated_at.utc > ClusterWaitForAppInstallationWorker::TIMEOUT Time.now.utc - app.updated_at.utc > ClusterWaitForAppInstallationWorker::TIMEOUT
end end
def remove_installation_pod
helm_api.delete_pod!(pod_name)
end
def installation_phase
helm_api.status(pod_name)
end
def installation_errors
helm_api.log(pod_name)
end
end end
end end
end end
# frozen_string_literal: true
module Clusters
module Applications
class CheckProgressService < BaseHelmService
def execute
return unless operation_in_progress?
case pod_phase
when Gitlab::Kubernetes::Pod::SUCCEEDED
on_success
when Gitlab::Kubernetes::Pod::FAILED
on_failed
else
check_timeout
end
rescue Kubeclient::HttpError => e
log_error(e)
app.make_errored!(_('Kubernetes error: %{error_code}') % { error_code: e.error_code })
end
private
def operation_in_progress?
raise NotImplementedError
end
def on_success
raise NotImplementedError
end
def pod_name
raise NotImplementedError
end
def on_failed
app.make_errored!(_('Operation failed. Check pod logs for %{pod_name} for more details.') % { pod_name: pod_name })
end
def timed_out?
raise NotImplementedError
end
def pod_phase
helm_api.status(pod_name)
end
end
end
end
...@@ -2,26 +2,13 @@ ...@@ -2,26 +2,13 @@
module Clusters module Clusters
module Applications module Applications
class CheckUninstallProgressService < BaseHelmService class CheckUninstallProgressService < CheckProgressService
def execute private
return unless app.uninstalling?
case installation_phase
when Gitlab::Kubernetes::Pod::SUCCEEDED
on_success
when Gitlab::Kubernetes::Pod::FAILED
on_failed
else
check_timeout
end
rescue Kubeclient::HttpError => e
log_error(e)
app.make_errored!(_('Kubernetes error: %{error_code}') % { error_code: e.error_code }) def operation_in_progress?
app.uninstalling?
end end
private
def on_success def on_success
app.post_uninstall app.post_uninstall
app.destroy! app.destroy!
...@@ -31,10 +18,6 @@ module Clusters ...@@ -31,10 +18,6 @@ module Clusters
remove_installation_pod remove_installation_pod
end end
def on_failed
app.make_errored!(_('Operation failed. Check pod logs for %{pod_name} for more details.') % { pod_name: pod_name })
end
def check_timeout def check_timeout
if timed_out? if timed_out?
app.make_errored!(_('Operation timed out. Check pod logs for %{pod_name} for more details.') % { pod_name: pod_name }) app.make_errored!(_('Operation timed out. Check pod logs for %{pod_name} for more details.') % { pod_name: pod_name })
...@@ -50,14 +33,6 @@ module Clusters ...@@ -50,14 +33,6 @@ module Clusters
def timed_out? def timed_out?
Time.now.utc - app.updated_at.utc > WaitForUninstallAppWorker::TIMEOUT Time.now.utc - app.updated_at.utc > WaitForUninstallAppWorker::TIMEOUT
end end
def remove_installation_pod
helm_api.delete_pod!(pod_name)
end
def installation_phase
helm_api.status(pod_name)
end
end end
end end
end end
...@@ -14,7 +14,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -14,7 +14,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
let(:phase) { a_phase } let(:phase) { a_phase }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
context "when phase is #{a_phase}" do context "when phase is #{a_phase}" do
...@@ -44,7 +44,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -44,7 +44,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
before do before do
application.update!(cluster: cluster) application.update!(cluster: cluster)
expect(service).to receive(:installation_phase).and_raise(error) expect(service).to receive(:pod_phase).and_raise(error)
end end
include_examples 'logs kubernetes errors' do include_examples 'logs kubernetes errors' do
...@@ -77,7 +77,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -77,7 +77,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
context 'when installation POD succeeded' do context 'when installation POD succeeded' do
let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED } let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'removes the installation POD' do it 'removes the installation POD' do
...@@ -101,7 +101,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -101,7 +101,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
let(:errors) { 'test installation failed' } let(:errors) { 'test installation failed' }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
...@@ -116,7 +116,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -116,7 +116,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
let(:application) { create(:clusters_applications_helm, :timed_out, :updating) } let(:application) { create(:clusters_applications_helm, :timed_out, :updating) }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
...@@ -138,7 +138,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -138,7 +138,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
context 'when installation POD succeeded' do context 'when installation POD succeeded' do
let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED } let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'removes the installation POD' do it 'removes the installation POD' do
...@@ -162,7 +162,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -162,7 +162,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
let(:errors) { 'test installation failed' } let(:errors) { 'test installation failed' }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
...@@ -177,7 +177,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do ...@@ -177,7 +177,7 @@ describe Clusters::Applications::CheckInstallationProgressService, '#execute' do
let(:application) { create(:clusters_applications_helm, :timed_out) } let(:application) { create(:clusters_applications_helm, :timed_out) }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
......
...@@ -20,7 +20,7 @@ describe Clusters::Applications::CheckUninstallProgressService do ...@@ -20,7 +20,7 @@ describe Clusters::Applications::CheckUninstallProgressService do
let(:phase) { a_phase } let(:phase) { a_phase }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
context "when phase is #{a_phase}" do context "when phase is #{a_phase}" do
...@@ -47,7 +47,7 @@ describe Clusters::Applications::CheckUninstallProgressService do ...@@ -47,7 +47,7 @@ describe Clusters::Applications::CheckUninstallProgressService do
context 'when installation POD succeeded' do context 'when installation POD succeeded' do
let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED } let(:phase) { Gitlab::Kubernetes::Pod::SUCCEEDED }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'removes the installation POD' do it 'removes the installation POD' do
...@@ -95,7 +95,7 @@ describe Clusters::Applications::CheckUninstallProgressService do ...@@ -95,7 +95,7 @@ describe Clusters::Applications::CheckUninstallProgressService do
let(:errors) { 'test installation failed' } let(:errors) { 'test installation failed' }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
...@@ -110,7 +110,7 @@ describe Clusters::Applications::CheckUninstallProgressService do ...@@ -110,7 +110,7 @@ describe Clusters::Applications::CheckUninstallProgressService do
let(:application) { create(:clusters_applications_prometheus, :timed_out, :uninstalling) } let(:application) { create(:clusters_applications_prometheus, :timed_out, :uninstalling) }
before do before do
expect(service).to receive(:installation_phase).once.and_return(phase) expect(service).to receive(:pod_phase).once.and_return(phase)
end end
it 'make the application errored' do it 'make the application errored' do
...@@ -131,7 +131,7 @@ describe Clusters::Applications::CheckUninstallProgressService do ...@@ -131,7 +131,7 @@ describe Clusters::Applications::CheckUninstallProgressService do
before do before do
application.update!(cluster: cluster) application.update!(cluster: cluster)
expect(service).to receive(:installation_phase).and_raise(error) expect(service).to receive(:pod_phase).and_raise(error)
end end
include_examples 'logs kubernetes errors' do include_examples 'logs kubernetes errors' do
......
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