Sha256: e2c6c1fc5efcf3f77bf7651c17d0c5678b8fa499e316ec983e000d91d91461b1

Contents?: true

Size: 1.8 KB

Versions: 6

Compression:

Stored size: 1.8 KB

Contents

# encoding: utf-8
# Copyright 2014 Aerospike, Inc.
#
# Portions may be licensed to Aerospike, Inc. under one or more contributor
# license agreements.
#
# 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 'thread'
require 'time'
require 'aerospike/atomic/atomic'

module Aerospike

  private

  class Task

    def initialize(cluster, done)
      @cluster = cluster
      @done = Atomic.new(done)
      @done_thread = Atomic.new(nil)

      self
    end

    def wait_till_completed(poll_interval = 0.1, allowed_failures = 3)
      return true if @done.value

      # make sure there will be only ONE thread polling for completetion status
      @done_thread.update do |dt|
        dt ? dt : Thread.new do
          Thread.current.abort_on_exception = true
          failures = 0
          while true
            begin
              sleep(poll_interval.to_f)
              break if completed?
            rescue => e
              Aerospike.logger.error(e)
              break if failures > allowed_failures
              failures += 1
            end
          end
        end
      end

      # wait for the poll thread to finish
      @done_thread.value.join
      # in case of errors and exceptions, the @done value might be false
      @done.value
    end

    def completed?
      @done.value ||= all_nodes_done?
    end

  end # class

end # module

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
aerospike-2.3.0 lib/aerospike/task/task.rb
aerospike-2.2.1 lib/aerospike/task/task.rb
aerospike-2.2.0 lib/aerospike/task/task.rb
aerospike-2.1.1 lib/aerospike/task/task.rb
aerospike-2.1.0 lib/aerospike/task/task.rb
aerospike-2.0.0 lib/aerospike/task/task.rb