Sha256: 154e2c0ffad8311c2e12a1e41f0d8db488a4ea6071fab13e3619b27458049978

Contents?: true

Size: 1.41 KB

Versions: 163

Compression:

Stored size: 1.41 KB

Contents

#!/usr/bin/env ruby
gem 'minitest', '>= 5.0.0'
require 'minitest/autorun'
require_relative 'nucleotide_count'

class NucleotideTest < Minitest::Test
  def test_empty_dna_strand_has_no_adenosine
    assert_equal 0, Nucleotide.from_dna('').count('A')
  end

  def test_repetitive_cytidine_gets_counted
    skip
    assert_equal 5, Nucleotide.from_dna('CCCCC').count('C')
  end

  def test_counts_only_thymidine
    skip
    assert_equal 1, Nucleotide.from_dna('GGGGGTAACCCGG').count('T')
  end

  def test_counts_a_nucleotide_only_once
    skip
    dna = Nucleotide.from_dna('CGATTGGG')
    dna.count('T')
    dna.count('T')
    assert_equal 2, dna.count('T')
  end

  def test_empty_dna_strand_has_no_nucleotides
    skip
    expected = { 'A' => 0, 'T' => 0, 'C' => 0, 'G' => 0 }
    assert_equal expected, Nucleotide.from_dna('').histogram
  end

  def test_repetitive_sequence_has_only_guanosine
    skip
    expected = { 'A' => 0, 'T' => 0, 'C' => 0, 'G' => 8 }
    assert_equal expected, Nucleotide.from_dna('GGGGGGGG').histogram
  end

  def test_counts_all_nucleotides
    skip
    s = 'AGCTTTTCATTCTGACTGCAACGGGCAATATGTCTCTGTGTGGATTAAAAAAAGAGTGTCTGATAGCAGC'
    dna = Nucleotide.from_dna(s)
    expected = { 'A' => 20, 'T' => 21, 'G' => 17, 'C' => 12 }
    assert_equal expected, dna.histogram
  end

  def test_validates_dna
    skip
    assert_raises ArgumentError do
      Nucleotide.from_dna('JOHNNYAPPLESEED')
    end
  end
end

Version data entries

163 entries across 163 versions & 1 rubygems

Version Path
trackler-2.1.0.7 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.6 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.5 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.4 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.3 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.2 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.1 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.1.0.0 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.55 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.54 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.53 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.52 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.51 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.50 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.49 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.48 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.47 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.46 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.45 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb
trackler-2.0.8.44 tracks/ruby/exercises/nucleotide-count/nucleotide_count_test.rb