Compare commits
77 Commits
lollipop-c
...
lollipop-r
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
944e192df6 | ||
|
|
2155882080 | ||
|
|
c32cd431fa | ||
|
|
1840121a6a | ||
|
|
90a1ed4f45 | ||
|
|
48116b3024 | ||
|
|
614ff987ce | ||
|
|
8e06009fcd | ||
|
|
8a2d72d586 | ||
|
|
d690d19dd0 | ||
|
|
b7672222a9 | ||
|
|
24a365fbe4 | ||
|
|
6c1389bf5f | ||
|
|
397c90bf3e | ||
|
|
5579bf649f | ||
|
|
ce77e55ce5 | ||
|
|
8eac9d69d8 | ||
|
|
28a7ed042f | ||
|
|
7ac9e617b8 | ||
|
|
9416df8139 | ||
|
|
3ae2ad2aea | ||
|
|
ad4be8f64f | ||
|
|
7ed41f97bb | ||
|
|
59551b8144 | ||
|
|
194ca8df2d | ||
|
|
44da474bb8 | ||
|
|
dc922ade9f | ||
|
|
b3613b4efd | ||
|
|
6078d68321 | ||
|
|
277c1b00f5 | ||
|
|
50982fd0c4 | ||
|
|
25232c43fc | ||
|
|
1d12f186ed | ||
|
|
fab4d76b46 | ||
|
|
604b2f5789 | ||
|
|
ddca20bda4 | ||
|
|
d0beefdcd3 | ||
|
|
ee809b90e8 | ||
|
|
b2c6088b1e | ||
|
|
dc3814bcf9 | ||
|
|
d9bead2357 | ||
|
|
8c673ec8e9 | ||
|
|
daebe2764b | ||
|
|
2fcb94d52c | ||
|
|
20dc3f8fa4 | ||
|
|
54a6221cc2 | ||
|
|
489b5d23fd | ||
|
|
5f17e16e92 | ||
|
|
3bd669c605 | ||
|
|
cb278332cb | ||
|
|
fe9787ece9 | ||
|
|
bae5898f3d | ||
|
|
08f6f664ed | ||
|
|
a0108accb2 | ||
|
|
58df7d814e | ||
|
|
147ce71ddc | ||
|
|
2e7c8634b7 | ||
|
|
25ffdd7b9f | ||
|
|
e9f34a3ee7 | ||
|
|
c323d5efb8 | ||
|
|
6cde02273f | ||
|
|
e3ff5fca61 | ||
|
|
b5e0854284 | ||
|
|
6b9b454d55 | ||
|
|
5984773a8d | ||
|
|
b4725def2e | ||
|
|
b8d00ef3ba | ||
|
|
39978ccb7f | ||
|
|
6447d2f4de | ||
|
|
1183762969 | ||
|
|
bdf601894f | ||
|
|
6a20f051a2 | ||
|
|
8bc74887c1 | ||
|
|
1b710ff000 | ||
|
|
13fb0584e1 | ||
|
|
4514aa630c | ||
|
|
0caf70e98e |
@@ -14,10 +14,10 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/resource.h>
|
|
||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#include <sys/resource.h>
|
||||||
|
|
||||||
#if defined(__GLIBC__)
|
#if defined(__GLIBC__)
|
||||||
/* The host glibc we're currently building with doesn't have prlimit64 yet. */
|
/* The host glibc we're currently building with doesn't have prlimit64 yet. */
|
||||||
static int prlimit64(pid_t, int resource, const struct rlimit64* new_limit, struct rlimit64* old_limit) {
|
static int prlimit64(pid_t, int resource, const struct rlimit64* new_limit, struct rlimit64* old_limit) {
|
||||||
@@ -29,7 +29,7 @@ static int prlimit64(pid_t, int resource, const struct rlimit64* new_limit, stru
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TEST(sys_resource, rlimit_struct_size) {
|
TEST(sys_resource, smoke) {
|
||||||
#if defined(__LP64__) || defined(__GLIBC__)
|
#if defined(__LP64__) || defined(__GLIBC__)
|
||||||
ASSERT_EQ(sizeof(rlimit), sizeof(rlimit64));
|
ASSERT_EQ(sizeof(rlimit), sizeof(rlimit64));
|
||||||
ASSERT_EQ(8U, sizeof(rlim_t));
|
ASSERT_EQ(8U, sizeof(rlim_t));
|
||||||
@@ -37,75 +37,51 @@ TEST(sys_resource, rlimit_struct_size) {
|
|||||||
ASSERT_NE(sizeof(rlimit), sizeof(rlimit64));
|
ASSERT_NE(sizeof(rlimit), sizeof(rlimit64));
|
||||||
ASSERT_EQ(4U, sizeof(rlim_t));
|
ASSERT_EQ(4U, sizeof(rlim_t));
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
|
|
||||||
class SysResourceTest : public ::testing::Test {
|
// Read with getrlimit, getrlimit64, and prlimit64.
|
||||||
protected:
|
// (prlimit is prlimit64 on LP64 and unimplemented on 32-bit.)
|
||||||
virtual void SetUp() {
|
rlimit l32;
|
||||||
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32_));
|
rlimit64 l64;
|
||||||
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64_));
|
rlimit64 pr_l64;
|
||||||
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64_));
|
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32));
|
||||||
}
|
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64));
|
||||||
|
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64));
|
||||||
void CheckResourceLimits();
|
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||||
|
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||||
protected:
|
ASSERT_EQ(l64.rlim_max, pr_l64.rlim_max);
|
||||||
rlimit l32_;
|
if (l64.rlim_max == RLIM64_INFINITY) {
|
||||||
rlimit64 l64_;
|
ASSERT_EQ(RLIM_INFINITY, l32.rlim_max);
|
||||||
rlimit64 pr_l64_;
|
|
||||||
};
|
|
||||||
|
|
||||||
void SysResourceTest::CheckResourceLimits() {
|
|
||||||
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32_));
|
|
||||||
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64_));
|
|
||||||
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64_));
|
|
||||||
ASSERT_EQ(l64_.rlim_cur, pr_l64_.rlim_cur);
|
|
||||||
if (l64_.rlim_cur == RLIM64_INFINITY) {
|
|
||||||
ASSERT_EQ(RLIM_INFINITY, l32_.rlim_cur);
|
|
||||||
} else {
|
} else {
|
||||||
ASSERT_EQ(l64_.rlim_cur, l32_.rlim_cur);
|
ASSERT_EQ(l64.rlim_max, l32.rlim_max);
|
||||||
}
|
}
|
||||||
|
|
||||||
ASSERT_EQ(l64_.rlim_max, pr_l64_.rlim_max);
|
// Write with setrlimit and read back with everything.
|
||||||
if (l64_.rlim_max == RLIM64_INFINITY) {
|
l32.rlim_cur = 123;
|
||||||
ASSERT_EQ(RLIM_INFINITY, l32_.rlim_max);
|
ASSERT_EQ(0, setrlimit(RLIMIT_CORE, &l32));
|
||||||
} else {
|
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32));
|
||||||
ASSERT_EQ(l64_.rlim_max, l32_.rlim_max);
|
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64));
|
||||||
}
|
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64));
|
||||||
}
|
ASSERT_EQ(123U, l32.rlim_cur);
|
||||||
|
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||||
|
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||||
|
|
||||||
// Force rlim_max to be bigger than a constant so we can continue following test.
|
// Write with setrlimit64 and read back with everything.
|
||||||
// Change resource limit setting with "ulimit -Hc" in the shell if this test fails.
|
l64.rlim_cur = 456;
|
||||||
TEST_F(SysResourceTest, RLIMIT_CORE_rlim_max_not_zero) {
|
ASSERT_EQ(0, setrlimit64(RLIMIT_CORE, &l64));
|
||||||
ASSERT_TRUE(l32_.rlim_max == RLIM_INFINITY || l32_.rlim_max >= 456U) <<
|
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32));
|
||||||
"RLIMIT_CORE rlim_max = " << l32_.rlim_max;
|
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64));
|
||||||
}
|
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64));
|
||||||
|
ASSERT_EQ(456U, l32.rlim_cur);
|
||||||
|
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||||
|
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||||
|
|
||||||
TEST_F(SysResourceTest, get_resource_limit_equal) {
|
// Write with prlimit64 and read back with everything.
|
||||||
CheckResourceLimits();
|
l64.rlim_cur = 789;
|
||||||
}
|
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, &l64, NULL));
|
||||||
|
ASSERT_EQ(0, getrlimit(RLIMIT_CORE, &l32));
|
||||||
TEST_F(SysResourceTest, setrlimit) {
|
ASSERT_EQ(0, getrlimit64(RLIMIT_CORE, &l64));
|
||||||
l32_.rlim_cur = 123U;
|
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, NULL, &pr_l64));
|
||||||
ASSERT_EQ(0, setrlimit(RLIMIT_CORE, &l32_));
|
ASSERT_EQ(789U, l32.rlim_cur);
|
||||||
CheckResourceLimits();
|
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||||
ASSERT_EQ(123U, l32_.rlim_cur);
|
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(SysResourceTest, setrlimit64) {
|
|
||||||
l64_.rlim_cur = 456U;
|
|
||||||
ASSERT_EQ(0, setrlimit64(RLIMIT_CORE, &l64_));
|
|
||||||
CheckResourceLimits();
|
|
||||||
ASSERT_EQ(456U, l64_.rlim_cur);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(SysResourceTest, prlimit64) {
|
|
||||||
pr_l64_.rlim_cur = pr_l64_.rlim_max;
|
|
||||||
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, &pr_l64_, NULL));
|
|
||||||
CheckResourceLimits();
|
|
||||||
ASSERT_EQ(pr_l64_.rlim_max, pr_l64_.rlim_cur);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(SysResourceTest, prlimit) {
|
|
||||||
// prlimit is prlimit64 on LP64 and unimplemented on 32-bit. So we only test prlimit64.
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user