🧑💻 MARLIN_TEST_BUILD – for future use (#24077)
This commit is contained in:
parent
bbf2033211
commit
2ccdc4f9ed
@ -4295,6 +4295,9 @@
|
|||||||
//
|
//
|
||||||
//#define PINS_DEBUGGING
|
//#define PINS_DEBUGGING
|
||||||
|
|
||||||
|
// Enable Tests that will run at startup and produce a report
|
||||||
|
//#define MARLIN_TEST_BUILD
|
||||||
|
|
||||||
// Enable Marlin dev mode which adds some special commands
|
// Enable Marlin dev mode which adds some special commands
|
||||||
//#define MARLIN_DEV_MODE
|
//#define MARLIN_DEV_MODE
|
||||||
|
|
||||||
|
@ -39,17 +39,13 @@
|
|||||||
#endif
|
#endif
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
#include "core/utility.h"
|
#include "module/endstops.h"
|
||||||
|
|
||||||
#include "module/motion.h"
|
#include "module/motion.h"
|
||||||
#include "module/planner.h"
|
#include "module/planner.h"
|
||||||
#include "module/endstops.h"
|
|
||||||
#include "module/temperature.h"
|
|
||||||
#include "module/settings.h"
|
|
||||||
#include "module/printcounter.h" // PrintCounter or Stopwatch
|
#include "module/printcounter.h" // PrintCounter or Stopwatch
|
||||||
|
#include "module/settings.h"
|
||||||
#include "module/stepper.h"
|
#include "module/stepper.h"
|
||||||
#include "module/stepper/indirection.h"
|
#include "module/temperature.h"
|
||||||
|
|
||||||
#include "gcode/gcode.h"
|
#include "gcode/gcode.h"
|
||||||
#include "gcode/parser.h"
|
#include "gcode/parser.h"
|
||||||
@ -248,6 +244,10 @@
|
|||||||
#include "feature/easythreed_ui.h"
|
#include "feature/easythreed_ui.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if ENABLED(MARLIN_TEST_BUILD)
|
||||||
|
#include "tests/marlin_tests.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
PGMSTR(M112_KILL_STR, "M112 Shutdown");
|
PGMSTR(M112_KILL_STR, "M112 Shutdown");
|
||||||
|
|
||||||
MarlinState marlin_state = MF_INITIALIZING;
|
MarlinState marlin_state = MF_INITIALIZING;
|
||||||
@ -1635,6 +1635,8 @@ void setup() {
|
|||||||
marlin_state = MF_RUNNING;
|
marlin_state = MF_RUNNING;
|
||||||
|
|
||||||
SETUP_LOG("setup() completed.");
|
SETUP_LOG("setup() completed.");
|
||||||
|
|
||||||
|
TERN_(MARLIN_TEST_BUILD, runStartupTests());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1669,5 +1671,7 @@ void loop() {
|
|||||||
|
|
||||||
TERN_(HAS_TFT_LVGL_UI, printer_state_polling());
|
TERN_(HAS_TFT_LVGL_UI, printer_state_polling());
|
||||||
|
|
||||||
|
TERN_(MARLIN_TEST_BUILD, runPeriodicTests());
|
||||||
|
|
||||||
} while (ENABLED(__AVR__)); // Loop forever on slower (AVR) boards
|
} while (ENABLED(__AVR__)); // Loop forever on slower (AVR) boards
|
||||||
}
|
}
|
||||||
|
47
Marlin/src/tests/marlin_tests.cpp
Normal file
47
Marlin/src/tests/marlin_tests.cpp
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/**
|
||||||
|
* Marlin 3D Printer Firmware
|
||||||
|
* Copyright (c) 2022 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
||||||
|
*
|
||||||
|
* Based on Sprinter and grbl.
|
||||||
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
||||||
|
*
|
||||||
|
* 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 3 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 <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "../inc/MarlinConfigPre.h"
|
||||||
|
|
||||||
|
#if ENABLED(MARLIN_TEST_BUILD)
|
||||||
|
|
||||||
|
#include "../module/endstops.h"
|
||||||
|
#include "../module/motion.h"
|
||||||
|
#include "../module/planner.h"
|
||||||
|
#include "../module/settings.h"
|
||||||
|
#include "../module/stepper.h"
|
||||||
|
#include "../module/temperature.h"
|
||||||
|
|
||||||
|
// Individual tests are localized in each module.
|
||||||
|
// Each test produces its own report.
|
||||||
|
|
||||||
|
// Startup tests are run at the end of setup()
|
||||||
|
void runStartupTests() {
|
||||||
|
// Call post-setup tests here to validate behaviors.
|
||||||
|
}
|
||||||
|
|
||||||
|
// Periodic tests are run from within loop()
|
||||||
|
void runPeriodicTests() {
|
||||||
|
// Call periodic tests here to validate behaviors.
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // MARLIN_TEST_BUILD
|
25
Marlin/src/tests/marlin_tests.h
Normal file
25
Marlin/src/tests/marlin_tests.h
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
/**
|
||||||
|
* Marlin 3D Printer Firmware
|
||||||
|
* Copyright (c) 2022 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
||||||
|
*
|
||||||
|
* Based on Sprinter and grbl.
|
||||||
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
||||||
|
*
|
||||||
|
* 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 3 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 <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
void runStartupTests();
|
||||||
|
void runPeriodicTests();
|
@ -14,6 +14,7 @@ YHCB2004 = red-scorp/LiquidCrystal_AIP31068@^1.0.4
|
|||||||
HAS_TFT_LVGL_UI = lvgl=https://github.com/makerbase-mks/LVGL-6.1.1-MKS/archive/master.zip
|
HAS_TFT_LVGL_UI = lvgl=https://github.com/makerbase-mks/LVGL-6.1.1-MKS/archive/master.zip
|
||||||
src_filter=+<src/lcd/extui/mks_ui>
|
src_filter=+<src/lcd/extui/mks_ui>
|
||||||
extra_scripts=download_mks_assets.py
|
extra_scripts=download_mks_assets.py
|
||||||
|
MARLIN_TEST_BUILD = src_filter=+<src/tests>
|
||||||
POSTMORTEM_DEBUGGING = src_filter=+<src/HAL/shared/cpu_exception> +<src/HAL/shared/backtrace>
|
POSTMORTEM_DEBUGGING = src_filter=+<src/HAL/shared/cpu_exception> +<src/HAL/shared/backtrace>
|
||||||
build_flags=-funwind-tables
|
build_flags=-funwind-tables
|
||||||
MKS_WIFI_MODULE = QRCode=https://github.com/makerbase-mks/QRCode/archive/master.zip
|
MKS_WIFI_MODULE = QRCode=https://github.com/makerbase-mks/QRCode/archive/master.zip
|
||||||
|
@ -51,7 +51,7 @@ extra_scripts =
|
|||||||
pre:buildroot/share/PlatformIO/scripts/preflight-checks.py
|
pre:buildroot/share/PlatformIO/scripts/preflight-checks.py
|
||||||
post:buildroot/share/PlatformIO/scripts/common-dependencies-post.py
|
post:buildroot/share/PlatformIO/scripts/common-dependencies-post.py
|
||||||
lib_deps =
|
lib_deps =
|
||||||
default_src_filter = +<src/*> -<src/config> -<src/HAL> +<src/HAL/shared> -<Marlin/Marlin.ino>
|
default_src_filter = +<src/*> -<src/config> -<src/HAL> +<src/HAL/shared> -<src/tests>
|
||||||
-<src/lcd/HD44780> -<src/lcd/TFTGLCD> -<src/lcd/dogm> -<src/lcd/tft> -<src/lcd/tft_io>
|
-<src/lcd/HD44780> -<src/lcd/TFTGLCD> -<src/lcd/dogm> -<src/lcd/tft> -<src/lcd/tft_io>
|
||||||
-<src/HAL/STM32/tft> -<src/HAL/STM32F1/tft>
|
-<src/HAL/STM32/tft> -<src/HAL/STM32F1/tft>
|
||||||
-<src/lcd/e3v2/common> -<src/lcd/e3v2/creality> -<src/lcd/e3v2/proui> -<src/lcd/e3v2/jyersui> -<src/lcd/e3v2/marlinui>
|
-<src/lcd/e3v2/common> -<src/lcd/e3v2/creality> -<src/lcd/e3v2/proui> -<src/lcd/e3v2/jyersui> -<src/lcd/e3v2/marlinui>
|
||||||
|
Loading…
Reference in New Issue
Block a user