Module: OracleBMC::LoadBalancer::Util
- Defined in:
- lib/oraclebmc/load_balancer/util.rb
Overview
Load balancer utility methods
Class Method Summary collapse
-
.wait_on_work_request(client, work_request_id, max_interval_seconds: 30, max_wait_seconds: 1200, raise_error_on_failure: true) ⇒ WorkRequest
Wait until the work request succeeds or fails, or max_wait_seconds is reached.
Class Method Details
.wait_on_work_request(client, work_request_id, max_interval_seconds: 30, max_wait_seconds: 1200, raise_error_on_failure: true) ⇒ WorkRequest
Wait until the work request succeeds or fails, or max_wait_seconds is reached. The work request will be polled at an increasing rate, with a maximum of max_interval_seconds between requests.
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/oraclebmc/load_balancer/util.rb', line 17 def self.wait_on_work_request(client, work_request_id, max_interval_seconds: 30, max_wait_seconds: 1200, raise_error_on_failure:true) fail "Work request ID not specified." unless work_request_id interval_seconds = 1 start_time = Time.now while true response = client.get_work_request(work_request_id) if response.data.lifecycle_state == OracleBMC::LoadBalancer::Models::WorkRequest::LIFECYCLE_STATE_SUCCEEDED return response.data elsif response.data.lifecycle_state == OracleBMC::LoadBalancer::Models::WorkRequest::LIFECYCLE_STATE_FAILED if raise_error_on_failure raise OracleBMC::Errors::WorkRequestFailedError.new(response.data) else return response.data end end elapsed_seconds = (Time.now - start_time).to_i if elapsed_seconds + interval_seconds > max_wait_seconds if max_wait_seconds > elapsed_seconds # Make one last request right at the maximum wait time. interval_seconds = max_wait_seconds - elapsed_seconds else raise OracleBMC::Errors::MaximumWaitTimeExceededError.new('Maximum wait time has been exceeded.') end end sleep(interval_seconds) interval_seconds *= 2 if interval_seconds > max_interval_seconds interval_seconds = max_interval_seconds end end end |