forked from mapsme/omim
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreader_writer_ops_test.cpp
119 lines (92 loc) · 2.33 KB
/
reader_writer_ops_test.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include "base/SRC_FIRST.hpp"
#include "testing/testing.hpp"
#include "coding/reader_writer_ops.hpp"
#include "coding/file_reader.hpp"
#include "coding/file_writer.hpp"
#include "coding/read_write_utils.hpp"
#include "coding/byte_stream.hpp"
#include "std/algorithm.hpp"
namespace
{
void GetReverseForReaderAndTmpFile(Reader const & src, vector<char> & buffer)
{
char const * tmpFile = "reversed_file.tmp";
{
FileWriter writer(tmpFile);
rw_ops::Reverse(src, writer);
}
{
FileReader reader(tmpFile);
buffer.clear();
MemWriter<vector<char> > writer(buffer);
rw_ops::Reverse(reader, writer);
}
FileWriter::DeleteFileX(tmpFile);
}
void FillRandFile(string const & fName, size_t count)
{
FileWriter writer(fName);
srand(666);
while (count-- > 0)
{
char const c = rand();
writer.Write(&c, 1);
}
}
}
UNIT_TEST(Reverse_Smoke)
{
{
char arr[] = { 0xA, 0xB, 0xC, 0xD, 0xF };
size_t const sz = ARRAY_SIZE(arr);
MemReader reader(&arr[0], sz);
vector<char> buffer;
GetReverseForReaderAndTmpFile(reader, buffer);
TEST_EQUAL(buffer.size(), ARRAY_SIZE(arr), ());
TEST(equal(arr, arr + ARRAY_SIZE(arr), buffer.begin()), ());
}
char const * tmpFile = "random_file.tmp";
{
{
FillRandFile(tmpFile, 10 * 1024 + 527);
FileReader reader(tmpFile);
vector<char> buffer;
GetReverseForReaderAndTmpFile(reader, buffer);
string str;
reader.ReadAsString(str);
TEST_EQUAL(str.size(), buffer.size(), ());
TEST(equal(str.begin(), str.end(), buffer.begin()), ());
}
FileWriter::DeleteFileX(tmpFile);
}
}
namespace
{
struct ThePOD
{
uint32_t m_i;
double m_d;
};
bool operator==(ThePOD const & r1, ThePOD const & r2)
{
return (r1.m_i == r2.m_i && r1.m_d == r2.m_d);
}
}
UNIT_TEST(ReadWrite_POD)
{
srand(666);
size_t const count = 1000;
vector<ThePOD> src(1000);
for (size_t i = 0; i < count; ++i)
{
src[i].m_i = rand();
src[i].m_d = double(rand()) / double(rand());
}
vector<char> buffer;
PushBackByteSink<vector<char> > sink(buffer);
rw::WriteVectorOfPOD(sink, src);
buffer_vector<ThePOD, 128> dest;
ArrayByteSource byteSrc(&buffer.at(0));
rw::ReadVectorOfPOD(byteSrc, dest);
TEST(equal(src.begin(), src.end(), dest.begin()), ());
}