| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- //===---- ADT/IntEqClassesTest.cpp - IntEqClasses unit tests ----*- C++ -*-===//
- //
- // The LLVM Compiler Infrastructure
- //
- // This file is distributed under the University of Illinois Open Source
- // License. See LICENSE.TXT for details.
- //
- //===----------------------------------------------------------------------===//
- #include "llvm/ADT/IntEqClasses.h"
- #include "gtest/gtest.h"
- using namespace llvm;
- namespace {
- TEST(IntEqClasses, Simple) {
- IntEqClasses ec(10);
- ec.join(0, 1);
- ec.join(3, 2);
- ec.join(4, 5);
- ec.join(7, 6);
- EXPECT_EQ(0u, ec.findLeader(0));
- EXPECT_EQ(0u, ec.findLeader(1));
- EXPECT_EQ(2u, ec.findLeader(2));
- EXPECT_EQ(2u, ec.findLeader(3));
- EXPECT_EQ(4u, ec.findLeader(4));
- EXPECT_EQ(4u, ec.findLeader(5));
- EXPECT_EQ(6u, ec.findLeader(6));
- EXPECT_EQ(6u, ec.findLeader(7));
- EXPECT_EQ(8u, ec.findLeader(8));
- EXPECT_EQ(9u, ec.findLeader(9));
- // join two non-leaders.
- ec.join(1, 3);
- EXPECT_EQ(0u, ec.findLeader(0));
- EXPECT_EQ(0u, ec.findLeader(1));
- EXPECT_EQ(0u, ec.findLeader(2));
- EXPECT_EQ(0u, ec.findLeader(3));
- EXPECT_EQ(4u, ec.findLeader(4));
- EXPECT_EQ(4u, ec.findLeader(5));
- EXPECT_EQ(6u, ec.findLeader(6));
- EXPECT_EQ(6u, ec.findLeader(7));
- EXPECT_EQ(8u, ec.findLeader(8));
- EXPECT_EQ(9u, ec.findLeader(9));
- // join two leaders.
- ec.join(4, 8);
- EXPECT_EQ(0u, ec.findLeader(0));
- EXPECT_EQ(0u, ec.findLeader(1));
- EXPECT_EQ(0u, ec.findLeader(2));
- EXPECT_EQ(0u, ec.findLeader(3));
- EXPECT_EQ(4u, ec.findLeader(4));
- EXPECT_EQ(4u, ec.findLeader(5));
- EXPECT_EQ(6u, ec.findLeader(6));
- EXPECT_EQ(6u, ec.findLeader(7));
- EXPECT_EQ(4u, ec.findLeader(8));
- EXPECT_EQ(9u, ec.findLeader(9));
- // join mixed.
- ec.join(9, 1);
- EXPECT_EQ(0u, ec.findLeader(0));
- EXPECT_EQ(0u, ec.findLeader(1));
- EXPECT_EQ(0u, ec.findLeader(2));
- EXPECT_EQ(0u, ec.findLeader(3));
- EXPECT_EQ(4u, ec.findLeader(4));
- EXPECT_EQ(4u, ec.findLeader(5));
- EXPECT_EQ(6u, ec.findLeader(6));
- EXPECT_EQ(6u, ec.findLeader(7));
- EXPECT_EQ(4u, ec.findLeader(8));
- EXPECT_EQ(0u, ec.findLeader(9));
- // compressed map.
- ec.compress();
- EXPECT_EQ(3u, ec.getNumClasses());
- EXPECT_EQ(0u, ec[0]);
- EXPECT_EQ(0u, ec[1]);
- EXPECT_EQ(0u, ec[2]);
- EXPECT_EQ(0u, ec[3]);
- EXPECT_EQ(1u, ec[4]);
- EXPECT_EQ(1u, ec[5]);
- EXPECT_EQ(2u, ec[6]);
- EXPECT_EQ(2u, ec[7]);
- EXPECT_EQ(1u, ec[8]);
- EXPECT_EQ(0u, ec[9]);
- // uncompressed map.
- ec.uncompress();
- EXPECT_EQ(0u, ec.findLeader(0));
- EXPECT_EQ(0u, ec.findLeader(1));
- EXPECT_EQ(0u, ec.findLeader(2));
- EXPECT_EQ(0u, ec.findLeader(3));
- EXPECT_EQ(4u, ec.findLeader(4));
- EXPECT_EQ(4u, ec.findLeader(5));
- EXPECT_EQ(6u, ec.findLeader(6));
- EXPECT_EQ(6u, ec.findLeader(7));
- EXPECT_EQ(4u, ec.findLeader(8));
- EXPECT_EQ(0u, ec.findLeader(9));
- }
- } // end anonymous namespace
|