Compare commits
77 Commits
android-ct
...
android-5.
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.
|
||||
*/
|
||||
|
||||
#include <sys/resource.h>
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
#include <sys/resource.h>
|
||||
|
||||
#if defined(__GLIBC__)
|
||||
/* 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) {
|
||||
@@ -29,7 +29,7 @@ static int prlimit64(pid_t, int resource, const struct rlimit64* new_limit, stru
|
||||
}
|
||||
#endif
|
||||
|
||||
TEST(sys_resource, rlimit_struct_size) {
|
||||
TEST(sys_resource, smoke) {
|
||||
#if defined(__LP64__) || defined(__GLIBC__)
|
||||
ASSERT_EQ(sizeof(rlimit), sizeof(rlimit64));
|
||||
ASSERT_EQ(8U, sizeof(rlim_t));
|
||||
@@ -37,75 +37,51 @@ TEST(sys_resource, rlimit_struct_size) {
|
||||
ASSERT_NE(sizeof(rlimit), sizeof(rlimit64));
|
||||
ASSERT_EQ(4U, sizeof(rlim_t));
|
||||
#endif
|
||||
}
|
||||
|
||||
class SysResourceTest : public ::testing::Test {
|
||||
protected:
|
||||
virtual void SetUp() {
|
||||
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();
|
||||
|
||||
protected:
|
||||
rlimit l32_;
|
||||
rlimit64 l64_;
|
||||
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);
|
||||
// Read with getrlimit, getrlimit64, and prlimit64.
|
||||
// (prlimit is prlimit64 on LP64 and unimplemented on 32-bit.)
|
||||
rlimit l32;
|
||||
rlimit64 l64;
|
||||
rlimit64 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));
|
||||
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||
ASSERT_EQ(l64.rlim_max, pr_l64.rlim_max);
|
||||
if (l64.rlim_max == RLIM64_INFINITY) {
|
||||
ASSERT_EQ(RLIM_INFINITY, l32.rlim_max);
|
||||
} 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);
|
||||
if (l64_.rlim_max == RLIM64_INFINITY) {
|
||||
ASSERT_EQ(RLIM_INFINITY, l32_.rlim_max);
|
||||
} else {
|
||||
ASSERT_EQ(l64_.rlim_max, l32_.rlim_max);
|
||||
}
|
||||
}
|
||||
// Write with setrlimit and read back with everything.
|
||||
l32.rlim_cur = 123;
|
||||
ASSERT_EQ(0, setrlimit(RLIMIT_CORE, &l32));
|
||||
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(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.
|
||||
// Change resource limit setting with "ulimit -Hc" in the shell if this test fails.
|
||||
TEST_F(SysResourceTest, RLIMIT_CORE_rlim_max_not_zero) {
|
||||
ASSERT_TRUE(l32_.rlim_max == RLIM_INFINITY || l32_.rlim_max >= 456U) <<
|
||||
"RLIMIT_CORE rlim_max = " << l32_.rlim_max;
|
||||
}
|
||||
// Write with setrlimit64 and read back with everything.
|
||||
l64.rlim_cur = 456;
|
||||
ASSERT_EQ(0, setrlimit64(RLIMIT_CORE, &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));
|
||||
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) {
|
||||
CheckResourceLimits();
|
||||
}
|
||||
|
||||
TEST_F(SysResourceTest, setrlimit) {
|
||||
l32_.rlim_cur = 123U;
|
||||
ASSERT_EQ(0, setrlimit(RLIMIT_CORE, &l32_));
|
||||
CheckResourceLimits();
|
||||
ASSERT_EQ(123U, l32_.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.
|
||||
// Write with prlimit64 and read back with everything.
|
||||
l64.rlim_cur = 789;
|
||||
ASSERT_EQ(0, prlimit64(0, RLIMIT_CORE, &l64, NULL));
|
||||
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(789U, l32.rlim_cur);
|
||||
ASSERT_EQ(l64.rlim_cur, l32.rlim_cur);
|
||||
ASSERT_EQ(l64.rlim_cur, pr_l64.rlim_cur);
|
||||
}
|
||||
|
Reference in New Issue
Block a user