forked from mirror/libcxx
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
390 lines
10 KiB
C++
390 lines
10 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
// Source Licenses. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
#ifndef SET_ALLOCATOR_REQUIREMENT_TEST_TEMPLATES_H
|
|
#define SET_ALLOCATOR_REQUIREMENT_TEST_TEMPLATES_H
|
|
|
|
// <set>
|
|
// <unordered_set>
|
|
|
|
// class set
|
|
// class unordered_set
|
|
|
|
// insert(...);
|
|
// emplace(...);
|
|
// emplace_hint(...);
|
|
|
|
|
|
#include <cassert>
|
|
|
|
#include "test_macros.h"
|
|
#include "count_new.hpp"
|
|
#include "container_test_types.h"
|
|
#include "assert_checkpoint.h"
|
|
|
|
|
|
template <class Container>
|
|
void testSetInsert()
|
|
{
|
|
typedef typename Container::value_type ValueTp;
|
|
ConstructController* cc = getConstructController();
|
|
cc->reset();
|
|
{
|
|
CHECKPOINT("Testing C::insert(const value_type&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
assert(c.insert(v).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
assert(c.insert(v2).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(value_type&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
assert(c.insert(v).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
assert(c.insert(v2).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(value_type&&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&&>();
|
|
assert(c.insert(std::move(v)).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
assert(c.insert(std::move(v2)).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(const value_type&&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
assert(c.insert(std::move(v)).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
assert(c.insert(std::move(v2)).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(std::initializer_list<ValueTp>)");
|
|
Container c;
|
|
std::initializer_list<ValueTp> il = { ValueTp(1), ValueTp(2) };
|
|
cc->expect<ValueTp const&>(2);
|
|
c.insert(il);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
c.insert(il);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type const&");
|
|
Container c;
|
|
const ValueTp ValueList[] = { ValueTp(1), ValueTp(2), ValueTp(3) };
|
|
cc->expect<ValueTp const&>(3);
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type&&");
|
|
Container c;
|
|
ValueTp ValueList[] = { ValueTp(1), ValueTp(2) , ValueTp(3) };
|
|
cc->expect<ValueTp&&>(3);
|
|
c.insert(std::move_iterator<ValueTp*>(std::begin(ValueList)),
|
|
std::move_iterator<ValueTp*>(std::end(ValueList)));
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp ValueList2[] = { ValueTp(1), ValueTp(2) , ValueTp(3) };
|
|
c.insert(std::move_iterator<ValueTp*>(std::begin(ValueList2)),
|
|
std::move_iterator<ValueTp*>(std::end(ValueList2)));
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type&");
|
|
Container c;
|
|
ValueTp ValueList[] = { ValueTp(1), ValueTp(2) , ValueTp(3) };
|
|
cc->expect<ValueTp const&>(3);
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
template <class Container>
|
|
void testSetEmplace()
|
|
{
|
|
typedef typename Container::value_type ValueTp;
|
|
ConstructController* cc = getConstructController();
|
|
cc->reset();
|
|
{
|
|
CHECKPOINT("Testing C::emplace(const value_type&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
assert(c.emplace(v).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
assert(c.emplace(v2).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(value_type&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&>();
|
|
assert(c.emplace(v).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
assert(c.emplace(v2).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(value_type&&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&&>();
|
|
assert(c.emplace(std::move(v)).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
assert(c.emplace(std::move(v2)).second == false);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(const value_type&&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&&>();
|
|
assert(c.emplace(std::move(v)).second);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
assert(c.emplace(std::move(v2)).second == false);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
template <class Container>
|
|
void testSetEmplaceHint()
|
|
{
|
|
typedef typename Container::value_type ValueTp;
|
|
typedef Container C;
|
|
typedef typename C::iterator It;
|
|
ConstructController* cc = getConstructController();
|
|
cc->reset();
|
|
{
|
|
CHECKPOINT("Testing C::emplace_hint(p, const value_type&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
It ret = c.emplace_hint(c.end(), v);
|
|
assert(ret != c.end());
|
|
assert(c.size() == 1);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
It ret2 = c.emplace_hint(c.begin(), v2);
|
|
assert(&(*ret2) == &(*ret));
|
|
assert(c.size() == 1);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace_hint(p, value_type&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&>();
|
|
It ret = c.emplace_hint(c.end(), v);
|
|
assert(ret != c.end());
|
|
assert(c.size() == 1);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
It ret2 = c.emplace_hint(c.begin(), v2);
|
|
assert(&(*ret2) == &(*ret));
|
|
assert(c.size() == 1);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace_hint(p, value_type&&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&&>();
|
|
It ret = c.emplace_hint(c.end(), std::move(v));
|
|
assert(ret != c.end());
|
|
assert(c.size() == 1);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
ValueTp v2(42);
|
|
It ret2 = c.emplace_hint(c.begin(), std::move(v2));
|
|
assert(&(*ret2) == &(*ret));
|
|
assert(c.size() == 1);
|
|
}
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace_hint(p, const value_type&&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&&>();
|
|
It ret = c.emplace_hint(c.end(), std::move(v));
|
|
assert(ret != c.end());
|
|
assert(c.size() == 1);
|
|
assert(!cc->unchecked());
|
|
{
|
|
DisableAllocationGuard g;
|
|
const ValueTp v2(42);
|
|
It ret2 = c.emplace_hint(c.begin(), std::move(v2));
|
|
assert(&(*ret2) == &(*ret));
|
|
assert(c.size() == 1);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
template <class Container>
|
|
void testMultisetInsert()
|
|
{
|
|
typedef typename Container::value_type ValueTp;
|
|
ConstructController* cc = getConstructController();
|
|
cc->reset();
|
|
{
|
|
CHECKPOINT("Testing C::insert(const value_type&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
c.insert(v);
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(value_type&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
c.insert(v);
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(value_type&&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&&>();
|
|
c.insert(std::move(v));
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(std::initializer_list<ValueTp>)");
|
|
Container c;
|
|
std::initializer_list<ValueTp> il = { ValueTp(1), ValueTp(2) };
|
|
cc->expect<ValueTp const&>(2);
|
|
c.insert(il);
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type const&");
|
|
Container c;
|
|
const ValueTp ValueList[] = { ValueTp(1), ValueTp(2), ValueTp(3) };
|
|
cc->expect<ValueTp const&>(3);
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type&&");
|
|
Container c;
|
|
ValueTp ValueList[] = { ValueTp(1), ValueTp(2) , ValueTp(3) };
|
|
cc->expect<ValueTp&&>(3);
|
|
c.insert(std::move_iterator<ValueTp*>(std::begin(ValueList)),
|
|
std::move_iterator<ValueTp*>(std::end(ValueList)));
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::insert(Iter, Iter) for *Iter = value_type&");
|
|
Container c;
|
|
ValueTp ValueList[] = { ValueTp(1), ValueTp(2) , ValueTp(1) };
|
|
cc->expect<ValueTp&>(3);
|
|
c.insert(std::begin(ValueList), std::end(ValueList));
|
|
assert(!cc->unchecked());
|
|
}
|
|
}
|
|
|
|
|
|
template <class Container>
|
|
void testMultisetEmplace()
|
|
{
|
|
typedef typename Container::value_type ValueTp;
|
|
ConstructController* cc = getConstructController();
|
|
cc->reset();
|
|
{
|
|
CHECKPOINT("Testing C::emplace(const value_type&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&>();
|
|
c.emplace(v);
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(value_type&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&>();
|
|
c.emplace(v);
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(value_type&&)");
|
|
Container c;
|
|
ValueTp v(42);
|
|
cc->expect<ValueTp&&>();
|
|
c.emplace(std::move(v));
|
|
assert(!cc->unchecked());
|
|
}
|
|
{
|
|
CHECKPOINT("Testing C::emplace(const value_type&&)");
|
|
Container c;
|
|
const ValueTp v(42);
|
|
cc->expect<const ValueTp&&>();
|
|
c.emplace(std::move(v));
|
|
assert(!cc->unchecked());
|
|
}
|
|
}
|
|
|
|
#endif
|