69 lines
1.6 KiB
Ruby
69 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Gitlab::Checks::TimedLogger do
|
|
let!(:timeout) { 50.seconds }
|
|
let!(:start) { Time.now }
|
|
let!(:ref) { "bar" }
|
|
let!(:logger) { described_class.new(start_time: start, timeout: timeout) }
|
|
let!(:log_messages) do
|
|
{
|
|
foo: "Foo message..."
|
|
}
|
|
end
|
|
|
|
before do
|
|
logger.append_message("Checking ref: #{ref}")
|
|
end
|
|
|
|
around do |example|
|
|
freeze_time do
|
|
example.run
|
|
end
|
|
end
|
|
|
|
describe '#log_timed' do
|
|
it 'logs message' do
|
|
travel_to(start + 30.seconds)
|
|
|
|
logger.log_timed(log_messages[:foo], start) { bar_check }
|
|
|
|
expect(logger.full_message).to eq("Checking ref: bar\nFoo message... (30000.0ms)")
|
|
end
|
|
|
|
context 'when time limit was reached' do
|
|
it 'cancels action' do
|
|
travel_to(start + 50.seconds)
|
|
|
|
expect do
|
|
logger.log_timed(log_messages[:foo], start) do
|
|
bar_check
|
|
end
|
|
end.to raise_error(described_class::TimeoutError)
|
|
|
|
expect(logger.full_message).to eq("Checking ref: bar\nFoo message... (cancelled)")
|
|
end
|
|
|
|
it 'cancels action with time elapsed if work was performed' do
|
|
travel_to(start + 30.seconds)
|
|
|
|
expect do
|
|
logger.log_timed(log_messages[:foo], start) do
|
|
grpc_check
|
|
end
|
|
end.to raise_error(described_class::TimeoutError)
|
|
|
|
expect(logger.full_message).to eq("Checking ref: bar\nFoo message... (cancelled after 30000.0ms)")
|
|
end
|
|
end
|
|
end
|
|
|
|
def bar_check
|
|
2 + 2
|
|
end
|
|
|
|
def grpc_check
|
|
raise GRPC::DeadlineExceeded
|
|
end
|
|
end
|