5c51b5726c9dfb615b29c080e6cdd7b1d48beef0
[platform/upstream/cmocka.git] / src / cmockery.c
1 /*
2  * Copyright 2008 Google Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 #ifdef HAVE_CONFIG_H
17 #include "config.h"
18 #endif
19 #ifdef HAVE_MALLOC_H
20 #include <malloc.h>
21 #endif
22 #include <setjmp.h>
23 #ifndef _WIN32
24 #include <signal.h>
25 #endif // !_WIN32
26 #include <stdarg.h>
27 #include <stddef.h>
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include <string.h>
31 #ifdef _WIN32
32 #include <windows.h>
33 #endif // _WIN32
34 #include <cmockery.h>
35
36 #ifdef _WIN32
37 #define vsnprintf _vsnprintf
38 #endif // _WIN32
39
40 /* Backwards compatibility with headers shipped with Visual Studio 2005 and
41  * earlier. */
42 #ifdef _WIN32
43 WINBASEAPI BOOL WINAPI IsDebuggerPresent(VOID);
44 #endif // _WIN32
45
46 // Size of guard bytes around dynamically allocated blocks.
47 #define MALLOC_GUARD_SIZE 16
48 // Pattern used to initialize guard blocks.
49 #define MALLOC_GUARD_PATTERN 0xEF
50 // Pattern used to initialize memory allocated with test_malloc().
51 #define MALLOC_ALLOC_PATTERN 0xBA
52 #define MALLOC_FREE_PATTERN 0xCD
53 // Alignment of allocated blocks.  NOTE: This must be base2.
54 #define MALLOC_ALIGNMENT sizeof(size_t)
55
56 // Printf formatting for source code locations.
57 #define SOURCE_LOCATION_FORMAT "%s:%d"
58
59 // Calculates the number of elements in an array.
60 #define ARRAY_LENGTH(x) (sizeof(x) / sizeof((x)[0]))
61
62 // Declare and initialize the pointer member of ValuePointer variable name
63 // with ptr.
64 #define declare_initialize_value_pointer_pointer(name, ptr) \
65     ValuePointer name ; \
66     name.value = 0; \
67     name.pointer = (void*)(ptr)
68
69 // Declare and initialize the value member of ValuePointer variable name
70 // with val.
71 #define declare_initialize_value_pointer_value(name, val) \
72     ValuePointer name ; \
73     name.value = val
74
75 // Cast a LargestIntegralType to pointer_type via a ValuePointer.
76 #define cast_largest_integral_type_to_pointer( \
77     pointer_type, largest_integral_type) \
78     ((pointer_type)((ValuePointer*)&(largest_integral_type))->pointer)
79
80 // Used to cast LargetIntegralType to void* and vice versa.
81 typedef union ValuePointer {
82     LargestIntegralType value;
83     void *pointer;
84 } ValuePointer;
85
86 // Doubly linked list node.
87 typedef struct ListNode {
88     const void *value;
89     int refcount;
90     struct ListNode *next;
91     struct ListNode *prev;
92 } ListNode;
93
94 // Debug information for malloc().
95 typedef struct MallocBlockInfo {
96     void* block;              // Address of the block returned by malloc().
97     size_t allocated_size;    // Total size of the allocated block.
98     size_t size;              // Request block size.
99     SourceLocation location;  // Where the block was allocated.
100     ListNode node;            // Node within list of all allocated blocks.
101 } MallocBlockInfo;
102
103 // State of each test.
104 typedef struct TestState {
105     const ListNode *check_point; // Check point of the test if there's a
106                                  // setup function.
107     void *state;                 // State associated with the test.
108 } TestState;
109
110 // Determines whether two values are the same.
111 typedef int (*EqualityFunction)(const void *left, const void *right);
112
113 // Value of a symbol and the place it was declared.
114 typedef struct SymbolValue {
115     SourceLocation location;
116     LargestIntegralType value;
117 } SymbolValue;
118
119 /* Contains a list of values for a symbol.
120  * NOTE: Each structure referenced by symbol_values_list_head must have a
121  * SourceLocation as its' first member.
122  */
123 typedef struct SymbolMapValue {
124     const char *symbol_name;
125     ListNode symbol_values_list_head;
126 } SymbolMapValue;
127
128 // Used by list_free() to deallocate values referenced by list nodes.
129 typedef void (*CleanupListValue)(const void *value, void *cleanup_value_data);
130
131 // Structure used to check the range of integer types.
132 typedef struct CheckIntegerRange {
133     CheckParameterEvent event;
134     LargestIntegralType minimum;
135     LargestIntegralType maximum;
136 } CheckIntegerRange;
137
138 // Structure used to check whether an integer value is in a set.
139 typedef struct CheckIntegerSet {
140     CheckParameterEvent event;
141     const LargestIntegralType *set;
142     size_t size_of_set;
143 } CheckIntegerSet;
144
145 /* Used to check whether a parameter matches the area of memory referenced by
146  * this structure.  */
147 typedef struct CheckMemoryData {
148     CheckParameterEvent event;
149     const void *memory;
150     size_t size;
151 } CheckMemoryData;
152
153 static ListNode* list_initialize(ListNode * const node);
154 static ListNode* list_add(ListNode * const head, ListNode *new_node);
155 static ListNode* list_add_value(ListNode * const head, const void *value,
156                                      const int count);
157 static ListNode* list_remove(
158     ListNode * const node, const CleanupListValue cleanup_value,
159     void * const cleanup_value_data);
160 static void list_remove_free(
161     ListNode * const node, const CleanupListValue cleanup_value,
162     void * const cleanup_value_data);
163 static int list_empty(const ListNode * const head);
164 static int list_find(
165     ListNode * const head, const void *value,
166     const EqualityFunction equal_func, ListNode **output);
167 static int list_first(ListNode * const head, ListNode **output);
168 static ListNode* list_free(
169     ListNode * const head, const CleanupListValue cleanup_value,
170     void * const cleanup_value_data);
171
172 static void add_symbol_value(
173     ListNode * const symbol_map_head, const char * const symbol_names[],
174     const size_t number_of_symbol_names, const void* value, const int count);
175 static int get_symbol_value(
176     ListNode * const symbol_map_head, const char * const symbol_names[],
177     const size_t number_of_symbol_names, void **output);
178 static void free_value(const void *value, void *cleanup_value_data);
179 static void free_symbol_map_value(
180     const void *value, void *cleanup_value_data);
181 static void remove_always_return_values(ListNode * const map_head,
182                                         const size_t number_of_symbol_names);
183 static int check_for_leftover_values(
184     const ListNode * const map_head, const char * const error_message,
185     const size_t number_of_symbol_names);
186 // This must be called at the beginning of a test to initialize some data
187 // structures.
188 static void initialize_testing(const char *test_name);
189 // This must be called at the end of a test to free() allocated structures.
190 static void teardown_testing(const char *test_name);
191
192
193 // Keeps track of the calling context returned by setenv() so that the fail()
194 // method can jump out of a test.
195 static jmp_buf global_run_test_env;
196 static int global_running_test = 0;
197
198 // Keeps track of the calling context returned by setenv() so that
199 // mock_assert() can optionally jump back to expect_assert_failure().
200 jmp_buf global_expect_assert_env;
201 int global_expecting_assert = 0;
202
203 // Keeps a map of the values that functions will have to return to provide
204 // mocked interfaces.
205 static ListNode global_function_result_map_head;
206 // Location of the last mock value returned was declared.
207 static SourceLocation global_last_mock_value_location;
208
209 /* Keeps a map of the values that functions expect as parameters to their
210  * mocked interfaces. */
211 static ListNode global_function_parameter_map_head;
212 // Location of last parameter value checked was declared.
213 static SourceLocation global_last_parameter_location;
214
215 // List of all currently allocated blocks.
216 static ListNode global_allocated_blocks;
217
218 #ifndef _WIN32
219 // Signals caught by exception_handler().
220 static const int exception_signals[] = {
221     SIGFPE,
222     SIGILL,
223     SIGSEGV,
224     SIGBUS,
225     SIGSYS,
226 };
227
228 // Default signal functions that should be restored after a test is complete.
229 typedef void (*SignalFunction)(int signal);
230 static SignalFunction default_signal_functions[
231     ARRAY_LENGTH(exception_signals)];
232
233 #else // _WIN32
234
235 // The default exception filter.
236 static LPTOP_LEVEL_EXCEPTION_FILTER previous_exception_filter;
237
238 // Fatal exceptions.
239 typedef struct ExceptionCodeInfo {
240     DWORD code;
241     const char* description;
242 } ExceptionCodeInfo;
243
244 #define EXCEPTION_CODE_INFO(exception_code) {exception_code, #exception_code}
245
246 static const ExceptionCodeInfo exception_codes[] = {
247     EXCEPTION_CODE_INFO(EXCEPTION_ACCESS_VIOLATION),
248     EXCEPTION_CODE_INFO(EXCEPTION_ARRAY_BOUNDS_EXCEEDED),
249     EXCEPTION_CODE_INFO(EXCEPTION_DATATYPE_MISALIGNMENT),
250     EXCEPTION_CODE_INFO(EXCEPTION_FLT_DENORMAL_OPERAND),
251     EXCEPTION_CODE_INFO(EXCEPTION_FLT_DIVIDE_BY_ZERO),
252     EXCEPTION_CODE_INFO(EXCEPTION_FLT_INEXACT_RESULT),
253     EXCEPTION_CODE_INFO(EXCEPTION_FLT_INVALID_OPERATION),
254     EXCEPTION_CODE_INFO(EXCEPTION_FLT_OVERFLOW),
255     EXCEPTION_CODE_INFO(EXCEPTION_FLT_STACK_CHECK),
256     EXCEPTION_CODE_INFO(EXCEPTION_FLT_UNDERFLOW),
257     EXCEPTION_CODE_INFO(EXCEPTION_GUARD_PAGE),
258     EXCEPTION_CODE_INFO(EXCEPTION_ILLEGAL_INSTRUCTION),
259     EXCEPTION_CODE_INFO(EXCEPTION_INT_DIVIDE_BY_ZERO),
260     EXCEPTION_CODE_INFO(EXCEPTION_INT_OVERFLOW),
261     EXCEPTION_CODE_INFO(EXCEPTION_INVALID_DISPOSITION),
262     EXCEPTION_CODE_INFO(EXCEPTION_INVALID_HANDLE),
263     EXCEPTION_CODE_INFO(EXCEPTION_IN_PAGE_ERROR),
264     EXCEPTION_CODE_INFO(EXCEPTION_NONCONTINUABLE_EXCEPTION),
265     EXCEPTION_CODE_INFO(EXCEPTION_PRIV_INSTRUCTION),
266     EXCEPTION_CODE_INFO(EXCEPTION_STACK_OVERFLOW),
267 };
268 #endif // !_WIN32
269
270
271 // Exit the currently executing test.
272 static void exit_test(const int quit_application) {
273     if (global_running_test) {
274         longjmp(global_run_test_env, 1);
275     } else if (quit_application) {
276         exit(-1);
277     }
278 }
279
280
281 // Initialize a SourceLocation structure.
282 static void initialize_source_location(SourceLocation * const location) {
283     assert_true(location);
284     location->file = NULL;
285     location->line = 0;
286 }
287
288
289 // Determine whether a source location is currently set.
290 static int source_location_is_set(const SourceLocation * const location) {
291     assert_true(location);
292     return location->file && location->line;
293 }
294
295
296 // Set a source location.
297 static void set_source_location(
298     SourceLocation * const location, const char * const file,
299     const int line) {
300     assert_true(location);
301     location->file = file;
302     location->line = line;
303 }
304
305
306 // Create function results and expected parameter lists.
307 void initialize_testing(const char *test_name) {
308     list_initialize(&global_function_result_map_head);
309     initialize_source_location(&global_last_mock_value_location);
310     list_initialize(&global_function_parameter_map_head);
311     initialize_source_location(&global_last_parameter_location);
312 }
313
314
315 void fail_if_leftover_values(const char *test_name) {
316     int error_occurred = 0;
317     remove_always_return_values(&global_function_result_map_head, 1);
318     if (check_for_leftover_values(
319             &global_function_result_map_head,
320             "%s() has remaining non-returned values.\n", 1)) {
321         error_occurred = 1;
322     }
323
324     remove_always_return_values(&global_function_parameter_map_head, 2);
325     if (check_for_leftover_values(
326             &global_function_parameter_map_head,
327             "%s parameter still has values that haven't been checked.\n", 2)) {
328         error_occurred = 1;
329     }
330     if (error_occurred) {
331         exit_test(1);
332     }
333 }
334
335
336 void teardown_testing(const char *test_name) {
337     list_free(&global_function_result_map_head, free_symbol_map_value,
338               (void*)0);
339     initialize_source_location(&global_last_mock_value_location);
340     list_free(&global_function_parameter_map_head, free_symbol_map_value,
341               (void*)1);
342     initialize_source_location(&global_last_parameter_location);
343 }
344
345 // Initialize a list node.
346 static ListNode* list_initialize(ListNode * const node) {
347     node->value = NULL;
348     node->next = node;
349     node->prev = node;
350     node->refcount = 1;
351     return node;
352 }
353
354
355 /* Adds a value at the tail of a given list.
356  * The node referencing the value is allocated from the heap. */
357 static ListNode* list_add_value(ListNode * const head, const void *value,
358                                      const int refcount) {
359     ListNode * const new_node = (ListNode*)malloc(sizeof(ListNode));
360     assert_true(head);
361     assert_true(value);
362     new_node->value = value;
363     new_node->refcount = refcount;
364     return list_add(head, new_node);
365 }
366
367
368 // Add new_node to the end of the list.
369 static ListNode* list_add(ListNode * const head, ListNode *new_node) {
370     assert_true(head);
371     assert_true(new_node);
372     new_node->next = head;
373     new_node->prev = head->prev;
374     head->prev->next = new_node;
375     head->prev = new_node;
376     return new_node;
377 }
378
379
380 // Remove a node from a list.
381 static ListNode* list_remove(
382         ListNode * const node, const CleanupListValue cleanup_value,
383         void * const cleanup_value_data) {
384     assert_true(node);
385     node->prev->next = node->next;
386     node->next->prev = node->prev;
387     if (cleanup_value) {
388         cleanup_value(node->value, cleanup_value_data);
389     }
390     return node;
391 }
392
393
394 /* Remove a list node from a list and free the node. */
395 static void list_remove_free(
396         ListNode * const node, const CleanupListValue cleanup_value,
397         void * const cleanup_value_data) {
398     assert_true(node);
399     free(list_remove(node, cleanup_value, cleanup_value_data));
400 }
401
402
403 /* Frees memory kept by a linked list
404  * The cleanup_value function is called for every "value" field of nodes in the
405  * list, except for the head.  In addition to each list value,
406  * cleanup_value_data is passed to each call to cleanup_value.  The head
407  * of the list is not deallocated.
408  */
409 static ListNode* list_free(
410         ListNode * const head, const CleanupListValue cleanup_value,
411         void * const cleanup_value_data) {
412     assert_true(head);
413     while (!list_empty(head)) {
414         list_remove_free(head->next, cleanup_value, cleanup_value_data);
415     }
416     return head;
417 }
418
419
420 // Determine whether a list is empty.
421 static int list_empty(const ListNode * const head) {
422     assert_true(head);
423     return head->next == head;
424 }
425
426
427 /* Find a value in the list using the equal_func to compare each node with the
428  * value.
429  */
430 static int list_find(ListNode * const head, const void *value,
431                      const EqualityFunction equal_func, ListNode **output) {
432     ListNode *current;
433     assert_true(head);
434     for (current = head->next; current != head; current = current->next) {
435         if (equal_func(current->value, value)) {
436             *output = current;
437             return 1;
438         }
439     }
440     return 0;
441 }
442
443 // Returns the first node of a list
444 static int list_first(ListNode * const head, ListNode **output) {
445     ListNode *target_node;
446     assert_true(head);
447     if (list_empty(head)) {
448         return 0;
449     }
450     target_node = head->next;
451     *output = target_node;
452     return 1;
453 }
454
455
456 // Deallocate a value referenced by a list.
457 static void free_value(const void *value, void *cleanup_value_data) {
458     assert_true(value);
459     free((void*)value);
460 }
461
462
463 // Releases memory associated to a symbol_map_value.
464 static void free_symbol_map_value(const void *value,
465                                   void *cleanup_value_data) {
466     SymbolMapValue * const map_value = (SymbolMapValue*)value;
467     const unsigned int children = (unsigned int)cleanup_value_data;
468     assert_true(value);
469     list_free(&map_value->symbol_values_list_head,
470               children ? free_symbol_map_value : free_value,
471               (void*)(children - 1));
472     free(map_value);
473 }
474
475
476 /* Determine whether a symbol name referenced by a symbol_map_value
477  * matches the specified function name. */
478 static int symbol_names_match(const void *map_value, const void *symbol) {
479     return !strcmp(((SymbolMapValue*)map_value)->symbol_name,
480                    (const char*)symbol);
481 }
482
483
484 /* Adds a value to the queue of values associated with the given
485  * hierarchy of symbols.  It's assumed value is allocated from the heap.
486  */
487 static void add_symbol_value(ListNode * const symbol_map_head,
488                              const char * const symbol_names[],
489                              const size_t number_of_symbol_names,
490                              const void* value, const int refcount) {
491     const char* symbol_name;
492     ListNode *target_node;
493     SymbolMapValue *target_map_value;
494     assert_true(symbol_map_head);
495     assert_true(symbol_names);
496     assert_true(number_of_symbol_names);
497     symbol_name = symbol_names[0];
498
499     if (!list_find(symbol_map_head, symbol_name, symbol_names_match,
500                    &target_node)) {
501         SymbolMapValue * const new_symbol_map_value =
502             malloc(sizeof(*new_symbol_map_value));
503         new_symbol_map_value->symbol_name = symbol_name;
504         list_initialize(&new_symbol_map_value->symbol_values_list_head);
505         target_node = list_add_value(symbol_map_head, new_symbol_map_value,
506                                           1);
507     }
508
509     target_map_value = (SymbolMapValue*)target_node->value;
510     if (number_of_symbol_names == 1) {
511             list_add_value(&target_map_value->symbol_values_list_head,
512                                 value, refcount);
513     } else {
514         add_symbol_value(&target_map_value->symbol_values_list_head,
515                          &symbol_names[1], number_of_symbol_names - 1, value,
516                          refcount);
517     }
518 }
519
520
521 /* Gets the next value associated with the given hierarchy of symbols.
522  * The value is returned as an output parameter with the function returning the
523  * node's old refcount value if a value is found, 0 otherwise.
524  * This means that a return value of 1 indicates the node was just removed from
525  * the list.
526  */
527 static int get_symbol_value(
528         ListNode * const head, const char * const symbol_names[],
529         const size_t number_of_symbol_names, void **output) {
530     const char* symbol_name;
531     ListNode *target_node;
532     assert_true(head);
533     assert_true(symbol_names);
534     assert_true(number_of_symbol_names);
535     assert_true(output);
536     symbol_name = symbol_names[0];
537
538     if (list_find(head, symbol_name, symbol_names_match, &target_node)) {
539         SymbolMapValue *map_value;
540         ListNode *child_list;
541         int return_value = 0;
542         assert_true(target_node);
543         assert_true(target_node->value);
544
545         map_value = (SymbolMapValue*)target_node->value;
546         child_list = &map_value->symbol_values_list_head;
547
548         if (number_of_symbol_names == 1) {
549             ListNode *value_node = NULL;
550             return_value = list_first(child_list, &value_node);
551             assert_true(return_value);
552             *output = (void*) value_node->value;
553             return_value = value_node->refcount;
554             if (--value_node->refcount == 0) {
555                 list_remove_free(value_node, NULL, NULL);
556             }
557         } else {
558             return_value = get_symbol_value(
559                 child_list, &symbol_names[1], number_of_symbol_names - 1,
560                 output);
561         }
562         if (list_empty(child_list)) {
563             list_remove_free(target_node, free_symbol_map_value, (void*)0);
564         }
565         return return_value;
566     } else {
567         print_error("No entries for symbol %s.\n", symbol_name);
568     }
569     return 0;
570 }
571
572
573 /* Traverse down a tree of symbol values and remove the first symbol value
574  * in each branch that has a refcount < -1 (i.e should always be returned
575  * and has been returned at least once).
576  */
577 static void remove_always_return_values(ListNode * const map_head,
578                                         const size_t number_of_symbol_names) {
579     ListNode *current;
580     assert_true(map_head);
581     assert_true(number_of_symbol_names);
582     current = map_head->next;
583     while (current != map_head) {
584         SymbolMapValue * const value = (SymbolMapValue*)current->value;
585         ListNode * const next = current->next;
586         ListNode *child_list;
587         assert_true(value);
588         child_list = &value->symbol_values_list_head;
589
590         if (!list_empty(child_list)) {
591             if (number_of_symbol_names == 1) {
592                 ListNode * const child_node = child_list->next;
593                 // If this item has been returned more than once, free it.
594                 if (child_node->refcount < -1) {
595                     list_remove_free(child_node, free_value, NULL);
596                 }
597             } else {
598                 remove_always_return_values(child_list,
599                                             number_of_symbol_names - 1);
600             }
601         }
602
603         if (list_empty(child_list)) {
604             list_remove_free(current, free_value, NULL);
605         }
606         current = next;
607     }
608 }
609
610 /* Checks if there are any leftover values set up by the test that were never
611  * retrieved through execution, and fail the test if that is the case.
612  */
613 static int check_for_leftover_values(
614         const ListNode * const map_head, const char * const error_message,
615         const size_t number_of_symbol_names) {
616     const ListNode *current;
617     int symbols_with_leftover_values = 0;
618     assert_true(map_head);
619     assert_true(number_of_symbol_names);
620
621     for (current = map_head->next; current != map_head;
622          current = current->next) {
623         const SymbolMapValue * const value =
624             (SymbolMapValue*)current->value;
625         const ListNode *child_list;
626         assert_true(value);
627         child_list = &value->symbol_values_list_head;
628
629         if (!list_empty(child_list)) {
630             if (number_of_symbol_names == 1) {
631                 const ListNode *child_node;
632                 print_error(error_message, value->symbol_name);
633                 print_error("  Remaining item(s) declared at...\n");
634
635                 for (child_node = child_list->next; child_node != child_list;
636                      child_node = child_node->next) {
637                     const SourceLocation * const location = child_node->value;
638                     print_error("    " SOURCE_LOCATION_FORMAT "\n",
639                                 location->file, location->line);
640                 }
641             } else {
642                 print_error("%s.", value->symbol_name);
643                 check_for_leftover_values(child_list, error_message,
644                                           number_of_symbol_names - 1);
645             }
646             symbols_with_leftover_values ++;
647         }
648     }
649     return symbols_with_leftover_values;
650 }
651
652
653 // Get the next return value for the specified mock function.
654 LargestIntegralType _mock(const char * const function, const char* const file,
655                           const int line) {
656     void *result;
657     const int rc = get_symbol_value(&global_function_result_map_head,
658                                     &function, 1, &result);
659     if (rc) {
660         SymbolValue * const symbol = (SymbolValue*)result;
661         const LargestIntegralType value = symbol->value;
662         global_last_mock_value_location = symbol->location;
663         if (rc == 1) {
664             free(symbol);
665         }
666         return value;
667     } else {
668         print_error("ERROR: " SOURCE_LOCATION_FORMAT " - Could not get value "
669                     "to mock function %s\n", file, line, function);
670         if (source_location_is_set(&global_last_mock_value_location)) {
671             print_error("Previously returned mock value was declared at "
672                         SOURCE_LOCATION_FORMAT "\n",
673                         global_last_mock_value_location.file,
674                         global_last_mock_value_location.line);
675         } else {
676             print_error("There were no previously returned mock values for "
677                         "this test.\n");
678         }
679         exit_test(1);
680     }
681     return 0;
682 }
683
684
685 // Add a return value for the specified mock function name.
686 void _will_return(const char * const function_name, const char * const file,
687                   const int line, const LargestIntegralType value,
688                   const int count) {
689     SymbolValue * const return_value = malloc(sizeof(*return_value));
690     assert_true(count > 0 || count == -1);
691     return_value->value = value;
692     set_source_location(&return_value->location, file, line);
693     add_symbol_value(&global_function_result_map_head, &function_name, 1,
694                      return_value, count);
695 }
696
697
698 /* Add a custom parameter checking function.  If the event parameter is NULL
699  * the event structure is allocated internally by this function.  If event
700  * parameter is provided it must be allocated on the heap and doesn't need to
701  * be deallocated by the caller.
702  */
703 void _expect_check(
704         const char* const function, const char* const parameter,
705         const char* const file, const int line,
706         const CheckParameterValue check_function,
707         const LargestIntegralType check_data,
708         CheckParameterEvent * const event, const int count) {
709     CheckParameterEvent * const check =
710         event ? event : malloc(sizeof(*check));
711     const char* symbols[] = {function, parameter};
712     check->parameter_name = parameter;
713     check->check_value = check_function;
714     check->check_value_data = check_data;
715     set_source_location(&check->location, file, line);
716     add_symbol_value(&global_function_parameter_map_head, symbols, 2, check,
717                      count);
718 }
719
720
721 /* Returns 1 if the specified values are equal.  If the values are not equal
722  * an error is displayed and 0 is returned. */
723 static int values_equal_display_error(const LargestIntegralType left,
724                                       const LargestIntegralType right) {
725     const int equal = left == right;
726     if (!equal) {
727         print_error(LargestIntegralTypePrintfFormat " != "
728                     LargestIntegralTypePrintfFormat "\n", left, right);
729     }
730     return equal;
731 }
732
733 /* Returns 1 if the specified values are not equal.  If the values are equal
734  * an error is displayed and 0 is returned. */
735 static int values_not_equal_display_error(const LargestIntegralType left,
736                                           const LargestIntegralType right) {
737     const int not_equal = left != right;
738     if (!not_equal) {
739         print_error(LargestIntegralTypePrintfFormat " == "
740                     LargestIntegralTypePrintfFormat "\n", left, right);
741     }
742     return not_equal;
743 }
744
745
746 /* Determine whether value is contained within check_integer_set.
747  * If invert is 0 and the value is in the set 1 is returned, otherwise 0 is
748  * returned and an error is displayed.  If invert is 1 and the value is not
749  * in the set 1 is returned, otherwise 0 is returned and an error is
750  * displayed. */
751 static int value_in_set_display_error(
752         const LargestIntegralType value,
753         const CheckIntegerSet * const check_integer_set, const int invert) {
754     int succeeded = invert;
755     assert_true(check_integer_set);
756     {
757         const LargestIntegralType * const set = check_integer_set->set;
758         const size_t size_of_set = check_integer_set->size_of_set;
759         size_t i;
760         for (i = 0; i < size_of_set; i++) {
761             if (set[i] == value) {
762                 // If invert = 0 and item is found, succeeded = 1.
763                 // If invert = 1 and item is found, succeeded = 0.
764                 succeeded = !succeeded;
765                 break;
766             }
767         }
768         if (succeeded) {
769             return 1;
770         }
771         print_error("%d is %sin the set (", value, invert ? "" : "not ");
772         for (i = 0; i < size_of_set; i++) {
773             print_error("%d, ", set[i]);
774         }
775         print_error(")\n");
776     }
777     return 0;
778 }
779
780
781 /* Determine whether a value is within the specified range.  If the value is
782  * within the specified range 1 is returned.  If the value isn't within the
783  * specified range an error is displayed and 0 is returned. */
784 static int integer_in_range_display_error(
785         const LargestIntegralType value, const LargestIntegralType range_min,
786         const LargestIntegralType range_max) {
787     if (value >= range_min && value <= range_max) {
788         return 1;
789     }
790     print_error("%d is not within the range %d-%d\n", value, range_min,
791                 range_max);
792     return 0;
793 }
794
795
796 /* Determine whether a value is within the specified range.  If the value
797  * is not within the range 1 is returned.  If the value is within the
798  * specified range an error is displayed and zero is returned. */
799 static int integer_not_in_range_display_error(
800         const LargestIntegralType value, const LargestIntegralType range_min,
801         const LargestIntegralType range_max) {
802     if (value < range_min || value > range_max) {
803         return 1;
804     }
805     print_error("%d is within the range %d-%d\n", value, range_min,
806                 range_max);
807     return 0;
808 }
809
810
811 /* Determine whether the specified strings are equal.  If the strings are equal
812  * 1 is returned.  If they're not equal an error is displayed and 0 is
813  * returned. */
814 static int string_equal_display_error(
815         const char * const left, const char * const right) {
816     if (strcmp(left, right) == 0) {
817         return 1;
818     }
819     print_error("\"%s\" != \"%s\"\n", left, right);
820     return 0;
821 }
822
823
824 /* Determine whether the specified strings are equal.  If the strings are not
825  * equal 1 is returned.  If they're not equal an error is displayed and 0 is
826  * returned */
827 static int string_not_equal_display_error(
828         const char * const left, const char * const right) {
829     if (strcmp(left, right) != 0) {
830         return 1;
831     }
832     print_error("\"%s\" == \"%s\"\n", left, right);
833     return 0;
834 }
835
836
837 /* Determine whether the specified areas of memory are equal.  If they're equal
838  * 1 is returned otherwise an error is displayed and 0 is returned. */
839 static int memory_equal_display_error(const char* const a, const char* const b,
840                                       const size_t size) {
841     int differences = 0;
842     size_t i;
843     for (i = 0; i < size; i++) {
844         const char l = a[i];
845         const char r = b[i];
846         if (l != r) {
847             print_error("difference at offset %d 0x%02x 0x%02x\n", i, l, r);
848             differences ++;
849         }
850     }
851     if (differences) {
852         print_error("%d bytes of 0x%08x and 0x%08x differ\n", differences,
853                     a, b);
854         return 0;
855     }
856     return 1;
857 }
858
859
860 /* Determine whether the specified areas of memory are not equal.  If they're
861  * not equal 1 is returned otherwise an error is displayed and 0 is
862  * returned. */
863 static int memory_not_equal_display_error(
864         const char* const a, const char* const b, const size_t size) {
865     int same = 0;
866     size_t i;
867     for (i = 0; i < size; i++) {
868         const char l = a[i];
869         const char r = b[i];
870         if (l == r) {
871             print_error("equal at offset %d 0x%02x 0x%02x\n", i, l, r);
872             same ++;
873         }
874     }
875     if (same) {
876         print_error("%d bytes of 0x%08x and 0x%08x the same\n", same,
877                     a, b);
878         return 0;
879     }
880     return 1;
881 }
882
883
884 // CheckParameterValue callback to check whether a value is within a set.
885 static int check_in_set(const LargestIntegralType value,
886                         const LargestIntegralType check_value_data) {
887     return value_in_set_display_error(value,
888         cast_largest_integral_type_to_pointer(CheckIntegerSet*,
889                                               check_value_data), 0);
890 }
891
892
893 // CheckParameterValue callback to check whether a value isn't within a set.
894 static int check_not_in_set(const LargestIntegralType value,
895                             const LargestIntegralType check_value_data) {
896     return value_in_set_display_error(value,
897         cast_largest_integral_type_to_pointer(CheckIntegerSet*,
898                                               check_value_data), 1);
899 }
900
901
902 /* Create the callback data for check_in_set() or check_not_in_set() and
903  * register a check event. */
904 static void expect_set(
905         const char* const function, const char* const parameter,
906         const char* const file, const int line,
907         const LargestIntegralType values[], const size_t number_of_values,
908         const CheckParameterValue check_function, const int count) {
909     CheckIntegerSet * const check_integer_set =
910         malloc(sizeof(*check_integer_set) +
911                (sizeof(values[0]) * number_of_values));
912     LargestIntegralType * const set = (LargestIntegralType*)(
913         check_integer_set + 1);
914     declare_initialize_value_pointer_pointer(check_data, check_integer_set);
915     assert_true(values);
916     assert_true(number_of_values);
917     memcpy(set, values, number_of_values * sizeof(values[0]));
918     check_integer_set->set = set;
919     _expect_check(
920         function, parameter, file, line, check_function,
921         check_data.value, &check_integer_set->event, count);
922 }
923
924
925 // Add an event to check whether a value is in a set.
926 void _expect_in_set(
927         const char* const function, const char* const parameter,
928         const char* const file, const int line,
929         const LargestIntegralType values[], const size_t number_of_values,
930         const int count) {
931     expect_set(function, parameter, file, line, values, number_of_values,
932                check_in_set, count);
933 }
934
935
936 // Add an event to check whether a value isn't in a set.
937 void _expect_not_in_set(
938         const char* const function, const char* const parameter,
939         const char* const file, const int line,
940         const LargestIntegralType values[], const size_t number_of_values,
941         const int count) {
942     expect_set(function, parameter, file, line, values, number_of_values,
943                check_not_in_set, count);
944 }
945
946
947 // CheckParameterValue callback to check whether a value is within a range.
948 static int check_in_range(const LargestIntegralType value,
949                           const LargestIntegralType check_value_data) {
950     CheckIntegerRange * const check_integer_range =
951         cast_largest_integral_type_to_pointer(CheckIntegerRange*,
952                                               check_value_data);
953     assert_true(check_integer_range);
954     return integer_in_range_display_error(value, check_integer_range->minimum,
955                                           check_integer_range->maximum);
956 }
957
958
959 // CheckParameterValue callback to check whether a value is not within a range.
960 static int check_not_in_range(const LargestIntegralType value,
961                               const LargestIntegralType check_value_data) {
962     CheckIntegerRange * const check_integer_range =
963         cast_largest_integral_type_to_pointer(CheckIntegerRange*,
964                                               check_value_data);
965     assert_true(check_integer_range);
966     return integer_not_in_range_display_error(
967         value, check_integer_range->minimum, check_integer_range->maximum);
968 }
969
970
971 /* Create the callback data for check_in_range() or check_not_in_range() and
972  * register a check event. */
973 static void expect_range(
974         const char* const function, const char* const parameter,
975         const char* const file, const int line,
976         const LargestIntegralType minimum, const LargestIntegralType maximum,
977         const CheckParameterValue check_function, const int count) {
978     CheckIntegerRange * const check_integer_range =
979         malloc(sizeof(*check_integer_range));
980     declare_initialize_value_pointer_pointer(check_data, check_integer_range);
981     check_integer_range->minimum = minimum;
982     check_integer_range->maximum = maximum;
983     _expect_check(function, parameter, file, line, check_function,
984                   check_data.value, &check_integer_range->event, count);
985 }
986
987
988 // Add an event to determine whether a parameter is within a range.
989 void _expect_in_range(
990         const char* const function, const char* const parameter,
991         const char* const file, const int line,
992         const LargestIntegralType minimum, const LargestIntegralType maximum,
993         const int count) {
994     expect_range(function, parameter, file, line, minimum, maximum,
995                  check_in_range, count);
996 }
997
998
999 // Add an event to determine whether a parameter is not within a range.
1000 void _expect_not_in_range(
1001         const char* const function, const char* const parameter,
1002         const char* const file, const int line,
1003         const LargestIntegralType minimum, const LargestIntegralType maximum,
1004         const int count) {
1005     expect_range(function, parameter, file, line, minimum, maximum,
1006                  check_not_in_range, count);
1007 }
1008
1009
1010 /* CheckParameterValue callback to check whether a value is equal to an
1011  * expected value. */
1012 static int check_value(const LargestIntegralType value,
1013                        const LargestIntegralType check_value_data) {
1014     return values_equal_display_error(value, check_value_data);
1015 }
1016
1017
1018 // Add an event to check a parameter equals an expected value.
1019 void _expect_value(
1020         const char* const function, const char* const parameter,
1021         const char* const file, const int line,
1022         const LargestIntegralType value, const int count) {
1023     _expect_check(function, parameter, file, line, check_value, value, NULL,
1024                   count);
1025 }
1026
1027
1028 /* CheckParameterValue callback to check whether a value is not equal to an
1029  * expected value. */
1030 static int check_not_value(const LargestIntegralType value,
1031                            const LargestIntegralType check_value_data) {
1032     return values_not_equal_display_error(value, check_value_data);
1033 }
1034
1035
1036 // Add an event to check a parameter is not equal to an expected value.
1037 void _expect_not_value(
1038         const char* const function, const char* const parameter,
1039         const char* const file, const int line,
1040         const LargestIntegralType value, const int count) {
1041     _expect_check(function, parameter, file, line, check_not_value, value,
1042                   NULL, count);
1043 }
1044
1045
1046 // CheckParameterValue callback to check whether a parameter equals a string.
1047 static int check_string(const LargestIntegralType value,
1048                         const LargestIntegralType check_value_data) {
1049     return string_equal_display_error(
1050         cast_largest_integral_type_to_pointer(char*, value),
1051         cast_largest_integral_type_to_pointer(char*, check_value_data));
1052 }
1053
1054
1055 // Add an event to check whether a parameter is equal to a string.
1056 void _expect_string(
1057         const char* const function, const char* const parameter,
1058         const char* const file, const int line, const char* string,
1059         const int count) {
1060     declare_initialize_value_pointer_pointer(string_pointer, (char*)string);
1061     _expect_check(function, parameter, file, line, check_string,
1062                   string_pointer.value, NULL, count);
1063 }
1064
1065
1066 /* CheckParameterValue callback to check whether a parameter is not equals to
1067  * a string. */
1068 static int check_not_string(const LargestIntegralType value,
1069                             const LargestIntegralType check_value_data) {
1070     return string_not_equal_display_error(
1071         cast_largest_integral_type_to_pointer(char*, value),
1072         cast_largest_integral_type_to_pointer(char*, check_value_data));
1073 }
1074
1075
1076 // Add an event to check whether a parameter is not equal to a string.
1077 void _expect_not_string(
1078         const char* const function, const char* const parameter,
1079         const char* const file, const int line, const char* string,
1080         const int count) {
1081     declare_initialize_value_pointer_pointer(string_pointer, (char*)string);
1082     _expect_check(function, parameter, file, line, check_not_string,
1083                   string_pointer.value, NULL, count);
1084 }
1085
1086 /* CheckParameterValue callback to check whether a parameter equals an area of
1087  * memory. */
1088 static int check_memory(const LargestIntegralType value,
1089                         const LargestIntegralType check_value_data) {
1090     CheckMemoryData * const check = cast_largest_integral_type_to_pointer(
1091         CheckMemoryData*, check_value_data);
1092     assert_true(check);
1093     return memory_equal_display_error(
1094         cast_largest_integral_type_to_pointer(void*, value),
1095         check->memory, check->size);
1096 }
1097
1098
1099 /* Create the callback data for check_memory() or check_not_memory() and
1100  * register a check event. */
1101 static void expect_memory_setup(
1102         const char* const function, const char* const parameter,
1103         const char* const file, const int line,
1104         const void * const memory, const size_t size,
1105         const CheckParameterValue check_function, const int count) {
1106     CheckMemoryData * const check_data = malloc(sizeof(*check_data) + size);
1107     void * const mem = (void*)(check_data + 1);
1108     declare_initialize_value_pointer_pointer(check_data_pointer, check_data);
1109     assert_true(memory);
1110     assert_true(size);
1111     memcpy(mem, memory, size);
1112     check_data->memory = mem;
1113     check_data->size = size;
1114     _expect_check(function, parameter, file, line, check_function,
1115                   check_data_pointer.value, &check_data->event, count);
1116 }
1117
1118
1119 // Add an event to check whether a parameter matches an area of memory.
1120 void _expect_memory(
1121         const char* const function, const char* const parameter,
1122         const char* const file, const int line, const void* const memory,
1123         const size_t size, const int count) {
1124     expect_memory_setup(function, parameter, file, line, memory, size,
1125                         check_memory, count);
1126 }
1127
1128
1129 /* CheckParameterValue callback to check whether a parameter is not equal to
1130  * an area of memory. */
1131 static int check_not_memory(const LargestIntegralType value,
1132                             const LargestIntegralType check_value_data) {
1133     CheckMemoryData * const check = cast_largest_integral_type_to_pointer(
1134         CheckMemoryData*, check_value_data);
1135     assert_true(check);
1136     return memory_not_equal_display_error(
1137         cast_largest_integral_type_to_pointer(void*, value), check->memory,
1138         check->size);
1139 }
1140
1141
1142 // Add an event to check whether a parameter doesn't match an area of memory.
1143 void _expect_not_memory(
1144         const char* const function, const char* const parameter,
1145         const char* const file, const int line, const void* const memory,
1146         const size_t size, const int count) {
1147     expect_memory_setup(function, parameter, file, line, memory, size,
1148                         check_not_memory, count);
1149 }
1150
1151
1152 // CheckParameterValue callback that always returns 1.
1153 static int check_any(const LargestIntegralType value,
1154                      const LargestIntegralType check_value_data) {
1155     return 1;
1156 }
1157
1158
1159 // Add an event to allow any value for a parameter.
1160 void _expect_any(
1161         const char* const function, const char* const parameter,
1162         const char* const file, const int line, const int count) {
1163     _expect_check(function, parameter, file, line, check_any, 0, NULL,
1164                   count);
1165 }
1166
1167
1168 void _check_expected(
1169         const char * const function_name, const char * const parameter_name,
1170         const char* file, const int line, const LargestIntegralType value) {
1171     void *result;
1172     const char* symbols[] = {function_name, parameter_name};
1173     const int rc = get_symbol_value(&global_function_parameter_map_head,
1174                                     symbols, 2, &result);
1175     if (rc) {
1176         CheckParameterEvent * const check = (CheckParameterEvent*)result;
1177         int check_succeeded;
1178         global_last_parameter_location = check->location;
1179         check_succeeded = check->check_value(value, check->check_value_data);
1180         if (rc == 1) {
1181             free(check);
1182         }
1183         if (!check_succeeded) {
1184             print_error("ERROR: Check of parameter %s, function %s failed\n"
1185                         "Expected parameter declared at "
1186                         SOURCE_LOCATION_FORMAT "\n",
1187                         parameter_name, function_name,
1188                         global_last_parameter_location.file,
1189                         global_last_parameter_location.line);
1190             _fail(file, line);
1191         }
1192     } else {
1193         print_error("ERROR: " SOURCE_LOCATION_FORMAT " - Could not get value "
1194                     "to check parameter %s of function %s\n", file, line,
1195                     parameter_name, function_name);
1196         if (source_location_is_set(&global_last_parameter_location)) {
1197             print_error("Previously declared parameter value was declared at "
1198                         SOURCE_LOCATION_FORMAT "\n",
1199                         global_last_parameter_location.file,
1200                         global_last_parameter_location.line);
1201         } else {
1202             print_error("There were no previously declared parameter values "
1203                         "for this test.\n");
1204         }
1205         exit_test(1);
1206     }
1207 }
1208
1209
1210 // Replacement for assert.
1211 void mock_assert(const int result, const char* const expression,
1212                  const char* const file, const int line) {
1213     if (!result) {
1214         if (global_expecting_assert) {
1215             longjmp(global_expect_assert_env, (int)expression);
1216         } else {
1217             print_error("ASSERT: %s\n", expression);
1218             _fail(file, line);
1219         }
1220     }
1221 }
1222
1223
1224 void _assert_true(const int result, const char * const expression,
1225                   const char * const file, const int line) {
1226     if (!result) {
1227         print_error("%s\n", expression);
1228         _fail(file, line);
1229     }
1230 }
1231
1232 void _assert_int_equal(
1233         const LargestIntegralType a, const LargestIntegralType b,
1234         const char * const file, const int line) {
1235     if (!values_equal_display_error(a, b)) {
1236         _fail(file, line);
1237     }
1238 }
1239
1240
1241 void _assert_int_not_equal(
1242         const LargestIntegralType a, const LargestIntegralType b,
1243         const char * const file, const int line) {
1244     if (!values_not_equal_display_error(a, b)) {
1245         _fail(file, line);
1246     }
1247 }
1248
1249
1250 void _assert_string_equal(const char * const a, const char * const b,
1251                           const char * const file, const int line) {
1252     if (!string_equal_display_error(a, b)) {
1253         _fail(file, line);
1254     }
1255 }
1256
1257
1258 void _assert_string_not_equal(const char * const a, const char * const b,
1259                               const char *file, const int line) {
1260     if (!string_not_equal_display_error(a, b)) {
1261         _fail(file, line);
1262     }
1263 }
1264
1265
1266 void _assert_memory_equal(const void * const a, const void * const b,
1267                           const size_t size, const char* const file,
1268                           const int line) {
1269     if (!memory_equal_display_error((const char*)a, (const char*)b, size)) {
1270         _fail(file, line);
1271     }
1272 }
1273
1274
1275 void _assert_memory_not_equal(const void * const a, const void * const b,
1276                               const size_t size, const char* const file,
1277                               const int line) {
1278     if (!memory_not_equal_display_error((const char*)a, (const char*)b,
1279                                         size)) {
1280         _fail(file, line);
1281     }
1282 }
1283
1284
1285 void _assert_in_range(
1286         const LargestIntegralType value, const LargestIntegralType minimum,
1287         const LargestIntegralType maximum, const char* const file,
1288         const int line) {
1289     if (!integer_in_range_display_error(value, minimum, maximum)) {
1290         _fail(file, line);
1291     }
1292 }
1293
1294 void _assert_not_in_range(
1295         const LargestIntegralType value, const LargestIntegralType minimum,
1296         const LargestIntegralType maximum, const char* const file,
1297         const int line) {
1298     if (!integer_not_in_range_display_error(value, minimum, maximum)) {
1299         _fail(file, line);
1300     }
1301 }
1302
1303 void _assert_in_set(const LargestIntegralType value,
1304                     const LargestIntegralType values[],
1305                     const size_t number_of_values, const char* const file,
1306                     const int line) {
1307     CheckIntegerSet check_integer_set;
1308     check_integer_set.set = values;
1309     check_integer_set.size_of_set = number_of_values;
1310     if (!value_in_set_display_error(value, &check_integer_set, 0)) {
1311         _fail(file, line);
1312     }
1313 }
1314
1315 void _assert_not_in_set(const LargestIntegralType value,
1316                         const LargestIntegralType values[],
1317                         const size_t number_of_values, const char* const file,
1318                         const int line) {
1319     CheckIntegerSet check_integer_set;
1320     check_integer_set.set = values;
1321     check_integer_set.size_of_set = number_of_values;
1322     if (!value_in_set_display_error(value, &check_integer_set, 1)) {
1323         _fail(file, line);
1324     }
1325 }
1326
1327
1328 // Get the list of allocated blocks.
1329 static ListNode* get_allocated_blocks_list() {
1330     // If it initialized, initialize the list of allocated blocks.
1331     if (!global_allocated_blocks.value) {
1332         list_initialize(&global_allocated_blocks);
1333         global_allocated_blocks.value = (void*)1;
1334     }
1335     return &global_allocated_blocks;
1336 }
1337
1338 // Use the real malloc in this function.
1339 #undef malloc
1340 void* _test_malloc(const size_t size, const char* file, const int line) {
1341     char* ptr;
1342     MallocBlockInfo *block_info;
1343     ListNode * const block_list = get_allocated_blocks_list();
1344     const size_t allocate_size = size + (MALLOC_GUARD_SIZE * 2) +
1345         sizeof(*block_info) + MALLOC_ALIGNMENT;
1346     char* const block = (char*)malloc(allocate_size);
1347     assert_true(block);
1348
1349     // Calculate the returned address.
1350     ptr = (char*)(((size_t)block + MALLOC_GUARD_SIZE + sizeof(*block_info) +
1351                   MALLOC_ALIGNMENT) & ~(MALLOC_ALIGNMENT - 1));
1352
1353     // Initialize the guard blocks.
1354     memset(ptr - MALLOC_GUARD_SIZE, MALLOC_GUARD_PATTERN, MALLOC_GUARD_SIZE);
1355     memset(ptr + size, MALLOC_GUARD_PATTERN, MALLOC_GUARD_SIZE);
1356     memset(ptr, MALLOC_ALLOC_PATTERN, size);
1357
1358     block_info = (MallocBlockInfo*)(ptr - (MALLOC_GUARD_SIZE +
1359                                              sizeof(*block_info)));
1360     set_source_location(&block_info->location, file, line);
1361     block_info->allocated_size = allocate_size;
1362     block_info->size = size;
1363     block_info->block = block;
1364     block_info->node.value = block_info;
1365     list_add(block_list, &block_info->node);
1366     return ptr;
1367 }
1368 #define malloc test_malloc
1369
1370
1371 void* _test_calloc(const size_t number_of_elements, const size_t size,
1372                    const char* file, const int line) {
1373     void* const ptr = _test_malloc(number_of_elements * size, file, line);
1374     if (ptr) {
1375         memset(ptr, 0, number_of_elements * size);
1376     }
1377     return ptr;
1378 }
1379
1380
1381 // Use the real free in this function.
1382 #undef free
1383 void _test_free(void* const ptr, const char* file, const int line) {
1384     unsigned int i;
1385     char *block = (char*)ptr;
1386     MallocBlockInfo *block_info;
1387     _assert_true((int)ptr, "ptr", file, line);
1388     block_info = (MallocBlockInfo*)(block - (MALLOC_GUARD_SIZE +
1389                                                sizeof(*block_info)));
1390     // Check the guard blocks.
1391     {
1392         char *guards[2] = {block - MALLOC_GUARD_SIZE,
1393                            block + block_info->size};
1394         for (i = 0; i < ARRAY_LENGTH(guards); i++) {
1395             unsigned int j;
1396             char * const guard = guards[i];
1397             for (j = 0; j < MALLOC_GUARD_SIZE; j++) {
1398                 const char diff = guard[j] - MALLOC_GUARD_PATTERN;
1399                 if (diff) {
1400                     print_error(
1401                         "Guard block of 0x%08x size=%d allocated by "
1402                         SOURCE_LOCATION_FORMAT " at 0x%08x is corrupt\n",
1403                         (size_t)ptr, block_info->size,
1404                         block_info->location.file, block_info->location.line,
1405                         (size_t)&guard[j]);
1406                     _fail(file, line);
1407                 }
1408             }
1409         }
1410     }
1411     list_remove(&block_info->node, NULL, NULL);
1412
1413     block = block_info->block;
1414     memset(block, MALLOC_FREE_PATTERN, block_info->allocated_size);
1415     free(block);
1416 }
1417 #define free test_free
1418
1419
1420 // Crudely checkpoint the current heap state.
1421 static const ListNode* check_point_allocated_blocks() {
1422     return get_allocated_blocks_list()->prev;
1423 }
1424
1425
1426 /* Display the blocks allocated after the specified check point.  This
1427  * function returns the number of blocks displayed. */
1428 static int display_allocated_blocks(const ListNode * const check_point) {
1429     const ListNode * const head = get_allocated_blocks_list();
1430     const ListNode *node;
1431     int allocated_blocks = 0;
1432     assert_true(check_point);
1433     assert_true(check_point->next);
1434
1435     for (node = check_point->next; node != head; node = node->next) {
1436         const MallocBlockInfo * const block_info = node->value;
1437         assert_true(block_info);
1438
1439         if (!allocated_blocks) {
1440             print_error("Blocks allocated...\n");
1441         }
1442         print_error("  0x%08x : " SOURCE_LOCATION_FORMAT "\n",
1443                     block_info->block, block_info->location.file,
1444                     block_info->location.line);
1445         allocated_blocks ++;
1446     }
1447     return allocated_blocks;
1448 }
1449
1450
1451 // Free all blocks allocated after the specified check point.
1452 static void free_allocated_blocks(const ListNode * const check_point) {
1453     const ListNode * const head = get_allocated_blocks_list();
1454     const ListNode *node;
1455     assert_true(check_point);
1456
1457     node = check_point->next;
1458     assert_true(node);
1459
1460     while (node != head) {
1461         MallocBlockInfo * const block_info = (MallocBlockInfo*)node->value;
1462         node = node->next;
1463         free((char*)block_info + sizeof(*block_info) + MALLOC_GUARD_SIZE);
1464     }
1465 }
1466
1467
1468 // Fail if any any blocks are allocated after the specified check point.
1469 static void fail_if_blocks_allocated(const ListNode * const check_point,
1470                                      const char * const test_name) {
1471     const int allocated_blocks = display_allocated_blocks(check_point);
1472     if (allocated_blocks) {
1473         free_allocated_blocks(check_point);
1474         print_error("ERROR: %s leaked %d block(s)\n", test_name,
1475                     allocated_blocks);
1476         exit_test(1);
1477     }
1478 }
1479
1480
1481 void _fail(const char * const file, const int line) {
1482     print_error("ERROR: " SOURCE_LOCATION_FORMAT " Failure!\n", file, line);
1483     exit_test(1);
1484 }
1485
1486
1487 #ifndef _WIN32
1488 static void exception_handler(int sig) {
1489     print_error("%s\n", strsignal(sig));
1490     exit_test(1);
1491 }
1492
1493 #else // _WIN32
1494
1495 static LONG WINAPI exception_filter(EXCEPTION_POINTERS *exception_pointers) {
1496     EXCEPTION_RECORD * const exception_record =
1497         exception_pointers->ExceptionRecord;
1498     const DWORD code = exception_record->ExceptionCode;
1499     unsigned int i;
1500     for (i = 0; i < ARRAY_LENGTH(exception_codes); i++) {
1501         const ExceptionCodeInfo * const code_info = &exception_codes[i];
1502         if (code == code_info->code) {
1503             static int shown_debug_message = 0;
1504             fflush(stdout);
1505             print_error("%s occurred at 0x%08x.\n", code_info->description,
1506                         exception_record->ExceptionAddress);
1507             if (!shown_debug_message) {
1508                 print_error(
1509                     "\n"
1510                     "To debug in Visual Studio...\n"
1511                     "1. Select menu item File->Open Project\n"
1512                     "2. Change 'Files of type' to 'Executable Files'\n"
1513                     "3. Open this executable.\n"
1514                     "4. Select menu item Debug->Start\n"
1515                     "\n"
1516                     "Alternatively, set the environment variable \n"
1517                     "UNIT_TESTING_DEBUG to 1 and rebuild this executable, \n"
1518                     "then click 'Debug' in the popup dialog box.\n"
1519                     "\n");
1520                 shown_debug_message = 1;
1521             }
1522             exit_test(0);
1523             return EXCEPTION_EXECUTE_HANDLER;
1524         }
1525     }
1526     return EXCEPTION_CONTINUE_SEARCH;
1527 }
1528 #endif // !_WIN32
1529
1530
1531 // Standard output and error print methods.
1532 void vprint_message(const char* const format, va_list args) {
1533     char buffer[1024];
1534     vsnprintf(buffer, sizeof(buffer), format, args);
1535     printf(buffer);
1536 #ifdef _WIN32
1537     OutputDebugString(buffer);
1538 #endif // _WIN32
1539 }
1540
1541
1542 void vprint_error(const char* const format, va_list args) {
1543     char buffer[1024];
1544     vsnprintf(buffer, sizeof(buffer), format, args);
1545     fprintf(stderr, buffer);
1546 #ifdef _WIN32
1547     OutputDebugString(buffer);
1548 #endif // _WIN32
1549 }
1550
1551
1552 void print_message(const char* const format, ...) {
1553     va_list args;
1554     va_start(args, format);
1555     vprint_message(format, args);
1556     va_end(args);
1557 }
1558
1559
1560 void print_error(const char* const format, ...) {
1561     va_list args;
1562     va_start(args, format);
1563     vprint_error(format, args);
1564     va_end(args);
1565 }
1566
1567
1568 int _run_test(
1569         const char * const function_name,  const UnitTestFunction Function,
1570         void ** const state, const UnitTestFunctionType function_type,
1571         const void* const heap_check_point) {
1572     const ListNode * const check_point = heap_check_point ?
1573         heap_check_point : check_point_allocated_blocks();
1574     void *current_state = NULL;
1575     int rc = 1;
1576     int handle_exceptions = 1;
1577 #ifdef _WIN32
1578     handle_exceptions = !IsDebuggerPresent();
1579 #endif // _WIN32
1580 #if UNIT_TESTING_DEBUG
1581     handle_exceptions = 0;
1582 #endif // UNIT_TESTING_DEBUG
1583
1584     if (handle_exceptions) {
1585 #ifndef _WIN32
1586         unsigned int i;
1587         for (i = 0; i < ARRAY_LENGTH(exception_signals); i++) {
1588             default_signal_functions[i] = signal(
1589                 exception_signals[i], exception_handler);
1590         }
1591 #else // _WIN32
1592         previous_exception_filter = SetUnhandledExceptionFilter(
1593             exception_filter);
1594 #endif // !_WIN32
1595     }
1596
1597     if (function_type == UNIT_TEST_FUNCTION_TYPE_TEST) {
1598         print_message("%s: Starting test\n", function_name);
1599     }
1600     initialize_testing(function_name);
1601     global_running_test = 1;
1602     if (setjmp(global_run_test_env) == 0) {
1603         Function(state ? state : &current_state);
1604         fail_if_leftover_values(function_name);
1605
1606         /* If this is a setup function then ignore any allocated blocks
1607          * only ensure they're deallocated on tear down. */
1608         if (function_type != UNIT_TEST_FUNCTION_TYPE_SETUP) {
1609             fail_if_blocks_allocated(check_point, function_name);
1610         }
1611
1612         global_running_test = 0;
1613
1614         if (function_type == UNIT_TEST_FUNCTION_TYPE_TEST) {
1615             print_message("%s: Test completed successfully.\n", function_name);
1616         }
1617         rc = 0;
1618     } else {
1619         global_running_test = 0;
1620         print_message("%s: Test failed.\n", function_name);
1621     }
1622     teardown_testing(function_name);
1623
1624     if (handle_exceptions) {
1625 #ifndef _WIN32
1626         unsigned int i;
1627         for (i = 0; i < ARRAY_LENGTH(exception_signals); i++) {
1628             signal(exception_signals[i], default_signal_functions[i]);
1629         }
1630 #else // _WIN32
1631         if (previous_exception_filter) {
1632             SetUnhandledExceptionFilter(previous_exception_filter);
1633             previous_exception_filter = NULL;
1634         }
1635 #endif // !_WIN32
1636     }
1637
1638     return rc;
1639 }
1640
1641
1642 int _run_tests(const UnitTest * const tests, const size_t number_of_tests) {
1643     // Whether to execute the next test.
1644     int run_next_test = 1;
1645     // Whether the previous test failed.
1646     int previous_test_failed = 0;
1647     // Check point of the heap state.
1648     const ListNode * const check_point = check_point_allocated_blocks();
1649     // Current test being executed.
1650     size_t current_test = 0;
1651     // Number of tests executed.
1652     size_t tests_executed = 0;
1653     // Number of failed tests.
1654     size_t total_failed = 0;
1655     // Number of setup functions.
1656     size_t setups = 0;
1657     // Number of teardown functions.
1658     size_t teardowns = 0;
1659     /* A stack of test states.  A state is pushed on the stack
1660      * when a test setup occurs and popped on tear down. */
1661     TestState* test_states = malloc(number_of_tests * sizeof(*test_states));
1662     size_t number_of_test_states = 0;
1663     // Names of the tests that failed.
1664     const char** failed_names = malloc(number_of_tests *
1665                                        sizeof(*failed_names));
1666     void **current_state = NULL;
1667     // Make sure LargestIntegralType is at least the size of a pointer.
1668     assert_true(sizeof(LargestIntegralType) >= sizeof(void*));
1669
1670     while (current_test < number_of_tests) {
1671         const ListNode *test_check_point = NULL;
1672         TestState *current_TestState;
1673         const UnitTest * const test = &tests[current_test++];
1674         if (!test->function) {
1675             continue;
1676         }
1677
1678         switch (test->function_type) {
1679         case UNIT_TEST_FUNCTION_TYPE_TEST:
1680             run_next_test = 1;
1681             break;
1682         case UNIT_TEST_FUNCTION_TYPE_SETUP: {
1683             // Checkpoint the heap before the setup.
1684             current_TestState = &test_states[number_of_test_states++];
1685             current_TestState->check_point = check_point_allocated_blocks();
1686             test_check_point = current_TestState->check_point;
1687             current_state = &current_TestState->state;
1688             *current_state = NULL;
1689             run_next_test = 1;
1690             setups ++;
1691             break;
1692         }
1693         case UNIT_TEST_FUNCTION_TYPE_TEARDOWN:
1694             // Check the heap based on the last setup checkpoint.
1695             assert_true(number_of_test_states);
1696             current_TestState = &test_states[--number_of_test_states];
1697             test_check_point = current_TestState->check_point;
1698             current_state = &current_TestState->state;
1699             teardowns ++;
1700             break;
1701         default:
1702             print_error("Invalid unit test function type %d\n",
1703                         test->function_type);
1704             exit_test(1);
1705             break;
1706         }
1707
1708         if (run_next_test) {
1709             int failed = _run_test(test->name, test->function, current_state,
1710                                    test->function_type, test_check_point);
1711             if (failed) {
1712                 failed_names[total_failed] = test->name;
1713             }
1714
1715             switch (test->function_type) {
1716             case UNIT_TEST_FUNCTION_TYPE_TEST:
1717                 previous_test_failed = failed;
1718                 total_failed += failed;
1719                 tests_executed ++;
1720                 break;
1721
1722             case UNIT_TEST_FUNCTION_TYPE_SETUP:
1723                 if (failed) {
1724                     total_failed ++;
1725                     tests_executed ++;
1726                     // Skip forward until the next test or setup function.
1727                     run_next_test = 0;
1728                 }
1729                 previous_test_failed = 0;
1730                 break;
1731
1732             case UNIT_TEST_FUNCTION_TYPE_TEARDOWN:
1733                 // If this test failed.
1734                 if (failed && !previous_test_failed) {
1735                     total_failed ++;
1736                 }
1737                 break;
1738             default:
1739                 assert_false("BUG: shouldn't be here!");
1740                 break;
1741             }
1742         }
1743     }
1744
1745     if (total_failed) {
1746         size_t i;
1747         print_error("%d out of %d tests failed!\n", total_failed,
1748                     tests_executed);
1749         for (i = 0; i < total_failed; i++) {
1750             print_error("    %s\n", failed_names[i]);
1751         }
1752     } else {
1753         print_message("All %d tests passed\n", tests_executed);
1754     }
1755
1756     if (number_of_test_states) {
1757         print_error("Mismatched number of setup %d and teardown %d "
1758                     "functions\n", setups, teardowns);
1759         total_failed = -1;
1760     }
1761
1762     free(test_states);
1763     free((void*)failed_names);
1764
1765     fail_if_blocks_allocated(check_point, "run_tests");
1766     return (int)total_failed;
1767 }