Sha256: c49833d464029acbbf680024ff19701c4a231a6bc576ed2cf17cb1a6a7e239d6

Contents?: true

Size: 1.28 KB

Versions: 2

Compression:

Stored size: 1.28 KB

Contents

# encoding: utf-8
require File.dirname(__FILE__) + '/spec_helper'

describe "Twitter::Regex regular expressions" do
  describe "matching URLS" do
    TestUrls::VALID.each do |url|
      it "should match the URL #{url}" do
        url.should match_autolink_expression
      end

      it "should match the URL #{url} when it's embedded in other text" do
        text = "Sweet url: #{url} I found. #awesome"
        url.should match_autolink_expression_in(text)
      end
    end
  end

  describe "invalid URLS" do
    it "does not link urls with invalid characters" do
      TestUrls::INVALID.each {|url| url.should_not match_autolink_expression}
    end
  end

  describe "matching List names" do
    it "should match if less than 25 characters" do
      name = "Shuffleboard Community"
      name.length.should < 25
      name.should match(Twitter::Regex::REGEXEN[:list_name])
    end

    it "should not match if greater than 25 characters" do
      name = "Most Glorious Shady Meadows Shuffleboard Community"
      name.length.should > 25
      name.should match(Twitter::Regex[:list_name])
    end

    it "should match Japense names less than 25 characters" do
      name = CGI.unescape("%E4%B9%97")
      name.length.should < 25
      name.should match(Twitter::Regex[:list_name])
    end

  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
twitter-text-1.1.6 spec/regex_spec.rb
twitter-text-1.1.5 spec/regex_spec.rb