Class: ForemanTasksCore::Runner::Dispatcher::RunnerActor

Inherits:
Dynflow::Actor
  • Object
show all
Defined in:
lib/foreman_tasks_core/runner/dispatcher.rb

Instance Method Summary collapse

Constructor Details

#initialize(dispatcher, suspended_action, runner, clock, logger, options = {}) ⇒ RunnerActor

Returns a new instance of RunnerActor.



13
14
15
16
17
18
19
20
21
22
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 13

def initialize(dispatcher, suspended_action, runner, clock, logger, options = {})
  @dispatcher = dispatcher
  @clock = clock
  @ticker = dispatcher.ticker
  @logger = logger
  @suspended_action = suspended_action
  @runner = runner
  @finishing = false
  @refresh_interval = options[:refresh_interval] || 1
end

Instance Method Details

#finishObject



64
65
66
67
68
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 64

def finish
  @logger.debug("finish runner #{@runner.id}")
  @finishing = true
  @dispatcher.finish(@runner.id)
end

#killObject



57
58
59
60
61
62
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 57

def kill
  @logger.debug("kill runner #{@runner.id}")
  @runner.kill
rescue => e
  handle_exception(e, false)
end

#on_envelope(*args) ⇒ Object



24
25
26
27
28
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 24

def on_envelope(*args)
  super
rescue => e
  handle_exception(e)
end

#refresh_runnerObject



39
40
41
42
43
44
45
46
47
48
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 39

def refresh_runner
  @logger.debug("refresh runner #{@runner.id}")
  if (update = @runner.run_refresh)
    @suspended_action << update
    finish if update.exit_status
  end
ensure
  @refresh_planned = false
  plan_next_refresh
end

#start_runnerObject



30
31
32
33
34
35
36
37
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 30

def start_runner
  @logger.debug("start runner #{@runner.id}")
  set_timeout if @runner.timeout_interval
  @runner.start
  refresh_runner
ensure
  plan_next_refresh
end

#start_termination(*args) ⇒ Object



70
71
72
73
74
75
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 70

def start_termination(*args)
  @logger.debug("terminate #{@runner.id}")
  super
  @runner.close
  finish_termination
end

#timeout_runnerObject



50
51
52
53
54
55
# File 'lib/foreman_tasks_core/runner/dispatcher.rb', line 50

def timeout_runner
  @logger.debug("timeout runner #{@runner.id}")
  @runner.timeout
rescue => e
  handle_exception(e, false)
end