1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
/*
* =====================================================================================
*
* Filename: RangeUtils_gtest.cpp
*
* Description: Test alignment/utils/RangeUtils.hpp
*
* Version: 1.0
* Created: 05/2/2013 06:01:01 PM
* Revision: 08/21/2014
* Compiler: gcc
*
* Author: Yuan Li (yli), yli@pacificbiosciences.com
* Company: Pacific Biosciences
*
* =====================================================================================
*/
#include <gtest/gtest.h>
#include <alignment/utils/RangeUtils.hpp>
TEST(RangeTest, RangeConstructor)
{
Range r(1, 2);
EXPECT_EQ(r.start, 1u);
EXPECT_EQ(r.end, 2u);
Range r2(1);
EXPECT_EQ(r2.end, 1u);
}
TEST(RangeTest, Ranges)
{
UInt queryInRange[11] = {1, 2, 3, 4, 10, 11, 12, 13, 14, 15, 20};
UInt queryNotInRange[8] = {0, 16, 17, 18, 19, 30, 5, 100000};
Ranges ranges1(std::string("1,2,3,4,10-15,20-20"));
for (int i = 0; i < 11; i++) {
EXPECT_TRUE(ranges1.contains(queryInRange[i]));
}
for (int i = 0; i < 8; i++) {
EXPECT_FALSE(ranges1.contains(queryNotInRange[i]));
}
}
TEST(RangeTest, SetRanges)
{
Ranges rs;
rs.setRanges("199");
EXPECT_TRUE(rs.contains(199));
EXPECT_EQ(rs.size(), 1);
}
TEST(RangeTest, max)
{
Ranges rs("199");
EXPECT_EQ(rs.max(), 199u);
Ranges rs1("1, 10000, 10-30, 4000-5000");
EXPECT_EQ(rs1.max(), 10000u);
Ranges rs2("1, 1000, 10-30, 4000-5000, 633-877");
EXPECT_EQ(rs2.max(), 5000u);
}
|