diff --git a/src/Main/CMakeLists.txt b/src/Main/CMakeLists.txt index cbd8fe839..9976a9833 100644 --- a/src/Main/CMakeLists.txt +++ b/src/Main/CMakeLists.txt @@ -109,10 +109,6 @@ if(ENABLE_METAR) install(TARGETS metar RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) endif() -if (COMMAND flightgear_test) - flightgear_test(autosaveMigration test_autosaveMigration.cxx) -endif() - if (MSVC) if (TARGET Qt5::qmake) # property is the full path to qmake.exe diff --git a/src/Main/globals.cxx b/src/Main/globals.cxx index 9e49368ef..83f74b8e9 100644 --- a/src/Main/globals.cxx +++ b/src/Main/globals.cxx @@ -778,13 +778,11 @@ static void tryAutosaveMigration(const SGPath& userDataPath, SGPropertyNode* pro copyProperties(&oldProps, props); // inform the user -#if !defined(FG_TESTLIB) flightgear::modalMessageBox("Settings migrated", "Saved settings were migrated from a previous version of FlightGear. " "If you encounter any problems when using the system, try restoring " "the default settings, before reporting a problem. " "Saved settings can affect the appearance, performance and features of the simulator."); -#endif } // Load user settings from the autosave file (normally in $FG_HOME) diff --git a/test_suite/CMakeLists.txt b/test_suite/CMakeLists.txt index cd8cd8a4a..f734955f8 100644 --- a/test_suite/CMakeLists.txt +++ b/test_suite/CMakeLists.txt @@ -66,6 +66,7 @@ add_test(AeroMeshSystemTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -s A # Unit test suites. add_test(AddonManagementUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u AddonManagementTests) add_test(AeroElementUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u AeroElementTests) +add_test(AutosaveMigrationUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u AutosaveMigrationTests) add_test(FlightplanUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u FlightplanTests) add_test(LaRCSimMatrixUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u LaRCSimMatrixTests) add_test(MktimeUnitTests ${TESTSUITE_OUTPUT_DIR}/run_test_suite --ctest -u MktimeTests) diff --git a/test_suite/unit_tests/Main/CMakeLists.txt b/test_suite/unit_tests/Main/CMakeLists.txt index 43350aca8..e6e5740c6 100644 --- a/test_suite/unit_tests/Main/CMakeLists.txt +++ b/test_suite/unit_tests/Main/CMakeLists.txt @@ -1,12 +1,14 @@ set(TESTSUITE_SOURCES ${TESTSUITE_SOURCES} ${CMAKE_CURRENT_SOURCE_DIR}/TestSuite.cxx + ${CMAKE_CURRENT_SOURCE_DIR}/test_autosaveMigration.cxx ${CMAKE_CURRENT_SOURCE_DIR}/test_posinit.cxx PARENT_SCOPE ) set(TESTSUITE_HEADERS ${TESTSUITE_HEADERS} + ${CMAKE_CURRENT_SOURCE_DIR}/test_autosaveMigration.hxx ${CMAKE_CURRENT_SOURCE_DIR}/test_posinit.hxx PARENT_SCOPE ) diff --git a/test_suite/unit_tests/Main/TestSuite.cxx b/test_suite/unit_tests/Main/TestSuite.cxx index fb2be144b..f5a3f684f 100644 --- a/test_suite/unit_tests/Main/TestSuite.cxx +++ b/test_suite/unit_tests/Main/TestSuite.cxx @@ -17,8 +17,10 @@ * along with this program. If not, see . */ +#include "test_autosaveMigration.hxx" #include "test_posinit.hxx" // Set up the unit tests. +CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(AutosaveMigrationTests, "Unit tests"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(PosInitTests, "Unit tests"); diff --git a/src/Main/test_autosaveMigration.cxx b/test_suite/unit_tests/Main/test_autosaveMigration.cxx similarity index 80% rename from src/Main/test_autosaveMigration.cxx rename to test_suite/unit_tests/Main/test_autosaveMigration.cxx index b367b16ab..c420c7d3a 100644 --- a/src/Main/test_autosaveMigration.cxx +++ b/test_suite/unit_tests/Main/test_autosaveMigration.cxx @@ -18,9 +18,10 @@ #include "config.h" -#include "test_suite/helpers/globals.hxx" +#include "test_autosaveMigration.hxx" + +#include "test_suite/FGTestApi/globals.hxx" -#include #include #include #include @@ -98,12 +99,24 @@ void writeLegacyAutosave2(SGPath userData, int majorVersion, int minorVersion) of.close(); } -void testMigration() +// Set up function for each test. +void AutosaveMigrationTests::setUp() { - fgtest::initTestGlobals("autosaveMigration"); + FGTestApi::setUp::initTestGlobals("autosaveMigration"); Options::reset(); +} + +// Clean up after each test. +void AutosaveMigrationTests::tearDown() +{ + FGTestApi::tearDown::shutdownTestGlobals(); +} + + +void AutosaveMigrationTests::testMigration() +{ SGPath testUserDataPath = globals->get_fg_home() / "test_autosave_migrate"; if (!testUserDataPath.exists()) { SGPath p = testUserDataPath / "foo"; @@ -118,7 +131,7 @@ void testMigration() writeLegacyAutosave(testUserDataPath, 2016, 1); const string_list versionParts = simgear::strutils::split(VERSION, "."); - SG_VERIFY(versionParts.size() == 3); + CPPUNIT_ASSERT(versionParts.size() == 3); const int currentMajor = simgear::strutils::to_int(versionParts[0]); const int currentMinor = simgear::strutils::to_int(versionParts[1]); @@ -129,7 +142,7 @@ void testMigration() SGPath p = globals->autosaveFilePath(testUserDataPath); if (p.exists()) { - SG_VERIFY(p.remove()); + CPPUNIT_ASSERT(p.remove()); } // write some blck-list rules to property tree @@ -142,24 +155,15 @@ void testMigration() // execute method under test globals->loadUserSettings(testUserDataPath); - SG_CHECK_EQUAL(globals->get_props()->getNode("sim")->getChildren("presets").size(), 2); - SG_CHECK_EQUAL(globals->get_props()->getNode("sim")->getChildren("gui").size(), 0); + CPPUNIT_ASSERT_EQUAL((int)globals->get_props()->getNode("sim")->getChildren("presets").size(), 2); + CPPUNIT_ASSERT_EQUAL((int)globals->get_props()->getNode("sim")->getChildren("gui").size(), 0); - SG_CHECK_EQUAL(globals->get_props()->getIntValue("sim/window-height"), 42); - SG_CHECK_EQUAL(globals->get_props()->getIntValue("sim/presets/foo"), 0); - SG_CHECK_EQUAL(globals->get_props()->getIntValue("sim/presets[1]/foo"), 13); + CPPUNIT_ASSERT_EQUAL(globals->get_props()->getIntValue("sim/window-height"), 42); + CPPUNIT_ASSERT_EQUAL(globals->get_props()->getIntValue("sim/presets/foo"), 0); + CPPUNIT_ASSERT_EQUAL(globals->get_props()->getIntValue("sim/presets[1]/foo"), 13); - SG_CHECK_EQUAL(globals->get_props()->getIntValue("some-setting"), 888); + CPPUNIT_ASSERT_EQUAL(globals->get_props()->getIntValue("some-setting"), 888); // if this is not zero, one of the bad autosaves was read - SG_CHECK_EQUAL(globals->get_props()->getIntValue("sim/bad"), 0); - - - fgtest::shutdownTestGlobals(); -} - -int main(int argc, char* argv[]) -{ - testMigration(); - return EXIT_SUCCESS; + CPPUNIT_ASSERT_EQUAL(globals->get_props()->getIntValue("sim/bad"), 0); } diff --git a/test_suite/unit_tests/Main/test_autosaveMigration.hxx b/test_suite/unit_tests/Main/test_autosaveMigration.hxx new file mode 100644 index 000000000..4e9871033 --- /dev/null +++ b/test_suite/unit_tests/Main/test_autosaveMigration.hxx @@ -0,0 +1,48 @@ +/* + * Copyright (C) 2018 Edward d'Auvergne + * + * This file is part of the program FlightGear. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + + +#ifndef _FG_AUTOSAVE_MIGRATION_UNIT_TESTS_HXX +#define _FG_AUTOSAVE_MIGRATION_UNIT_TESTS_HXX + + +#include +#include + + +// The unit tests. +class AutosaveMigrationTests : public CppUnit::TestFixture +{ + // Set up the test suite. + CPPUNIT_TEST_SUITE(AutosaveMigrationTests); + CPPUNIT_TEST(testMigration); + CPPUNIT_TEST_SUITE_END(); + +public: + // Set up function for each test. + void setUp(); + + // Clean up after each test. + void tearDown(); + + // The tests. + void testMigration(); +}; + +#endif // _FG_AUTOSAVE_MIGRATION_UNIT_TESTS_HXX