File: GEOSGetExteriorRingTest.cpp

package info (click to toggle)
geos 3.14.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 31,212 kB
  • sloc: cpp: 199,103; xml: 56,065; ansic: 6,162; sh: 287; makefile: 26
file content (57 lines) | stat: -rw-r--r-- 1,445 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
47
48
49
50
51
52
53
54
55
56
57
#include <tut/tut.hpp>
// geos
#include <geos_c.h>

#include "capi_test_utils.h"

namespace tut
{
    //
    // Test Group
    //

    struct test_geosgetexteriorring_data : public capitest::utility
    {
    };

    typedef test_group<test_geosgetexteriorring_data> group;
    typedef group::object object;

    group test_geosgetexteriorring("capi::GEOSGetExteriorRing");

    template <>
    template <>
    void object::test<1>()
    {
        geom1_ = fromWKT("POLYGON ((35 10, 45 45, 15 40, 10 20, 35 10),(20 30, 35 35, 30 20, 20 30))");
        ensure(nullptr != geom1_);

        GEOSGeometry *result = const_cast<GEOSGeometry *>(GEOSGetExteriorRing(geom1_));
        ensure(nullptr != result);
        ensure_equals("LINEARRING (35 10, 45 45, 15 40, 10 20, 35 10)", toWKT(result));
    }

    template <>
    template <>
    void object::test<2>()
    {
        geom1_ = fromWKT("LINESTRING (0 0, 1 0, 1 1, 0 0)");
        ensure(nullptr != geom1_);

        ensure(GEOSGetExteriorRing(geom1_) == nullptr);
    }

    template<>
    template<>
    void object::test<3>()
    {
        input_ = fromWKT("CURVEPOLYGON (COMPOUNDCURVE (CIRCULARSTRING (0 0, 1 1, 2 0), (2 0, 0 0)))");
        ensure(input_ != nullptr);

        const GEOSGeometry* extring = GEOSGetExteriorRing(input_);
        ensure(extring);

        ensure_equals(toWKT(extring), "COMPOUNDCURVE (CIRCULARSTRING (0 0, 1 1, 2 0), (2 0, 0 0))");
    }

} // namespace tut