Sha256: 853d8d0bac5f6dcd40d2ef77b014f1b226c85bc2431ae051f418c95dd6f0421f

Contents?: true

Size: 1.99 KB

Versions: 1

Compression:

Stored size: 1.99 KB

Contents

require 'test/unit'
require 'amatch'

class TC_LongestSubstring < Test::Unit::TestCase
  include Amatch

  D = 0.000001

  def setup
    @small   = LongestSubstring.new('test')
    @empty   = LongestSubstring.new('')
  end

  def test_empty_substring
    assert_in_delta 0, @empty.match(''), D
    assert_in_delta 0, @empty.match('a'), D
    assert_in_delta 0, @small.match(''), D
    assert_in_delta 0, @empty.match('not empty'), D
  end

  def test_small_substring
    assert_in_delta 4, @small.match('test'), D
    assert_in_delta 4, @small.match('testa'), D
    assert_in_delta 4, @small.match('atest'), D
    assert_in_delta 2, @small.match('teast'), D
    assert_in_delta 3, @small.match('est'), D
    assert_in_delta 3, @small.match('tes'), D
    assert_in_delta 2, @small.match('tst'), D
    assert_in_delta 3, @small.match('best'), D
    assert_in_delta 2, @small.match('tost'), D
    assert_in_delta 3, @small.match('tesa'), D
    assert_in_delta 1, @small.match('taex'), D
    assert_in_delta 1, @small.match('aaatbbb'), D
    assert_in_delta 1, @small.match('aaasbbb'), D
    assert_in_delta 4, @small.match('aaatestbbb'), D
  end

  def test_similar
    assert_in_delta 1, @empty.similar(''), D
    assert_in_delta 0, @empty.similar('not empty'), D
    assert_in_delta 0.0, @small.similar(''), D
    assert_in_delta 1.0, @small.similar('test'), D
    assert_in_delta 0.8, @small.similar('testa'), D
    assert_in_delta 0.8, @small.similar('atest'), D
    assert_in_delta 0.4, @small.similar('teast'), D
    assert_in_delta 0.75, @small.similar('est'), D
    assert_in_delta 0.75, @small.similar('tes'), D
    assert_in_delta 0.5, @small.similar('tst'), D
    assert_in_delta 0.75, @small.similar('best'), D
    assert_in_delta 0.5, @small.similar('tost'), D
    assert_in_delta 0.75, @small.similar('tesa'), D
    assert_in_delta 0.25, @small.similar('taex'), D
    assert_in_delta 0.4, @small.similar('aaatestbbb'), D
    assert_in_delta 0.75, @small.pattern.levenshtein_similar('est'), D
  end
end
  # vim: set et sw=2 ts=2:

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
amatch-0.2.0 tests/test_longest_substring.rb