#include <stdlib.h>
#include <itksys/SystemTools.hxx>
const int NO_OUTPUT_OPTION=-1;
+const int TEST_EXITED=1;
int getOutputOptionIndex(int argc, char** argv){
for(int i=1; i<argc; i++){
std::string s = argv[i];
}
return NO_OUTPUT_OPTION;
}
+
std::string getTmpFileName(){
- char buffer [L_tmpnam];
- char* back = tmpnam (buffer);
- if(back==NULL){
+#ifdef _WIN32
+ char fileName[L_tmpnam_s];
+ errno_t err = tmpnam_s(fileName);
+#else
+ char fileName[] = "/tmp/vvTempXXXXXX";
+ int err=0;
+ int fd = mkstemp(fileName);
+ if(fd==-1) err=1;
+#endif
+ if(err){
+ std::cout<<"couldnot create file. Exiting"<<std::endl;
+ exit(TEST_EXITED);
+ }
+ return std::string(fileName);
+}
+
+void assertFalse(int fail, const std::string &message=""){
+ if(fail){
+ std::cout<<message<<std::endl;
exit(1);
}
- return std::string(back);
}
/**
* argv
* [1] executable
* [2] random options
* [2.x] -o
- * [2.x+1] outFileName
* [3] reference file
*
- * [2.x] and [2.x+1] are optional
+ * [2.x] is optional. If set a temporary file will be generated. So NO need to pass a random outputFileName
*/
int main(int argc, char** argv){
//reference file must exist or we fail
char* refFile = argv[argc-1];
- if(!(itksys::SystemTools::FileExists(refFile, true))){
- std::cout<<"refFile "<<refFile<<" doesn't exist"<<std::endl;
- return 1;
- }
+ assertFalse(!(itksys::SystemTools::FileExists(refFile, true)), "refFile "+std::string(refFile)+" doesn't exist");
std::ostringstream cmd_line;
cmd_line<<CLITK_TEST_TOOLS_PATH;
int outputOptionIndex = getOutputOptionIndex(argc, argv);
std::string outFile;
if(NO_OUTPUT_OPTION==outputOptionIndex){
- outFile = getTmpFileName();
- cmd_line<<">"<<outFile;
+ outFile = getTmpFileName();
+ cmd_line<<">"<<outFile;
}else{
- //todo test this else branch
- outFile = std::string(CLITK_TEST_DATA_PATH);
- outFile += argv[outputOptionIndex];
+ outFile = argv[argc-2];
}
+ std::cout<<cmd_line.str()<<std::endl;;
//run the command line
system(cmd_line.str().c_str());
- exit(1);
+ //compare source files
+ assertFalse((itksys::SystemTools::FilesDiffer(outFile.c_str(), refFile)), "Source Files are different");
+
+ //eventually raw files associated
+ //should be passed as a boolean to check also for raw or not
- //files should be equal, so if this is the case return success=0
- int fail = (itksys::SystemTools::FilesDiffer(outFile.c_str(), refFile))?1:0;
+ std::string refRawFile = std::string(refFile)+".raw";
+
+
+ int found=outFile.find_last_of(".");
+ std::string rawFile = outFile.substr(0, found)+".raw";
+ if((itksys::SystemTools::FileExists(refRawFile.c_str(), true))){
+ //compare the raw stuff
+ if((itksys::SystemTools::FileExists(rawFile.c_str(), true))){
+ std::cout<<"Checking raws"<<std::endl;
+ assertFalse(itksys::SystemTools::FilesDiffer(refRawFile.c_str(), rawFile.c_str()), "Raws are different");
+ }
+ //file is not removed if there is a fail
+ remove(rawFile.c_str());
+ }
+ //neither the mhd is
remove(outFile.c_str());
- return fail;
+
+ //success
+ return 0;
}