forked from EA31337/EA31337-classes
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTester.mqh
89 lines (82 loc) · 3.26 KB
/
Tester.mqh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
//+------------------------------------------------------------------+
//| EA31337 - multi-strategy advanced trading robot. |
//| Copyright 2016-2017, 31337 Investments Ltd |
//| https://github.com/EA31337 |
//+------------------------------------------------------------------+
/*
* 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 <http://www.gnu.org/licenses/>.
*
*/
// Includes.
#include "SymbolInfo.mqh"
#include "Terminal.mqh"
/**
* Class to provide functions to work with the strategy tester.
*/
class Tester : public Terminal {
public:
/**
* Check whether spread is valid.
*/
static bool ValidSpread(string _symbol = NULL, bool verbose = true) {
uint _symbol_spread = SymbolInfo::GetSpread(_symbol);
uint _real_spread = SymbolInfo::GetRealSpread(_symbol);
double _lot_step = SymbolInfo::GetVolumeStep(_symbol);
uint _digits = SymbolInfo::GetDigits(_symbol);
if (_real_spread == 0 || _symbol_spread != _real_spread) {
if (verbose) {
PrintFormat("Reported spread: %d pts", _symbol_spread);
PrintFormat("Real spread : %d pts", _real_spread);
PrintFormat("Ask/Bid : %g/%g", SymbolInfo::GetAsk(_symbol), SymbolInfo::GetBid(_symbol));
PrintFormat("Symbol digits : %g", SymbolInfo::GetDigits(_symbol));
PrintFormat("Lot step : %g", _lot_step);
PrintFormat("Error: Spread is not valid, it's %d!", _real_spread);
}
return (false);
}
return (true);
}
/**
* Check whether lot step is valid.
*/
static bool ValidLotstep(string _symbol = NULL, bool verbose = true) {
uint _symbol_spread = SymbolInfo::GetSpread(_symbol);
uint _real_spread = SymbolInfo::GetRealSpread(_symbol);
double _lot_step = SymbolInfo::GetVolumeStep(_symbol);
uint _digits = SymbolInfo::GetDigits(_symbol);
switch (_digits) {
case 4:
if (_lot_step != 0.1) {
if (verbose) {
PrintFormat("Symbol digits : %g", _digits);
PrintFormat("Lot step : %g", _lot_step);
PrintFormat("Error: Expected lot step for %d digits: 0.1, found: %g", _digits, _lot_step);
}
return (false);
}
break;
case 5:
if (_lot_step != 0.01) {
if (verbose) {
PrintFormat("Symbol digits : %g", _digits);
PrintFormat("Lot step : %g", _lot_step);
PrintFormat("Error: Expected lot step for %d digits: 0.01, found: %g", _digits, _lot_step);
}
return (false);
}
break;
}
return (true);
}
};