Sha256: dd45b67d8ceb384f9bc4f2d37ff5a0baad132fc860c13a2d87d4f62199fa012f

Contents?: true

Size: 1.69 KB

Versions: 25

Compression:

Stored size: 1.69 KB

Contents

#!/usr/bin/env ruby
# frozen_string_literal: true
example_description = <<DESC

  Sub Plans Example
  ===================

  This example shows, how singleton actions can be used for making sure
  there is only one instance of the action running at a time.

  Singleton actions try to obtain a lock at the beggining of their plan
  phase and fail if they can't do so. In run phase they check if they
  have the lock and try to acquire it again if they don't. These actions
  release the lock at the end of their finalize phase.

DESC

require_relative 'example_helper'

class SingletonExample < Dynflow::Action
  include Dynflow::Action::Singleton

  def run
    sleep 10
  end
end

class SingletonExampleA < SingletonExample; end
class SingletonExampleB < SingletonExample; end

if $0 == __FILE__
  ExampleHelper.world.action_logger.level = Logger::INFO
  ExampleHelper.world
  t1 = ExampleHelper.world.trigger(SingletonExampleA)
  t2 = ExampleHelper.world.trigger(SingletonExampleA)
  ExampleHelper.world.trigger(SingletonExampleA) unless SingletonExampleA.singleton_locked?(ExampleHelper.world)
  t3 = ExampleHelper.world.trigger(SingletonExampleB)
  db = ExampleHelper.world.persistence.adapter.db

  puts example_description
  puts <<-MSG.gsub(/^.*\|/, '')
    |  3 execution plans were triggered:
    |  #{t1.id} should finish successfully
    |  #{t3.id} should finish successfully because it is a singleton of different class
    |  #{t2.id} should fail because #{t1.id} holds the lock
    |
    |  You can see the details at
    |    #{ExampleHelper::DYNFLOW_URL}/#{t1.id}
    |    #{ExampleHelper::DYNFLOW_URL}/#{t2.id}
    |    #{ExampleHelper::DYNFLOW_URL}/#{t3.id}
    |
  MSG
  ExampleHelper.run_web_console
end

Version data entries

25 entries across 25 versions & 1 rubygems

Version Path
dynflow-1.8.2 examples/singletons.rb
dynflow-1.8.1 examples/singletons.rb
dynflow-1.8.0 examples/singletons.rb
dynflow-1.7.0 examples/singletons.rb
dynflow-1.6.11 examples/singletons.rb
dynflow-1.6.10 examples/singletons.rb
dynflow-1.6.8 examples/singletons.rb
dynflow-1.6.7 examples/singletons.rb
dynflow-1.6.6 examples/singletons.rb
dynflow-1.6.5 examples/singletons.rb
dynflow-1.6.4 examples/singletons.rb
dynflow-1.6.3 examples/singletons.rb
dynflow-1.6.2 examples/singletons.rb
dynflow-1.6.1 examples/singletons.rb
dynflow-1.4.9 examples/singletons.rb
dynflow-1.4.8 examples/singletons.rb
dynflow-1.5.0 examples/singletons.rb
dynflow-1.4.7 examples/singletons.rb
dynflow-1.4.6 examples/singletons.rb
dynflow-1.4.5 examples/singletons.rb