Skip to content

Commit

Permalink
Undelete specs when I meant to delete tags
Browse files Browse the repository at this point in the history
  • Loading branch information
enebo committed Oct 27, 2014
1 parent fa759ef commit 85422a6
Showing 1 changed file with 74 additions and 0 deletions.
74 changes: 74 additions & 0 deletions spec/ruby/language/match_spec.rb
@@ -0,0 +1,74 @@
require File.expand_path('../../spec_helper', __FILE__)
require File.expand_path('../fixtures/match_operators', __FILE__)

describe "The !~ operator" do
before :each do
@obj = OperatorImplementor.new
end

it "evaluates as a call to !~" do
expected = "hello world"

opval = (@obj !~ expected)
methodval = @obj.send(:"!~", expected)

opval.should == expected
methodval.should == expected
end
end

describe "The =~ operator" do
before :each do
@impl = OperatorImplementor.new
end

it "calls the =~ method" do
expected = "hello world"

opval = (@obj =~ expected)
methodval = @obj.send(:"=~", expected)

opval.should == expected
methodval.should == expected
end
end

describe "The =~ operator with named captures" do
before(:each) do
@regexp = /(?<matched>foo)(?<unmatched>bar)?/
@string = "foofoo"
end

describe "on syntax of /regexp/ =~ string_variable" do
it "sets local variables by the captured pairs" do
/(?<matched>foo)(?<unmatched>bar)?/ =~ @string
local_variables.should == [:matched, :unmatched]
matched.should == "foo"
unmatched.should == nil
end
end

describe "on syntax of string_variable =~ /regexp/" do
it "does not set local variables" do
@string =~ /(?<matched>foo)(?<unmatched>bar)?/
local_variables.should == []
end
end

describe "on syntax of regexp_variable =~ string_variable" do
it "does not set local variables" do
@regexp =~ @string
local_variables.should == []
end
end

describe "on the method calling" do
it "does not set local variables" do
@regexp.=~(@string)
local_variables.should == []

@regexp.send :=~, @string
local_variables.should == []
end
end
end

0 comments on commit 85422a6

Please sign in to comment.