106 if( ! dirEntry.
IsFile() ) {
111 string name =
file.GetName();
120 const string sFileName =
file.GetName();
121 vector<string> vecFileNamePieces;
123 BOOST_REQUIRE(vecFileNamePieces.size() == 2);
125 string sTestName = vecFileNamePieces[0];
126 BOOST_REQUIRE(!sTestName.empty());
127 string sFileType = vecFileNamePieces[1];
128 BOOST_REQUIRE(!sFileType.empty());
131 (*m_pTestNameToInfoMap)[vecFileNamePieces[0]];
132 test_info_to_load.
mObjType =
"align";
153 BOOST_FAIL(
"Unknown file type " << sFileName <<
".");
178 BOOST_FAIL(
"input file " <<
input <<
" does not exist.");
182 cerr <<
"Creating new test case from " <<
input <<
" ..." << endl;
200 for (
const auto& entry : entry_it) {
211 pWriter->WriteAlign(*pAlign);
212 pWriter->WriteFooter();
213 while (!pI->EndOfData()) {
216 pWriter->WriteAlign(*pAlign);
217 pWriter->WriteFooter();
225 cerr <<
" Produced new flybase file " <<
output <<
"." << endl;
226 cerr <<
" ... Done." << endl;
233 const vector<string> kEmptyStringVec;
245 const string & sName = name_to_info_it->first;
278 for (
const auto& entry :entry_it) {
289 pWriter->WriteAlign(*pAlign);
290 pWriter->WriteFooter();
291 while (!pI->EndOfData()) {
294 pWriter->WriteAlign(*pAlign);
295 pWriter->WriteFooter();
311 BOOST_ERROR(
"Error: " << sTestName <<
" failed due to post processing diffs.");
317 if (!success && keep) {
322 BOOST_ERROR(
"Error: " << sTestName <<
" failed due to error handling diffs.");
331 arg_descrs->AddDefaultKey(
"test-dir",
"TEST_FILE_DIRECTORY",
332 "Set the root directory under which all test files can be found.",
335 arg_descrs->AddDefaultKey(
"update-case",
"UPDATE_CASE",
336 "Produce .asn and .error files from given name for new or updated test case.",
339 arg_descrs->AddFlag(
"update-all",
340 "Update all test cases to current reader code (dangerous).",
342 arg_descrs->AddFlag(
"keep-diffs",
343 "Keep output files that are different from the expected.",
355 CDir test_cases_dir( args[
"test-dir"].AsDirectory() );
356 BOOST_REQUIRE_MESSAGE( test_cases_dir.
IsDir(),
357 "Cannot find dir: " << test_cases_dir.
GetPath() );
359 bool update_all = args[
"update-all"].AsBoolean();
365 string update_case = args[
"update-case"].AsString();
366 if (!update_case.empty()) {
371 const vector<string> kEmptyStringVec;
383 const string & sName = name_to_info_it->first;
384 const STestInfo & testInfo = name_to_info_it->second;
385 cout <<
"Verifying: " << sName << endl;
396 const string & sName = name_to_info_it->first;
397 const STestInfo & testInfo = name_to_info_it->second;
399 cout <<
"Running test: " << sName << endl;
401 BOOST_CHECK_NO_THROW(
sRunTest(sName, testInfo, args[
"keep-diffs"]));
virtual bool WriteHeader() override
static CNcbiApplication * Instance(void)
Singleton method.
TTestNameToInfoMap * m_pTestNameToInfoMap
CTestNameToInfoMapLoader(TTestNameToInfoMap *pTestNameToInfoMap, const string &extInput, const string &extOutput, const string &extErrors, const string &extDatabase)
void operator()(const CDirEntry &dirEntry)
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.
static CRef< CObjectManager > GetInstance(void)
Return the existing object manager or create one.
CSeq_entry_Handle AddTopLevelSeqEntry(CSeq_entry &top_entry, TPriority pri=kPriority_Default, EExist action=eExist_Default)
Add seq_entry, default priority is higher than for defaults or loaders Add object to the score with p...
IO_PREFIX::ofstream CNcbiOfstream
Portable alias for ofstream.
IO_PREFIX::ostream CNcbiOstream
Portable alias for ostream.
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.
use only n Cassandra database for the lookups</td > n</tr > n< tr > n< td > yes</td > n< td > do not use tables BIOSEQ_INFO and BLOB_PROP in the Cassandra database
Defines the CNcbiApplication and CAppException classes for creating NCBI applications.
Defines classes: CDirEntry, CFile, CDir, CSymLink, CMemoryFile, CFileUtil, CFileLock,...
static SQLCHAR output[256]
static char test_name[128]
Utility stuff for more convenient using of Boost.Test library.
static int RunTests(void)
Code to iterate through all tests to run.
BOOST_AUTO_TEST_CASE(RunTests)
const string extErrors("errors")
void sUpdateAll(CDir &test_cases_dir)
map< TTestName, STestInfo > TTestNameToInfoMap
const string extOutput("gff3")
void sUpdateCase(CDir &test_cases_dir, const string &test_name)
CGff3FlybaseWriter * sGetWriter(CScope &scope, CNcbiOstream &ostr)
const string extInput("asn")
const string dirTestFiles("gff3flybasewriter_test_cases")
const string extKeep("new")
const string extDatabase("database")
void sRunTest(const string &sTestName, const STestInfo &testInfo, bool keep)
NCBITEST_INIT_CMDLINE(arg_descrs)