123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793 |
- /**
- * @file
- * @author Marek Kuhn
- */
- // For now the functions are just COPIED (lots of depencendies in ultralcd.h)
- #include "catch.hpp"
- #include <iostream>
- std::string itostr3(int i){
- return std::to_string(i);
- }
- std::string eeprom_read_word(uint16_t* /*i*/){
- return "eeprom_read";
- }
- int _millis(){return 10000;}
- static int farm_no;
- static int busy_state;
- static int PAUSED_FOR_USER;
- static int status_number;
- static int total_filament_used;
- static int feedmultiply;
- static int longFilenameOLD;
- static int starttime;
- static int isPrintPaused;
- static int IS_SD_PRINTING;
- static int farm_status;
- static int farm_timer;
- static int loading_flag;
- static int target_temperature[1];
- static int current_temperature[1];
- static int target_temperature_bed;
- static int current_temperature_bed;
- static uint16_t nozzle_diameter;
- static uint16_t* EEPROM_NOZZLE_DIAMETER_uM;
- static std::string FW_VERSION;
- struct Card {
- int paused = 0;
- int percentDone(){ return 50; }
- };
- static Card card;
- void setup_mockups(){
- farm_no = 0;
- busy_state = 0;
- status_number = 0;
- PAUSED_FOR_USER = 0;
- total_filament_used = 0;
- feedmultiply = 0;
- longFilenameOLD = 0;
- starttime = 0;
- FW_VERSION = "3.8.0";
- isPrintPaused = 0;
- IS_SD_PRINTING = 0;
- farm_status = 0;
- farm_timer = 1;
- loading_flag = 0;
- target_temperature[0] = {215};
- current_temperature[0] = {204};
- target_temperature_bed = 60;
- current_temperature_bed = 55;
- nozzle_diameter = 400;
- EEPROM_NOZZLE_DIAMETER_uM = &nozzle_diameter;
- }
- // Copy of pre 3.8 version set of functions
- namespace old_code
- {
- // Mocking Serial line
- static std::string SERIAL_BUFFER = "";
- void SERIAL_ECHO(std::string s){
- SERIAL_BUFFER += s;
- }
- void SERIAL_ECHO(int i){
- SERIAL_BUFFER += std::to_string(i);
- }
- void SERIAL_ECHO(char c){
- SERIAL_BUFFER += char(c);
- }
- void SERIAL_ECHOLN(std::string s){
- SERIAL_BUFFER += s + "\n";
- }
- void SERIAL_ECHOLN(char c){
- SERIAL_BUFFER += char(c);
- }
- void SERIAL_RESET(){
- SERIAL_BUFFER.clear();
- }
- struct MySerial {
- void print(int i){
- SERIAL_ECHO(i);
- }
- void println(){
- SERIAL_ECHO("\n");
- }
- };
- static MySerial MYSERIAL;
- static void prusa_stat_printerstatus(int _status)
- {
- SERIAL_ECHO("[PRN:");
- SERIAL_ECHO(_status);
- SERIAL_ECHO("]");
- }
- static void prusa_stat_farm_number() {
- SERIAL_ECHO("[PFN:");
- SERIAL_ECHO(farm_no);
- SERIAL_ECHO("]");
- }
- static void prusa_stat_diameter() {
- SERIAL_ECHO("[DIA:");
- SERIAL_ECHO(eeprom_read_word((uint16_t*)EEPROM_NOZZLE_DIAMETER_uM));
- SERIAL_ECHO("]");
- }
- static void prusa_stat_temperatures()
- {
- SERIAL_ECHO("[ST0:");
- SERIAL_ECHO(target_temperature[0]);
- SERIAL_ECHO("][STB:");
- SERIAL_ECHO(target_temperature_bed);
- SERIAL_ECHO("][AT0:");
- SERIAL_ECHO(current_temperature[0]);
- SERIAL_ECHO("][ATB:");
- SERIAL_ECHO(current_temperature_bed);
- SERIAL_ECHO("]");
- }
- static void prusa_stat_printinfo()
- {
- SERIAL_ECHO("[TFU:");
- SERIAL_ECHO(total_filament_used);
- SERIAL_ECHO("][PCD:");
- SERIAL_ECHO(itostr3(card.percentDone()));
- SERIAL_ECHO("][FEM:");
- SERIAL_ECHO(itostr3(feedmultiply));
- SERIAL_ECHO("][FNM:");
- SERIAL_ECHO(longFilenameOLD);
- SERIAL_ECHO("][TIM:");
- if (starttime != 0)
- {
- SERIAL_ECHO(_millis() / 1000 - starttime / 1000);
- }
- else
- {
- SERIAL_ECHO(0);
- }
- SERIAL_ECHO("][FWR:");
- SERIAL_ECHO(FW_VERSION);
- SERIAL_ECHO("]");
- prusa_stat_diameter();
- }
- void prusa_statistics(int _message, uint8_t _fil_nr) {
- #ifdef DEBUG_DISABLE_PRUSA_STATISTICS
- return;
- #endif //DEBUG_DISABLE_PRUSA_STATISTICS
- switch (_message)
- {
- case 0: // default message
- if (busy_state == PAUSED_FOR_USER)
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(15);
- prusa_stat_farm_number();
- prusa_stat_printinfo();
- SERIAL_ECHOLN("}");
- status_number = 15;
- }
- else if (isPrintPaused || card.paused)
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(14);
- prusa_stat_farm_number();
- prusa_stat_printinfo();
- SERIAL_ECHOLN("}");
- status_number = 14;
- }
- else if (IS_SD_PRINTING || loading_flag)
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(4);
- prusa_stat_farm_number();
- prusa_stat_printinfo();
- SERIAL_ECHOLN("}");
- status_number = 4;
- }
- else
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(1);
- prusa_stat_farm_number();
- prusa_stat_diameter();
- SERIAL_ECHOLN("}");
- status_number = 1;
- }
- break;
- case 1: // 1 heating
- farm_status = 2;
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(2);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 2;
- farm_timer = 1;
- break;
- case 2: // heating done
- farm_status = 3;
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(3);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 3;
- farm_timer = 1;
- if (IS_SD_PRINTING || loading_flag)
- {
- farm_status = 4;
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(4);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 4;
- }
- else
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(3);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 3;
- }
- farm_timer = 1;
- break;
- case 3: // filament change
- break;
- case 4: // print succesfull
- SERIAL_ECHO("{[RES:1][FIL:");
- MYSERIAL.print(int(_fil_nr));
- SERIAL_ECHO("]");
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- farm_timer = 2;
- break;
- case 5: // print not succesfull
- SERIAL_ECHO("{[RES:0][FIL:");
- MYSERIAL.print(int(_fil_nr));
- SERIAL_ECHO("]");
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- farm_timer = 2;
- break;
- case 6: // print done
- SERIAL_ECHO("{[PRN:8]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 8;
- farm_timer = 2;
- break;
- case 7: // print done - stopped
- SERIAL_ECHO("{[PRN:9]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 9;
- farm_timer = 2;
- break;
- case 8: // printer started
- SERIAL_ECHO("{[PRN:0][PFN:");
- status_number = 0;
- SERIAL_ECHO(farm_no);
- SERIAL_ECHOLN("]}");
- farm_timer = 2;
- break;
- case 20: // echo farm no
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- farm_timer = 4;
- break;
- case 21: // temperatures
- SERIAL_ECHO("{");
- prusa_stat_temperatures();
- prusa_stat_farm_number();
- prusa_stat_printerstatus(status_number);
- SERIAL_ECHOLN("}");
- break;
- case 22: // waiting for filament change
- SERIAL_ECHO("{[PRN:5]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- status_number = 5;
- break;
-
- case 90: // Error - Thermal Runaway
- SERIAL_ECHO("{[ERR:1]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- break;
- case 91: // Error - Thermal Runaway Preheat
- SERIAL_ECHO("{[ERR:2]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- break;
- case 92: // Error - Min temp
- SERIAL_ECHO("{[ERR:3]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- break;
- case 93: // Error - Max temp
- SERIAL_ECHO("{[ERR:4]");
- prusa_stat_farm_number();
- SERIAL_ECHOLN("}");
- break;
- case 99: // heartbeat
- SERIAL_ECHO("{[PRN:99]");
- prusa_stat_temperatures();
- SERIAL_ECHO("[PFN:");
- SERIAL_ECHO(farm_no);
- SERIAL_ECHO("]");
- SERIAL_ECHOLN("}");
-
- break;
- }
- }
- }
- // Copy of 3.8 version of functions
- namespace new_code
- {
- // Mocking Serial line
- static std::string SERIAL_BUFFER = "";
- void SERIAL_ECHO(std::string s){
- SERIAL_BUFFER += s;
- }
- void SERIAL_ECHO(int i){
- SERIAL_BUFFER += std::to_string(i);
- }
- void SERIAL_ECHO(char c){
- SERIAL_BUFFER += char(c);
- }
- void SERIAL_ECHOLN(std::string s){
- SERIAL_BUFFER += s + "\n";
- }
- void SERIAL_ECHOLN(char c){
- SERIAL_BUFFER += char(c);
- SERIAL_BUFFER += "\n";
- }
- void SERIAL_RESET(){
- SERIAL_BUFFER.clear();
- }
- struct MySerial {
- void print(int i){
- SERIAL_ECHO(i);
- }
- void println(){
- SERIAL_ECHO("\n");
- }
- };
- static MySerial MYSERIAL;
- static void prusa_stat_printerstatus(int _status)
- {
- SERIAL_ECHO("[PRN:");
- SERIAL_ECHO(_status);
- SERIAL_ECHO(']');
- }
- static void prusa_stat_farm_number() {
- SERIAL_ECHO("[PFN:");
- SERIAL_ECHO(farm_no);
- SERIAL_ECHO(']');
- }
- static void prusa_stat_diameter() {
- SERIAL_ECHO("[DIA:");
- SERIAL_ECHO(eeprom_read_word((uint16_t*)EEPROM_NOZZLE_DIAMETER_uM));
- SERIAL_ECHO(']');
- }
- static void prusa_stat_temperatures()
- {
- SERIAL_ECHO("[ST0:");
- SERIAL_ECHO(target_temperature[0]);
- SERIAL_ECHO("][STB:");
- SERIAL_ECHO(target_temperature_bed);
- SERIAL_ECHO("][AT0:");
- SERIAL_ECHO(current_temperature[0]);
- SERIAL_ECHO("][ATB:");
- SERIAL_ECHO(current_temperature_bed);
- SERIAL_ECHO(']');
- }
- static void prusa_stat_printinfo()
- {
- SERIAL_ECHO("[TFU:");
- SERIAL_ECHO(total_filament_used);
- SERIAL_ECHO("][PCD:");
- SERIAL_ECHO(itostr3(card.percentDone()));
- SERIAL_ECHO("][FEM:");
- SERIAL_ECHO(itostr3(feedmultiply));
- SERIAL_ECHO("][FNM:");
- SERIAL_ECHO(longFilenameOLD);
- SERIAL_ECHO("][TIM:");
- if (starttime != 0)
- {
- SERIAL_ECHO(_millis() / 1000 - starttime / 1000);
- }
- else
- {
- SERIAL_ECHO(0);
- }
- SERIAL_ECHO("][FWR:");
- SERIAL_ECHO(FW_VERSION);
- SERIAL_ECHO(']');
- prusa_stat_diameter();
- }
- void prusa_statistics_err(char c){
- SERIAL_ECHO("{[ERR:");
- SERIAL_ECHO(c);
- SERIAL_ECHO(']');
- prusa_stat_farm_number();
- }
- void prusa_statistics_case0(uint8_t statnr){
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(statnr);
- prusa_stat_farm_number();
- prusa_stat_printinfo();
- }
- void prusa_statistics(int _message, uint8_t _fil_nr) {
- #ifdef DEBUG_DISABLE_PRUSA_STATISTICS
- return;
- #endif //DEBUG_DISABLE_PRUSA_STATISTICS
- switch (_message)
- {
- case 0: // default message
- if (busy_state == PAUSED_FOR_USER)
- {
- prusa_statistics_case0(15);
- }
- else if (isPrintPaused || card.paused)
- {
- prusa_statistics_case0(14);
- }
- else if (IS_SD_PRINTING || loading_flag)
- {
- prusa_statistics_case0(4);
- }
- else
- {
- SERIAL_ECHO("{");
- prusa_stat_printerstatus(1);
- prusa_stat_farm_number();
- prusa_stat_diameter();
- status_number = 1;
- }
- break;
- case 1: // 1 heating
- farm_status = 2;
- SERIAL_ECHO('{');
- prusa_stat_printerstatus(2);
- prusa_stat_farm_number();
- status_number = 2;
- farm_timer = 1;
- break;
- case 2: // heating done
- farm_status = 3;
- SERIAL_ECHO('{');
- prusa_stat_printerstatus(3);
- prusa_stat_farm_number();
- SERIAL_ECHOLN('}');
- status_number = 3;
- farm_timer = 1;
- if (IS_SD_PRINTING || loading_flag)
- {
- farm_status = 4;
- SERIAL_ECHO('{');
- prusa_stat_printerstatus(4);
- prusa_stat_farm_number();
- status_number = 4;
- }
- else
- {
- SERIAL_ECHO('{');
- prusa_stat_printerstatus(3);
- prusa_stat_farm_number();
- status_number = 3;
- }
- farm_timer = 1;
- break;
- case 3: // filament change
- // must do a return here to prevent doing SERIAL_ECHOLN("}") at the very end of this function
- // saved a considerable amount of FLASH
- return;
- case 4: // print succesfull
- SERIAL_ECHO("{[RES:1][FIL:");
- MYSERIAL.print(int(_fil_nr));
- SERIAL_ECHO(']');
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- farm_timer = 2;
- break;
- case 5: // print not succesfull
- SERIAL_ECHO("{[RES:0][FIL:");
- MYSERIAL.print(int(_fil_nr));
- SERIAL_ECHO(']');
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- farm_timer = 2;
- break;
- case 6: // print done
- SERIAL_ECHO("{[PRN:8]");
- prusa_stat_farm_number();
- status_number = 8;
- farm_timer = 2;
- break;
- case 7: // print done - stopped
- SERIAL_ECHO("{[PRN:9]");
- prusa_stat_farm_number();
- status_number = 9;
- farm_timer = 2;
- break;
- case 8: // printer started
- SERIAL_ECHO("{[PRN:0][PFN:");
- status_number = 0;
- SERIAL_ECHO(farm_no);
- SERIAL_ECHO(']');
- farm_timer = 2;
- break;
- case 20: // echo farm no
- SERIAL_ECHO('{');
- prusa_stat_printerstatus(status_number);
- prusa_stat_farm_number();
- farm_timer = 4;
- break;
- case 21: // temperatures
- SERIAL_ECHO('{');
- prusa_stat_temperatures();
- prusa_stat_farm_number();
- prusa_stat_printerstatus(status_number);
- break;
- case 22: // waiting for filament change
- SERIAL_ECHO("{[PRN:5]");
- prusa_stat_farm_number();
- status_number = 5;
- break;
-
- case 90: // Error - Thermal Runaway
- prusa_statistics_err('1');
- break;
- case 91: // Error - Thermal Runaway Preheat
- prusa_statistics_err('2');
- break;
- case 92: // Error - Min temp
- prusa_statistics_err('3');
- break;
- case 93: // Error - Max temp
- prusa_statistics_err('4');
- break;
- case 99: // heartbeat
- SERIAL_ECHO("{[PRN:99]");
- prusa_stat_temperatures();
- SERIAL_ECHO("[PFN:");
- SERIAL_ECHO(farm_no);
- SERIAL_ECHO(']');
-
- break;
- }
- SERIAL_ECHOLN('}');
- }
- } // end namespace new
- void SERIALS_RESET(){
- old_code::SERIAL_RESET();
- new_code::SERIAL_RESET();
- }
- std::string SERIALS_SERIALIZE(){
- return old_code::SERIAL_BUFFER + "\n" + new_code::SERIAL_BUFFER;
- }
- void SERIALS_PRINT(){
- std::cout << "[Printing buffers...] \n";
- std::cout << old_code::SERIAL_BUFFER << "\n";
- std::cout << new_code::SERIAL_BUFFER << "\n";
- }
- int SERIALS_COMPARE(){
- // Trim the newline at the end
- if(old_code::SERIAL_BUFFER.back() == '\n'){
- old_code::SERIAL_BUFFER.pop_back();
- }
- if(new_code::SERIAL_BUFFER.back() == '\n'){
- new_code::SERIAL_BUFFER.pop_back();
- }
- std::cout << "Comparing: \n";
- std::cout << old_code::SERIAL_BUFFER << "\n";
- std::cout << new_code::SERIAL_BUFFER << "\n";
- return old_code::SERIAL_BUFFER.compare(new_code::SERIAL_BUFFER);
- }
- // --------------- TEST CASES ---------------- //
- TEST_CASE("Serials compare ignore newline at the end", "[helper]")
- {
- SERIALS_RESET();
- old_code::SERIAL_BUFFER = "Hello compare me.";
- new_code::SERIAL_BUFFER = "Hello compare me.";
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- old_code::SERIAL_BUFFER = "Hello compare me.\n";
- new_code::SERIAL_BUFFER = "Hello compare me.";
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- old_code::SERIAL_BUFFER = "Hello compare me.";
- new_code::SERIAL_BUFFER = "Hello compare me.\n";
- CHECK(SERIALS_COMPARE() == 0);
- }
- TEST_CASE("Printer status is shown", "[prusa_stats]")
- {
- SERIALS_RESET();
- setup_mockups();
- old_code::prusa_stat_printerstatus(1);
- new_code::prusa_stat_printerstatus(1);
- INFO(SERIALS_SERIALIZE());
- CHECK(SERIALS_COMPARE() == 0);
- }
- TEST_CASE("Printer info is shown", "[prusa_stats]")
- {
- SERIALS_RESET();
- setup_mockups();
- old_code::prusa_stat_printinfo();
- new_code::prusa_stat_printinfo();
- INFO(SERIALS_SERIALIZE());
- CHECK(SERIALS_COMPARE() == 0);
- }
- TEST_CASE("Printer temperatures are shown", "[prusa_stats]")
- {
- SERIALS_RESET();
- setup_mockups();
- old_code::prusa_stat_temperatures();
- new_code::prusa_stat_temperatures();
-
- INFO(SERIALS_SERIALIZE());
- CHECK(SERIALS_COMPARE() == 0);
- }
- TEST_CASE("Prusa_statistics test", "[prusa_stats]")
- {
- SERIALS_RESET();
- setup_mockups();
- int test_codes[] = {0,1,2,3,4,5,6,7,8,20,21,22,90,91,92,93,99};
- int size = sizeof(test_codes)/sizeof(test_codes[0]);
- for(int i = 0; i < size; i++){
- std::cout << "Testing prusa_statistics(" << std::to_string(i) << ")\n";
-
- switch(i)
- {
- case 0: {
- busy_state = 0;
- PAUSED_FOR_USER = 0;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- busy_state = 1;
- PAUSED_FOR_USER = 0;
- isPrintPaused = 1;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- isPrintPaused = 0;
- card.paused = 0;
- IS_SD_PRINTING = 1;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- busy_state = 1;
- PAUSED_FOR_USER = 0;
- isPrintPaused = 0;
- IS_SD_PRINTING = 0;
- loading_flag = 0;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- break;
- }
- case 2: {
- IS_SD_PRINTING = 1;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- IS_SD_PRINTING = 0;
- loading_flag = 0;
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- break;
- }
- default:{
- old_code::prusa_statistics(test_codes[i],0);
- new_code::prusa_statistics(test_codes[i],0);
- CHECK(SERIALS_COMPARE() == 0);
- SERIALS_RESET();
- }
- }
- }
- }
|