restructured messages
This commit is contained in:
parent
1c25d7c73c
commit
847c77ef0f
@ -25,9 +25,9 @@ module Hydra #:nodoc:
|
||||
def send_file(worker)
|
||||
f = @files.pop
|
||||
if f
|
||||
worker[:io].write(Hydra::Messages::Worker::RunFile.new(:file => f))
|
||||
worker[:io].write(Hydra::Messages::Master::RunFile.new(:file => f))
|
||||
else
|
||||
worker[:io].write(Hydra::Messages::Worker::Shutdown.new)
|
||||
worker[:io].write(Hydra::Messages::Master::Shutdown.new)
|
||||
Thread.exit
|
||||
end
|
||||
end
|
||||
@ -50,7 +50,6 @@ module Hydra #:nodoc:
|
||||
def process_messages
|
||||
@running = true
|
||||
|
||||
# TODO catch exceptions and report to stdout
|
||||
Thread.abort_on_exception = true
|
||||
|
||||
@workers.each do |w|
|
||||
|
@ -1,6 +1,19 @@
|
||||
module Hydra #:nodoc:
|
||||
module Messages #:nodoc:
|
||||
module Master #:nodoc:
|
||||
# Message telling a worker to delegate a file to a runner
|
||||
class RunFile < Hydra::Messages::Worker::RunFile
|
||||
def handle(worker) #:nodoc:
|
||||
worker.delegate_file(self)
|
||||
end
|
||||
end
|
||||
|
||||
# Message telling the worker to shut down.
|
||||
class Shutdown < Hydra::Messages::Worker::Shutdown
|
||||
def handle(worker) #:nodoc:
|
||||
worker.shutdown
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -8,19 +8,6 @@ module Hydra #:nodoc:
|
||||
end
|
||||
end
|
||||
|
||||
# Message telling the Runner to run a file
|
||||
# TODO: move to worker
|
||||
class RunFile < Hydra::Message
|
||||
# The file that should be run
|
||||
attr_accessor :file
|
||||
def serialize #:nodoc:
|
||||
super(:file => @file)
|
||||
end
|
||||
def handle(runner) #:nodoc:
|
||||
runner.run_file(@file)
|
||||
end
|
||||
end
|
||||
|
||||
# Message for the Runner to respond with its results
|
||||
class Results < Hydra::Message
|
||||
# The output from running the test
|
||||
@ -35,14 +22,6 @@ module Hydra #:nodoc:
|
||||
end
|
||||
end
|
||||
|
||||
# Message to tell the Runner to shut down
|
||||
# TODO: move to worker
|
||||
class Shutdown < Hydra::Message
|
||||
def handle(runner) #:nodoc:
|
||||
runner.stop
|
||||
end
|
||||
end
|
||||
|
||||
# Message a runner sends to a worker to verify the connection
|
||||
class Ping < Hydra::Message
|
||||
def handle(worker, runner) #:nodoc:
|
||||
|
@ -8,11 +8,22 @@ module Hydra #:nodoc:
|
||||
end
|
||||
end
|
||||
|
||||
# Message telling a worker to delegate a file to a runner
|
||||
# TODO: move to master messages
|
||||
class RunFile < Hydra::Messages::Runner::RunFile
|
||||
def handle(worker) #:nodoc:
|
||||
worker.delegate_file(self)
|
||||
# Message telling the Runner to run a file
|
||||
class RunFile < Hydra::Message
|
||||
# The file that should be run
|
||||
attr_accessor :file
|
||||
def serialize #:nodoc:
|
||||
super(:file => @file)
|
||||
end
|
||||
def handle(runner) #:nodoc:
|
||||
runner.run_file(@file)
|
||||
end
|
||||
end
|
||||
|
||||
# Message to tell the Runner to shut down
|
||||
class Shutdown < Hydra::Message
|
||||
def handle(runner) #:nodoc:
|
||||
runner.stop
|
||||
end
|
||||
end
|
||||
|
||||
@ -23,14 +34,6 @@ module Hydra #:nodoc:
|
||||
end
|
||||
end
|
||||
|
||||
# Message telling the worker to shut down.
|
||||
# TODO: move to master
|
||||
class Shutdown < Hydra::Messages::Runner::Shutdown
|
||||
def handle(worker) #:nodoc:
|
||||
worker.shutdown
|
||||
end
|
||||
end
|
||||
|
||||
# Message a worker sends to a master to verify the connection
|
||||
class Ping < Hydra::Message
|
||||
def handle(master, worker) #:nodoc:
|
||||
|
@ -38,7 +38,7 @@ module Hydra #:nodoc:
|
||||
def delegate_file(message)
|
||||
r = idle_runner
|
||||
r[:idle] = false
|
||||
r[:io].write(Hydra::Messages::Runner::RunFile.new(eval(message.serialize)))
|
||||
r[:io].write(Hydra::Messages::Worker::RunFile.new(eval(message.serialize)))
|
||||
end
|
||||
|
||||
# When a runner finishes, it sends the results up to the worker. Then the
|
||||
@ -60,7 +60,7 @@ module Hydra #:nodoc:
|
||||
@runners.each do |r|
|
||||
$stdout.write "WORKER| Sending Shutdown to Runner\n" if @verbose
|
||||
$stdout.write " | #{r.inspect}\n" if @verbose
|
||||
r[:io].write(Hydra::Messages::Runner::Shutdown.new)
|
||||
r[:io].write(Hydra::Messages::Worker::Shutdown.new)
|
||||
end
|
||||
Thread.exit
|
||||
end
|
||||
|
@ -41,13 +41,13 @@ class RunnerTest < Test::Unit::TestCase
|
||||
|
||||
# make sure it asks for a file, then give it one
|
||||
assert pipe.gets.is_a?(Hydra::Messages::Runner::RequestFile)
|
||||
pipe.write(Hydra::Messages::Runner::RunFile.new(:file => TESTFILE))
|
||||
pipe.write(Hydra::Messages::Worker::RunFile.new(:file => TESTFILE))
|
||||
|
||||
# grab its response. This makes us wait for it to finish
|
||||
response = pipe.gets
|
||||
|
||||
# tell it to shut down
|
||||
pipe.write(Hydra::Messages::Runner::Shutdown.new)
|
||||
pipe.write(Hydra::Messages::Worker::Shutdown.new)
|
||||
|
||||
# ensure it ran
|
||||
assert File.exists?(TARGET)
|
||||
|
@ -44,11 +44,11 @@ class WorkerTest < Test::Unit::TestCase
|
||||
num_runners.times do
|
||||
assert pipe.gets.is_a?(Hydra::Messages::Worker::RequestFile)
|
||||
end
|
||||
pipe.write(Hydra::Messages::Worker::RunFile.new(:file => TESTFILE))
|
||||
pipe.write(Hydra::Messages::Master::RunFile.new(:file => TESTFILE))
|
||||
|
||||
assert pipe.gets.is_a?(Hydra::Messages::Worker::Results)
|
||||
|
||||
pipe.write(Hydra::Messages::Worker::Shutdown.new)
|
||||
pipe.write(Hydra::Messages::Master::Shutdown.new)
|
||||
|
||||
assert File.exists?(TARGET)
|
||||
assert_equal "HYDRA", File.read(TARGET)
|
||||
|
Loading…
Reference in New Issue
Block a user