File: oom.c

package info (click to toggle)
libgit2 0.27.7%2Bdfsg.1-0.2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 31,400 kB
  • sloc: ansic: 157,824; sh: 406; python: 182; php: 65; makefile: 61
file content (53 lines) | stat: -rw-r--r-- 1,530 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include "clar_libgit2.h"
#include "buffer.h"

/*
 * We want to use some ridiculous size that `malloc` will fail with
 * but that does not otherwise interfere with testing.  On Linux, choose
 * a number that is large enough to fail immediately but small enough
 * that valgrind doesn't believe it to erroneously be a negative number.
 * On macOS, choose a number that is large enough to fail immediately
 * without having libc print warnings to stderr.
 */
#if defined(GIT_ARCH_64) && defined(__linux__)
# define TOOBIG 0x0fffffffffffffff
#elif defined(__linux__)
# define TOOBIG 0x0fffffff
#elif defined(GIT_ARCH_64)
# define TOOBIG 0xffffffffffffff00
#else
# define TOOBIG 0xffffff00
#endif

/**
 * If we make a ridiculously large request the first time we
 * actually allocate some space in the git_buf, the realloc()
 * will fail.  And because the git_buf_grow() wrapper always
 * sets mark_oom, the code in git_buf_try_grow() will free
 * the internal buffer and set it to git_buf__oom.
 * 
 * We initialized the internal buffer to (the static variable)
 * git_buf__initbuf.  The purpose of this test is to make sure
 * that we don't try to free the static buffer.
 */
void test_buf_oom__grow(void)
{
	git_buf buf = GIT_BUF_INIT;

	git_buf_clear(&buf);

	cl_assert(git_buf_grow(&buf, TOOBIG) == -1);
	cl_assert(git_buf_oom(&buf));

	git_buf_free(&buf);
}

void test_buf_oom__grow_by(void)
{
	git_buf buf = GIT_BUF_INIT;

	buf.size = SIZE_MAX-10;

	cl_assert(git_buf_grow_by(&buf, 50) == -1);
	cl_assert(git_buf_oom(&buf));
}