mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
Cleans up header order/grouping for consistency: associated header, C/C++ system/standard library headers, library headers, platform-specific #includes. Adds <cstring> where strlen, memcpy are being used: there are a bunch of places we use them transitively. Applies linter-required cleanups. Disables linter on one file due to included RapidJson header. See https://github.com/flutter/flutter/issues/65676 This patch does not cover flutter/shell/platform/darwin. There's a separate, slightly more intensive cleanup for those in progress.
136 lines
4.7 KiB
C++
136 lines
4.7 KiB
C++
// Copyright 2013 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#define FML_USED_ON_EMBEDDER
|
|
|
|
#include "flutter/shell/common/pipeline.h"
|
|
|
|
#include <functional>
|
|
#include <future>
|
|
#include <memory>
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
namespace flutter {
|
|
namespace testing {
|
|
|
|
using IntPipeline = Pipeline<int>;
|
|
using Continuation = IntPipeline::ProducerContinuation;
|
|
|
|
TEST(PipelineTest, ConsumeOneVal) {
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(2);
|
|
|
|
Continuation continuation = pipeline->Produce();
|
|
|
|
const int test_val = 1;
|
|
bool result = continuation.Complete(std::make_unique<int>(test_val));
|
|
ASSERT_EQ(result, true);
|
|
|
|
PipelineConsumeResult consume_result = pipeline->Consume(
|
|
[&test_val](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val); });
|
|
|
|
ASSERT_EQ(consume_result, PipelineConsumeResult::Done);
|
|
}
|
|
|
|
TEST(PipelineTest, ContinuationCanOnlyBeUsedOnce) {
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(2);
|
|
|
|
Continuation continuation = pipeline->Produce();
|
|
|
|
const int test_val = 1;
|
|
bool result = continuation.Complete(std::make_unique<int>(test_val));
|
|
ASSERT_EQ(result, true);
|
|
|
|
PipelineConsumeResult consume_result_1 = pipeline->Consume(
|
|
[&test_val](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val); });
|
|
|
|
result = continuation.Complete(std::make_unique<int>(test_val));
|
|
ASSERT_EQ(result, false);
|
|
ASSERT_EQ(consume_result_1, PipelineConsumeResult::Done);
|
|
|
|
PipelineConsumeResult consume_result_2 =
|
|
pipeline->Consume([](std::unique_ptr<int> v) { FAIL(); });
|
|
|
|
result = continuation.Complete(std::make_unique<int>(test_val));
|
|
ASSERT_EQ(result, false);
|
|
ASSERT_EQ(consume_result_2, PipelineConsumeResult::NoneAvailable);
|
|
}
|
|
|
|
TEST(PipelineTest, PushingMoreThanDepthCompletesFirstSubmission) {
|
|
const int depth = 1;
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(depth);
|
|
|
|
Continuation continuation_1 = pipeline->Produce();
|
|
Continuation continuation_2 = pipeline->Produce();
|
|
|
|
const int test_val_1 = 1, test_val_2 = 2;
|
|
bool result = continuation_1.Complete(std::make_unique<int>(test_val_1));
|
|
ASSERT_EQ(result, true);
|
|
result = continuation_2.Complete(std::make_unique<int>(test_val_2));
|
|
ASSERT_EQ(result, false);
|
|
|
|
PipelineConsumeResult consume_result_1 = pipeline->Consume(
|
|
[&test_val_1](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val_1); });
|
|
|
|
ASSERT_EQ(consume_result_1, PipelineConsumeResult::Done);
|
|
}
|
|
|
|
TEST(PipelineTest, PushingMultiProcessesInOrder) {
|
|
const int depth = 2;
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(depth);
|
|
|
|
Continuation continuation_1 = pipeline->Produce();
|
|
Continuation continuation_2 = pipeline->Produce();
|
|
|
|
const int test_val_1 = 1, test_val_2 = 2;
|
|
bool result = continuation_1.Complete(std::make_unique<int>(test_val_1));
|
|
ASSERT_EQ(result, true);
|
|
result = continuation_2.Complete(std::make_unique<int>(test_val_2));
|
|
ASSERT_EQ(result, true);
|
|
|
|
PipelineConsumeResult consume_result_1 = pipeline->Consume(
|
|
[&test_val_1](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val_1); });
|
|
ASSERT_EQ(consume_result_1, PipelineConsumeResult::MoreAvailable);
|
|
|
|
PipelineConsumeResult consume_result_2 = pipeline->Consume(
|
|
[&test_val_2](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val_2); });
|
|
ASSERT_EQ(consume_result_2, PipelineConsumeResult::Done);
|
|
}
|
|
|
|
TEST(PipelineTest, ProduceIfEmptyDoesNotConsumeWhenQueueIsNotEmpty) {
|
|
const int depth = 2;
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(depth);
|
|
|
|
Continuation continuation_1 = pipeline->Produce();
|
|
Continuation continuation_2 = pipeline->ProduceIfEmpty();
|
|
|
|
const int test_val_1 = 1, test_val_2 = 2;
|
|
bool result = continuation_1.Complete(std::make_unique<int>(test_val_1));
|
|
ASSERT_EQ(result, true);
|
|
result = continuation_2.Complete(std::make_unique<int>(test_val_2));
|
|
ASSERT_EQ(result, false);
|
|
|
|
PipelineConsumeResult consume_result_1 = pipeline->Consume(
|
|
[&test_val_1](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val_1); });
|
|
ASSERT_EQ(consume_result_1, PipelineConsumeResult::Done);
|
|
}
|
|
|
|
TEST(PipelineTest, ProduceIfEmptySuccessfulIfQueueIsEmpty) {
|
|
const int depth = 1;
|
|
fml::RefPtr<IntPipeline> pipeline = fml::MakeRefCounted<IntPipeline>(depth);
|
|
|
|
Continuation continuation_1 = pipeline->ProduceIfEmpty();
|
|
|
|
const int test_val_1 = 1;
|
|
bool result = continuation_1.Complete(std::make_unique<int>(test_val_1));
|
|
ASSERT_EQ(result, true);
|
|
|
|
PipelineConsumeResult consume_result_1 = pipeline->Consume(
|
|
[&test_val_1](std::unique_ptr<int> v) { ASSERT_EQ(*v, test_val_1); });
|
|
ASSERT_EQ(consume_result_1, PipelineConsumeResult::Done);
|
|
}
|
|
|
|
} // namespace testing
|
|
} // namespace flutter
|