From 535c5992d6692124357247a70a37772fae1a8569 Mon Sep 17 00:00:00 2001 From: Elliott Hughes Date: Wed, 10 Feb 2016 20:43:22 -0800 Subject: [PATCH] Add tests for zero-sized allocations. POSIX lets us return null and set errno, but that would be annoying and surprising. Bug: http://b/27101951 (cherry picked from commit 884f76e3aa081740f7cfe582b11af7446bf77bd9) Change-Id: Ice4fd3cd427523edc2ca4ba25caf9701c353db47 --- tests/malloc_test.cpp | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/tests/malloc_test.cpp b/tests/malloc_test.cpp index 5af5a6fb5..d3a9d01e4 100644 --- a/tests/malloc_test.cpp +++ b/tests/malloc_test.cpp @@ -391,3 +391,42 @@ TEST(malloc, calloc_usable_size) { free(zero_mem); } } + +TEST(malloc, malloc_0) { + void* p = malloc(0); + ASSERT_TRUE(p != nullptr); + free(p); +} + +TEST(malloc, calloc_0_0) { + void* p = calloc(0, 0); + ASSERT_TRUE(p != nullptr); + free(p); +} + +TEST(malloc, calloc_0_1) { + void* p = calloc(0, 1); + ASSERT_TRUE(p != nullptr); + free(p); +} + +TEST(malloc, calloc_1_0) { + void* p = calloc(1, 0); + ASSERT_TRUE(p != nullptr); + free(p); +} + +TEST(malloc, realloc_nullptr_0) { + // realloc(nullptr, size) is actually malloc(size). + void* p = realloc(nullptr, 0); + ASSERT_TRUE(p != nullptr); + free(p); +} + +TEST(malloc, realloc_0) { + void* p = malloc(1024); + ASSERT_TRUE(p != nullptr); + // realloc(p, 0) is actually free(p). + void* p2 = realloc(p, 0); + ASSERT_TRUE(p2 == nullptr); +}