Finalize half-edge consistency tests
This commit is contained in:
		
							parent
							
								
									a3bac07c2b
								
							
						
					
					
						commit
						a2b604de2f
					
				| @ -104,6 +104,8 @@ int main(void) | |||||||
| 							 test_parse_obj4)) || | 							 test_parse_obj4)) || | ||||||
| 		(NULL == CU_add_test(pSuite, "test5 parsing .obj", | 		(NULL == CU_add_test(pSuite, "test5 parsing .obj", | ||||||
| 							 test_parse_obj5)) || | 							 test_parse_obj5)) || | ||||||
|  | 		(NULL == CU_add_test(pSuite, "test6 parsing .obj", | ||||||
|  | 							 test_parse_obj6)) || | ||||||
| 		(NULL == CU_add_test(pSuite, "test1 finding center ob obj", | 		(NULL == CU_add_test(pSuite, "test1 finding center ob obj", | ||||||
| 							 test_find_center1)) || | 							 test_find_center1)) || | ||||||
| 		(NULL == CU_add_test(pSuite, "test2 finding center ob obj", | 		(NULL == CU_add_test(pSuite, "test2 finding center ob obj", | ||||||
|  | |||||||
| @ -43,6 +43,7 @@ void test_parse_obj2(void); | |||||||
| void test_parse_obj3(void); | void test_parse_obj3(void); | ||||||
| void test_parse_obj4(void); | void test_parse_obj4(void); | ||||||
| void test_parse_obj5(void); | void test_parse_obj5(void); | ||||||
|  | void test_parse_obj6(void); | ||||||
| 
 | 
 | ||||||
| void test_find_center1(void); | void test_find_center1(void); | ||||||
| void test_find_center2(void); | void test_find_center2(void); | ||||||
|  | |||||||
| @ -469,13 +469,66 @@ void test_parse_obj5(void) | |||||||
| 		while(next_edge != start_edge) { | 		while(next_edge != start_edge) { | ||||||
| 			CU_ASSERT_PTR_NOT_NULL(next_edge); | 			CU_ASSERT_PTR_NOT_NULL(next_edge); | ||||||
| 			CU_ASSERT_PTR_NOT_NULL(next_edge->pair->pair); | 			CU_ASSERT_PTR_NOT_NULL(next_edge->pair->pair); | ||||||
|  | 			/* check if edges have all the same face */ | ||||||
| 			CU_ASSERT_EQUAL(next_edge->face, &(obj->faces[i])); | 			CU_ASSERT_EQUAL(next_edge->face, &(obj->faces[i])); | ||||||
|  | 			/* check if pairs are consistently set */ | ||||||
| 			CU_ASSERT_EQUAL(next_edge->pair->pair, next_edge); | 			CU_ASSERT_EQUAL(next_edge->pair->pair, next_edge); | ||||||
|  | 			CU_ASSERT_NOT_EQUAL(next_edge->pair, next_edge); | ||||||
|  | 			/* check if vertices are consistent with edges */ | ||||||
|  | 			CU_ASSERT_PTR_NOT_NULL(next_edge->vert->edge); | ||||||
|  | 			CU_ASSERT_EQUAL(next_edge->vert->edge->vert, next_edge->vert); | ||||||
| 			next_edge = next_edge->next; | 			next_edge = next_edge->next; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * Test the whole object for consistency by walking | ||||||
|  |  * through all vertices and checking them for consistency. | ||||||
|  |  */ | ||||||
|  | void test_parse_obj6(void) | ||||||
|  | { | ||||||
|  | 	char const * const string = "" | ||||||
|  | 		"v 9.0 10.0 11.0\n" | ||||||
|  | 		"v 11.0 10.0 11.0\n" | ||||||
|  | 		"v 9.0 11.0 11.0\n" | ||||||
|  | 		"v 11.0 11.0 11.0\n" | ||||||
|  | 		"v 9.0 11.0 9.0\n" | ||||||
|  | 		"v 11.0 11.0 9.0\n" | ||||||
|  | 		"v 9.0 10.0 9.0\n" | ||||||
|  | 		"v 11.0 10.0 9.0\n" | ||||||
|  | 		"f 1 2 4 3\n" | ||||||
|  | 		"f 3 4 6 5\n" | ||||||
|  | 		"f 5 6 8 7\n" | ||||||
|  | 		"f 7 8 2 1\n" | ||||||
|  | 		"f 2 8 6 4\n" | ||||||
|  | 		"f 7 1 3 5\n"; | ||||||
|  | 
 | ||||||
|  | 	HE_obj *obj = parse_obj(string); | ||||||
|  | 
 | ||||||
|  | 	CU_ASSERT_PTR_NOT_NULL(obj); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	for (uint32_t i = 0; i < obj->vc; i++) { | ||||||
|  | 		HE_edge *edge = obj->vertices[i].edge; | ||||||
|  | 
 | ||||||
|  | 		do { | ||||||
|  | 			/* check if pairs are consistently set */ | ||||||
|  | 			CU_ASSERT_EQUAL(edge->pair->pair, edge); | ||||||
|  | 			CU_ASSERT_NOT_EQUAL(edge->pair, edge); | ||||||
|  | 			/* check if neighbor vertex is consistently connected
 | ||||||
|  | 			 * to half-edge */ | ||||||
|  | 			CU_ASSERT_NOT_EQUAL(edge->pair->vert, edge->vert); | ||||||
|  | 			CU_ASSERT_PTR_NOT_NULL(edge->pair->vert->edge); | ||||||
|  | 			CU_ASSERT_EQUAL(edge->pair->next->vert, edge->vert); | ||||||
|  | 			CU_ASSERT_EQUAL(edge->vert->edge->vert, edge->vert); | ||||||
|  | 
 | ||||||
|  | 			edge = edge->pair->next; | ||||||
|  | 
 | ||||||
|  | 		} while (edge && edge != obj->vertices[i].edge); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Test finding the center of an object. |  * Test finding the center of an object. | ||||||
|  */ |  */ | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user