Newer
Older
exercism-cpp / nucleotide-count / nucleotide_count_test.cpp
#include "nucleotide_count.h"
#ifdef EXERCISM_TEST_SUITE
#include <catch2/catch.hpp>
#else
#include "test/catch.hpp"
#endif
#include <map>
#include <stdexcept>

TEST_CASE("has_no_nucleotides")
{
    const nucleotide_count::counter dna("");
    const std::map<char, int> expected{ {'A', 0}, {'T', 0}, {'C', 0}, {'G', 0} };

    const auto actual = dna.nucleotide_counts();

    REQUIRE(expected == actual);
}

#if defined(EXERCISM_RUN_ALL_TESTS)
TEST_CASE("has_no_adenosine")
{
    const nucleotide_count::counter dna("");

    REQUIRE(0 == dna.count('A'));
}

TEST_CASE("repetitive_cytidine_gets_counts")
{
    const nucleotide_count::counter dna("CCCCC");

    REQUIRE(5 == dna.count('C'));
}

TEST_CASE("repetitive_sequence_has_only_guanosine")
{
    const nucleotide_count::counter dna("GGGGGGGG");
    const std::map<char, int> expected{ {'A', 0}, {'T', 0}, {'C', 0}, {'G', 8} };

    const auto actual = dna.nucleotide_counts();

    REQUIRE(expected == actual);
}

TEST_CASE("counts_only_thymidine")
{
    const nucleotide_count::counter dna("GGGGTAACCCGG");

    REQUIRE(1 == dna.count('T'));
}

TEST_CASE("counts_a_nucleotide_only_once")
{
    const nucleotide_count::counter dna("GGTTGG");

    dna.count('T');

    REQUIRE(2 == dna.count('T'));
}

TEST_CASE("validates_nucleotides")
{
    const nucleotide_count::counter dna("GGTTGG");

    REQUIRE_THROWS_AS(dna.count('X'), std::invalid_argument);
}

TEST_CASE("validates_nucleotides_on_construction")
{
    REQUIRE_THROWS_AS(nucleotide_count::counter("GGTTGGX"), std::invalid_argument);
}

TEST_CASE("counts_all_nucleotides")
{
    const nucleotide_count::counter dna("AGCTTTTCATTCTGACTGCAACGGGCAATATGTCTCTGTGTGGATTAAAAAAAGAGTGTCTGATAGCAGC");
    std::map<char, int> expected{ {'A', 20}, {'T', 21}, {'G', 17}, {'C', 12} };

    auto actual = dna.nucleotide_counts();

    REQUIRE(expected == actual);
}
#endif