Merge pull request #320 from ennorehling/feature/issue-318

cJSON memory leak in test_export_land_region
This commit is contained in:
Enno Rehling 2015-10-15 21:01:13 +02:00
commit 53fd192d63

View file

@ -53,7 +53,7 @@ static cJSON *export_a_region(CuTest * tc, const struct terrain_type *terrain, r
stream out = { 0 }; stream out = { 0 };
int err; int err;
region *r; region *r;
cJSON *json, *attr; cJSON *json, *attr, *result, *regs;
r = test_create_region(0, 0, terrain); r = test_create_region(0, 0, terrain);
@ -69,19 +69,21 @@ static cJSON *export_a_region(CuTest * tc, const struct terrain_type *terrain, r
CuAssertIntEquals(tc, cJSON_Object, json->type); CuAssertIntEquals(tc, cJSON_Object, json->type);
CuAssertPtrEquals(tc, 0, cJSON_GetObjectItem(json, "factions")); CuAssertPtrEquals(tc, 0, cJSON_GetObjectItem(json, "factions"));
CuAssertPtrEquals(tc, 0, cJSON_GetObjectItem(json, "units")); CuAssertPtrEquals(tc, 0, cJSON_GetObjectItem(json, "units"));
CuAssertPtrNotNull(tc, json = cJSON_GetObjectItem(json, "regions")); CuAssertPtrNotNull(tc, regs = cJSON_GetObjectItem(json, "regions"));
CuAssertIntEquals(tc, cJSON_Object, json->type); CuAssertIntEquals(tc, cJSON_Object, regs->type);
json = json->child; result = regs->child;
CuAssertIntEquals(tc, r->uid, atoi(json->string)); regs->child = 0;
CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(json, "x")); cJSON_Delete(json);
CuAssertIntEquals(tc, r->uid, atoi(result->string));
CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(result, "x"));
CuAssertIntEquals(tc, r->x, attr->valueint); CuAssertIntEquals(tc, r->x, attr->valueint);
CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(json, "y")); CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(result, "y"));
CuAssertIntEquals(tc, r->y, attr->valueint); CuAssertIntEquals(tc, r->y, attr->valueint);
CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(json, "type")); CuAssertPtrNotNull(tc, attr = cJSON_GetObjectItem(result, "type"));
CuAssertStrEquals(tc, terrain->_name, attr->valuestring); CuAssertStrEquals(tc, terrain->_name, attr->valuestring);
if (_r) *_r = r; if (_r) *_r = r;
return json; return result;
} }
static void test_export_land_region(CuTest * tc) { static void test_export_land_region(CuTest * tc) {