2022-04-26 21:30:10 +08:00
|
|
|
// unit tests for public member functions of the Error class
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
#include "error.h"
|
|
|
|
#include "info.h"
|
|
|
|
#include "lammps.h"
|
|
|
|
#include "output.h"
|
|
|
|
#include "thermo.h"
|
|
|
|
|
|
|
|
#include "../testing/core.h"
|
|
|
|
#include "gmock/gmock.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
// whether to print verbose output (i.e. not capturing LAMMPS screen output).
|
|
|
|
bool verbose = false;
|
|
|
|
|
|
|
|
namespace LAMMPS_NS {
|
2022-01-30 05:35:30 +08:00
|
|
|
using ::testing::ContainsRegex;
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
class Error_class : public LAMMPSTest {
|
|
|
|
protected:
|
|
|
|
Error *error;
|
|
|
|
Thermo *thermo;
|
|
|
|
|
|
|
|
void SetUp() override
|
|
|
|
{
|
|
|
|
testbinary = "ErrorClass";
|
|
|
|
LAMMPSTest::SetUp();
|
|
|
|
error = lmp->error;
|
|
|
|
thermo = lmp->output->thermo;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Error_class, message)
|
|
|
|
{
|
|
|
|
auto output = CAPTURE_OUTPUT([&] {
|
|
|
|
error->message(FLERR, "one message");
|
|
|
|
});
|
2022-01-30 05:35:30 +08:00
|
|
|
ASSERT_THAT(output, ContainsRegex("one message .*test_error_class.cpp:.*"));
|
2021-05-06 02:55:47 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Error_class, warning)
|
|
|
|
{
|
|
|
|
// standard warning
|
|
|
|
auto output = CAPTURE_OUTPUT([&] {
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
});
|
2022-01-30 05:35:30 +08:00
|
|
|
ASSERT_THAT(output, ContainsRegex("WARNING: one warning .*test_error_class.cpp:.*"));
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), 100);
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
// warnings disabled
|
|
|
|
HIDE_OUTPUT([&] {
|
|
|
|
command("thermo_modify warn ignore");
|
|
|
|
});
|
|
|
|
output = CAPTURE_OUTPUT([&] {
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
});
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), -1);
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
BEGIN_HIDE_OUTPUT();
|
|
|
|
command("thermo_modify warn 2");
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
END_HIDE_OUTPUT();
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), 2);
|
|
|
|
ASSERT_THAT(error->get_numwarn(), 5);
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
output = CAPTURE_OUTPUT([&] {
|
|
|
|
thermo->lost_check();
|
|
|
|
});
|
2022-01-30 05:35:30 +08:00
|
|
|
ASSERT_THAT(output, ContainsRegex("WARNING: Too many warnings: 5 vs 2. All future.*"));
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
output = CAPTURE_OUTPUT([&] {
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
});
|
|
|
|
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_EQ(output, "");
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
BEGIN_HIDE_OUTPUT();
|
|
|
|
command("thermo_modify warn reset");
|
|
|
|
thermo->lost_check();
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
END_HIDE_OUTPUT();
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), 2);
|
|
|
|
ASSERT_THAT(error->get_numwarn(), 1);
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
output = CAPTURE_OUTPUT([&] {
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
});
|
2022-01-30 05:35:30 +08:00
|
|
|
ASSERT_THAT(output, ContainsRegex("WARNING: one warning.*"));
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
BEGIN_HIDE_OUTPUT();
|
|
|
|
command("thermo_modify warn default");
|
|
|
|
thermo->lost_check();
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
END_HIDE_OUTPUT();
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), 100);
|
|
|
|
ASSERT_THAT(error->get_numwarn(), 1);
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
BEGIN_HIDE_OUTPUT();
|
|
|
|
command("thermo_modify warn always");
|
|
|
|
thermo->lost_check();
|
|
|
|
error->warning(FLERR, "one warning");
|
|
|
|
END_HIDE_OUTPUT();
|
2021-05-06 06:18:05 +08:00
|
|
|
ASSERT_THAT(error->get_maxwarn(), 0);
|
|
|
|
ASSERT_THAT(error->get_numwarn(), 2);
|
2021-05-06 02:55:47 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Error_class, one)
|
|
|
|
{
|
|
|
|
TEST_FAILURE("ERROR on proc 0: one error.*test_error_class.cpp:.*",
|
|
|
|
error->one(FLERR, "one error"););
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(Error_class, all)
|
|
|
|
{
|
|
|
|
TEST_FAILURE("ERROR: one error.*test_error_class.cpp:.*", error->all(FLERR, "one error"););
|
|
|
|
};
|
|
|
|
} // namespace LAMMPS_NS
|
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
MPI_Init(&argc, &argv);
|
|
|
|
::testing::InitGoogleMock(&argc, argv);
|
|
|
|
|
2022-08-29 05:22:26 +08:00
|
|
|
if (LAMMPS_NS::platform::mpi_vendor() == "Open MPI" && !Info::has_exceptions())
|
2022-04-26 21:30:10 +08:00
|
|
|
std::cout << "Warning: using OpenMPI without exceptions. Death tests will be skipped\n";
|
2021-05-06 02:55:47 +08:00
|
|
|
|
|
|
|
// handle arguments passed via environment variable
|
|
|
|
if (const char *var = getenv("TEST_ARGS")) {
|
2022-08-29 05:22:26 +08:00
|
|
|
std::vector<std::string> env = LAMMPS_NS::utils::split_words(var);
|
2021-05-06 02:55:47 +08:00
|
|
|
for (auto arg : env) {
|
|
|
|
if (arg == "-v") {
|
|
|
|
verbose = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((argc > 1) && (strcmp(argv[1], "-v") == 0)) verbose = true;
|
|
|
|
|
|
|
|
int rv = RUN_ALL_TESTS();
|
|
|
|
MPI_Finalize();
|
|
|
|
return rv;
|
|
|
|
}
|