|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
From 990e42d9c751d089cea161a25b7c2ade0a15d279 Mon Sep 17 00:00:00 2001
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
From: Edward Thomson <ethomson@edwardthomson.com>
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
Date: Thu, 13 Sep 2018 13:27:07 +0100
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
Subject: [PATCH] tests: don't run buf::oom on 32-bit systems
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
On a 32-bit Linux systems, the value large enough to make malloc
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
guarantee a failure is also large enough that valgrind considers it
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
"fishy". Skip this test on those systems entirely.
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
(cherry picked from commit 415a8ae9c9b6ac18f0524b6af8e58408b426457d)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
---
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
tests/buf/oom.c | 14 +++++++++-----
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
1 file changed, 9 insertions(+), 5 deletions(-)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
diff --git a/tests/buf/oom.c b/tests/buf/oom.c
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
index 16a03cc1a..86f5e7239 100644
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
--- a/tests/buf/oom.c
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+++ b/tests/buf/oom.c
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
@@ -11,12 +11,8 @@
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
*/
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
#if defined(GIT_ARCH_64) && defined(__linux__)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
# define TOOBIG 0x0fffffffffffffff
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
-#elif defined(__linux__)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
-# define TOOBIG 0x0fffffff
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
#elif defined(GIT_ARCH_64)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
# define TOOBIG 0xffffffffffffff00
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
-#else
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
-# define TOOBIG 0xffffff00
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
#endif
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
/**
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
@@ -25,13 +21,18 @@
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* will fail. And because the git_buf_grow() wrapper always
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* sets mark_oom, the code in git_buf_try_grow() will free
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* the internal buffer and set it to git_buf__oom.
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
- *
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ *
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* We initialized the internal buffer to (the static variable)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* git_buf__initbuf. The purpose of this test is to make sure
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
* that we don't try to free the static buffer.
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ *
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ * Skip this test entirely on 32-bit platforms; a buffer large enough
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ * to guarantee malloc failures is so large that valgrind considers
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ * it likely to be an error.
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
*/
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
void test_buf_oom__grow(void)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
{
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+#ifdef GIT_ARCH_64
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
git_buf buf = GIT_BUF_INIT;
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
git_buf_clear(&buf;;
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
@@ -40,6 +41,9 @@ void test_buf_oom__grow(void)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
cl_assert(git_buf_oom(&buf));
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
git_buf_free(&buf;;
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+#else
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+ cl_skip();
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
+#endif
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
}
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
void test_buf_oom__grow_by(void)
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
--
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
2.19.1
|
|
![](https://seccdn.libravatar.org/avatar/0d7412ac72ab5524e5d2c4f5b4f4f412f381b5cf3ccecba2f096234efa75fcc9?s=16&d=retro) |
fa2b99e |
|