mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	to load rubygems. if it activated, ruby raises LoadError about rbconfig.rb. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@30611 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
require_relative '../ruby/envutil'
 | 
						|
require "webrick"
 | 
						|
begin
 | 
						|
  require "webrick/https"
 | 
						|
rescue LoadError
 | 
						|
end
 | 
						|
require "webrick/httpproxy"
 | 
						|
 | 
						|
module TestWEBrick
 | 
						|
  NullWriter = Object.new
 | 
						|
  def NullWriter.<<(msg)
 | 
						|
    puts msg if $DEBUG
 | 
						|
    return self
 | 
						|
  end
 | 
						|
 | 
						|
  RubyBin = "\"#{EnvUtil.rubybin}\""
 | 
						|
  RubyBin << " --disable-gems"
 | 
						|
  RubyBin << " \"-I#{File.expand_path("../..", File.dirname(__FILE__))}/lib\""
 | 
						|
  RubyBin << " \"-I#{File.dirname(EnvUtil.rubybin)}/.ext/common\""
 | 
						|
  RubyBin << " \"-I#{File.dirname(EnvUtil.rubybin)}/.ext/#{RUBY_PLATFORM}\""
 | 
						|
 | 
						|
  module_function
 | 
						|
 | 
						|
  def start_server(klass, config={}, &block)
 | 
						|
    log_string = ""
 | 
						|
    logger = Object.new
 | 
						|
    logger.instance_eval do
 | 
						|
      define_singleton_method(:<<) {|msg| log_string << msg }
 | 
						|
    end
 | 
						|
    log = proc { "webrick log start:\n" + log_string.gsub(/^/, "  ").chomp + "\nwebrick log end" }
 | 
						|
    server = klass.new({
 | 
						|
      :BindAddress => "127.0.0.1", :Port => 0,
 | 
						|
      :ShutdownSocketWithoutClose =>true,
 | 
						|
      :ServerType => Thread,
 | 
						|
      :Logger => WEBrick::Log.new(logger),
 | 
						|
      :AccessLog => [[logger, ""]]
 | 
						|
    }.update(config))
 | 
						|
    begin
 | 
						|
      server.start
 | 
						|
      addr = server.listeners[0].addr
 | 
						|
      block.yield([server, addr[3], addr[1], log])
 | 
						|
    ensure
 | 
						|
      server.shutdown
 | 
						|
      until server.status == :Stop
 | 
						|
        sleep 0.1
 | 
						|
      end
 | 
						|
    end
 | 
						|
    log_string
 | 
						|
  end
 | 
						|
 | 
						|
  def start_httpserver(config={}, &block)
 | 
						|
    start_server(WEBrick::HTTPServer, config, &block)
 | 
						|
  end
 | 
						|
 | 
						|
  def start_httpproxy(config={}, &block)
 | 
						|
    start_server(WEBrick::HTTPProxyServer, config, &block)
 | 
						|
  end
 | 
						|
end
 |