jdk-24/test/hotspot/gtest/gc/x/test_xArray.cpp
Stefan Karlsson d20034b09c 8307058: Implementation of Generational ZGC
Co-authored-by: Stefan Karlsson <stefank@openjdk.org>
Co-authored-by: Erik Österlund <eosterlund@openjdk.org>
Co-authored-by: Axel Boldt-Christmas <aboldtch@openjdk.org>
Co-authored-by: Per Liden <pliden@openjdk.org>
Co-authored-by: Stefan Johansson <sjohanss@openjdk.org>
Co-authored-by: Albert Mingkun Yang <ayang@openjdk.org>
Co-authored-by: Erik Helin <ehelin@openjdk.org>
Co-authored-by: Roberto Castañeda Lozano <rcastanedalo@openjdk.org>
Co-authored-by: Nils Eliasson <neliasso@openjdk.org>
Co-authored-by: Martin Doerr <mdoerr@openjdk.org>
Co-authored-by: Leslie Zhai <lzhai@openjdk.org>
Co-authored-by: Fei Yang <fyang@openjdk.org>
Co-authored-by: Yadong Wang <yadongwang@openjdk.org>
Reviewed-by: eosterlund, aboldtch, rcastanedalo
2023-05-11 13:59:37 +00:00

84 lines
2.1 KiB
C++

/*
* Copyright (c) 2017, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
#include "precompiled.hpp"
#include "gc/x/xArray.inline.hpp"
#include "unittest.hpp"
TEST(XArray, sanity) {
XArray<int> a;
// Add elements
for (int i = 0; i < 10; i++) {
a.append(i);
}
XArray<int> b;
b.swap(&a);
// Check size
ASSERT_EQ(a.length(), 0);
ASSERT_EQ(a.capacity(), 0);
ASSERT_EQ(a.is_empty(), true);
ASSERT_EQ(b.length(), 10);
ASSERT_GE(b.capacity(), 10);
ASSERT_EQ(b.is_empty(), false);
// Clear elements
a.clear();
// Check that b is unaffected
ASSERT_EQ(b.length(), 10);
ASSERT_GE(b.capacity(), 10);
ASSERT_EQ(b.is_empty(), false);
a.append(1);
// Check that b is unaffected
ASSERT_EQ(b.length(), 10);
ASSERT_GE(b.capacity(), 10);
ASSERT_EQ(b.is_empty(), false);
}
TEST(XArray, iterator) {
XArray<int> a;
// Add elements
for (int i = 0; i < 10; i++) {
a.append(i);
}
// Iterate
int count = 0;
XArrayIterator<int> iter(&a);
for (int value; iter.next(&value);) {
ASSERT_EQ(a.at(count), count);
count++;
}
// Check count
ASSERT_EQ(count, 10);
}