mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	* object.c, numeric.c, enum.c, ext/-test-/bignum/mul.c, lib/rexml/quickpath.rb, lib/rexml/text.rb, lib/rexml/xpath_parser.rb, lib/rubygems/specification.rb, lib/uri/generic.rb, bootstraptest/test_eval.rb, basictest/test.rb, test/-ext-/bignum/test_big2str.rb, test/-ext-/bignum/test_div.rb, test/-ext-/bignum/test_mul.rb, test/-ext-/bignum/test_str2big.rb, test/csv/test_data_converters.rb, test/date/test_date.rb, test/json/test_json_generate.rb, test/minitest/test_minitest_mock.rb, test/openssl/test_cipher.rb, test/rexml/test_jaxen.rb, test/ruby/test_array.rb, test/ruby/test_basicinstructions.rb, test/ruby/test_bignum.rb, test/ruby/test_case.rb, test/ruby/test_class.rb, test/ruby/test_complex.rb, test/ruby/test_enum.rb, test/ruby/test_eval.rb, test/ruby/test_iseq.rb, test/ruby/test_literal.rb, test/ruby/test_math.rb, test/ruby/test_module.rb, test/ruby/test_numeric.rb, test/ruby/test_range.rb, test/ruby/test_rational.rb, test/ruby/test_refinement.rb, test/ruby/test_rubyvm.rb, test/ruby/test_struct.rb, test/ruby/test_variable.rb, test/rubygems/test_gem_specification.rb, test/thread/test_queue.rb: Use Integer instead of Fixnum and Bignum. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55029 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			146 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: false
 | 
						|
require 'test/unit'
 | 
						|
 | 
						|
class TestCase < Test::Unit::TestCase
 | 
						|
  def test_case
 | 
						|
    case 5
 | 
						|
    when 1, 2, 3, 4, 6, 7, 8
 | 
						|
      assert(false)
 | 
						|
    when 5
 | 
						|
      assert(true)
 | 
						|
    end
 | 
						|
 | 
						|
    case 5
 | 
						|
    when 5
 | 
						|
      assert(true)
 | 
						|
    when 1..10
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case 5
 | 
						|
    when 1..10
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case 5
 | 
						|
    when 5
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case "foobar"
 | 
						|
    when /^f.*r$/
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case
 | 
						|
    when true
 | 
						|
      assert(true)
 | 
						|
    when false, nil
 | 
						|
      assert(false)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case "+"
 | 
						|
    when *%w/. +/
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    case
 | 
						|
    when *[], false
 | 
						|
      assert(false)
 | 
						|
    else
 | 
						|
      assert(true)
 | 
						|
    end
 | 
						|
 | 
						|
    case
 | 
						|
    when *false, []
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
 | 
						|
    assert_raise(NameError) do
 | 
						|
      case
 | 
						|
      when false, *x, false
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def test_deoptimization
 | 
						|
    assert_in_out_err(['-e', <<-EOS], '', %w[42], [])
 | 
						|
      class Symbol; undef ===; def ===(o); p 42; true; end; end; case :foo; when :foo; end
 | 
						|
    EOS
 | 
						|
 | 
						|
    assert_in_out_err(['-e', <<-EOS], '', %w[42], [])
 | 
						|
      class Integer; undef ===; def ===(o); p 42; true; end; end; case 1; when 1; end
 | 
						|
    EOS
 | 
						|
  end
 | 
						|
 | 
						|
  def test_optimization
 | 
						|
    case 1
 | 
						|
    when 0.9, 1.1
 | 
						|
      assert(false)
 | 
						|
    when 1.0
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
    case 536870912
 | 
						|
    when 536870911.9, 536870912.1
 | 
						|
      assert(false)
 | 
						|
    when 536870912.0
 | 
						|
      assert(true)
 | 
						|
    else
 | 
						|
      assert(false)
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def test_method_missing
 | 
						|
    flag = false
 | 
						|
 | 
						|
    case 1
 | 
						|
    when Class.new(BasicObject) { def method_missing(*) true end }.new
 | 
						|
      flag = true
 | 
						|
    end
 | 
						|
 | 
						|
    assert(flag)
 | 
						|
  end
 | 
						|
 | 
						|
  def test_nomethoderror
 | 
						|
    assert_raise(NoMethodError) {
 | 
						|
      case 1
 | 
						|
      when Class.new(BasicObject) { }.new
 | 
						|
      end
 | 
						|
    }
 | 
						|
  end
 | 
						|
 | 
						|
  module NilEqq
 | 
						|
    refine NilClass do
 | 
						|
      def === other
 | 
						|
        false
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  class NilEqqClass
 | 
						|
    using NilEqq
 | 
						|
 | 
						|
    def eqq(a)
 | 
						|
      case a; when nil then nil; else :not_nil; end
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
 | 
						|
  def test_deoptimize_nil
 | 
						|
    assert_equal :not_nil, NilEqqClass.new.eqq(nil)
 | 
						|
  end
 | 
						|
end
 |