PostGIS  3.7.0dev-r@@SVN_REVISION@@

◆ test_lwgeom_node()

static void test_lwgeom_node ( void  )
static

Definition at line 20 of file cu_node.c.

21 {
22  LWGEOM *in, *out;
23  const char *wkt;
24  char *tmp;
25 
26  /* Because i don't trust that much prior tests... ;) */
28 
29  wkt = "LINESTRING(0 0,5 5, 10 0)";
31  out = lwgeom_node(in);
32  /* printf("%s\n", lwgeom_to_ewkt(out)); */
33  CU_ASSERT_FATAL(out != NULL);
34  CU_ASSERT(lwgeom_same(in, out));
35  lwgeom_free(out); lwgeom_free(in);
36 
37  wkt = "MULTILINESTRING((0 0,0 5),(10 0, -10 5))";
39  out = lwgeom_node(in);
40  CU_ASSERT_FATAL(out != NULL);
41  tmp = lwgeom_to_ewkt(out);
42  ASSERT_STRING_EQUAL(tmp, "MULTILINESTRING((0 2.5,-10 5),(0 0,0 2.5),(0 2.5,0 5),(10 0,0 2.5))");
43  lwfree(tmp); lwgeom_free(out); lwgeom_free(in);
44 
45  wkt = "MULTILINESTRING((0 0,5 5,10 0, 11 0, 20 0),(10 0, 12 0, 22 0))";
47  out = lwgeom_node(in);
48  CU_ASSERT_FATAL(out != NULL);
49  tmp = lwgeom_to_ewkt(out);
50  /* printf("%s\n", tmp); */
51  ASSERT_STRING_EQUAL(tmp, "MULTILINESTRING((0 0,5 5,10 0),(10 0,11 0,12 0,20 0),(20 0,22 0))");
52  lwfree(tmp); lwgeom_free(out); lwgeom_free(in);
53 
54  wkt = "MULTILINESTRING((0 0,5 5,10 0, 11 0, 20 0),(22 0, 12 0, 10 0),(0 5, 5 0))";
56  out = lwgeom_node(in);
57  CU_ASSERT_FATAL(out != NULL);
58  tmp = lwgeom_to_ewkt(out);
59  /* printf("%s\n", tmp); */
61  "MULTILINESTRING((0 0,2.5 2.5),(0 5,2.5 2.5),(2.5 2.5,5 5,10 0),(10 0,11 0,12 0,20 0),(20 0,22 0),(2.5 2.5,5 0))"
62  );
63  lwfree(tmp); lwgeom_free(out); lwgeom_free(in);
64 
65  /* See https://trac.osgeo.org/postgis/ticket/5685 */
66  wkt = "LINESTRING(0 0,0 0)";
68  out = lwgeom_node(in);
69  /* printf("%s\n", lwgeom_to_ewkt(out)); */
70  CU_ASSERT_FATAL(out != NULL);
71  ASSERT_LWGEOM_EQUAL(in, out);
72  lwgeom_free(out); lwgeom_free(in);
73 }
void cu_error_msg_reset()
#define ASSERT_STRING_EQUAL(o, e)
#define ASSERT_LWGEOM_EQUAL(o, e)
char lwgeom_same(const LWGEOM *lwgeom1, const LWGEOM *lwgeom2)
geom1 same as geom2 iff
Definition: lwgeom.c:591
LWGEOM * lwgeom_node(const LWGEOM *lwgeom_in)
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1218
#define LW_PARSER_CHECK_NONE
Definition: liblwgeom.h:2146
char * lwgeom_to_ewkt(const LWGEOM *lwgeom)
Return an allocated string.
Definition: lwgeom.c:565
void lwfree(void *mem)
Definition: lwutil.c:248
LWGEOM * lwgeom_from_wkt(const char *wkt, const char check)
Definition: lwin_wkt.c:940

References ASSERT_LWGEOM_EQUAL, ASSERT_STRING_EQUAL, cu_error_msg_reset(), LW_PARSER_CHECK_NONE, lwfree(), lwgeom_free(), lwgeom_from_wkt(), lwgeom_node(), lwgeom_same(), and lwgeom_to_ewkt().

Referenced by node_suite_setup().

Here is the call graph for this function:
Here is the caller graph for this function: