/*
 *  Copyright 2014 The WebRTC Project Authors. All rights reserved.
 *
 *  Use of this source code is governed by a BSD-style license
 *  that can be found in the LICENSE file in the root of the source
 *  tree. An additional intellectual property rights grant can be found
 *  in the file PATENTS.  All contributing project authors may
 *  be found in the AUTHORS file in the root of the source tree.
 */

#include <memory>

#include "webrtc/base/constructormagic.h"
#include "webrtc/base/scopedptrcollection.h"
#include "webrtc/base/gunit.h"

namespace rtc {

namespace {

class InstanceCounter {
 public:
  explicit InstanceCounter(int* num_instances)
      : num_instances_(num_instances) {
    ++(*num_instances_);
  }
  ~InstanceCounter() {
    --(*num_instances_);
  }

 private:
  int* num_instances_;

  RTC_DISALLOW_COPY_AND_ASSIGN(InstanceCounter);
};

}  // namespace

class ScopedPtrCollectionTest : public testing::Test {
 protected:
  ScopedPtrCollectionTest()
      : num_instances_(0),
      collection_(new ScopedPtrCollection<InstanceCounter>()) {
  }

  int num_instances_;
  std::unique_ptr<ScopedPtrCollection<InstanceCounter> > collection_;
};

TEST_F(ScopedPtrCollectionTest, PushBack) {
  EXPECT_EQ(0u, collection_->collection().size());
  EXPECT_EQ(0, num_instances_);
  const int kNum = 100;
  for (int i = 0; i < kNum; ++i) {
    collection_->PushBack(new InstanceCounter(&num_instances_));
  }
  EXPECT_EQ(static_cast<size_t>(kNum), collection_->collection().size());
  EXPECT_EQ(kNum, num_instances_);
  collection_.reset();
  EXPECT_EQ(0, num_instances_);
}

TEST_F(ScopedPtrCollectionTest, Remove) {
  InstanceCounter* ic = new InstanceCounter(&num_instances_);
  collection_->PushBack(ic);
  EXPECT_EQ(1u, collection_->collection().size());
  collection_->Remove(ic);
  EXPECT_EQ(1, num_instances_);
  collection_.reset();
  EXPECT_EQ(1, num_instances_);
  delete ic;
  EXPECT_EQ(0, num_instances_);
}


}  // namespace rtc