mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	Deprecate taint/trust and related methods, and make the methods no-ops
This removes the related tests, and puts the related specs behind version guards. This affects all code in lib, including some libraries that may want to support older versions of Ruby.
This commit is contained in:
		
							parent
							
								
									c5c05460ac
								
							
						
					
					
						commit
						ffd0820ab3
					
				
				
				Notes:
				
					git
				
				2019-11-18 08:01:15 +09:00 
				
			
			
			
		
		
					 201 changed files with 2292 additions and 2874 deletions
				
			
		| 
						 | 
				
			
			@ -9,14 +9,16 @@ describe :extract_range, shared: true do
 | 
			
		|||
    ch.should be_an_instance_of(String)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  it "taints the returned String if the input was tainted" do
 | 
			
		||||
    str = 'abc'
 | 
			
		||||
    str.taint
 | 
			
		||||
  ruby_version_is ''...'2.7' do
 | 
			
		||||
    it "taints the returned String if the input was tainted" do
 | 
			
		||||
      str = 'abc'
 | 
			
		||||
      str.taint
 | 
			
		||||
 | 
			
		||||
    s = StringScanner.new(str)
 | 
			
		||||
      s = StringScanner.new(str)
 | 
			
		||||
 | 
			
		||||
    s.send(@method).tainted?.should be_true
 | 
			
		||||
    s.send(@method).tainted?.should be_true
 | 
			
		||||
    s.send(@method).tainted?.should be_true
 | 
			
		||||
      s.send(@method).tainted?.should be_true
 | 
			
		||||
      s.send(@method).tainted?.should be_true
 | 
			
		||||
      s.send(@method).tainted?.should be_true
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -11,12 +11,14 @@ describe :extract_range_matched, shared: true do
 | 
			
		|||
    ch.should be_an_instance_of(String)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  it "taints the returned String if the input was tainted" do
 | 
			
		||||
    str = 'abc'
 | 
			
		||||
    str.taint
 | 
			
		||||
  ruby_version_is ''...'2.7' do
 | 
			
		||||
    it "taints the returned String if the input was tainted" do
 | 
			
		||||
      str = 'abc'
 | 
			
		||||
      str.taint
 | 
			
		||||
 | 
			
		||||
    s = StringScanner.new(str)
 | 
			
		||||
    s.scan(/\w{1}/)
 | 
			
		||||
    s.send(@method).tainted?.should be_true
 | 
			
		||||
      s = StringScanner.new(str)
 | 
			
		||||
      s.scan(/\w{1}/)
 | 
			
		||||
      s.send(@method).tainted?.should be_true
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -37,11 +37,13 @@ describe :strscan_peek, shared: true do
 | 
			
		|||
    ch.should be_an_instance_of(String)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  it "taints the returned String if the input was tainted" do
 | 
			
		||||
    str = 'abc'
 | 
			
		||||
    str.taint
 | 
			
		||||
  ruby_version_is ''...'2.7' do
 | 
			
		||||
    it "taints the returned String if the input was tainted" do
 | 
			
		||||
      str = 'abc'
 | 
			
		||||
      str.taint
 | 
			
		||||
 | 
			
		||||
    s = StringScanner.new(str)
 | 
			
		||||
    s.send(@method, 1).tainted?.should be_true
 | 
			
		||||
      s = StringScanner.new(str)
 | 
			
		||||
      s.send(@method, 1).tainted?.should be_true
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue