1 STDIN.sync = STDOUT.sync = STDERR.sync = true
8 trap('CHLD') { Process.waitpid(-1, Process::WNOHANG) rescue nil }
16 attr_reader :lasterr, :lasterrstr
19 @responses = Hash.new { |h,k| h[k] = [] }
25 err_camel = err_snake.gsub(/(?:^|_)([a-z])/) { $1.upcase } << 'Error'
26 unless MogileFS::Backend.const_defined?(err_camel)
27 MogileFS::Backend.class_eval("class #{err_camel} < MogileFS::Error; end")
29 MogileFS::Backend.const_get(err_camel)
32 def method_missing(meth, *args)
34 if meth =~ /(.*)=$/ then
35 @responses[$1] << args.first
37 response = @responses[meth].shift
40 @lasterr = response.first
41 @lasterrstr = response.last
42 raise error(@lasterr), @lasterrstr
51 class MogileFS::Client
57 attr_reader :port, :pid
60 ObjectSpace.each_object(TempServer) { |t| t.destroy! }
63 at_exit { TempServer.destroy_all! }
65 def initialize(server_proc)
66 @pid = @port = @sock = nil
69 @port = 1024 + rand(32768 - 1024)
70 @sock = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0)
71 @sock.bind(Socket.pack_sockaddr_in(@port, '127.0.0.1'))
73 rescue Errno::EADDRINUSE, Errno::EACCES
74 @sock.close rescue nil
75 retry if (retries += 1) < 10
77 @pid = fork { server_proc.call(@sock, @port) }
78 @sock.close rescue nil
82 @sock.close rescue nil
83 Process.kill('KILL', @pid) rescue nil
88 class TestMogileFS < Test::Unit::TestCase
90 undef_method :default_test if method_defined?(:default_test)
93 @client = @klass.new :hosts => ['kaa:6001'], :domain => 'test'
94 @backend = FakeBackend.new
95 @client.instance_variable_set '@backend', @backend
100 # for our mock results
102 alias_method :fetch_row, :shift
108 # devid, hostip, altip, http_port, http_get_port
109 [ 1, '10.0.0.1', '192.168.0.1', 7500, 7600 ],
110 [ 2, '10.0.0.2', '192.168.0.2', 7500, 7600 ],
111 [ 3, '10.0.0.3', nil, 7500, nil ],
112 [ 4, '10.0.0.4', nil, 7500, nil ],
125 str.to_s.gsub(/\\/, '\&\&').gsub(/'/, "''")
130 when MogileFS::Mysql::GET_DEVICES then TBL_DEVICES
131 when MogileFS::Mysql::GET_DOMAINS then TBL_DOMAINS