require File.join(File.dirname(__FILE__), *%w[.. lib god]) God::EventHandler.load require 'test/unit' require 'set' include God if RUBY_PLATFORM =~ /linux/i && Process.uid != 0 abort <<-EOF ********************************************************************* * * * You need to run these tests as root (netlink requires it) * * * ********************************************************************* EOF end begin require 'mocha' rescue LoadError unless gems ||= false require 'rubygems' gems = true retry else abort "=> You need the Mocha gem to run these tests." end end module God module Conditions class FakeCondition < Condition def test true end end class FakePollCondition < PollCondition def test true end end class FakeEventCondition < EventCondition def register end def deregister end end end module Behaviors class FakeBehavior < Behavior def before_start 'foo' end def after_start 'bar' end end end module Contacts class FakeContact < Contact end class InvalidContact end end def self.reset self.watches = nil self.groups = nil self.server = nil self.inited = nil self.host = nil self.port = nil self.pid_file_directory = nil self.registry.reset end end def silence_warnings old_verbose, $VERBOSE = $VERBOSE, nil yield ensure $VERBOSE = old_verbose end def no_stdout old_stdout = $stdout.dup $stdout.reopen(File.open((PLATFORM =~ /mswin/ ? "NUL" : "/dev/null"), 'w')) yield $stdout.reopen(old_stdout) end def no_stderr old_stderr = $stderr.dup $stderr.reopen(File.open((PLATFORM =~ /mswin/ ? "NUL" : "/dev/null"), 'w')) yield $stderr.reopen(old_stderr) end module Kernel def abort(text) raise SystemExit end def exit(code) raise SystemExit end end module Test::Unit::Assertions def assert_abort assert_raise SystemExit do yield end end end # This allows you to be a good OOP citizen and honor encapsulation, but # still make calls to private methods (for testing) by doing # # obj.bypass.private_thingie(arg1, arg2) # # Which is easier on the eye than # # obj.send(:private_thingie, arg1, arg2) # class Object class Bypass instance_methods.each do |m| undef_method m unless m =~ /^__/ end def initialize(ref) @ref = ref end def method_missing(sym, *args) @ref.__send__(sym, *args) end end def bypass Bypass.new(self) end end