reader_test.cc 1.8 KB
Newer Older
Y
yuyang18 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
// Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
//
// 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 "paddle/fluid/framework/reader.h"
#include <memory>
#include "gtest/gtest.h"

class StubDecoratedReader : public paddle::framework::DecoratedReader {
 public:
  explicit StubDecoratedReader(const std::shared_ptr<ReaderBase> &reader)
      : DecoratedReader(reader) {}

F
fengjiayi 已提交
24
  void ReadNextImpl(std::vector<paddle::framework::LoDTensor> *out) override {}
Y
yuyang18 已提交
25 26 27 28
};

class StubRootReader : public paddle::framework::ReaderBase {
 public:
F
fengjiayi 已提交
29
  void ReadNextImpl(std::vector<paddle::framework::LoDTensor> *out) override {}
Y
yuyang18 已提交
30 31 32 33
};

TEST(READER, decorate_chain) {
  auto root = std::make_shared<StubRootReader>();
34 35 36 37
  auto end_point1 =
      paddle::framework::MakeDecoratedReader<StubDecoratedReader>(root);
  auto end_point2 =
      paddle::framework::MakeDecoratedReader<StubDecoratedReader>(root);
Y
yuyang18 已提交
38 39 40 41

  {
    auto endpoints = root->GetEndPoints();
    ASSERT_EQ(endpoints.size(), 2U);
T
Tao Luo 已提交
42
    ASSERT_NE(endpoints.count(end_point1.get()), 0UL);
43
    ASSERT_NE(endpoints.count(end_point2.get()), 0UL);
Y
yuyang18 已提交
44 45 46
  }

  {
47 48
    auto end_point3 =
        paddle::framework::MakeDecoratedReader<StubDecoratedReader>(root);
Y
yuyang18 已提交
49 50 51 52
    ASSERT_EQ(root->GetEndPoints().size(), 3U);
  }
  { ASSERT_EQ(root->GetEndPoints().size(), 2U); }
}