| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // |
| /////////////////////////////////////////////////////////////////////////////// |
| |
| #include "tink/python/cc/output_stream_adapter.h" |
| |
| #include <algorithm> |
| #include <sstream> |
| |
| #include "gtest/gtest.h" |
| #include "absl/memory/memory.h" |
| #include "tink/output_stream.h" |
| #include "tink/subtle/random.h" |
| #include "tink/util/ostream_output_stream.h" |
| #include "tink/util/test_matchers.h" |
| |
| namespace crypto { |
| namespace tink { |
| namespace { |
| |
| std::unique_ptr<OutputStreamAdapter> GetOutputStreamAdapter( |
| int buffer_size, std::stringbuf** buffer_ref) { |
| auto string_stream = absl::make_unique<std::stringstream>(); |
| // Reference to the stringstream buffer used for later validation. |
| *buffer_ref = string_stream->rdbuf(); |
| auto output_stream = absl::make_unique<util::OstreamOutputStream>( |
| std::move(string_stream), buffer_size); |
| return absl::make_unique<OutputStreamAdapter>(std::move(output_stream)); |
| } |
| |
| TEST(OutputStreamAdapterTest, Basic) { |
| std::stringbuf* buffer_ref; |
| auto adapter = GetOutputStreamAdapter(-1, &buffer_ref); |
| auto write_result = adapter->Write("something"); |
| ASSERT_THAT(write_result.status(), test::IsOk()); |
| EXPECT_EQ(write_result.ValueOrDie(), 9); |
| EXPECT_THAT(adapter->Close(), test::IsOk()); |
| EXPECT_EQ(buffer_ref->str(), "something"); |
| } |
| |
| TEST(OutputStreamAdapterTest, MultipleWrite) { |
| std::stringbuf* buffer_ref; |
| auto adapter = GetOutputStreamAdapter(-1, &buffer_ref); |
| auto write_result = adapter->Write("something"); |
| ASSERT_THAT(write_result.status(), test::IsOk()); |
| EXPECT_EQ(write_result.ValueOrDie(), 9); |
| write_result = adapter->Write("123"); |
| ASSERT_THAT(write_result.status(), test::IsOk()); |
| EXPECT_EQ(write_result.ValueOrDie(), 3); |
| write_result = adapter->Write("456"); |
| ASSERT_THAT(write_result.status(), test::IsOk()); |
| EXPECT_EQ(write_result.ValueOrDie(), 3); |
| EXPECT_THAT(adapter->Close(), test::IsOk()); |
| EXPECT_EQ(buffer_ref->str(), "something123456"); |
| } |
| |
| TEST(OutputStreamAdapterTest, WriteAfterClose) { |
| std::stringbuf* buffer_ref; |
| auto adapter = GetOutputStreamAdapter(-1, &buffer_ref); |
| ASSERT_THAT(adapter->Close(), test::IsOk()); |
| EXPECT_THAT(adapter->Write("something").status(), |
| test::StatusIs(util::error::FAILED_PRECONDITION, |
| testing::HasSubstr("Stream closed"))); |
| } |
| |
| // In this test size of the OstreamOutputStream buffer is smaller than the |
| // size of data to be written, so multiple calls to Next() will be needed. |
| TEST(OutputStreamAdapterTest, MultipleNext) { |
| std::stringbuf* buffer_ref; |
| auto adapter = GetOutputStreamAdapter(10, &buffer_ref); |
| std::string data = subtle::Random::GetRandomBytes(35); |
| auto write_result = adapter->Write(data); |
| ASSERT_THAT(write_result.status(), test::IsOk()); |
| EXPECT_EQ(write_result.ValueOrDie(), 35); |
| EXPECT_THAT(adapter->Close(), test::IsOk()); |
| EXPECT_EQ(buffer_ref->str(), data); |
| } |
| |
| } // namespace |
| } // namespace tink |
| } // namespace crypto |