bca595a964
Changes: - remove report from task engine; - remove old logic for hangs and 'idling' statuses; - increase code redability; - add code docs; - support retries in case of MClient errors for status and run actions; - replace timeout raise on usual code; - descrease waiting time for puppet run (from 120 to 10) and time between try (from 30 to 2); - mcollective retry descrease from 5 to 1. Now it will use puppet retries if failed during network/mcollective problem after 1 try. Closes-Bug: #1613396 Change-Id: I98fe3df65ef335b03eceb2c401eba12cf68ee1c8
50 lines
1.1 KiB
Ruby
50 lines
1.1 KiB
Ruby
# Copyright 2016 Mirantis, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
require 'timeout'
|
|
|
|
module Astute
|
|
class TimeObserver
|
|
|
|
def initialize(timeout)
|
|
@timeout = timeout
|
|
end
|
|
|
|
def start
|
|
@time_before = Time.now
|
|
end
|
|
|
|
def since_start
|
|
(Time.now - @time_before).to_i
|
|
end
|
|
|
|
def enough_time?
|
|
since_start < time_limit
|
|
end
|
|
|
|
def time_is_up?
|
|
!enough_time?
|
|
end
|
|
|
|
def left_time
|
|
time_limit - since_start
|
|
end
|
|
|
|
def time_limit
|
|
@timeout
|
|
end
|
|
|
|
end #TimeObserver
|
|
end
|