Index: mojo/system/local_data_pipe_unittest.cc |
diff --git a/mojo/system/local_data_pipe_unittest.cc b/mojo/system/local_data_pipe_unittest.cc |
index 4f32e6ba6f824499fa6467274991d07264749374..98a5ae1080e4c5da5c7264f7e73596c2a8116893 100644 |
--- a/mojo/system/local_data_pipe_unittest.cc |
+++ b/mojo/system/local_data_pipe_unittest.cc |
@@ -476,8 +476,110 @@ TEST(LocalDataPipeTest, BasicConsumerWaiting) { |
} |
} |
-// TODO(vtl): More: discard (with/without "all or none"). More "all or none" |
-// tests. |
+void Seq(int32_t start, size_t count, int32_t* out) { |
+ for (size_t i = 0; i < count; i++) |
+ out[i] = start + static_cast<int32_t>(i); |
+} |
+ |
+TEST(LocalDataPipeTest, MayDiscard) { |
+ const MojoCreateDataPipeOptions options = { |
+ kSizeOfOptions, // |struct_size|. |
+ MOJO_CREATE_DATA_PIPE_OPTIONS_FLAG_MAY_DISCARD, // |flags|. |
+ static_cast<uint32_t>(sizeof(int32_t)), // |element_num_bytes|. |
+ 10 * sizeof(int32_t) // |capacity_num_bytes|. |
+ }; |
+ MojoCreateDataPipeOptions validated_options = { 0 }; |
+ EXPECT_EQ(MOJO_RESULT_OK, |
+ DataPipe::ValidateOptions(&options, &validated_options)); |
+ |
+ scoped_refptr<LocalDataPipe> dp(new LocalDataPipe(validated_options)); |
+ |
+ int32_t buffer[100] = { 0 }; |
+ uint32_t num_bytes = 0; |
+ |
+ num_bytes = 20u * sizeof(int32_t); |
+ Seq(0, arraysize(buffer), buffer); |
+ // Try writing more than capacity. (This test relies on the implementation |
+ // enforcing the capacity strictly.) |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ProducerWriteData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(10u * sizeof(int32_t), num_bytes); |
+ |
+ // Read half of what we wrote. |
+ num_bytes = 5u * sizeof(int32_t); |
+ memset(buffer, 0xab, sizeof(buffer)); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ConsumerReadData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(5u * sizeof(int32_t), num_bytes); |
+ int32_t expected_buffer[100]; |
+ memset(expected_buffer, 0xab, sizeof(expected_buffer)); |
+ Seq(0, 5u, expected_buffer); |
+ EXPECT_EQ(0, memcmp(buffer, expected_buffer, sizeof(buffer))); |
+ // Internally, a circular buffer would now look like: |
+ // -, -, -, -, -, 5, 6, 7, 8, 9 |
+ |
+ // Write a bit more than the space that's available. |
+ num_bytes = 8u * sizeof(int32_t); |
+ Seq(100, arraysize(buffer), buffer); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ProducerWriteData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(8u * sizeof(int32_t), num_bytes); |
+ // Internally, a circular buffer would now look like: |
+ // 100, 101, 102, 103, 104, 105, 106, 107, 8, 9 |
+ |
+ // Read half of what's available. |
+ num_bytes = 5u * sizeof(int32_t); |
+ memset(buffer, 0xab, sizeof(buffer)); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ConsumerReadData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(5u * sizeof(int32_t), num_bytes); |
+ memset(expected_buffer, 0xab, sizeof(expected_buffer)); |
+ expected_buffer[0] = 8; |
+ expected_buffer[1] = 9; |
+ expected_buffer[2] = 100; |
+ expected_buffer[3] = 101; |
+ expected_buffer[4] = 102; |
+ EXPECT_EQ(0, memcmp(buffer, expected_buffer, sizeof(buffer))); |
+ // Internally, a circular buffer would now look like: |
+ // -, -, -, 103, 104, 105, 106, 107, -, - |
+ |
+ // Write one integer. |
+ num_bytes = 1u * sizeof(int32_t); |
+ Seq(200, arraysize(buffer), buffer); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ProducerWriteData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(1u * sizeof(int32_t), num_bytes); |
+ // Internally, a circular buffer would now look like: |
+ // -, -, -, 103, 104, 105, 106, 107, 200, - |
+ |
+ // Write five more. |
+ num_bytes = 5u * sizeof(int32_t); |
+ Seq(300, arraysize(buffer), buffer); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ProducerWriteData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(5u * sizeof(int32_t), num_bytes); |
+ // Internally, a circular buffer would now look like: |
+ // 301, 302, 303, 304, 104, 105, 106, 107, 200, 300 |
+ |
+ // Read it all. |
+ num_bytes = sizeof(buffer); |
+ memset(buffer, 0xab, sizeof(buffer)); |
+ EXPECT_EQ(MOJO_RESULT_OK, dp->ConsumerReadData(buffer, &num_bytes, false)); |
+ EXPECT_EQ(10u * sizeof(int32_t), num_bytes); |
+ memset(expected_buffer, 0xab, sizeof(expected_buffer)); |
+ expected_buffer[0] = 104; |
+ expected_buffer[1] = 105; |
+ expected_buffer[2] = 106; |
+ expected_buffer[3] = 107; |
+ expected_buffer[4] = 200; |
+ expected_buffer[5] = 300; |
+ expected_buffer[6] = 301; |
+ expected_buffer[7] = 302; |
+ expected_buffer[8] = 303; |
+ expected_buffer[9] = 304; |
+ EXPECT_EQ(0, memcmp(buffer, expected_buffer, sizeof(buffer))); |
+ |
+ // TODO(vtl): Test two-phase write when it supports "may discard". |
+ |
+ dp->ProducerClose(); |
+ dp->ConsumerClose(); |
+} |
+ |
+// TODO(vtl): More "all or none" tests (without and with "may discard"). |
// Tests that |ProducerWriteData()| and |ConsumerReadData()| writes and reads, |
// respectively, as much as possible, even if it has to "wrap around" the |