mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Update to ruby/spec@83063a3
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62094 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
1e658d45e1
commit
3fa5bd38af
494 changed files with 4133 additions and 3109 deletions
|
@ -1,5 +1,5 @@
|
|||
require File.expand_path('../../../shared/enumerator/each', __FILE__)
|
||||
|
||||
describe "Enumerator#each" do
|
||||
it_behaves_like(:enum_each, :each)
|
||||
it_behaves_like :enum_each, :each
|
||||
end
|
||||
|
|
|
@ -3,8 +3,8 @@ require File.expand_path('../../../shared/enumerator/with_index', __FILE__)
|
|||
require File.expand_path('../../enumerable/shared/enumeratorized', __FILE__)
|
||||
|
||||
describe "Enumerator#each_with_index" do
|
||||
it_behaves_like(:enum_with_index, :each_with_index)
|
||||
it_behaves_like(:enumeratorized_with_origin_size, :each_with_index, [1,2,3].select)
|
||||
it_behaves_like :enum_with_index, :each_with_index
|
||||
it_behaves_like :enumeratorized_with_origin_size, :each_with_index, [1,2,3].select
|
||||
|
||||
it "returns a new Enumerator when no block is given" do
|
||||
enum1 = [1,2,3].select
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
require File.expand_path('../../../shared/enumerator/each', __FILE__)
|
||||
|
||||
describe "Enumerator#inject" do
|
||||
it_behaves_like(:enum_each, :each)
|
||||
it_behaves_like :enum_each, :each
|
||||
|
||||
it "works when chained against each_with_index" do
|
||||
passed_values = []
|
||||
|
|
71
spec/ruby/core/enumerator/lazy/chunk_spec.rb
Normal file
71
spec/ruby/core/enumerator/lazy/chunk_spec.rb
Normal file
|
@ -0,0 +1,71 @@
|
|||
# -*- encoding: us-ascii -*-
|
||||
|
||||
require File.expand_path('../../../../spec_helper', __FILE__)
|
||||
require File.expand_path('../fixtures/classes', __FILE__)
|
||||
|
||||
describe "Enumerator::Lazy#chunk" do
|
||||
|
||||
before :each do
|
||||
@yieldsmixed = EnumeratorLazySpecs::YieldsMixed.new.to_enum.lazy
|
||||
@eventsmixed = EnumeratorLazySpecs::EventsMixed.new.to_enum.lazy
|
||||
ScratchPad.record []
|
||||
end
|
||||
|
||||
after :each do
|
||||
ScratchPad.clear
|
||||
end
|
||||
|
||||
it "returns a new instance of Enumerator::Lazy" do
|
||||
ret = @yieldsmixed.chunk {}
|
||||
ret.should be_an_instance_of(Enumerator::Lazy)
|
||||
ret.should_not equal(@yieldsmixed)
|
||||
end
|
||||
|
||||
it "sets #size to nil" do
|
||||
Enumerator::Lazy.new(Object.new, 100) {}.chunk { |v| v }.size.should == nil
|
||||
end
|
||||
|
||||
ruby_version_is ""..."2.4" do
|
||||
it "raises an ArgumentError if called without a block" do
|
||||
lambda do
|
||||
@yieldsmixed.chunk
|
||||
end.should raise_error(ArgumentError)
|
||||
end
|
||||
end
|
||||
|
||||
ruby_version_is "2.4" do
|
||||
it "returns an Enumerator if called without a block" do
|
||||
chunk = @yieldsmixed.chunk
|
||||
chunk.should be_an_instance_of(Enumerator::Lazy)
|
||||
|
||||
res = chunk.each { |v| true }.force
|
||||
res.should == [[true, EnumeratorLazySpecs::YieldsMixed.gathered_yields]]
|
||||
end
|
||||
end
|
||||
|
||||
describe "when the returned lazy enumerator is evaluated by Enumerable#first" do
|
||||
it "stops after specified times" do
|
||||
first_two = (0..Float::INFINITY).lazy.chunk { |n| n.even? }.first(2)
|
||||
first_two.should == [[true, [0]], [false, [1]]]
|
||||
end
|
||||
end
|
||||
|
||||
it "calls the block with gathered values when yield with multiple arguments" do
|
||||
yields = []
|
||||
@yieldsmixed.chunk { |v| yields << v; true }.force
|
||||
yields.should == EnumeratorLazySpecs::YieldsMixed.gathered_yields
|
||||
end
|
||||
|
||||
describe "on a nested Lazy" do
|
||||
it "sets #size to nil" do
|
||||
Enumerator::Lazy.new(Object.new, 100) {}.take(20).chunk { |v| v }.size.should == nil
|
||||
end
|
||||
|
||||
describe "when the returned lazy enumerator is evaluated by Enumerable#first" do
|
||||
it "stops after specified times" do
|
||||
remains_lazy = (0..Float::INFINITY).lazy.chunk { |n| n }
|
||||
remains_lazy.chunk { |n| n }.first(2).size.should == 2
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
|
@ -2,5 +2,5 @@ require File.expand_path('../../../spec_helper', __FILE__)
|
|||
require File.expand_path('../../../shared/enumerator/new', __FILE__)
|
||||
|
||||
describe "Enumerator.new" do
|
||||
it_behaves_like(:enum_new, :new)
|
||||
it_behaves_like :enum_new, :new
|
||||
end
|
||||
|
|
|
@ -2,5 +2,5 @@ require File.expand_path('../../../spec_helper', __FILE__)
|
|||
require File.expand_path('../../../shared/enumerator/next', __FILE__)
|
||||
|
||||
describe "Enumerator#next" do
|
||||
it_behaves_like(:enum_next,:next)
|
||||
it_behaves_like :enum_next,:next
|
||||
end
|
||||
|
|
|
@ -3,7 +3,7 @@ require File.expand_path('../../../shared/enumerator/rewind', __FILE__)
|
|||
require File.expand_path('../fixtures/common', __FILE__)
|
||||
|
||||
describe "Enumerator#rewind" do
|
||||
it_behaves_like(:enum_rewind, :rewind)
|
||||
it_behaves_like :enum_rewind, :rewind
|
||||
|
||||
it "calls the enclosed object's rewind method if one exists" do
|
||||
obj = mock('rewinder')
|
||||
|
|
|
@ -3,8 +3,8 @@ require File.expand_path('../../../shared/enumerator/with_index', __FILE__)
|
|||
require File.expand_path('../../enumerable/shared/enumeratorized', __FILE__)
|
||||
|
||||
describe "Enumerator#with_index" do
|
||||
it_behaves_like(:enum_with_index, :with_index)
|
||||
it_behaves_like(:enumeratorized_with_origin_size, :with_index, [1,2,3].select)
|
||||
it_behaves_like :enum_with_index, :with_index
|
||||
it_behaves_like :enumeratorized_with_origin_size, :with_index, [1,2,3].select
|
||||
|
||||
it "returns a new Enumerator when no block is given" do
|
||||
enum1 = [1,2,3].select
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue