From 1f0d4508373ada7f919cb2a02771b2d78a33569a Mon Sep 17 00:00:00 2001 From: kenorb Date: Mon, 9 Sep 2024 00:35:17 +0100 Subject: [PATCH] Adds initial Backtest class --- .github/workflows/test-platform.yml | 1 + Platform/Backtest.h | 62 +++++++++++++++++++++++++++++ Platform/tests/Backtest.test.cpp | 34 ++++++++++++++++ Platform/tests/Backtest.test.mq4 | 28 +++++++++++++ Platform/tests/Backtest.test.mq5 | 50 +++++++++++++++++++++++ Trade.enum.h | 1 + Trade.mqh | 11 +++++ Trade.struct.h | 3 ++ 8 files changed, 190 insertions(+) create mode 100644 Platform/Backtest.h create mode 100644 Platform/tests/Backtest.test.cpp create mode 100644 Platform/tests/Backtest.test.mq4 create mode 100644 Platform/tests/Backtest.test.mq5 diff --git a/.github/workflows/test-platform.yml b/.github/workflows/test-platform.yml index b93eaa308..87bca78e7 100644 --- a/.github/workflows/test-platform.yml +++ b/.github/workflows/test-platform.yml @@ -37,6 +37,7 @@ jobs: strategy: matrix: test: + - Backtest.test - Order.test - OrderQuery.test - Orders.test diff --git a/Platform/Backtest.h b/Platform/Backtest.h new file mode 100644 index 000000000..e19567798 --- /dev/null +++ b/Platform/Backtest.h @@ -0,0 +1,62 @@ +//+------------------------------------------------------------------+ +//| EA31337 framework | +//| Copyright 2016-2024, EA31337 Ltd | +//| https://ea31337.github.io | +//+------------------------------------------------------------------+ + +/* + * This file 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 . + * + */ + +/** + * @file + * Implements Backtest class for internally backtesting strategies. + */ + +#ifndef __MQL__ +// Allows the preprocessor to include a header file when it is needed. +#pragma once +#endif + +// Includes. +#include "../EA.mqh" + +class Backtest { + protected: + // Class variables. + EA *ea; + + /** + * Init code (called on constructor). + */ + void Init() { + // ... + } + + public: + /** + * Class constructor. + */ + Backtest() { + Init(); + } + + /** + * Class constructor. + */ + Backtest(EAParams &_eparam) : ea(new EA(_eparam)) { + Init(); + } +}; diff --git a/Platform/tests/Backtest.test.cpp b/Platform/tests/Backtest.test.cpp new file mode 100644 index 000000000..24122286f --- /dev/null +++ b/Platform/tests/Backtest.test.cpp @@ -0,0 +1,34 @@ +//+------------------------------------------------------------------+ +//| EA31337 framework | +//| Copyright 2016-2024, EA31337 Ltd | +//| https://ea31337.github.io | +//+------------------------------------------------------------------+ + +/* + * This file 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 . + */ + +/** + * @file + * Test C++ compilation of Backtest class. + */ + +// Includes. +#include "../Backtest.h" + +int main(int argc, char **argv) { + // @todo + + return 0; +} diff --git a/Platform/tests/Backtest.test.mq4 b/Platform/tests/Backtest.test.mq4 new file mode 100644 index 000000000..1546b901d --- /dev/null +++ b/Platform/tests/Backtest.test.mq4 @@ -0,0 +1,28 @@ +//+------------------------------------------------------------------+ +//| EA31337 framework | +//| Copyright 2016-2024, EA31337 Ltd | +//| https://ea31337.github.io | +//+------------------------------------------------------------------+ + +/* + * This file 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 . + */ + +/** + * @file + * Test functionality of Backtest class. + */ + +// Includes. +#include "Backtest.test.mq5" diff --git a/Platform/tests/Backtest.test.mq5 b/Platform/tests/Backtest.test.mq5 new file mode 100644 index 000000000..170d97c70 --- /dev/null +++ b/Platform/tests/Backtest.test.mq5 @@ -0,0 +1,50 @@ +//+------------------------------------------------------------------+ +//| EA31337 framework | +//| Copyright 2016-2024, EA31337 Ltd | +//| https://ea31337.github.io | +//+------------------------------------------------------------------+ + +/* + * This file 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 . + */ + +/** + * @file + * Test functionality of Backtest class. + */ + +// Includes. +#include "../../Test.mqh" +#include "../Backtest.h" + +// Test Backtest. +bool TestBacktest01() { + bool _result = true; + // @todo + return _result; +} + +/** + * Implements OnInit(). + */ +int OnInit() { + bool _result = true; + assertTrueOrFail(TestBacktest01(), "Fail!"); + return _result && GetLastError() == 0 ? INIT_SUCCEEDED : INIT_FAILED; +} + +/** + * Implements Tick event handler. + */ +void OnTick() {} diff --git a/Trade.enum.h b/Trade.enum.h index 89190879e..b34c681e9 100644 --- a/Trade.enum.h +++ b/Trade.enum.h @@ -80,6 +80,7 @@ enum ENUM_TRADE_CONDITION { // Defines enumeration for trade parameters. enum ENUM_TRADE_PARAM { TRADE_PARAM_BARS_MIN = 0, // Bars minimum + TRADE_PARAM_DUMMY, // Dummy trading // @todo: Move to TRADE_MODE TRADE_PARAM_LOG_LEVEL, // Log level TRADE_PARAM_LOT_SIZE, // Lot size TRADE_PARAM_MAGIC_NO, // Magic number diff --git a/Trade.mqh b/Trade.mqh index d849be21b..ea539bbac 100644 --- a/Trade.mqh +++ b/Trade.mqh @@ -805,6 +805,7 @@ HistorySelect(0, TimeCurrent()); // Select history for access. break; } Order *_order = new Order(_request, _oparams); + OnOrderOpen(_oparams); _result = OrderAdd(_order); if (_result) { OnOrderOpen(PTR_TO_REF(_order)); @@ -1761,6 +1762,16 @@ HistorySelect(0, TimeCurrent()); // Select history for access. /* Event methods */ + + /** + * Event on trade's order open. + * + * @param + * _order OrderParams instance of order struct to be open. + */ + virtual void OnOrderOpen(const OrderParams &_oparams) { + } + /** * Event on trade's order open. * diff --git a/Trade.struct.h b/Trade.struct.h index fa3fad96e..b196a60d5 100644 --- a/Trade.struct.h +++ b/Trade.struct.h @@ -129,6 +129,7 @@ struct TradeStats { /* Structure for trade parameters. */ struct TradeParams { + bool dummy; // Whether trades should be opened as dummy (fake orders). float lot_size; // Default lot size. float max_spread; // Maximum spread to trade (in pips). float risk_margin; // Maximum account margin to risk (in %). @@ -141,6 +142,7 @@ struct TradeParams { // Constructors. TradeParams(float _lot_size = 0, float _risk_margin = 1.0f, unsigned int _slippage = 0, ENUM_LOG_LEVEL _ll = V_INFO) : bars_min(100), + dummy(false), order_comment(""), log_level(_ll), lot_size(_lot_size), @@ -151,6 +153,7 @@ struct TradeParams { } TradeParams(uint64 _magic_no, ENUM_LOG_LEVEL _ll = V_INFO) : bars_min(100), + dummy(false), lot_size(0), order_comment(""), log_level(_ll),