summaryrefslogtreecommitdiff
path: root/spec/ruby/core/regexp/linear_time_spec.rb
blob: cf9e73c37c2b640323d39be9f96e7277ba3dea08 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
require_relative '../../spec_helper'

describe "Regexp.linear_time?" do
  it "returns true if matching can be done in linear time" do
    Regexp.linear_time?(/a/).should == true
    Regexp.linear_time?('a').should == true
  end

  it "returns true if matching can be done in linear time for a binary Regexp" do
    Regexp.linear_time?(/[\x80-\xff]/n).should == true
  end

  it "return false if matching can't be done in linear time" do
    Regexp.linear_time?(/(a)\1/).should == false
    Regexp.linear_time?("(a)\\1").should == false
  end

  it "accepts flags for string argument" do
    Regexp.linear_time?('a', Regexp::IGNORECASE).should == true
  end

  it "warns about flags being ignored for regexp arguments" do
    -> {
      Regexp.linear_time?(/a/, Regexp::IGNORECASE)
    }.should complain(/warning: flags ignored/)
  end

  ruby_version_is "3.3" do
    it "returns true for positive lookarounds" do
      Regexp.linear_time?(/(?:(?=a*)a)*/).should == true
    end
  end
end