mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-12 04:34:43 +04:00
* Api Symbols: replace asserts with checks * Api Symbols: replace asserts with checks part 2 * Update no args function signatures with void, to help compiler to track incorrect usage * More unavoidable void * Update PVS config and code to make it happy * Format sources * nfc: fix checks * dead code cleanup & include fixes Co-authored-by: gornekich <n.gorbadey@gmail.com> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: hedger <hedger@nanode.su>
40 lines
902 B
C
40 lines
902 B
C
#include "../minunit.h"
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
|
|
void test_furi_memmgr(void) {
|
|
void* ptr;
|
|
|
|
// allocate memory case
|
|
ptr = malloc(100);
|
|
mu_check(ptr != NULL);
|
|
// test that memory is zero-initialized after allocation
|
|
for(int i = 0; i < 100; i++) {
|
|
mu_assert_int_eq(0, ((uint8_t*)ptr)[i]);
|
|
}
|
|
free(ptr);
|
|
|
|
// reallocate memory case
|
|
ptr = malloc(100);
|
|
memset(ptr, 66, 100);
|
|
ptr = realloc(ptr, 200);
|
|
mu_check(ptr != NULL);
|
|
|
|
// test that memory is really reallocated
|
|
for(int i = 0; i < 100; i++) {
|
|
mu_assert_int_eq(66, ((uint8_t*)ptr)[i]);
|
|
}
|
|
|
|
free(ptr);
|
|
|
|
// allocate and zero-initialize array (calloc)
|
|
ptr = calloc(100, 2);
|
|
mu_check(ptr != NULL);
|
|
for(int i = 0; i < 100 * 2; i++) {
|
|
mu_assert_int_eq(0, ((uint8_t*)ptr)[i]);
|
|
}
|
|
free(ptr);
|
|
}
|