|
4 | 4 | // Created Date: 2025-01-14 // |
5 | 5 | // Author: Matthew Carroll // |
6 | 6 | // ----- // |
7 | | -// Last Modified: 2025-06-06 // |
8 | | -// Modified By: Matthew Carroll // |
| 7 | +// Last Modified: 2025-07-24 // |
| 8 | +// Modified By: Andrew Clark // |
9 | 9 | // ----- // |
10 | 10 | // Copyright (c) 2025 Syndemics Lab at Boston Medical Center // |
11 | 11 | //////////////////////////////////////////////////////////////////////////////// |
@@ -246,3 +246,54 @@ TEST_F(WriterTest, WriteTotalsData) { |
246 | 246 | writer->WriteTotalsData(totals, "", OutputType::kString); |
247 | 247 | ASSERT_EQ(expected, result); |
248 | 248 | } |
| 249 | + |
| 250 | +TEST_F(WriterTest, WriteTimedMatrix3dOutOfBoundsMatrixAccess) { |
| 251 | + TimedMatrix3d utilities; |
| 252 | + Matrix3d mat3d(1, 1, 1); |
| 253 | + mat3d.setConstant(0.9); |
| 254 | + utilities[0] = mat3d; |
| 255 | + |
| 256 | + ASSERT_THROW(writer->WriteUtilityData(utilities, "", OutputType::kString), |
| 257 | + std::runtime_error); |
| 258 | +} |
| 259 | + |
| 260 | +TEST_F(WriterTest, WriteDirectoryDoesNotExist) { |
| 261 | + std::string fake_dir = "FakeDir"; |
| 262 | + std::string expected = "failure\n\nfailure\n\nfailure\n\n" |
| 263 | + "failure\n\nfailure"; |
| 264 | + |
| 265 | + MockDataLoader data_loader; |
| 266 | + Matrix3d behavior(9, 16, 1); |
| 267 | + behavior.setConstant(0.9); |
| 268 | + |
| 269 | + Matrix3d intervention(81, 4, 1); |
| 270 | + intervention.setConstant(0.8); |
| 271 | + |
| 272 | + Matrix3d standard(9, 4, 1); |
| 273 | + standard.setConstant(0.7); |
| 274 | + |
| 275 | + // WriteOUDTransitionRates |
| 276 | + EXPECT_CALL(data_loader, GetOUDTransitionRates()) |
| 277 | + .WillRepeatedly(Return(behavior)); |
| 278 | + |
| 279 | + // WriteInterventionTransitionRates |
| 280 | + EXPECT_CALL(data_loader, GetInterventionTransitionRates(_)) |
| 281 | + .WillRepeatedly(Return(intervention)); |
| 282 | + |
| 283 | + // WriteInterventionInitRates |
| 284 | + EXPECT_CALL(data_loader, GetInterventionInitRates()) |
| 285 | + .WillRepeatedly(Return(behavior)); |
| 286 | + |
| 287 | + // WriteOverdoseRates |
| 288 | + EXPECT_CALL(data_loader, GetOverdoseRates(_)) |
| 289 | + .WillRepeatedly(Return(standard)); |
| 290 | + |
| 291 | + // WriteFatalOverdoseRates |
| 292 | + EXPECT_CALL(data_loader, GetFatalOverdoseRates(_)) |
| 293 | + .WillRepeatedly(Return(standard)); |
| 294 | + |
| 295 | + std::string result = |
| 296 | + writer->WriteInputData(data_loader, fake_dir, OutputType::kFile); |
| 297 | + |
| 298 | + ASSERT_EQ(expected, result); |
| 299 | +} |
0 commit comments