Class: Dynflow::Testing::DummyWorld

Inherits:
Object
  • Object
show all
Extended by:
Mimic
Defined in:
lib/dynflow/testing/dummy_world.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Mimic

mimic!

Constructor Details

#initialize(_config = nil) ⇒ DummyWorld

Returns a new instance of DummyWorld.



12
13
14
15
16
17
18
# File 'lib/dynflow/testing/dummy_world.rb', line 12

def initialize(_config = nil)
  @logger_adapter = Testing.logger_adapter
  @clock          = ManagedClock.new
  @executor       = DummyExecutor.new(self)
  @middleware     = Middleware::World.new
  @coordinator    = DummyCoordinator.new
end

Instance Attribute Details

#actionObject

Returns the value of attribute action.



10
11
12
# File 'lib/dynflow/testing/dummy_world.rb', line 10

def action
  @action
end

#clockObject (readonly)

Returns the value of attribute clock.



9
10
11
# File 'lib/dynflow/testing/dummy_world.rb', line 9

def clock
  @clock
end

#coordinatorObject (readonly)

Returns the value of attribute coordinator.



9
10
11
# File 'lib/dynflow/testing/dummy_world.rb', line 9

def coordinator
  @coordinator
end

#delayed_executorObject (readonly)

Returns the value of attribute delayed_executor.



9
10
11
# File 'lib/dynflow/testing/dummy_world.rb', line 9

def delayed_executor
  @delayed_executor
end

#executorObject (readonly)

Returns the value of attribute executor.



9
10
11
# File 'lib/dynflow/testing/dummy_world.rb', line 9

def executor
  @executor
end

#middlewareObject (readonly)

Returns the value of attribute middleware.



9
10
11
# File 'lib/dynflow/testing/dummy_world.rb', line 9

def middleware
  @middleware
end

Instance Method Details

#action_loggerObject



20
21
22
# File 'lib/dynflow/testing/dummy_world.rb', line 20

def action_logger
  @logger_adapter.action_logger
end

#event(execution_plan_id, step_id, event, future = Concurrent::Promises.resolvable_future) ⇒ Object



36
37
38
# File 'lib/dynflow/testing/dummy_world.rb', line 36

def event(execution_plan_id, step_id, event, future = Concurrent::Promises.resolvable_future)
  executor.event execution_plan_id, step_id, event, future
end

#loggerObject



24
25
26
# File 'lib/dynflow/testing/dummy_world.rb', line 24

def logger
  @logger_adapter.dynflow_logger
end

#persistenceObject



48
49
50
# File 'lib/dynflow/testing/dummy_world.rb', line 48

def persistence
  nil
end

#plan_event(execution_plan_id, step_id, event, time, accepted = Concurrent::Promises.resolvable_future) ⇒ Object



40
41
42
43
44
45
46
# File 'lib/dynflow/testing/dummy_world.rb', line 40

def plan_event(execution_plan_id, step_id, event, time, accepted = Concurrent::Promises.resolvable_future)
  if time.nil? || time < Time.now
    event(execution_plan_id, step_id, event, accepted)
  else
    clock.ping(executor, time, Director::Event[SecureRandom.uuid, execution_plan_id, step_id, event, accepted], :delayed_event)
  end
end

#silence_logger!Object



28
29
30
# File 'lib/dynflow/testing/dummy_world.rb', line 28

def silence_logger!
  action_logger.level = 4
end

#subscribed_actions(klass) ⇒ Object



32
33
34
# File 'lib/dynflow/testing/dummy_world.rb', line 32

def subscribed_actions(klass)
  []
end