File: inclinationparsingtests.cpp

package info (click to toggle)
dewalls 1.0.0%2Bds1-9
  • links: PTS
  • area: main
  • in suites: bookworm, bullseye, sid
  • size: 780 kB
  • sloc: cpp: 6,464; makefile: 62
file content (46 lines) | stat: -rw-r--r-- 2,732 bytes parent folder | download | duplicates (2)
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
#include "catch.hpp"
#include "../src/wallssurveyparser.h"
#include "approx.h"

using namespace dewalls;

typedef UnitizedDouble<Angle> UAngle;

TEST_CASE( "inclination parsing tests" , "[dewalls, inclination]" ) {
    SECTION( "defaultUnit works") {
        CHECK( WallsSurveyParser("2.5").inclination(Angle::Degrees) == UAngle(2.5, Angle::Degrees) );
        CHECK( WallsSurveyParser("2.5").inclination(Angle::Gradians) == UAngle(2.5, Angle::Gradians) );
    }
    SECTION( "units suffixes work" ) {
        CHECK( WallsSurveyParser("2.5g").inclination(Angle::Degrees) == UAngle(2.5, Angle::Gradians) );
        CHECK( WallsSurveyParser("2.5m").inclination(Angle::Degrees) == UAngle(2.5, Angle::MilsNATO) );
        CHECK( WallsSurveyParser("2.5p").inclination(Angle::Degrees) == UAngle(2.5, Angle::PercentGrade) );
    }
    SECTION( "negative numbers work" ) {
        CHECK( WallsSurveyParser("-2.5").inclination(Angle::Degrees) == UAngle(-2.5, Angle::Degrees) );
    }
    SECTION( "degrees:minutes:seconds work" ) {
        CHECK( WallsSurveyParser("5:4:23").inclination(Angle::Degrees) == UAngle(5 + (4 + 23 / 60.0) / 60.0, Angle::Degrees) );
        CHECK( WallsSurveyParser("5:4").inclination(Angle::Degrees) == UAngle(5 + 4 / 60.0, Angle::Degrees) );
        CHECK( WallsSurveyParser("-5::23").inclination(Angle::Degrees) == UAngle(-5 - (23 / 60.0) / 60.0, Angle::Degrees) );
        CHECK( approxEquals(WallsSurveyParser("::23.5").inclination(Angle::Degrees), UAngle((23.5 / 60.0) / 60.0, Angle::Degrees)) );
        CHECK( WallsSurveyParser("-:4").inclination(Angle::Degrees) == UAngle(-4 / 60.0, Angle::Degrees) );
    }
    SECTION( "plus sign works" ) {
        CHECK( WallsSurveyParser("+::2.5").inclination(Angle::Degrees) == UAngle(2.5 / 3600.0, Angle::Degrees) );
    }
    SECTION( "misc invalid values throw" ) {
        CHECK_THROWS( WallsSurveyParser("").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("-").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("+").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("-.").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser(".").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser(" ").inclination(Angle::Degrees) );
    }
    SECTION( "out of range values throw" ) {
        CHECK_THROWS( WallsSurveyParser("90.0001").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("-90.00001").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("100.0001g").inclination(Angle::Degrees) );
        CHECK_THROWS( WallsSurveyParser("-100.00001g").inclination(Angle::Degrees) );
    }
}