OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/common/media_galleries/pmp_test_helper.h" | 5 #include "chrome/common/media_galleries/pmp_test_helper.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <iterator> | 8 #include <iterator> |
9 | 9 |
10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
51 | 51 |
52 return total; | 52 return total; |
53 } | 53 } |
54 | 54 |
55 } // namespace | 55 } // namespace |
56 | 56 |
57 PmpTestHelper::PmpTestHelper(const std::string& table_name) | 57 PmpTestHelper::PmpTestHelper(const std::string& table_name) |
58 : table_name_(table_name) { | 58 : table_name_(table_name) { |
59 } | 59 } |
60 | 60 |
61 bool PmpTestHelper::Init() { | 61 bool PmpTestHelper::Init(ColumnFileDestination column_file_destination) { |
62 if (!temp_dir_.CreateUniqueTempDir() || !temp_dir_.IsValid()) | 62 if (!root_dir_.CreateUniqueTempDir() || |
| 63 !root_dir_.IsValid() || |
| 64 !file_util::CreateDirectory(GetDatabaseDirPath()) || |
| 65 !file_util::CreateDirectory(GetTempDirPath())) { |
63 return false; | 66 return false; |
| 67 } |
64 | 68 |
65 base::FilePath indicator_path = temp_dir_.path().Append( | 69 if (column_file_destination == DATABASE_DIRECTORY) |
| 70 column_file_destination_directory_ = GetDatabaseDirPath(); |
| 71 else if (column_file_destination == TEMPORARY_DIRECTORY) |
| 72 column_file_destination_directory_ = GetTempDirPath(); |
| 73 else |
| 74 NOTREACHED(); |
| 75 |
| 76 base::FilePath indicator_path = column_file_destination_directory_.Append( |
66 base::FilePath::FromUTF8Unsafe(table_name_ + "_0")); | 77 base::FilePath::FromUTF8Unsafe(table_name_ + "_0")); |
67 | 78 |
68 return file_util::WriteFile(indicator_path, NULL, 0) == 0; | 79 return file_util::WriteFile(indicator_path, NULL, 0) == 0; |
69 } | 80 } |
70 | 81 |
71 base::FilePath PmpTestHelper::GetTempDirPath() { | 82 base::FilePath PmpTestHelper::GetDatabaseDirPath() const { |
72 DCHECK(temp_dir_.IsValid()); | 83 DCHECK(root_dir_.IsValid()); |
73 return temp_dir_.path(); | 84 return root_dir_.path().AppendASCII(kPicasaDatabaseDirName); |
| 85 } |
| 86 |
| 87 base::FilePath PmpTestHelper::GetTempDirPath() const { |
| 88 DCHECK(root_dir_.IsValid()); |
| 89 return root_dir_.path().AppendASCII(kPicasaTempDirName); |
74 } | 90 } |
75 | 91 |
76 template<class T> | 92 template<class T> |
77 bool PmpTestHelper::WriteColumnFileFromVector( | 93 bool PmpTestHelper::WriteColumnFileFromVector( |
78 const std::string& column_name, const PmpFieldType field_type, | 94 const std::string& column_name, const PmpFieldType field_type, |
79 const std::vector<T>& elements_vector) { | 95 const std::vector<T>& elements_vector) const { |
80 DCHECK(temp_dir_.IsValid()); | |
81 | |
82 std::string file_name = table_name_ + "_" + column_name + "." + kPmpExtension; | 96 std::string file_name = table_name_ + "_" + column_name + "." + kPmpExtension; |
83 | 97 |
84 base::FilePath path = temp_dir_.path().Append( | 98 base::FilePath path = |
85 base::FilePath::FromUTF8Unsafe(file_name)); | 99 column_file_destination_directory_.AppendASCII(file_name); |
86 | 100 |
87 std::vector<char> data = PmpTestHelper::MakeHeaderAndBody( | 101 std::vector<char> data = PmpTestHelper::MakeHeaderAndBody( |
88 field_type, elements_vector.size(), elements_vector); | 102 field_type, elements_vector.size(), elements_vector); |
89 | 103 |
90 size_t bytes_written = file_util::WriteFile(path, &data[0], data.size()); | 104 size_t bytes_written = file_util::WriteFile(path, &data[0], data.size()); |
91 return (bytes_written == data.size()); | 105 return (bytes_written == data.size()); |
92 } | 106 } |
93 | 107 |
94 // Explicit Instantiation for all the valid types. | 108 // Explicit Instantiation for all the valid types. |
95 template bool PmpTestHelper::WriteColumnFileFromVector<std::string>( | 109 template bool PmpTestHelper::WriteColumnFileFromVector<std::string>( |
96 const std::string&, const PmpFieldType, const std::vector<std::string>&); | 110 const std::string&, const PmpFieldType, |
| 111 const std::vector<std::string>&) const; |
97 template bool PmpTestHelper::WriteColumnFileFromVector<uint32>( | 112 template bool PmpTestHelper::WriteColumnFileFromVector<uint32>( |
98 const std::string&, const PmpFieldType, const std::vector<uint32>&); | 113 const std::string&, const PmpFieldType, const std::vector<uint32>&) const; |
99 template bool PmpTestHelper::WriteColumnFileFromVector<double>( | 114 template bool PmpTestHelper::WriteColumnFileFromVector<double>( |
100 const std::string&, const PmpFieldType, const std::vector<double>&); | 115 const std::string&, const PmpFieldType, const std::vector<double>&) const; |
101 template bool PmpTestHelper::WriteColumnFileFromVector<uint8>( | 116 template bool PmpTestHelper::WriteColumnFileFromVector<uint8>( |
102 const std::string&, const PmpFieldType, const std::vector<uint8>&); | 117 const std::string&, const PmpFieldType, const std::vector<uint8>&) const; |
103 template bool PmpTestHelper::WriteColumnFileFromVector<uint64>( | 118 template bool PmpTestHelper::WriteColumnFileFromVector<uint64>( |
104 const std::string&, const PmpFieldType, const std::vector<uint64>&); | 119 const std::string&, const PmpFieldType, const std::vector<uint64>&) const; |
105 | 120 |
106 // Return a vector so we don't have to worry about memory management. | 121 // Return a vector so we don't have to worry about memory management. |
107 std::vector<char> PmpTestHelper::MakeHeader(const PmpFieldType field_type, | 122 std::vector<char> PmpTestHelper::MakeHeader(const PmpFieldType field_type, |
108 const uint32 row_count) { | 123 const uint32 row_count) { |
109 std::vector<char> header(picasa::kPmpHeaderSize); | 124 std::vector<char> header(picasa::kPmpHeaderSize); |
110 | 125 |
111 // Copy in magic bytes. | 126 // Copy in magic bytes. |
112 memcpy(&header[picasa::kPmpMagic1Offset], &picasa::kPmpMagic1, | 127 memcpy(&header[picasa::kPmpMagic1Offset], &picasa::kPmpMagic1, |
113 sizeof(picasa::kPmpMagic1)); | 128 sizeof(picasa::kPmpMagic1)); |
114 memcpy(&header[picasa::kPmpMagic2Offset], &picasa::kPmpMagic2, | 129 memcpy(&header[picasa::kPmpMagic2Offset], &picasa::kPmpMagic2, |
(...skipping 30 matching lines...) Expand all Loading... |
145 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint32>( | 160 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint32>( |
146 const PmpFieldType, const uint32, const std::vector<uint32>&); | 161 const PmpFieldType, const uint32, const std::vector<uint32>&); |
147 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<double>( | 162 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<double>( |
148 const PmpFieldType, const uint32, const std::vector<double>&); | 163 const PmpFieldType, const uint32, const std::vector<double>&); |
149 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint8>( | 164 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint8>( |
150 const PmpFieldType, const uint32, const std::vector<uint8>&); | 165 const PmpFieldType, const uint32, const std::vector<uint8>&); |
151 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint64>( | 166 template std::vector<char> PmpTestHelper::MakeHeaderAndBody<uint64>( |
152 const PmpFieldType, const uint32, const std::vector<uint64>&); | 167 const PmpFieldType, const uint32, const std::vector<uint64>&); |
153 | 168 |
154 } // namespace picasa | 169 } // namespace picasa |
OLD | NEW |