Sha256: c08643faeaa41f49094cc753dc56b1aec3689ca3b6a048469259206d503018ca

Contents?: true

Size: 1.69 KB

Versions: 5012

Compression:

Stored size: 1.69 KB

Contents

# frozen_string_literal: true

require 'spec_helper'

describe Diff::LCS::Internals, '.lcs' do
  include Diff::LCS::SpecHelper::Matchers

  it 'returns a meaningful LCS array with (seq1, seq2)' do
    res = Diff::LCS::Internals.lcs(seq1, seq2)
    # The result of the LCS (less the +nil+ values) must be as long as the
    # correct result.
    expect(res.compact.size).to eq(correct_lcs.size)
    expect(res).to correctly_map_sequence(seq1).to_other_sequence(seq2)

    # Compact these transformations and they should be the correct LCS.
    x_seq1 = (0...res.size).map { |ix| res[ix] ? seq1[ix] : nil }.compact
    x_seq2 = (0...res.size).map { |ix| res[ix] ? seq2[res[ix]] : nil }.compact

    expect(x_seq1).to eq(correct_lcs)
    expect(x_seq2).to eq(correct_lcs)
  end

  it 'returns all indexes with (hello, hello)' do
    expect(Diff::LCS::Internals.lcs(hello, hello)).to \
      eq((0...hello.size).to_a)
  end

  it 'returns all indexes with (hello_ary, hello_ary)' do
    expect(Diff::LCS::Internals.lcs(hello_ary, hello_ary)).to \
      eq((0...hello_ary.size).to_a)
  end
end

describe Diff::LCS, '.LCS' do
  include Diff::LCS::SpecHelper::Matchers

  it 'returns the correct compacted values from Diff::LCS.LCS' do
    res = Diff::LCS.LCS(seq1, seq2)
    expect(res).to eq(correct_lcs)
    expect(res.compact).to eq(res)
  end

  it 'is transitive' do
    res = Diff::LCS.LCS(seq2, seq1)
    expect(res).to eq(correct_lcs)
    expect(res.compact).to eq(res)
  end

  it 'returns %W(h e l l o) with (hello, hello)' do
    expect(Diff::LCS.LCS(hello, hello)).to eq(hello.split(//))
  end

  it 'returns hello_ary with (hello_ary, hello_ary)' do
    expect(Diff::LCS.LCS(hello_ary, hello_ary)).to eq(hello_ary)
  end
end

Version data entries

5,012 entries across 4,963 versions & 53 rubygems

Version Path
mux_ruby-3.20.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
mux_ruby-3.19.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.15 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.14 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
mux_ruby-3.18.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.13 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.12 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.11 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
mux_ruby-3.17.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
cm-admin-1.5.22 vendor/bundle/ruby/3.3.0/gems/diff-lcs-1.4.4/spec/lcs_spec.rb
cm-admin-1.5.21 vendor/bundle/ruby/3.3.0/gems/diff-lcs-1.4.4/spec/lcs_spec.rb
cm-admin-1.5.20 vendor/bundle/ruby/3.3.0/gems/diff-lcs-1.4.4/spec/lcs_spec.rb
moneykit-0.1.10 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.9 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
harbr-2.8.1 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
mux_ruby-3.15.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
avalara_sdk-24.2.29 vendor/bundle/ruby/2.7.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
mux_ruby-3.14.0 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.6 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb
moneykit-0.1.5 vendor/bundle/ruby/3.2.0/gems/diff-lcs-1.5.0/spec/lcs_spec.rb