mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
6ecfad14f8
- Bug 1140558 - Part 2 - Make the testing deepEqual implementation shared properly in ObjectUtils.jsm. r=yoric (f1a217e34a) - Bug 1154773 - Change undefined property a.prototype. r=Yoric (8a4dc37d6c) - Bug 1202971 (part 1) - Fix compile warnings in libmar. r=rstrong. (30cdf015c2) - bug 1200360 - fix $(DEFINES) usage in modules/libmar/tool/moz.build. r=mshal (26f1c5640b) - Bug 903135 - Updates to libmar needed to support B2G MAR signature verification. r=bbondy (81612e2200) - Bug 1228332 - Fix a potentially uninitialized pointer read, flagged by static analysis. r=spohl (9cac770c90) - Bug 1202971 (part 2) - Fix compile warnings in toolkit/mozapps/update/tests. r=rstrong. (814f2b3b8b) - Bug 973933 - Fix libmar warnings. r=rstrong. a=Callek (e0c2d3edcc) - Bug 1232219 (part 1) - Fix -Wunused warnings in libmar/. r=bbondy. (dc046504df) - Bug 1228281 - [GTK3] add padding to buttons. r=karlt (fe8ca55f58) - Bug 1232219 (part 2.5) - Fix -Wunused warnings in parser/expat/lib/. r=hsivonen. (e4d10c5d68) - Bug 1232219 (part 3) - Fix remaining -Wunused warnings. r=glandium. (35c5f3c38e) - Bug 1232219 (follow-up) - Fix nsinstall.c bustage in SM(e) builds. r=me. (d62c12cf35) - Bug 1186815 (part 1) - Replace nsBaseHashtable::Enumerate() calls in modules/libjar/ with iterators. r=mwu. (6959b19fab) - Bug 1186815 (part 2) - Replace nsBaseHashtable::Enumerate() calls in modules/libjar/ with iterators. r=mwu. (02c6f50482) - Bug 1181444 (part 1.5) - Remove dead PLDHashOperator declarations. r=froydnj. (c956e03dc0) - Bug 1225407 - Replace nsInterfaceHashtable::EnumerateRead() call in SubstitutingProtocolHandler with an iterator. r=michal (aa71f5499c) - Bug 1187781 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in dom/xbl/ with iterators. r=mrbkap. (68f51d05ba) - Bug 1187781 (part 2) - Replace nsBaseHashtable::EnumerateRead() calls in dom/xbl/ with iterators. r=mrbkap. (1dfc261267) - Bug 1187781 (part 3) - Replace nsBaseHashtable::EnumerateRead() calls in dom/xbl/ with iterators. r=mrbkap. (922fc4e4ef) - Bug 1187781 (part 4) - Replace nsBaseHashtable::EnumerateRead() calls in dom/xbl/ with iterators. r=mrbkap. (7b1915053f) - Bug 1187781 (part 5) - Replace nsBaseHashtable::EnumerateRead() calls in dom/xbl/ with iterators. r=mrbkap. (5df4cc1d09) - Bug 1181444 (part 2) - Remove nsBaseHashtable::Enumerate(). r=froydnj. (c606342f1d) - Bug 1243912 - Remove unused Loader::RemoveEntriesWithURI declaration. r=njn (e59b2ef892) - Bug 1187137 (part 4) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (17fb17c48f) - Bug 1187137 (part 5) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (89d430cf98) - Bug 1187137 (part 6) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (37befe08c6) - Bug 1187137 (part 7) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin (a8227c4b3e) - Bug 1187137 (part 1) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=michal. (05f71a4a94) - Bug 1187137 (part 2) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=michal. (5defa991b5) - Bug 1187137 (part 3) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=michal. (f2e0a4be0f) - Bug 1187137 (part 8) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (11b77f3b67) - Bug 1187137 (part 9) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (7a6bd9a17e) - Bug 1230743 - telemtry for nsConnectionEntry hit rate r=hurley (a75d6ec52c) - Bug 1218297 - eventtokenbucket shutdown leak r=valentin (1723059684) - Bug 1239961 - Minimize amount of PR_Poll and PR_Read calls during shutdown. r=mcmanus (127259afb6) - Bug 1187137 (part 10) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (eee20459fb) - Bug 1187137 (part 11) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (864bc96862) - Bug 1187137 (part 12) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (4fd9540167) - Bug 1187137 (part 13) - Replace nsBaseHashtable::Enumerate() calls in netwerk/protocol/ with iterators. r=valentin. (65a01f4083) - Bug 1187151 (part 14) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=baku. (a71b4169a9) - Bug 1187141 - Replace nsBaseHashtable::Enumerate() calls in storage/ with iterators. r=mak. (d95fb168c9) - Bug 1187151 (part 11) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=khuey. (dda92d0455) - Bug 1187151 (part 10) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=khuey. (f59270049c) - Bug 1191460 Contextual Identity tests r=tanvi,r=ttaubert (03c079ede9) - Bug 1187151 (part 12) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=khuey. (0aa9356990) - Bug 1187151 (part 15) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=baku. (10e60a4b55) - Bug 1187151 (part 16) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=mccr8. (2ef1033aae) - Bug 1187151 (part 17) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=mccr8. (dc37dfc17b) - Bug 1241763: Don't fire dom-window-destroyed on outer windows. r=bz (ea30677af6) - Bug 1192128 - In DOM memory reporter, handle WindowID() being a uint64_t. r=mccr8. (b3f834b8f6) - Bug 1187151 (part 18) - Replace nsBaseHashtable::Enumerate() calls in dom/ with iterators. r=mccr8. (22d4fbe0f0) - Bug 1187138 (part 2) - Replace nsBaseHashtable::Enumerate() calls in toolkit/ with iterators. r=froydnj. (b4740ef44b) - Bug 1187138 (part 3) - Replace nsBaseHashtable::Enumerate() calls in toolkit/ with iterators. r=froydnj. (931eb9e813) - Bug 1187138 (part 4) - Replace nsBaseHashtable::Enumerate() calls in toolkit/ with iterators. r=froydnj. (a92fef3586) - Bug 1192189 - Fix assertion condition to use to-be-restyled element's composed document. r=dbaron (6c7733b7cc) - Bug 1187144 (part 10) - Replace nsBaseHashtable::Enumerate() calls in layout/ with iterators. r=heycam. (e93ad4330c) - Bug 1250525 - remove #IFDEF ENABLE_TESTS from dom/quota/ActorsParent.cpp. r=janv (22bc8fc0af) - Bug 1236632 - remove unused variable in FactoryOp::WaitForTransactions; r=janv (3c56b90fff) - Bug 1187116 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (f37ac71816) - Bug 1187116 (part 2) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (6bf16c51fe) - Bug 1187116 (part 3) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (351b7d5d34) - Bug 1187116 (part 4) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (330678dde4) - Bug 1187116 (part 5) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (43d20a7fa3) - Bug 1187116 (part 6) - Replace nsBaseHashtable::EnumerateRead() calls in dom/indexedDB/ with iterators. r=khuey. (d448d80726) - quick fix by revert of anticipated patch (00a093055d) - Bug 1186814 - Replace nsBaseHashtable::EnumerateRead() calls in extensions/spellcheck/ with iterators. r=ehsan. (ff78039ba0)
360 lines
11 KiB
C++
360 lines
11 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "PLDHashTable.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
// This test mostly focuses on edge cases. But more coverage of normal
|
|
// operations wouldn't be a bad thing.
|
|
|
|
#ifdef XP_UNIX
|
|
#include <unistd.h>
|
|
#include <sys/types.h>
|
|
#include <sys/wait.h>
|
|
|
|
// This global variable is defined in toolkit/xre/nsSigHandlers.cpp.
|
|
extern unsigned int _gdb_sleep_duration;
|
|
#endif
|
|
|
|
#ifdef MOZ_CRASHREPORTER
|
|
#include "nsICrashReporter.h"
|
|
#endif
|
|
|
|
// We can test that certain operations cause expected aborts by forking
|
|
// and then checking that the child aborted in the expected way (i.e. via
|
|
// MOZ_CRASH). We skip this for the following configurations.
|
|
// - On Windows, because it doesn't have fork().
|
|
// - On non-DEBUG builds, because the crashes cause the crash reporter to pop
|
|
// up when running this test locally, which is surprising and annoying.
|
|
// - On ASAN builds, because ASAN alters the way a MOZ_CRASHing process
|
|
// terminates, which makes it harder to test if the right thing has occurred.
|
|
void
|
|
TestCrashyOperation(void (*aCrashyOperation)())
|
|
{
|
|
#if defined(XP_UNIX) && defined(DEBUG) && !defined(MOZ_ASAN)
|
|
// We're about to trigger a crash. When it happens don't pause to allow GDB
|
|
// to be attached.
|
|
unsigned int old_gdb_sleep_duration = _gdb_sleep_duration;
|
|
_gdb_sleep_duration = 0;
|
|
|
|
int pid = fork();
|
|
ASSERT_NE(pid, -1);
|
|
|
|
if (pid == 0) {
|
|
// Disable the crashreporter -- writing a crash dump in the child will
|
|
// prevent the parent from writing a subsequent dump. Crashes here are
|
|
// expected, so we don't want their stacks to show up in the log anyway.
|
|
#ifdef MOZ_CRASHREPORTER
|
|
nsCOMPtr<nsICrashReporter> crashreporter =
|
|
do_GetService("@mozilla.org/toolkit/crash-reporter;1");
|
|
crashreporter->SetEnabled(false);
|
|
#endif
|
|
|
|
// Child: perform the crashy operation.
|
|
aCrashyOperation();
|
|
fprintf(stderr, "TestCrashyOperation: didn't crash?!\n");
|
|
ASSERT_TRUE(false); // shouldn't reach here
|
|
}
|
|
|
|
// Parent: check that child crashed as expected.
|
|
int status;
|
|
ASSERT_NE(waitpid(pid, &status, 0), -1);
|
|
|
|
// The path taken here depends on the platform and configuration.
|
|
ASSERT_TRUE(WIFEXITED(status) || WTERMSIG(status));
|
|
if (WIFEXITED(status)) {
|
|
// This occurs if the ah_crap_handler() is run, i.e. we caught the crash.
|
|
// It returns the number of the caught signal.
|
|
int signum = WEXITSTATUS(status);
|
|
if (signum != SIGSEGV && signum != SIGBUS) {
|
|
fprintf(stderr, "TestCrashyOperation 'exited' failure: %d\n", signum);
|
|
ASSERT_TRUE(false);
|
|
}
|
|
} else if (WIFSIGNALED(status)) {
|
|
// This one occurs if we didn't catch the crash. The exit code is the
|
|
// number of the terminating signal.
|
|
int signum = WTERMSIG(status);
|
|
if (signum != SIGSEGV && signum != SIGBUS) {
|
|
fprintf(stderr, "TestCrashyOperation 'signaled' failure: %d\n", signum);
|
|
ASSERT_TRUE(false);
|
|
}
|
|
}
|
|
|
|
_gdb_sleep_duration = old_gdb_sleep_duration;
|
|
#endif
|
|
}
|
|
|
|
void
|
|
InitCapacityOk_InitialLengthTooBig()
|
|
{
|
|
PLDHashTable t(PLDHashTable::StubOps(), sizeof(PLDHashEntryStub),
|
|
PLDHashTable::kMaxInitialLength + 1);
|
|
}
|
|
|
|
void
|
|
InitCapacityOk_InitialEntryStoreTooBig()
|
|
{
|
|
// Try the smallest disallowed power-of-two entry store size, which is 2^32
|
|
// bytes (which overflows to 0). (Note that the 2^23 *length* gets converted
|
|
// to a 2^24 *capacity*.)
|
|
PLDHashTable t(PLDHashTable::StubOps(), (uint32_t)1 << 23, (uint32_t)1 << 8);
|
|
}
|
|
|
|
TEST(PLDHashTableTest, InitCapacityOk)
|
|
{
|
|
// Try the largest allowed capacity. With kMaxCapacity==1<<26, this
|
|
// would allocate (if we added an element) 0.5GB of entry store on 32-bit
|
|
// platforms and 1GB on 64-bit platforms.
|
|
PLDHashTable t1(PLDHashTable::StubOps(), sizeof(PLDHashEntryStub),
|
|
PLDHashTable::kMaxInitialLength);
|
|
|
|
// Try the largest allowed power-of-two entry store size, which is 2^31 bytes
|
|
// (Note that the 2^23 *length* gets converted to a 2^24 *capacity*.)
|
|
PLDHashTable t2(PLDHashTable::StubOps(), (uint32_t)1 << 23, (uint32_t)1 << 7);
|
|
|
|
// Try a too-large capacity (which aborts).
|
|
TestCrashyOperation(InitCapacityOk_InitialLengthTooBig);
|
|
|
|
// Try a large capacity combined with a large entry size that when multiplied
|
|
// overflow (causing abort).
|
|
TestCrashyOperation(InitCapacityOk_InitialEntryStoreTooBig);
|
|
|
|
// Ideally we'd also try a large-but-ok capacity that almost but doesn't
|
|
// quite overflow, but that would result in allocating slightly less than 4
|
|
// GiB of entry storage. That would be very likely to fail on 32-bit
|
|
// platforms, so such a test wouldn't be reliable.
|
|
}
|
|
|
|
TEST(PLDHashTableTest, LazyStorage)
|
|
{
|
|
PLDHashTable t(PLDHashTable::StubOps(), sizeof(PLDHashEntryStub));
|
|
|
|
// PLDHashTable allocates entry storage lazily. Check that all the non-add
|
|
// operations work appropriately when the table is empty and the storage
|
|
// hasn't yet been allocated.
|
|
|
|
ASSERT_EQ(t.Capacity(), 0u);
|
|
ASSERT_EQ(t.EntrySize(), sizeof(PLDHashEntryStub));
|
|
ASSERT_EQ(t.EntryCount(), 0u);
|
|
ASSERT_EQ(t.Generation(), 0u);
|
|
|
|
ASSERT_TRUE(!t.Search((const void*)1));
|
|
|
|
// No result to check here, but call it to make sure it doesn't crash.
|
|
t.Remove((const void*)2);
|
|
|
|
for (auto iter = t.Iter(); !iter.Done(); iter.Next()) {
|
|
ASSERT_TRUE(false); // shouldn't hit this on an empty table
|
|
}
|
|
|
|
ASSERT_EQ(t.ShallowSizeOfExcludingThis(moz_malloc_size_of), 0u);
|
|
}
|
|
|
|
// A trivial hash function is good enough here. It's also super-fast for the
|
|
// GrowToMaxCapacity test because we insert the integers 0.., which means it's
|
|
// collision-free.
|
|
static PLDHashNumber
|
|
TrivialHash(PLDHashTable *table, const void *key)
|
|
{
|
|
return (PLDHashNumber)(size_t)key;
|
|
}
|
|
|
|
static void
|
|
TrivialInitEntry(PLDHashEntryHdr* aEntry, const void* aKey)
|
|
{
|
|
auto entry = static_cast<PLDHashEntryStub*>(aEntry);
|
|
entry->key = aKey;
|
|
}
|
|
|
|
static const PLDHashTableOps trivialOps = {
|
|
TrivialHash,
|
|
PLDHashTable::MatchEntryStub,
|
|
PLDHashTable::MoveEntryStub,
|
|
PLDHashTable::ClearEntryStub,
|
|
TrivialInitEntry
|
|
};
|
|
|
|
TEST(PLDHashTableTest, MoveSemantics)
|
|
{
|
|
PLDHashTable t1(&trivialOps, sizeof(PLDHashEntryStub));
|
|
t1.Add((const void*)88);
|
|
PLDHashTable t2(&trivialOps, sizeof(PLDHashEntryStub));
|
|
t2.Add((const void*)99);
|
|
|
|
t1 = mozilla::Move(t1); // self-move
|
|
|
|
t1 = mozilla::Move(t2); // empty overwritten with empty
|
|
|
|
PLDHashTable t3(&trivialOps, sizeof(PLDHashEntryStub));
|
|
PLDHashTable t4(&trivialOps, sizeof(PLDHashEntryStub));
|
|
t3.Add((const void*)88);
|
|
|
|
t3 = mozilla::Move(t4); // non-empty overwritten with empty
|
|
|
|
PLDHashTable t5(&trivialOps, sizeof(PLDHashEntryStub));
|
|
PLDHashTable t6(&trivialOps, sizeof(PLDHashEntryStub));
|
|
t6.Add((const void*)88);
|
|
|
|
t5 = mozilla::Move(t6); // empty overwritten with non-empty
|
|
|
|
PLDHashTable t7(&trivialOps, sizeof(PLDHashEntryStub));
|
|
PLDHashTable t8(mozilla::Move(t7)); // new table constructed with uninited
|
|
|
|
PLDHashTable t9(&trivialOps, sizeof(PLDHashEntryStub));
|
|
t9.Add((const void*)88);
|
|
PLDHashTable t10(mozilla::Move(t9)); // new table constructed with inited
|
|
}
|
|
|
|
TEST(PLDHashTableTest, Clear)
|
|
{
|
|
PLDHashTable t1(&trivialOps, sizeof(PLDHashEntryStub));
|
|
|
|
t1.Clear();
|
|
ASSERT_EQ(t1.EntryCount(), 0u);
|
|
|
|
t1.ClearAndPrepareForLength(100);
|
|
ASSERT_EQ(t1.EntryCount(), 0u);
|
|
|
|
t1.Add((const void*)77);
|
|
t1.Add((const void*)88);
|
|
t1.Add((const void*)99);
|
|
ASSERT_EQ(t1.EntryCount(), 3u);
|
|
|
|
t1.Clear();
|
|
ASSERT_EQ(t1.EntryCount(), 0u);
|
|
|
|
t1.Add((const void*)55);
|
|
t1.Add((const void*)66);
|
|
t1.Add((const void*)77);
|
|
t1.Add((const void*)88);
|
|
t1.Add((const void*)99);
|
|
ASSERT_EQ(t1.EntryCount(), 5u);
|
|
|
|
t1.ClearAndPrepareForLength(8192);
|
|
ASSERT_EQ(t1.EntryCount(), 0u);
|
|
}
|
|
|
|
TEST(PLDHashTableTest, Iterator)
|
|
{
|
|
PLDHashTable t(&trivialOps, sizeof(PLDHashEntryStub));
|
|
|
|
// Explicitly test the move constructor. We do this because, due to copy
|
|
// elision, compilers might optimize away move constructor calls for normal
|
|
// iterator use.
|
|
{
|
|
PLDHashTable::Iterator iter1(&t);
|
|
PLDHashTable::Iterator iter2(mozilla::Move(iter1));
|
|
}
|
|
|
|
// Iterate through the empty table.
|
|
for (PLDHashTable::Iterator iter(&t); !iter.Done(); iter.Next()) {
|
|
(void) iter.Get();
|
|
ASSERT_TRUE(false); // shouldn't hit this
|
|
}
|
|
|
|
// Add three entries.
|
|
t.Add((const void*)77);
|
|
t.Add((const void*)88);
|
|
t.Add((const void*)99);
|
|
|
|
// Check the iterator goes through each entry once.
|
|
bool saw77 = false, saw88 = false, saw99 = false;
|
|
int n = 0;
|
|
for (auto iter(t.Iter()); !iter.Done(); iter.Next()) {
|
|
auto entry = static_cast<PLDHashEntryStub*>(iter.Get());
|
|
if (entry->key == (const void*)77) {
|
|
saw77 = true;
|
|
}
|
|
if (entry->key == (const void*)88) {
|
|
saw88 = true;
|
|
}
|
|
if (entry->key == (const void*)99) {
|
|
saw99 = true;
|
|
}
|
|
n++;
|
|
}
|
|
ASSERT_TRUE(saw77 && saw88 && saw99 && n == 3);
|
|
|
|
t.Clear();
|
|
|
|
// First, we insert 64 items, which results in a capacity of 128, and a load
|
|
// factor of 50%.
|
|
for (intptr_t i = 0; i < 64; i++) {
|
|
t.Add((const void*)i);
|
|
}
|
|
ASSERT_EQ(t.EntryCount(), 64u);
|
|
ASSERT_EQ(t.Capacity(), 128u);
|
|
|
|
// The first removing iterator does no removing; capacity and entry count are
|
|
// unchanged.
|
|
for (PLDHashTable::Iterator iter(&t); !iter.Done(); iter.Next()) {
|
|
(void) iter.Get();
|
|
}
|
|
ASSERT_EQ(t.EntryCount(), 64u);
|
|
ASSERT_EQ(t.Capacity(), 128u);
|
|
|
|
// The second removing iterator removes 16 items. This reduces the load
|
|
// factor to 37.5% (48 / 128), which isn't low enough to shrink the table.
|
|
for (auto iter = t.Iter(); !iter.Done(); iter.Next()) {
|
|
auto entry = static_cast<PLDHashEntryStub*>(iter.Get());
|
|
if ((intptr_t)(entry->key) % 4 == 0) {
|
|
iter.Remove();
|
|
}
|
|
}
|
|
ASSERT_EQ(t.EntryCount(), 48u);
|
|
ASSERT_EQ(t.Capacity(), 128u);
|
|
|
|
// The third removing iterator removes another 16 items. This reduces
|
|
// the load factor to 25% (32 / 128), so the table is shrunk.
|
|
for (auto iter = t.Iter(); !iter.Done(); iter.Next()) {
|
|
auto entry = static_cast<PLDHashEntryStub*>(iter.Get());
|
|
if ((intptr_t)(entry->key) % 2 == 0) {
|
|
iter.Remove();
|
|
}
|
|
}
|
|
ASSERT_EQ(t.EntryCount(), 32u);
|
|
ASSERT_EQ(t.Capacity(), 64u);
|
|
|
|
// The fourth removing iterator removes all remaining items. This reduces
|
|
// the capacity to the minimum.
|
|
for (auto iter = t.Iter(); !iter.Done(); iter.Next()) {
|
|
iter.Remove();
|
|
}
|
|
ASSERT_EQ(t.EntryCount(), 0u);
|
|
ASSERT_EQ(t.Capacity(), unsigned(PLDHashTable::kMinCapacity));
|
|
}
|
|
|
|
// See bug 931062, we skip this test on Android due to OOM. Also, it's slow,
|
|
// and so should always be last.
|
|
#ifndef MOZ_WIDGET_ANDROID
|
|
TEST(PLDHashTableTest, GrowToMaxCapacity)
|
|
{
|
|
// This is infallible.
|
|
PLDHashTable* t =
|
|
new PLDHashTable(&trivialOps, sizeof(PLDHashEntryStub), 128);
|
|
|
|
// Keep inserting elements until failure occurs because the table is full.
|
|
size_t numInserted = 0;
|
|
while (true) {
|
|
if (!t->Add((const void*)numInserted, mozilla::fallible)) {
|
|
break;
|
|
}
|
|
numInserted++;
|
|
}
|
|
|
|
// We stop when the element count is 96.875% of PLDHashTable::kMaxCapacity
|
|
// (see MaxLoadOnGrowthFailure()).
|
|
if (numInserted !=
|
|
PLDHashTable::kMaxCapacity - (PLDHashTable::kMaxCapacity >> 5)) {
|
|
delete t;
|
|
ASSERT_TRUE(false);
|
|
}
|
|
|
|
delete t;
|
|
}
|
|
#endif
|
|
|