summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorYabin Cui <yabinc@google.com>2015-01-16 21:52:11 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2015-01-16 21:52:11 +0000
commitcfe7e75fc13afb987d86aaaee305040f3369f797 (patch)
treeac3de6bfc420be48155a0402ce7a30ac2d8b5b73 /tests
parentffad8df672363bad43528898cc47aa2ed3d08c66 (diff)
parent4853f40f3fb6664cb1b7af97b6b3e795717026b1 (diff)
downloadbionic-cfe7e75fc13afb987d86aaaee305040f3369f797.zip
bionic-cfe7e75fc13afb987d86aaaee305040f3369f797.tar.gz
bionic-cfe7e75fc13afb987d86aaaee305040f3369f797.tar.bz2
Merge "Make sys_resource test more robust."
Diffstat (limited to 'tests')
-rw-r--r--tests/sys_resource_test.cpp112
1 files changed, 68 insertions, 44 deletions
diff --git a/tests/sys_resource_test.cpp b/tests/sys_resource_test.cpp
index 91d07ab..8cefc65 100644
--- a/tests/sys_resource_test.cpp
+++ b/tests/sys_resource_test.cpp
@@ -14,11 +14,11 @@
* limitations under the License.
*/
-#include <gtest/gtest.h>
-
#include <sys/resource.h>
-TEST(sys_resource, smoke) {
+#include <gtest/gtest.h>
+
+TEST(sys_resource, rlimit_struct_size) {
#if defined(__LP64__) || defined(__GLIBC__)
ASSERT_EQ(sizeof(rlimit), sizeof(rlimit64));
ASSERT_EQ(8U, sizeof(rlim_t));
@@ -26,51 +26,75 @@ TEST(sys_resource, smoke) {
ASSERT_NE(sizeof(rlimit), sizeof(rlimit64));
ASSERT_EQ(4U, sizeof(rlim_t));
#endif
+}
- // 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);
+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);
} else {
- ASSERT_EQ(l64.rlim_max, l32.rlim_max);
+ ASSERT_EQ(l64_.rlim_cur, l32_.rlim_cur);
}
- // 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);
+ 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);
+ }
+}
+
+// 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;
+}
+
+TEST_F(SysResourceTest, get_resource_limit_equal) {
+ CheckResourceLimits();
+}
- // 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, 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);
+}
- // 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);
+TEST_F(SysResourceTest, prlimit) {
+ // prlimit is prlimit64 on LP64 and unimplemented on 32-bit. So we only test prlimit64.
}