DGtal  1.4.beta
testTableReader.cpp
Go to the documentation of this file.
1 
31 #include <iostream>
32 #include "DGtal/base/Common.h"
33 #include "DGtal/io/readers/TableReader.h"
34 #include "DGtal/helpers/StdDefs.h"
35 
36 #include "ConfigTest.h"
37 
39 
40 using namespace std;
41 using namespace DGtal;
42 
43 
45 // Functions for testing class TableReader.
47 
52 {
53  unsigned int nbok = 0;
54  unsigned int nb = 0;
55 
56  trace.beginBlock ( "Testing reading Integers ..." );
57  std::string filename = testPath + "samples/pointList1.pl";
58 
59  vector<unsigned int> vectIntegers = TableReader<unsigned int>::getColumnElementsFromFile(filename, 1);
60  for(unsigned int k=0;k < vectIntegers.size(); k++){
61  trace.info() << " integer: "<< vectIntegers.at(k)<< endl;
62  }
63  nbok += (vectIntegers.at(0)==2 && vectIntegers.at(1)==44 && vectIntegers.at(2)==23
64  && vectIntegers.at(3)==1) ? 1 : 0;
65  nb++;
66  trace.info() << "(" << nbok << "/" << nb << ") "<< std::endl;
67  trace.endBlock();
68 
69  trace.beginBlock( "Testing reading all numbers from each lines ..." );
70 
71  std::vector<vector<unsigned int>> vectLineIntegers =
73  for ( unsigned int k = 0; k < vectLineIntegers.size(); k++ )
74  {
75  for ( unsigned int l = 0; l < vectLineIntegers.at( k ).size(); l++ )
76  {
77  trace.info() << " integer: " << vectLineIntegers.at( k ).at( l ) << " ";
78  }
79  trace.info() << endl;
80  }
81 
82  nbok += ( vectLineIntegers.at( 0 ).at( 0 ) == 1 &&
83  vectLineIntegers.at( 2 ).at( 2 ) == 9 &&
84  vectLineIntegers.at( 3 ).at( 2 ) == 1 )
85  ? 1
86  : 0;
87  nb++;
88  trace.info() << "(" << nbok << "/" << nb << ") " << std::endl;
89  trace.endBlock();
90 
91  trace.beginBlock ( "Testing reading string ..." );
92 
93  vector<std::string> vectStrings = TableReader<std::string>::getColumnElementsFromFile(filename, 2);
94  for(unsigned int k=0;k < vectStrings.size(); k++){
95  trace.info() << " string: "<< vectStrings.at(k)<< endl;
96  }
97  nbok += (vectStrings.at(0)=="3" && vectStrings.at(1)=="4" && vectStrings.at(2)=="9"
98  && vectStrings.at(3)=="1") ? 1 : 0;
99  nb++;
100  trace.info() << "(" << nbok << "/" << nb << ") "<< std::endl;
101  trace.endBlock();
102 
103  return nbok == nb;
104 }
105 
107 // Standard services - public :
108 
109 int main( int argc, char** argv )
110 {
111  trace.beginBlock ( "Testing class TableReader" );
112  trace.info() << "Args:";
113  for ( int i = 0; i < argc; ++i )
114  trace.info() << " " << argv[ i ];
115  trace.info() << endl;
116 
117 
118  bool res = testNumberReader(); // && ... other tests
119  trace.emphase() << ( res ? "Passed." : "Error." ) << endl;
120  trace.endBlock();
121  return res ? 0 : 1;
122 }
123 // //
void beginBlock(const std::string &keyword="")
std::ostream & emphase()
std::ostream & info()
double endBlock()
DGtal is the top-level namespace which contains all DGtal functions and types.
Trace trace
Definition: Common.h:153
Aim: Implements method to read a set of numbers represented in each line of a file.
Definition: TableReader.h:87
int main(int argc, char **argv)
bool testNumberReader()