build system: make check update

time-shift
Houtan Bastani 2011-04-05 16:48:11 +02:00
parent e91f0776f2
commit 99cbbaed30
1 changed files with 57 additions and 36 deletions

View File

@ -106,16 +106,12 @@ putenv("GNUTERM", "dumb")
## BASE TESTS ## BASE TESTS
failed = {}; failed = {};
top_test_dir = [pwd '/']; top_test_dir = pwd;
addpath(top_test_dir); addpath(top_test_dir);
addpath([top_test_dir '../matlab']);
for i=1:size(name,2) for i=1:size(name,2)
save('makecheck.mat', 'name', 'failed', 'i', 'top_test_dir');
clear -all;
load 'makecheck.mat';
try try
[directory, testfile, ext] = fileparts([top_test_dir name{i}]); [directory, testfile, ext] = fileparts([top_test_dir '/' name{i}]);
cd(directory); cd(directory);
printf("*** TESTING: %s ***\n", name{i}); printf("*** TESTING: %s ***\n", name{i});
dynare([testfile ext], 'noclearall') dynare([testfile ext], 'noclearall')
@ -123,14 +119,17 @@ for i=1:size(name,2)
failed{size(failed,2)+1} = name{i}; failed{size(failed,2)+1} = name{i};
printMakeCheckErrMsg(name{i}, lasterror); printMakeCheckErrMsg(name{i}, lasterror);
end_try_catch end_try_catch
cd(top_test_dir);
save('makeCheckBase.mat', 'name', 'failed', 'i', 'top_test_dir');
clear -all;
load('makeCheckBase.mat');
end end
save('makecheck.mat', 'name', 'failed', 'top_test_dir');
clear -all;
load 'makecheck.mat';
## BLOCK TEST ## BLOCK TEST
cd([top_test_dir 'block_bytecode/']); clear i;
clear name;
failed = {};
num_block_tests = 0; num_block_tests = 0;
for block = 0:1 for block = 0:1
for bytecode = 0:1 for bytecode = 0:1
@ -150,68 +149,90 @@ for block = 0:1
endif endif
for i = 1:length(solve_algos) for i = 1:length(solve_algos)
save ws cd([top_test_dir '/block_bytecode']);
num_block_tests = num_block_tests + 1;
if !block && !bytecode && (i == 1) if !block && !bytecode && (i == 1)
try try
num_block_tests = num_block_tests + 1;
run_ls2003(block, bytecode, solve_algos(i), default_stack_solve_algo) run_ls2003(block, bytecode, solve_algos(i), default_stack_solve_algo)
y_ref = oo_.endo_simul; y_ref = oo_.endo_simul;
save('test.mat','y_ref'); save('test.mat','y_ref');
catch catch
failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')']; failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')'], lasterror); printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch end_try_catch
else else
try try
num_block_tests = num_block_tests + 1;
run_ls2003(block, bytecode, solve_algos(i), default_stack_solve_algo) run_ls2003(block, bytecode, solve_algos(i), default_stack_solve_algo)
load('test.mat','y_ref'); load('test.mat','y_ref');
diff = oo_.endo_simul - y_ref; diff = oo_.endo_simul - y_ref;
if (abs(diff) <= options_.dynatol) if (abs(diff) <= options_.dynatol)
failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')']; failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')'], lasterror); printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end end
catch catch
failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')']; failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')'], lasterror); printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch end_try_catch
endif endif
load ws
cd(top_test_dir);
save('makeCheckBlock.mat', 'failed', 'num_block_tests', 'top_test_dir', 'i', ...
'solve_algos', 'block', 'bytecode', 'default_stack_solve_algo', 'default_solve_algo', 'stack_solve_algos');
clear -all;
load('makeCheckBlock.mat');
endfor endfor
for i = 1:length(stack_solve_algos) for i = 1:length(stack_solve_algos)
save ws cd([top_test_dir '/block_bytecode']);
num_block_tests = num_block_tests + 1;
try try
num_block_tests = num_block_tests + 1;
run_ls2003(block, bytecode, default_solve_algo, stack_solve_algos(i)) run_ls2003(block, bytecode, default_solve_algo, stack_solve_algos(i))
catch catch
failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')']; failed{size(failed,2)+1} = ['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'];
printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) num2str(bytecode) num2str(solve_algos(i)) num2str(default_stack_solve_algo) ')'], lasterror); printMakeCheckErrMsg(['block_bytecode/run_ls2003.m(' num2str(block) ', ' num2str(bytecode) ', ' num2str(solve_algos(i)) ', ' num2str(default_stack_solve_algo) ')'], lasterror);
end_try_catch end_try_catch
load ws
cd(top_test_dir);
save('makeCheckBlock.mat', 'failed', 'num_block_tests', 'top_test_dir', 'i', ...
'solve_algos', 'block', 'bytecode', 'default_stack_solve_algo', 'default_solve_algo', 'stack_solve_algos');
clear -all;
load('makeCheckBlock.mat');
endfor endfor
endfor endfor
endfor endfor
save('makecheck.mat', 'name', 'failed', 'top_test_dir', 'num_block_tests'); cd(top_test_dir);
clear -all; clear -all
load 'makecheck.mat';
delete 'makecheck.mat'; load('makeCheckBase.mat');
failedBase = failed;
delete('makeCheckBase.mat');
load('makeCheckBlock.mat');
failedBlock = failed;
delete('makeCheckBlock.mat');
total_tests = size(name,2)+num_block_tests; total_tests = size(name,2)+num_block_tests;
printf("\n\n\n"); printf("\n\n\n");
printf("***************************************\n"); printf("***************************************\n");
printf("* DYNARE TEST RESULTS *\n"); printf("* DYNARE TEST RESULTS *\n");
printf("***************************************\n"); printf("***************************************\n");
printf(" %d tests PASSED out of %d tests run\n", total_tests-size(failed,2), total_tests); printf(" %d tests PASSED out of %d tests run\n", total_tests-size(failedBase,2)-size(failedBlock,2), total_tests);
printf("***************************************\n"); printf("***************************************\n");
if size(failed,2) > 0 if size(failedBase,2) > 0 || size(failedBlock,2) > 0
printf("List of %d tests FAILED:\n", size(failed,2)); printf("List of %d tests FAILED:\n", size(failedBase,2)+size(failedBlock,2));
for i=1:size(failed,2) for i=1:size(failedBase,2)
printf(" * %s\n",failed{i}); printf(" * %s\n",failedBase{i});
end
for i=1:size(failedBlock,2)
printf(" * %s\n",failedBlock{i});
end end
printf("***************************************\n\n"); printf("***************************************\n\n");
clear -all
error("Make Check FAILED"); error("Make Check FAILED");
end end
clear -all
## Local variables: ## Local variables:
## mode: Octave ## mode: Octave