mirror of
https://github.com/rmontanana/mdlp.git
synced 2025-08-16 07:55:58 +00:00
Fix conan (#10)
* Fix debug conan build target * Add viewcoverage and fix coverage generation * Add more tests to cover new integrity checks * Add tests to accomplish 100% * Fix conan-create makefile target
This commit is contained in:
committed by
GitHub
parent
c1759ba1ce
commit
6d8b55a808
@@ -167,6 +167,15 @@ namespace mdlp {
|
||||
indices = { 1, 2, 0 };
|
||||
}
|
||||
|
||||
TEST_F(TestFImdlp, SortIndicesOutOfBounds)
|
||||
{
|
||||
// Test for out of bounds exception in sortIndices
|
||||
samples_t X_long = { 1.0f, 2.0f, 3.0f };
|
||||
labels_t y_short = { 1, 2 };
|
||||
EXPECT_THROW_WITH_MESSAGE(sortIndices(X_long, y_short), std::out_of_range, "Index out of bounds in sort comparison");
|
||||
}
|
||||
|
||||
|
||||
TEST_F(TestFImdlp, TestShortDatasets)
|
||||
{
|
||||
vector<precision_t> computed;
|
||||
@@ -364,4 +373,55 @@ namespace mdlp {
|
||||
EXPECT_EQ(computed_ft[i], expected[i]);
|
||||
}
|
||||
}
|
||||
TEST_F(TestFImdlp, SafeXAccessIndexOutOfBounds)
|
||||
{
|
||||
// Test safe_X_access with index out of bounds for indices array
|
||||
X = { 1.0f, 2.0f, 3.0f };
|
||||
y = { 1, 2, 3 };
|
||||
indices = { 0, 1 }; // shorter than expected
|
||||
|
||||
// This should trigger the first exception in safe_X_access (idx >= indices.size())
|
||||
EXPECT_THROW_WITH_MESSAGE(safe_X_access(2), std::out_of_range, "Index out of bounds for indices array");
|
||||
}
|
||||
|
||||
TEST_F(TestFImdlp, SafeXAccessXOutOfBounds)
|
||||
{
|
||||
// Test safe_X_access with real_idx out of bounds for X array
|
||||
X = { 1.0f, 2.0f }; // shorter array
|
||||
y = { 1, 2, 3 };
|
||||
indices = { 0, 1, 5 }; // indices[2] = 5 is out of bounds for X
|
||||
|
||||
// This should trigger the second exception in safe_X_access (real_idx >= X.size())
|
||||
EXPECT_THROW_WITH_MESSAGE(safe_X_access(2), std::out_of_range, "Index out of bounds for X array");
|
||||
}
|
||||
|
||||
TEST_F(TestFImdlp, SafeYAccessIndexOutOfBounds)
|
||||
{
|
||||
// Test safe_y_access with index out of bounds for indices array
|
||||
X = { 1.0f, 2.0f, 3.0f };
|
||||
y = { 1, 2, 3 };
|
||||
indices = { 0, 1 }; // shorter than expected
|
||||
|
||||
// This should trigger the first exception in safe_y_access (idx >= indices.size())
|
||||
EXPECT_THROW_WITH_MESSAGE(safe_y_access(2), std::out_of_range, "Index out of bounds for indices array");
|
||||
}
|
||||
|
||||
TEST_F(TestFImdlp, SafeYAccessYOutOfBounds)
|
||||
{
|
||||
// Test safe_y_access with real_idx out of bounds for y array
|
||||
X = { 1.0f, 2.0f, 3.0f };
|
||||
y = { 1, 2 }; // shorter array
|
||||
indices = { 0, 1, 5 }; // indices[2] = 5 is out of bounds for y
|
||||
|
||||
// This should trigger the second exception in safe_y_access (real_idx >= y.size())
|
||||
EXPECT_THROW_WITH_MESSAGE(safe_y_access(2), std::out_of_range, "Index out of bounds for y array");
|
||||
}
|
||||
|
||||
TEST_F(TestFImdlp, SafeSubtractUnderflow)
|
||||
{
|
||||
// Test safe_subtract with underflow condition (b > a)
|
||||
EXPECT_THROW_WITH_MESSAGE(safe_subtract(3, 5), std::underflow_error, "Subtraction would cause underflow");
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user