2019-12-16 22:33:55 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe Ci::UpdateRunnerService do
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:runner) { create(:ci_runner) }
|
|
|
|
|
|
|
|
describe '#update' do
|
|
|
|
before do
|
|
|
|
allow(runner).to receive(:tick_runner_queue)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with description params' do
|
|
|
|
let(:params) { { description: 'new runner' } }
|
|
|
|
|
|
|
|
it 'updates the runner and ticking the queue' do
|
|
|
|
expect(update).to be_truthy
|
|
|
|
|
|
|
|
runner.reload
|
|
|
|
|
|
|
|
expect(runner).to have_received(:tick_runner_queue)
|
|
|
|
expect(runner.description).to eq('new runner')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when params are not valid' do
|
|
|
|
let(:params) { { run_untagged: false } }
|
|
|
|
|
|
|
|
it 'does not update and give false because it is not valid' do
|
|
|
|
expect(update).to be_falsey
|
|
|
|
|
|
|
|
runner.reload
|
|
|
|
|
|
|
|
expect(runner).not_to have_received(:tick_runner_queue)
|
|
|
|
expect(runner.run_untagged).to be_truthy
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
described_class.new(runner).update(params)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|