diff --git a/src/core/model/ascii-test.h b/src/core/model/ascii-test.h index b3674b028..3a44d38ab 100644 --- a/src/core/model/ascii-test.h +++ b/src/core/model/ascii-test.h @@ -14,6 +14,7 @@ #include "ascii-file.h" #include "test.h" +#include #include /** @@ -28,11 +29,19 @@ do \ { \ uint64_t line(0); \ - bool diff = AsciiFile::Diff(gotFilename, expectedFilename, line); \ - NS_TEST_EXPECT_MSG_EQ(diff, \ - false, \ - "ASCII traces " << gotFilename << " and " << expectedFilename \ - << " differ starting from line " << line); \ + bool fileExists = std::filesystem::exists(expectedFilename); \ + if (fileExists) \ + { \ + bool diff = AsciiFile::Diff(gotFilename, expectedFilename, line); \ + NS_TEST_EXPECT_MSG_EQ(diff, \ + false, \ + "ASCII traces " << gotFilename << " and " << expectedFilename \ + << " differ starting from line " << line); \ + } \ + else \ + { \ + NS_TEST_EXPECT_MSG_EQ(fileExists, true, "File " << expectedFilename << " not found"); \ + } \ } while (false) #endif /* ASCII_TEST_H */ diff --git a/src/core/model/example-as-test.cc b/src/core/model/example-as-test.cc index 93d644dfb..ba246c034 100644 --- a/src/core/model/example-as-test.cc +++ b/src/core/model/example-as-test.cc @@ -122,7 +122,7 @@ ExampleAsTestCase::DoRun() if (m_shouldNotErr) { // Make sure the example didn't outright crash - NS_TEST_ASSERT_MSG_EQ(status, 0, "example " + m_program + " failed"); + NS_TEST_ASSERT_MSG_EQ(status, 0, "example " + m_program + " exited abnormally"); } // If we're just introspecting the command-line