dynare/tests/run_test_octave.m

202 lines
8.7 KiB
Matlab
Raw Normal View History

2011-03-28 18:46:53 +02:00
## Copyright (C) 2009-2011 Dynare Team
##
## This file is part of Dynare.
##
## Dynare 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.
##
## Dynare 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 Dynare. If not, see <http://www.gnu.org/licenses/>.
## Implementation notes:
##
## Before every call to Dynare, the contents of the workspace is saved in
## 'wsOct', and reloaded after Dynare has finished (this is necessary since
## Dynare does a 'clear -all').
top_test_dir = pwd;
addpath(top_test_dir);
addpath([top_test_dir '/../matlab']);
2011-03-28 18:46:53 +02:00
## Test Dynare Version
if !strcmp(dynare_version(), getenv("DYNARE_VERSION"))
2012-04-06 21:53:50 +02:00
error("Incorrect version of Dynare is being tested")
2011-03-28 18:46:53 +02:00
endif
## Ask gnuplot to create graphics in text mode
## Note that setenv() was introduced in Octave 3.0.2, for compatibility
## with MATLAB
putenv("GNUTERM", "dumb")
## Test MOD files listed in Makefile.am
name = strsplit(getenv("MODFILES"), " ");
2011-04-06 16:06:18 +02:00
failedBase = {};
2011-03-28 18:46:53 +02:00
for i=1:size(name,2)
2012-04-06 21:53:50 +02:00
[directory, testfile, ext] = fileparts([top_test_dir '/' name{i}]);
cd(directory);
printf("\n*** TESTING: %s ***\n", name{i});
try
old_path = path;
save wsOct
dynare([testfile ext])
clear -all
load wsOct
path(old_path);
catch
clear -all
load wsOct
path(old_path);
failedBase{size(failedBase,2)+1} = name{i};
printMakeCheckOctaveErrMsg(name{i}, lasterror);
end_try_catch
delete('wsOct');
cd(top_test_dir);
2011-04-05 16:48:11 +02:00
end
2011-03-28 18:46:53 +02:00
## Test block_bytecode/ls2003.mod with various combinations of
## block/bytecode/solve_algo/stack_solve_algo
2011-04-06 16:06:18 +02:00
failedBlock = {};
2011-03-28 18:46:53 +02:00
num_block_tests = 0;
2011-04-06 16:06:18 +02:00
cd([top_test_dir '/block_bytecode']);
2011-04-14 11:23:03 +02:00
for blockFlag = 0:1
2012-04-06 21:53:50 +02:00
for bytecodeFlag = 0:1
## Recall that solve_algo=7 and stack_solve_algo=2 are not supported
## under Octave
default_solve_algo = 2;
default_stack_solve_algo = 0;
if !blockFlag && !bytecodeFlag
solve_algos = 0:4;
stack_solve_algos = [0 6];
2012-04-06 21:53:50 +02:00
elseif blockFlag && !bytecodeFlag
solve_algos = [0:4 6 8];
stack_solve_algos = [0 1 3 4];
else
solve_algos = [0:6 8];
stack_solve_algos = [0 1 3:5];
endif
2012-04-06 21:53:50 +02:00
sleep(1) # Workaround for strange race condition related to the _static.m file
2012-04-06 21:53:50 +02:00
for i = 1:length(solve_algos)
num_block_tests = num_block_tests + 1;
if !blockFlag && !bytecodeFlag && (i == 1)
## This is the reference simulation path against which all
## other simulations will be tested
try
old_path = path;
save wsOct
run_ls2003(blockFlag, bytecodeFlag, solve_algos(i), default_stack_solve_algo)
load wsOct
path(old_path);
y_ref = oo_.endo_simul;
save('test.mat','y_ref');
catch
load wsOct
path(old_path);
failedBlock{size(failedBlock,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckOctaveErrMsg(['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch
else
try
old_path = path;
save wsOct
run_ls2003(blockFlag, bytecodeFlag, solve_algos(i), default_stack_solve_algo)
load wsOct
path(old_path);
## Test against the reference simulation path
load('test.mat','y_ref');
diff = oo_.endo_simul - y_ref;
if(abs(diff) > options_.dynatol.x)
failedBlock{size(failedBlock,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
differr.message = ["ERROR: simulation path differs from the reference path" ];
printMakeCheckOctaveErrMsg(['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], differr);
endif
catch
load wsOct
path(old_path);
failedBlock{size(failedBlock,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckOctaveErrMsg(['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch
endif
endfor
for i = 1:length(stack_solve_algos)
num_block_tests = num_block_tests + 1;
try
old_path = path;
save wsOct
run_ls2003(blockFlag, bytecodeFlag, default_solve_algo, stack_solve_algos(i))
load wsOct
path(old_path);
## Test against the reference simulation path
load('test.mat','y_ref');
diff = oo_.endo_simul - y_ref;
if(abs(diff) > options_.dynatol.x)
failedBlock{size(failedBlock,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(default_solve_algo) ', ' num2str(stack_solve_algos(i)) ')'];
differr.message = ["ERROR: simulation path differs from the reference path" ];
printMakeCheckOctaveErrMsg(['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(default_solve_algo) ', ' num2str(stack_solve_algos(i)) ')'], differr);
endif
catch
load wsOct
path(old_path);
failedBlock{size(failedBlock,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckOctaveErrMsg(['block_bytecode/run_ls2003.m(' num2str(blockFlag) ', ' num2str(bytecodeFlag) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch
endfor
2011-03-28 18:46:53 +02:00
endfor
endfor
delete('wsOct');
2011-04-05 16:48:11 +02:00
2011-04-06 16:06:18 +02:00
cd(top_test_dir);
2011-04-05 16:48:11 +02:00
2011-03-28 18:46:53 +02:00
total_tests = size(name,2)+num_block_tests;
2011-04-05 16:48:11 +02:00
2012-04-06 21:53:50 +02:00
% print output to screen and to file
2011-08-19 18:10:18 +02:00
fid = fopen("run_test_octave_output.txt", "w");
2011-03-28 18:46:53 +02:00
printf("\n\n\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,'\n\n\n');
2011-03-28 18:46:53 +02:00
printf("***************************************\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,"***************************************\n");
2011-03-28 18:46:53 +02:00
printf("* DYNARE TEST RESULTS *\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,"* DYNARE TEST RESULTS *\n");
printf("* for make check-octave *\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,"* for make check-octave *\n");
2011-03-28 18:46:53 +02:00
printf("***************************************\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,"***************************************\n");
2011-04-05 16:48:11 +02:00
printf(" %d tests PASSED out of %d tests run\n", total_tests-size(failedBase,2)-size(failedBlock,2), total_tests);
2011-08-19 18:10:18 +02:00
fprintf(fid," %d tests PASSED out of %d tests run\n", total_tests-size(failedBase,2)-size(failedBlock,2), total_tests);
2011-03-28 18:46:53 +02:00
printf("***************************************\n");
2011-08-19 18:10:18 +02:00
fprintf(fid,"***************************************\n");
2011-04-05 16:48:11 +02:00
if size(failedBase,2) > 0 || size(failedBlock,2) > 0
2012-04-06 21:53:50 +02:00
printf("List of %d tests FAILED:\n", size(failedBase,2)+size(failedBlock,2));
fprintf(fid,"List of %d tests FAILED:\n", size(failedBase,2)+size(failedBlock,2));
for i=1:size(failedBase,2)
printf(" * %s\n",failedBase{i});
fprintf(fid," * %s\n", failedBase{i});
end
for i=1:size(failedBlock,2)
printf(" * %s\n",failedBlock{i});
fprintf(fid," * %s\n", failedBlock{i});
end
printf("***************************************\n\n");
fprintf(fid,"***************************************\n\n");
fclose(fid);
error("make check-octave FAILED");
2011-09-13 18:05:22 +02:00
else
2012-04-06 21:53:50 +02:00
fclose(fid);
2011-09-13 18:05:22 +02:00
endif
## Local variables:
## mode: Octave
## End: