source: trunk/test/stats_test.cc @ 717

Last change on this file since 717 was 717, checked in by Peter Johansson, 13 years ago

refs #338 added some tests for AddStats

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 6.1 KB
Line 
1// $Id: stats_test.cc 717 2008-11-30 19:41:53Z peter $
2
3/*
4  Copyright (C) 2008 Peter Johansson
5
6  This file is part of svndigest, http://dev.thep.lu.se/svndigest
7
8  svndigest is free software; you can redistribute it and/or modify it
9  under the terms of the GNU General Public License as published by
10  the Free Software Foundation; either version 3 of the License, or
11  (at your option) any later version.
12
13  svndigest is distributed in the hope that it will be useful, but
14  WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  General Public License for more details.
17
18  You should have received a copy of the GNU General Public License
19  along with svndigest. If not, see <http://www.gnu.org/licenses/>.
20*/
21
22#include "Suite.h"
23
24#include "AddStats.h"
25#include "BlameStats.h"
26#include "ClassicStats.h"
27#include "Configuration.h"
28#include "Stats.h"
29#include "SVN.h"
30
31#include <algorithm>
32#include <cassert>
33#include <cstddef>
34#include <iterator>
35#include <iostream>
36#include <numeric>
37#include <string>
38#include <sstream>
39#include <vector>
40
41namespace theplu{
42namespace svndigest{
43
44  bool check(const Stats& stats, const std::vector<size_t>& correct,
45             int linetype, const std::string& descr, const std::string& author);
46  std::string path(void);
47  bool test_add(void);
48  bool test_blame(void);
49  bool test_classic(void);
50  bool test_base_class(const Stats&);
51  bool test_cache(const Stats&);
52 
53}} // end of namespace svndigest and theplu
54
55
56int main( int argc, char* argv[])
57{
58  using namespace theplu::svndigest;
59  bool verbose=false;
60  bool ok=true;
61  if (argc>1 && argv[1]==std::string("-v") )
62    verbose=true;
63  SVN* svn=SVN::instance(test::filename("toy_project"));
64  if (!svn){
65    std::cerr << "error: cannot create SVN instance\n";
66    return 1;
67  }
68
69  ok &= test_add();
70  ok &= test_blame();
71  ok &= test_classic();
72                                                                               
73  if (verbose)
74    if (ok)
75      std::cout << "Test is ok.\n";
76    else
77      std::cout << "Test failed.\n";
78  if (ok)
79    return 0;
80  return 1;
81}
82
83
84namespace theplu{
85namespace svndigest{
86
87  std::string path(void)
88  {
89    return test::filename("toy_project/bin/svnstat.cc");
90  }
91
92  bool test_add(void)
93  {
94    bool ok =true;
95    AddStats cs(path());
96    cs.parse(path());
97    ok &= test_base_class(cs);
98
99    std::vector<size_t> correct(62,0);
100    correct[15] = 71;
101    correct[16] = 3;
102    correct[17] = 7;
103    correct[28] = 35;
104    correct[30] = 63;
105    ok &= check(cs, correct, LineTypeParser::total, "total", "jari");
106    correct[42] = 1;
107    correct[43] = 1;
108    correct[44] = 2;
109    correct[47] = 2;
110    ok &= check(cs, correct, LineTypeParser::total, "total", "all");
111    std::fill(correct.begin(), correct.end(), 0);
112    correct[42] = 1;
113    correct[43] = 1;
114    correct[44] = 2;
115    correct[47] = 2;
116    ok &= check(cs, correct, LineTypeParser::copyright, "copyright", "peter");
117    std::fill(correct.begin(), correct.end(), 0);
118    correct[15] = 49;
119    correct[16] = 3;
120    correct[17] = 7;
121    correct[28] = 11;
122    correct[30] = 54;
123    ok &= check(cs, correct, LineTypeParser::code, "code", "jari");
124    std::fill(correct.begin(), correct.end(), 0);
125    correct[15] = 5;
126    correct[28] = 13;
127    correct[30] = 7;
128    ok &= check(cs, correct, LineTypeParser::comment, "comment", "jari");
129    std::fill(correct.begin(), correct.end(), 0);
130    correct[15] = 17;
131    correct[28] = 10;
132    correct[30] = 2;
133    ok &= check(cs, correct, LineTypeParser::other, "other", "jari");
134
135    return ok;
136  }
137 
138 
139  bool test_blame(void)
140  {
141    bool ok =true;
142    BlameStats cs(path());
143    cs.parse(path());
144    ok &= test_base_class(cs);
145
146    return ok;
147  }
148
149 
150  bool test_cache(const Stats& stats)
151  {
152    std::stringstream out;
153    stats.print(out);
154    std::stringstream in(out.str());
155    ClassicStats stats2(path());
156    assert(in.good());
157    if (!stats2.load_cache(in)){
158      std::cout << "load_cache() failed\n";
159      return false;
160    }
161
162    std::stringstream out2;
163    stats2.print(out2);
164   
165    if (out.str()!=out2.str()) {
166      std::cout << "test_cache() failed\n";
167      return false;
168    }
169    return true;
170  }
171
172
173  bool test_classic(void)
174  {
175    bool ok =true;
176    ClassicStats cs(path());
177    cs.parse(path());
178    ok &= test_base_class(cs);
179
180    // testing copyright lines for peter
181    std::vector<size_t> correct(48,0);
182    correct[47]=2;
183    ok &= check(cs, correct, LineTypeParser::copyright, "copyright", "peter");
184
185    // testing code lines for jari
186    correct.resize(0);
187    correct.resize(48,0);
188    correct[15]=20;
189    correct[16]=1;
190    correct[17]=1;
191    correct[28]=8;
192    correct[30]=54;
193    ok &= check(cs, correct, LineTypeParser::code, "code", "jari");
194
195    // testing comment lines for jari
196    correct.resize(0);
197    correct.resize(48,0);
198    correct[15]=1;
199    correct[28]=13;
200    correct[30]=7;
201    ok &= check(cs, correct, LineTypeParser::comment, "comment", "jari");
202
203    // testing blank lines for jari
204    correct.resize(0);
205    correct.resize(48,0);
206    correct[15]=10;
207    correct[28]=10;
208    correct[30]=2;
209    ok &= check(cs, correct, LineTypeParser::other, "other", "jari");
210
211    // testing code all lines for total
212    correct.resize(0);
213    correct.resize(48,0);
214    correct[15]=31;
215    correct[16]=1;
216    correct[17]=1;
217    correct[28]=31;
218    correct[30]=63;
219    correct[47]=2;
220    ok &= check(cs, correct, LineTypeParser::total, "total", "all");
221
222    return ok;
223  }
224 
225  bool check(const Stats& stats, const std::vector<size_t>& correct,
226             int linetype, const std::string& descr, const std::string& author)
227  {
228    bool ok=true;
229    std::vector<size_t> sum(correct.size());
230    std::partial_sum(correct.begin(), correct.end(), sum.begin());
231    for (size_t rev=0; rev<sum.size(); ++rev){
232      size_t n = stats(linetype, author, rev);
233      if (n != sum[rev]){
234        std::cerr << "error: " << descr << " " << author << " rev:" << rev
235                  << ": found " << n << " expected " << sum[rev] << "\n";
236        ok = false;
237      }
238    }
239    return ok;
240  }
241
242  bool test_base_class(const Stats& s)
243  {
244    if (!test_cache(s))
245      return false;
246    if (s.code()+s.comments()+s.empty()!=s.lines()){
247      std::cerr << "Code plus comments plus empty do not add up to lines\n";
248      std::cerr << "code: " << s.code() << "\n";
249      std::cerr << "comment: " << s.comments() << "\n";
250      std::cerr << "empty: " << s.empty() << "\n";
251      std::cerr << "lines: " << s.lines() << "\n";
252      return false;
253    }
254    return true;
255  }
256
257}} // end of namespace svndigest and theplu
Note: See TracBrowser for help on using the repository browser.