Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1279)

Unified Diff: mojo/public/c/system/tests/handle_unittest.cc

Issue 2056513002: Plumb MojoReplaceHandleWithReducedRights() out. (Closed) Base URL: https://github.com/domokit/mojo.git@work790_replace_reduce_1
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: mojo/public/c/system/tests/handle_unittest.cc
diff --git a/mojo/public/c/system/tests/handle_unittest.cc b/mojo/public/c/system/tests/handle_unittest.cc
index 685fd82b6d85ae61d580360940081b33228e3bdc..0de5748b49b24eea4b53a85e58e57a67e8d5ef22 100644
--- a/mojo/public/c/system/tests/handle_unittest.cc
+++ b/mojo/public/c/system/tests/handle_unittest.cc
@@ -8,32 +8,109 @@
// handles.
#include "mojo/public/c/system/handle.h"
+#include "mojo/public/c/system/message_pipe.h"
#include "mojo/public/c/system/result.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace {
+const MojoHandleRights kDefaultMessagePipeHandleRights =
+ MOJO_HANDLE_RIGHT_TRANSFER | MOJO_HANDLE_RIGHT_READ |
+ MOJO_HANDLE_RIGHT_WRITE | MOJO_HANDLE_RIGHT_GET_OPTIONS |
+ MOJO_HANDLE_RIGHT_SET_OPTIONS;
+
TEST(HandleTest, InvalidHandle) {
- // Close:
+ // MojoClose:
EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT, MojoClose(MOJO_HANDLE_INVALID));
- // GetRights:
+ // MojoGetRights:
MojoHandleRights rights = MOJO_HANDLE_RIGHT_NONE;
EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT,
MojoGetRights(MOJO_HANDLE_INVALID, &rights));
- // DuplicateHandleWithReducedRights:
+ // MojoReplaceHandleWithReducedRights:
+ MojoHandle replacement_handle = MOJO_HANDLE_INVALID;
+ EXPECT_EQ(
+ MOJO_RESULT_INVALID_ARGUMENT,
+ MojoReplaceHandleWithReducedRights(
+ MOJO_HANDLE_INVALID, MOJO_HANDLE_RIGHT_NONE, &replacement_handle));
+
+ // MojoDuplicateHandleWithReducedRights:
MojoHandle new_handle = MOJO_HANDLE_INVALID;
EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT,
MojoDuplicateHandleWithReducedRights(
MOJO_HANDLE_INVALID, MOJO_HANDLE_RIGHT_DUPLICATE, &new_handle));
EXPECT_EQ(MOJO_HANDLE_INVALID, new_handle);
- // DuplicateHandle:
+ // MojoDuplicateHandle:
new_handle = MOJO_HANDLE_INVALID;
EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT,
MojoDuplicateHandle(MOJO_HANDLE_INVALID, &new_handle));
EXPECT_EQ(MOJO_HANDLE_INVALID, new_handle);
}
+// |MojoReplaceHandleWithReducedRights()| is not handle-type specific, so we'll
+// test it here, even though it requires actually creating/using a specific
+// handle type.
+TEST(HandleTest, ReplaceHandleWithReducedRights) {
+ MojoHandle h0 = MOJO_HANDLE_INVALID;
+ MojoHandle h1 = MOJO_HANDLE_INVALID;
+ // That |MojoCreateMessagePipe()| works correctly is checked in
+ // |MessagePipeTest|.
+ EXPECT_EQ(MOJO_RESULT_OK, MojoCreateMessagePipe(nullptr, &h0, &h1));
+
+ // Still check the rights on one of the handles, just to make sure that
+ // |kDefaultMessagePipeHandleRights| stays in sync with reality.
+ MojoHandleRights rights = MOJO_HANDLE_RIGHT_NONE;
+ EXPECT_EQ(MOJO_RESULT_OK, MojoGetRights(h0, &rights));
+ EXPECT_EQ(kDefaultMessagePipeHandleRights, rights);
+
+ // First try replacing without reducing rights.
+ MojoHandle h0r0 = MOJO_HANDLE_INVALID;
+ EXPECT_EQ(MOJO_RESULT_OK, MojoReplaceHandleWithReducedRights(
+ h0, MOJO_HANDLE_RIGHT_NONE, &h0r0));
+ EXPECT_NE(h0r0, MOJO_HANDLE_INVALID);
+ // Not guaranteed, but we depend on handle values not being reused eagerly.
+ EXPECT_NE(h0r0, h0);
+ EXPECT_NE(h0r0, h1); // |h0r0| should definitely not be the same as |h1|.
+ // |h0| should be dead, so this should fail.
+ EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT, MojoClose(h0));
+
+ // Check that the rights remain the same.
+ rights = MOJO_HANDLE_RIGHT_NONE;
+ EXPECT_EQ(MOJO_RESULT_OK, MojoGetRights(h0r0, &rights));
+ EXPECT_EQ(kDefaultMessagePipeHandleRights, rights);
+
+ // Make sure the replacement handle is still usable.
+ char x = 'x';
+ EXPECT_EQ(MOJO_RESULT_OK, MojoWriteMessage(h0r0, &x, 1u, nullptr, 0,
+ MOJO_WRITE_MESSAGE_FLAG_NONE));
+
+ // Try replacing, but removing a couple of rights.
+ MojoHandle h0r1 = MOJO_HANDLE_INVALID;
+ constexpr MojoHandleRights kRightsToRemove =
+ MOJO_HANDLE_RIGHT_TRANSFER | MOJO_HANDLE_RIGHT_WRITE;
+ EXPECT_EQ(MOJO_RESULT_OK,
+ MojoReplaceHandleWithReducedRights(h0r0, kRightsToRemove, &h0r1));
+ EXPECT_NE(h0r1, MOJO_HANDLE_INVALID);
+ // Not guaranteed, but we depend on handle values not being reused eagerly.
+ EXPECT_NE(h0r1, h0r0);
+ EXPECT_NE(h0r1, h1); // |h0r1| should definitely not be the same as |h1|.
+ // |h0r0| should be dead, so this should fail.
+ EXPECT_EQ(MOJO_RESULT_INVALID_ARGUMENT, MojoClose(h0r0));
+
+ // Check that |h0r1| has the expected rights.
+ rights = MOJO_HANDLE_RIGHT_NONE;
+ EXPECT_EQ(MOJO_RESULT_OK, MojoGetRights(h0r1, &rights));
+ EXPECT_EQ(kDefaultMessagePipeHandleRights & ~kRightsToRemove, rights);
+
+ // Make sure that the rights are actually correctly enforced.
+ EXPECT_EQ(
+ MOJO_RESULT_PERMISSION_DENIED,
+ MojoWriteMessage(h0r1, &x, 1u, nullptr, 0, MOJO_WRITE_MESSAGE_FLAG_NONE));
+
+ EXPECT_EQ(MOJO_RESULT_OK, MojoClose(h0r1));
+ EXPECT_EQ(MOJO_RESULT_OK, MojoClose(h1));
+}
+
} // namespace

Powered by Google App Engine
This is Rietveld 408576698