Sha256: 30d12e7634d9a69524adbd767fff07b79c9372d3bf1acfbd11c5cae595f3c5f0

Contents?: true

Size: 1.93 KB

Versions: 5

Compression:

Stored size: 1.93 KB

Contents

require 'test/unit'
require 'amatch'

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

  D = 0.000001

  def setup
    @small   = Hamming.new('test')
    @empty   = Hamming.new('')
    @long    = Hamming.new('A' * 160)
  end

  def test_empty
    assert_in_delta 0, @empty.match(''), D
    assert_in_delta 9, @empty.match('not empty'), D
    assert_in_delta 1, @empty.similar(''), D
    assert_in_delta 0, @empty.similar('not empty'), D
  end

  def test_small_match
    assert_in_delta 4, @small.match(''), D
    assert_in_delta 0, @small.match('test'), D
    assert_in_delta 1, @small.match('testa'), D
    assert_in_delta 5, @small.match('atest'), D
    assert_in_delta 3, @small.match('teast'), D
    assert_in_delta 4, @small.match('est'), D
    assert_in_delta 1, @small.match('tes'), D
    assert_in_delta 3, @small.match('tst'), D
    assert_in_delta 1, @small.match('best'), D
    assert_in_delta 1, @small.match('tost'), D
    assert_in_delta 1, @small.match('tesa'), D
    assert_in_delta 3, @small.match('taex'), D
    assert_in_delta 9, @small.match('aaatestbbb'), D
  end

  def test_small_similar
    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.0, @small.similar('atest'), D
    assert_in_delta 0.4, @small.similar('teast'), D
    assert_in_delta 0, @small.similar('est'), D
    assert_in_delta 0.75, @small.similar('tes'), D
    assert_in_delta 0.25, @small.similar('tst'), D
    assert_in_delta 0.75, @small.similar('best'), D
    assert_in_delta 0.75, @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.1, @small.similar('aaatestbbb'), D
    assert_in_delta 0.8, @small.pattern.hamming_similar('testa'), D
  end

  def test_long
    assert_in_delta 1.0, @long.similar(@long.pattern), D
  end
end
  # vim: set et sw=2 ts=2:

Version data entries

5 entries across 5 versions & 3 rubygems

Version Path
47primes-amatch-0.2.3 tests/test_hamming.rb
mumboe-amatch-0.2.3 tests/test_hamming.rb
amatch-0.2.1 tests/test_hamming.rb
amatch-0.2.2 tests/test_hamming.rb
amatch-0.2.3 tests/test_hamming.rb