Adds unit testing framework to ABC

Signed-off-by: Ethan Mahintorabi <ethanmoon@google.com>
This commit is contained in:
Ethan Mahintorabi 2023-09-13 18:24:01 +00:00 committed by Miodrag Milanovic
parent fa186342ba
commit 1d7c05988f
4 changed files with 73 additions and 0 deletions

View File

@ -44,6 +44,10 @@ jobs:
run: |
cmake --build build
- name: Run Unit Tests
run: |
ctest --output-on-failure
- name: Test Executable
run: |
./build/abc -c "r i10.aig; b; ps; b; rw -l; rw -lz; b; rw -lz; b; ps; cec"

View File

@ -114,3 +114,17 @@ add_library(libabc-pic EXCLUDE_FROM_ALL ${ABC_SRC})
abc_properties(libabc-pic PUBLIC)
set_property(TARGET libabc-pic PROPERTY POSITION_INDEPENDENT_CODE ON)
set_property(TARGET libabc-pic PROPERTY OUTPUT_NAME abc-pic)
if(NOT DEFINED ABC_SKIP_TESTS)
enable_testing()
include(FetchContent)
FetchContent_Declare(
googletest
DOWNLOAD_EXTRACT_TIMESTAMP TRUE
# Specify the commit you depend on and update it regularly.
URL "https://github.com/google/googletest/archive/refs/tags/v1.14.0.zip"
)
FetchContent_MakeAvailable(googletest)
include(GoogleTest)
add_subdirectory(test)
endif()

1
test/CMakeLists.txt Normal file
View File

@ -0,0 +1 @@
add_subdirectory(gia)

54
test/gia/gia_test.cc Normal file
View File

@ -0,0 +1,54 @@
#include "gtest/gtest.h"
#include "aig/gia/gia.h"
ABC_NAMESPACE_IMPL_START
TEST(GiaTest, CanAllocateGiaManager) {
Gia_Man_t* aig_manager = Gia_ManStart(100);
EXPECT_TRUE(aig_manager != nullptr);
Gia_ManStop(aig_manager);
}
TEST(GiaTest, CanAddACi) {
Gia_Man_t* aig_manager = Gia_ManStart(100);
Gia_ManAppendCi(aig_manager);
EXPECT_EQ(Gia_ManCiNum(aig_manager), 1);
Gia_ManStop(aig_manager);
}
TEST(GiaTest, CanAddACo) {
Gia_Man_t* aig_manager = Gia_ManStart(100);
int input1 = Gia_ManAppendCi(aig_manager);
Gia_ManAppendCo(aig_manager, input1);
EXPECT_EQ(Gia_ManCiNum(aig_manager), 1);
EXPECT_EQ(Gia_ManCoNum(aig_manager), 1);
Gia_ManStop(aig_manager);
}
TEST(GiaTest, CanAddAnAndGate) {
Gia_Man_t* aig_manager = Gia_ManStart(100);
int input1 = Gia_ManAppendCi(aig_manager);
int input2 = Gia_ManAppendCi(aig_manager);
int and_output = Gia_ManAppendAnd(aig_manager, input1, input2);
Gia_ManAppendCo(aig_manager, and_output);
Vec_Wrd_t* stimulus = Vec_WrdAlloc(2);
Vec_WrdPush(stimulus, /*A*/1);
Vec_WrdPush(stimulus, /*B*/1);
Vec_Wrd_t* output = Gia_ManSimPatSimOut(aig_manager, stimulus, /*fouts*/1);
EXPECT_EQ(Gia_ManCiNum(aig_manager), 2);
EXPECT_EQ(Gia_ManCoNum(aig_manager), 1);
// A = 1, B = 1 -> A & B == 1
EXPECT_EQ(Vec_WrdGetEntry(output, 0), 1);
Vec_WrdFree(output);
Gia_ManStop(aig_manager);
}
ABC_NAMESPACE_IMPL_END