( ! dirEntry.
IsFile() ) {
105 stringname =
file.GetName();
114 const stringsFileName =
file.GetName();
115vector<string> vecFileNamePieces;
116 NStr::Split( sFileName,
".", vecFileNamePieces );
117BOOST_REQUIRE(vecFileNamePieces.size() == 2);
119 stringsTestName = vecFileNamePieces[0];
120BOOST_REQUIRE(!sTestName.empty());
121 stringsFileType = vecFileNamePieces[1];
122BOOST_REQUIRE(!sFileType.empty());
125(*m_pTestNameToInfoMap)[vecFileNamePieces[0]];
127test_info_to_load.
mObjType=
"align";
144BOOST_FAIL(
"Unknown file type "<< sFileName <<
".");
163BOOST_FAIL(
"input file "<<
input<<
" does not exist.");
165cerr <<
"Creating new test case from "<<
input<<
" ..."<< endl;
185 while(!pI->EndOfData()) {
196cerr <<
" Produced new alignment file "<<
output<<
"."<< endl;
197cerr <<
" ... Done."<< endl;
204 constvector<string> kEmptyStringVec;
216 const string& sName = name_to_info_it->first;
226cerr <<
"Testing "<< testInfo.
mInFile.
GetName() <<
" against "<<
250 while(!pI->EndOfData()) {
269BOOST_ERROR(
"Error: "<< sTestName <<
" failed due to post processing diffs.");
275 if(!success && keep) {
280BOOST_ERROR(
"Error: "<< sTestName <<
" failed due to error handling diffs.");
290arg_descrs->AddDefaultKey(
"test-dir",
"TEST_FILE_DIRECTORY",
291 "Set the root directory under which all test files can be found.",
294arg_descrs->AddDefaultKey(
"update-case",
"UPDATE_CASE",
295 "Produce .asn and .error files from given name for new or updated test case.",
298arg_descrs->AddFlag(
"update-all",
299 "Update all test cases to current reader code (dangerous).",
301arg_descrs->AddFlag(
"keep-diffs",
302 "Keep output files that are different from the expected.",
314 CDirtest_cases_dir( args[
"test-dir"].AsDirectory() );
315BOOST_REQUIRE_MESSAGE( test_cases_dir.
IsDir(),
316 "Cannot find dir: "<< test_cases_dir.
GetPath() );
318 boolupdate_all = args[
"update-all"].AsBoolean();
324 stringupdate_case = args[
"update-case"].AsString();
325 if(!update_case.empty()) {
330 constvector<string> kEmptyStringVec;
342 const string& sName = name_to_info_it->first;
343 const STestInfo& testInfo = name_to_info_it->second;
344cout <<
"Verifying: "<< sName << endl;
353 const string& sName = name_to_info_it->first;
354 const STestInfo& testInfo = name_to_info_it->second;
356cout <<
"Running test: "<< sName << endl;
358BOOST_CHECK_NO_THROW(
sRunTest(sName, testInfo, args[
"keep-diffs"]));
bool WriteAlign(const CSeq_align &align, const string &name="", const string &descr="") override
Write a raw Seq-align to the internal output stream.
static TRegisterLoaderInfo RegisterInObjectManager(CObjectManager &om, CReader *reader=0, CObjectManager::EIsDefault is_default=CObjectManager::eDefault, CObjectManager::TPriority priority=CObjectManager::kPriority_NotSet)
static CNcbiApplication * Instance(void)
Singleton method.
TTestNameToInfoMap * m_pTestNameToInfoMap
void operator()(const CDirEntry &dirEntry)
CTestNameToInfoMapLoader(TTestNameToInfoMap *pTestNameToInfoMap, const string &extInput, const string &extOutput, const string &extErrors)
static SQLCHAR output[256]
static int RunTests(void)
Code to iterate through all tests to run.
static char test_name[128]
virtual const CArgs & GetArgs(void) const
Get parsed command line arguments.
#define ITERATE(Type, Var, Cont)
ITERATE macro to sequence through container elements.
@ eString
An arbitrary string.
@ eDirectory
Name of file directory.
void FindFilesInDir(const CDir &dir, const vector< string > &masks, const vector< string > &masks_subdir, TFindFunc &find_func, TFindFiles flags=fFF_Default)
Find files in the specified directory.
virtual bool Remove(TRemoveFlags flags=eRecursive) const
Remove a directory entry.
bool IsDir(EFollowLinks follow=eFollowLinks) const
Check whether a directory entry is a directory.
bool CompareTextContents(const string &file, ECompareText mode, size_t buf_size=0) const
Compare files contents in text form.
bool IsFile(EFollowLinks follow=eFollowLinks) const
Check whether a directory entry is a file.
static string GetTmpName(ETmpFileCreationMode mode=eTmpFileGetName)
Get temporary file name.
static string ConcatPath(const string &first, const string &second)
Concatenate two parts of the path for the current OS.
string GetName(void) const
Get the base entry name with extension (if any).
const string & GetPath(void) const
Get entry path.
virtual bool Copy(const string &new_path, TCopyFlags flags=fCF_Default, size_t buf_size=0) const
Copy the entry to a location specified by "new_path".
virtual bool Exists(void) const
Check existence of file.
@ fCF_Overwrite
The following flags define what to do when the destination entry already exists:
@ fFF_Recursive
descend into sub-dirs
@ fFF_Default
default behavior
@ eSerial_AsnText
ASN.1 text.
static CObjectIStream * Open(ESerialDataFormat format, CNcbiIstream &inStream, bool deleteInStream)
Create serial object reader and attach it to an input stream.
TLoader * GetLoader(void) const
Get pointer to the loader.
static CRef< CObjectManager > GetInstance(void)
Return the existing object manager or create one.
void AddDefaults(TPriority pri=kPriority_Default)
Add default data loaders from object manager.
IO_PREFIX::ofstream CNcbiOfstream
Portable alias for ofstream.
IO_PREFIX::ifstream CNcbiIfstream
Portable alias for ifstream.
static list< string > & Split(const CTempString str, const CTempString delim, list< string > &arr, TSplitFlags flags=0, vector< SIZE_TYPE > *token_pos=NULL)
Split a string using specified delimiters.
static bool EndsWith(const CTempString str, const CTempString end, ECase use_case=eCase)
Check if a string ends with a specified suffix value.
static bool StartsWith(const CTempString str, const CTempString start, ECase use_case=eCase)
Check if a string starts with a specified prefix value.
Defines the CNcbiApplication and CAppException classes for creating NCBI applications.
Defines classes: CDirEntry, CFile, CDir, CSymLink, CMemoryFile, CFileUtil, CFileLock,...
Utility stuff for more convenient using of Boost.Test library.
BOOST_AUTO_TEST_CASE(RunTests)
const string extErrors("errors")
const string extOutput("aln")
void sUpdateAll(CDir &test_cases_dir)
map< TTestName, STestInfo > TTestNameToInfoMap
void sUpdateCase(CDir &test_cases_dir, const string &test_name)
const string extInput("asn")
const string dirTestFiles("alnwriter_test_cases")
const string extKeep("new")
void sRunTest(const string &sTestName, const STestInfo &testInfo, bool keep)
NCBITEST_INIT_CMDLINE(arg_descrs)
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4