Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(108)

Side by Side Diff: chrome/browser/chromeos/gdata/gdata_parser_unittest.cc

Issue 10546034: Adds parsing for the app_id field from an "open-with-" link (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "base/file_path.h" 5 #include "base/file_path.h"
6 #include "base/file_util.h" 6 #include "base/file_util.h"
7 #include "base/json/json_file_value_serializer.h" 7 #include "base/json/json_file_value_serializer.h"
8 #include "base/path_service.h" 8 #include "base/path_service.h"
9 #include "base/string16.h" 9 #include "base/string16.h"
10 #include "base/time.h" 10 #include "base/time.h"
11 #include "base/utf_string_conversions.h" 11 #include "base/utf_string_conversions.h"
12 #include "base/values.h" 12 #include "base/values.h"
13 #include "chrome/browser/chromeos/gdata/gdata_parser.h" 13 #include "chrome/browser/chromeos/gdata/gdata_parser.h"
14 #include "chrome/common/chrome_paths.h" 14 #include "chrome/common/chrome_paths.h"
15 #include "testing/gtest/include/gtest/gtest.h" 15 #include "testing/gtest/include/gtest/gtest.h"
16 #include "third_party/libxml/chromium/libxml_utils.h" 16 #include "third_party/libxml/chromium/libxml_utils.h"
17 17
18 using base::Value; 18 using base::Value;
19 using base::DictionaryValue; 19 using base::DictionaryValue;
20 using base::ListValue; 20 using base::ListValue;
21 21
22 #define IF_EXPECT_EQ(arg1, arg2) \
23 EXPECT_EQ(arg1, arg2); \
24 if (arg1 == arg2)
25
26 #define IF_EXPECT_TRUE(arg) \
27 EXPECT_TRUE(arg); \
28 if (arg)
29
22 namespace gdata { 30 namespace gdata {
23 31
24 class GDataParserTest : public testing::Test { 32 class GDataParserTest : public testing::Test {
25 protected: 33 protected:
26 static Value* LoadJSONFile(const std::string& filename) { 34 static Value* LoadJSONFile(const std::string& filename) {
27 FilePath path; 35 FilePath path;
28 std::string error; 36 std::string error;
29 // Test files for this unit test are located in 37 // Test files for this unit test are located in
30 // src/chrome/test/data/chromeos/gdata/* 38 // src/chrome/test/data/chromeos/gdata/*
31 PathService::Get(chrome::DIR_TEST_DATA, &path); 39 PathService::Get(chrome::DIR_TEST_DATA, &path);
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
67 } 75 }
68 return entry.release(); 76 return entry.release();
69 } 77 }
70 }; 78 };
71 79
72 // Test document feed parsing. 80 // Test document feed parsing.
73 TEST_F(GDataParserTest, DocumentFeedJsonParser) { 81 TEST_F(GDataParserTest, DocumentFeedJsonParser) {
74 std::string error; 82 std::string error;
75 scoped_ptr<Value> document(LoadJSONFile("basic_feed.json")); 83 scoped_ptr<Value> document(LoadJSONFile("basic_feed.json"));
76 ASSERT_TRUE(document.get()); 84 ASSERT_TRUE(document.get());
77 ASSERT_TRUE(document->GetType() == Value::TYPE_DICTIONARY); 85 ASSERT_EQ(Value::TYPE_DICTIONARY, document->GetType());
78 scoped_ptr<DocumentFeed> feed(DocumentFeed::ExtractAndParse(*document)); 86 scoped_ptr<DocumentFeed> feed(DocumentFeed::ExtractAndParse(*document));
79 ASSERT_TRUE(feed.get()); 87 ASSERT_TRUE(feed.get());
80 88
81 base::Time update_time; 89 base::Time update_time;
82 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-12-14T01:03:21.151Z", 90 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-12-14T01:03:21.151Z",
83 &update_time)); 91 &update_time));
84 92
85 EXPECT_EQ(1, feed->start_index()); 93 EXPECT_EQ(1, feed->start_index());
86 EXPECT_EQ(1000, feed->items_per_page()); 94 EXPECT_EQ(1000, feed->items_per_page());
87 EXPECT_EQ(update_time, feed->updated_time()); 95 EXPECT_EQ(update_time, feed->updated_time());
88 96
89 // Check authors. 97 // Check authors.
90 ASSERT_EQ(1U, feed->authors().size()); 98 IF_EXPECT_EQ(1U, feed->authors().size()) {
91 EXPECT_EQ(ASCIIToUTF16("tester"), feed->authors()[0]->name()); 99 EXPECT_EQ(ASCIIToUTF16("tester"), feed->authors()[0]->name());
92 EXPECT_EQ("tester@testing.com", feed->authors()[0]->email()); 100 EXPECT_EQ("tester@testing.com", feed->authors()[0]->email());
101 }
93 102
94 // Check links. 103 // Check links.
95 ASSERT_EQ(feed->links().size(), 6U); 104 IF_EXPECT_EQ(6U, feed->links().size()) {
96 const Link* self_link = feed->GetLinkByType(Link::SELF); 105 const Link* self_link = feed->GetLinkByType(Link::SELF);
97 ASSERT_TRUE(self_link); 106 IF_EXPECT_TRUE(self_link) {
98 EXPECT_EQ("https://self_link/", self_link->href().spec()); 107 EXPECT_EQ("https://self_link/", self_link->href().spec());
99 EXPECT_EQ("application/atom+xml", self_link->mime_type()); 108 EXPECT_EQ("application/atom+xml", self_link->mime_type());
109 }
110 }
100 111
101 const Link* resumable_link = 112 const Link* resumable_link =
102 feed->GetLinkByType(Link::RESUMABLE_CREATE_MEDIA); 113 feed->GetLinkByType(Link::RESUMABLE_CREATE_MEDIA);
103 ASSERT_TRUE(resumable_link); 114 IF_EXPECT_TRUE(resumable_link) {
104 EXPECT_EQ("https://resumable_create_media_link/", 115 EXPECT_EQ("https://resumable_create_media_link/",
105 resumable_link->href().spec()); 116 resumable_link->href().spec());
106 EXPECT_EQ("application/atom+xml", resumable_link->mime_type()); 117 EXPECT_EQ("application/atom+xml", resumable_link->mime_type());
118 }
107 119
108 // Check entries. 120 // Check entries.
109 ASSERT_EQ(4U, feed->entries().size()); 121 ASSERT_EQ(4U, feed->entries().size());
110 122
111 // Check a folder entry. 123 // Check a folder entry.
112 const DocumentEntry* folder_entry = feed->entries()[0]; 124 const DocumentEntry* folder_entry = feed->entries()[0];
113 ASSERT_TRUE(folder_entry); 125 ASSERT_TRUE(folder_entry);
114 EXPECT_EQ(DocumentEntry::FOLDER, folder_entry->kind()); 126 EXPECT_EQ(DocumentEntry::FOLDER, folder_entry->kind());
115 EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", folder_entry->etag()); 127 EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", folder_entry->etag());
116 EXPECT_EQ("folder:1_folder_resouce_id", folder_entry->resource_id()); 128 EXPECT_EQ("folder:1_folder_resouce_id", folder_entry->resource_id());
117 EXPECT_EQ("https://1_folder_id", folder_entry->id()); 129 EXPECT_EQ("https://1_folder_id", folder_entry->id());
118 EXPECT_EQ(ASCIIToUTF16("Entry 1 Title"), folder_entry->title()); 130 EXPECT_EQ(ASCIIToUTF16("Entry 1 Title"), folder_entry->title());
119 base::Time entry1_update_time; 131 base::Time entry1_update_time;
120 base::Time entry1_publish_time; 132 base::Time entry1_publish_time;
121 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-04-01T18:34:08.234Z", 133 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-04-01T18:34:08.234Z",
122 &entry1_update_time)); 134 &entry1_update_time));
123 ASSERT_TRUE(FeedEntry::GetTimeFromString("2010-11-07T05:03:54.719Z", 135 ASSERT_TRUE(FeedEntry::GetTimeFromString("2010-11-07T05:03:54.719Z",
124 &entry1_publish_time)); 136 &entry1_publish_time));
125 ASSERT_EQ(entry1_update_time, folder_entry->updated_time()); 137 EXPECT_EQ(entry1_update_time, folder_entry->updated_time());
126 ASSERT_EQ(entry1_publish_time, folder_entry->published_time()); 138 EXPECT_EQ(entry1_publish_time, folder_entry->published_time());
127 139
128 ASSERT_EQ(1U, folder_entry->authors().size()); 140 IF_EXPECT_EQ(1U, folder_entry->authors().size()) {
zel 2012/06/06 23:29:59 we shouldn't replace ASSERT_TRUE() here. what are
129 EXPECT_EQ(ASCIIToUTF16("entry_tester"), folder_entry->authors()[0]->name()); 141 EXPECT_EQ(ASCIIToUTF16("entry_tester"), folder_entry->authors()[0]->name());
130 EXPECT_EQ("entry_tester@testing.com", folder_entry->authors()[0]->email()); 142 EXPECT_EQ("entry_tester@testing.com", folder_entry->authors()[0]->email());
131 EXPECT_EQ("https://1_folder_content_url/", 143 EXPECT_EQ("https://1_folder_content_url/",
132 folder_entry->content_url().spec()); 144 folder_entry->content_url().spec());
133 EXPECT_EQ("application/atom+xml;type=feed", 145 EXPECT_EQ("application/atom+xml;type=feed",
134 folder_entry->content_mime_type()); 146 folder_entry->content_mime_type());
147 }
135 148
136 ASSERT_EQ(1U, folder_entry->feed_links().size()); 149 ASSERT_EQ(1U, folder_entry->feed_links().size());
137 const FeedLink* feed_link = folder_entry->feed_links()[0]; 150 const FeedLink* feed_link = folder_entry->feed_links()[0];
138 ASSERT_TRUE(feed_link); 151 ASSERT_TRUE(feed_link);
139 ASSERT_EQ(FeedLink::ACL, feed_link->type()); 152 ASSERT_EQ(FeedLink::ACL, feed_link->type());
140 153
141 const Link* entry1_alternate_link = 154 const Link* entry1_alternate_link =
142 folder_entry->GetLinkByType(Link::ALTERNATE); 155 folder_entry->GetLinkByType(Link::ALTERNATE);
143 ASSERT_TRUE(entry1_alternate_link); 156 IF_EXPECT_TRUE(entry1_alternate_link) {
144 EXPECT_EQ("https://1_folder_alternate_link/", 157 EXPECT_EQ("https://1_folder_alternate_link/",
145 entry1_alternate_link->href().spec()); 158 entry1_alternate_link->href().spec());
146 EXPECT_EQ("text/html", entry1_alternate_link->mime_type()); 159 EXPECT_EQ("text/html", entry1_alternate_link->mime_type());
160 }
147 161
148 const Link* entry1_edit_link = folder_entry->GetLinkByType(Link::EDIT); 162 const Link* entry1_edit_link = folder_entry->GetLinkByType(Link::EDIT);
149 ASSERT_TRUE(entry1_edit_link); 163 IF_EXPECT_TRUE(entry1_edit_link) {
150 EXPECT_EQ("https://1_edit_link/", entry1_edit_link->href().spec()); 164 EXPECT_EQ("https://1_edit_link/", entry1_edit_link->href().spec());
151 EXPECT_EQ("application/atom+xml", entry1_edit_link->mime_type()); 165 EXPECT_EQ("application/atom+xml", entry1_edit_link->mime_type());
166 }
152 167
153 // Check a file entry. 168 // Check a file entry.
154 const DocumentEntry* file_entry = feed->entries()[1]; 169 const DocumentEntry* file_entry = feed->entries()[1];
155 ASSERT_TRUE(file_entry); 170 IF_EXPECT_TRUE(file_entry) {
156 EXPECT_EQ(DocumentEntry::FILE, file_entry->kind()); 171 EXPECT_EQ(DocumentEntry::FILE, file_entry->kind());
157 EXPECT_EQ(ASCIIToUTF16("filename.m4a"), file_entry->filename()); 172 EXPECT_EQ(ASCIIToUTF16("filename.m4a"), file_entry->filename());
158 EXPECT_EQ(ASCIIToUTF16("sugg_file_name.m4a"), 173 EXPECT_EQ(ASCIIToUTF16("sugg_file_name.m4a"),
159 file_entry->suggested_filename()); 174 file_entry->suggested_filename());
160 EXPECT_EQ("3b4382ebefec6e743578c76bbd0575ce", file_entry->file_md5()); 175 EXPECT_EQ("3b4382ebefec6e743578c76bbd0575ce", file_entry->file_md5());
161 EXPECT_EQ(892721, file_entry->file_size()); 176 EXPECT_EQ(892721, file_entry->file_size());
162 const Link* file_parent_link = file_entry->GetLinkByType(Link::PARENT); 177 const Link* file_parent_link = file_entry->GetLinkByType(Link::PARENT);
163 ASSERT_TRUE(file_parent_link); 178 IF_EXPECT_TRUE(file_parent_link) {
164 EXPECT_EQ("https://file_link_parent/", file_parent_link->href().spec()); 179 EXPECT_EQ("https://file_link_parent/", file_parent_link->href().spec());
165 EXPECT_EQ("application/atom+xml", file_parent_link->mime_type()); 180 EXPECT_EQ("application/atom+xml", file_parent_link->mime_type());
166 EXPECT_EQ(ASCIIToUTF16("Medical"), file_parent_link->title()); 181 EXPECT_EQ(ASCIIToUTF16("Medical"), file_parent_link->title());
182 }
183 }
167 184
168 // Check a file entry. 185 // Check a file entry.
169 const DocumentEntry* document_entry = feed->entries()[2]; 186 const DocumentEntry* document_entry = feed->entries()[2];
170 ASSERT_TRUE(document_entry); 187 IF_EXPECT_TRUE(document_entry) {
171 EXPECT_EQ(DocumentEntry::DOCUMENT, document_entry->kind()); 188 EXPECT_EQ(DocumentEntry::DOCUMENT, document_entry->kind());
172 EXPECT_TRUE(document_entry->is_hosted_document()); 189 EXPECT_TRUE(document_entry->is_hosted_document());
173 EXPECT_TRUE(document_entry->is_google_document()); 190 EXPECT_TRUE(document_entry->is_google_document());
174 EXPECT_FALSE(document_entry->is_external_document()); 191 EXPECT_FALSE(document_entry->is_external_document());
192 }
175 193
176 // Check an external document entry. 194 // Check an external document entry.
177 const DocumentEntry* app_entry = feed->entries()[3]; 195 const DocumentEntry* app_entry = feed->entries()[3];
178 ASSERT_TRUE(app_entry); 196 IF_EXPECT_TRUE(app_entry) {
179 EXPECT_EQ(DocumentEntry::EXTERNAL_APP, app_entry->kind()); 197 EXPECT_EQ(DocumentEntry::EXTERNAL_APP, app_entry->kind());
180 EXPECT_TRUE(app_entry->is_hosted_document()); 198 EXPECT_TRUE(app_entry->is_hosted_document());
181 EXPECT_TRUE(app_entry->is_external_document()); 199 EXPECT_TRUE(app_entry->is_external_document());
182 EXPECT_FALSE(app_entry->is_google_document()); 200 EXPECT_FALSE(app_entry->is_google_document());
201 }
183 } 202 }
184 203
185 204
186 // Test document feed parsing. 205 // Test document feed parsing.
187 TEST_F(GDataParserTest, DocumentEntryXmlParser) { 206 TEST_F(GDataParserTest, DocumentEntryXmlParser) {
188 scoped_ptr<DocumentEntry> entry(LoadDocumentEntryFromXml("entry.xml")); 207 scoped_ptr<DocumentEntry> entry(LoadDocumentEntryFromXml("entry.xml"));
189 ASSERT_TRUE(entry.get()); 208 ASSERT_TRUE(entry.get());
190 209
191 EXPECT_EQ(DocumentEntry::FILE, entry->kind()); 210 EXPECT_EQ(DocumentEntry::FILE, entry->kind());
192 EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", entry->etag()); 211 EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", entry->etag());
193 EXPECT_EQ("file:xml_file_resouce_id", entry->resource_id()); 212 EXPECT_EQ("file:xml_file_resouce_id", entry->resource_id());
194 EXPECT_EQ("https://xml_file_id", entry->id()); 213 EXPECT_EQ("https://xml_file_id", entry->id());
195 EXPECT_EQ(ASCIIToUTF16("Xml Entry File Title.tar"), entry->title()); 214 EXPECT_EQ(ASCIIToUTF16("Xml Entry File Title.tar"), entry->title());
196 base::Time entry1_update_time; 215 base::Time entry1_update_time;
197 base::Time entry1_publish_time; 216 base::Time entry1_publish_time;
198 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-04-01T18:34:08.234Z", 217 ASSERT_TRUE(FeedEntry::GetTimeFromString("2011-04-01T18:34:08.234Z",
199 &entry1_update_time)); 218 &entry1_update_time));
200 ASSERT_TRUE(FeedEntry::GetTimeFromString("2010-11-07T05:03:54.719Z", 219 ASSERT_TRUE(FeedEntry::GetTimeFromString("2010-11-07T05:03:54.719Z",
201 &entry1_publish_time)); 220 &entry1_publish_time));
202 ASSERT_EQ(entry1_update_time, entry->updated_time()); 221 EXPECT_EQ(entry1_update_time, entry->updated_time());
203 ASSERT_EQ(entry1_publish_time, entry->published_time()); 222 EXPECT_EQ(entry1_publish_time, entry->published_time());
204 223
205 ASSERT_EQ(1U, entry->authors().size()); 224 EXPECT_EQ(1U, entry->authors().size());
206 EXPECT_EQ(ASCIIToUTF16("entry_tester"), entry->authors()[0]->name()); 225 EXPECT_EQ(ASCIIToUTF16("entry_tester"), entry->authors()[0]->name());
207 EXPECT_EQ("entry_tester@testing.com", entry->authors()[0]->email()); 226 EXPECT_EQ("entry_tester@testing.com", entry->authors()[0]->email());
208 EXPECT_EQ("https://1_xml_file_entry_content_url/", 227 EXPECT_EQ("https://1_xml_file_entry_content_url/",
209 entry->content_url().spec()); 228 entry->content_url().spec());
210 EXPECT_EQ("application/x-tar", 229 EXPECT_EQ("application/x-tar",
211 entry->content_mime_type()); 230 entry->content_mime_type());
212 231
213 // Check feed links. 232 // Check feed links.
214 ASSERT_EQ(2U, entry->feed_links().size()); 233 IF_EXPECT_EQ(2U, entry->feed_links().size()) {
215 const FeedLink* feed_link_1 = entry->feed_links()[0]; 234 const FeedLink* feed_link_1 = entry->feed_links()[0];
216 ASSERT_TRUE(feed_link_1); 235 IF_EXPECT_TRUE(feed_link_1) {
217 ASSERT_EQ(FeedLink::ACL, feed_link_1->type()); 236 EXPECT_EQ(FeedLink::ACL, feed_link_1->type());
218 const FeedLink* feed_link_2 = entry->feed_links()[1]; 237 }
219 ASSERT_TRUE(feed_link_2); 238 const FeedLink* feed_link_2 = entry->feed_links()[1];
220 ASSERT_EQ(FeedLink::REVISIONS, feed_link_2->type()); 239 IF_EXPECT_TRUE(feed_link_2) {
240 EXPECT_EQ(FeedLink::REVISIONS, feed_link_2->type());
241 }
242 }
221 243
222 // Check links. 244 // Check links.
223 ASSERT_EQ(7U, entry->links().size()); 245 IF_EXPECT_EQ(9U, entry->links().size()) {
224 const Link* entry1_alternate_link = entry->GetLinkByType(Link::ALTERNATE); 246 const Link* entry1_alternate_link = entry->GetLinkByType(Link::ALTERNATE);
225 ASSERT_TRUE(entry1_alternate_link); 247 IF_EXPECT_TRUE(entry1_alternate_link) {
226 EXPECT_EQ("https://xml_file_entry_id_alternate_link/", 248 EXPECT_EQ("https://xml_file_entry_id_alternate_link/",
227 entry1_alternate_link->href().spec()); 249 entry1_alternate_link->href().spec());
228 EXPECT_EQ("text/html", entry1_alternate_link->mime_type()); 250 EXPECT_EQ("text/html", entry1_alternate_link->mime_type());
251 }
229 252
230 const Link* entry1_edit_link = entry->GetLinkByType(Link::EDIT_MEDIA); 253 const Link* entry1_edit_link = entry->GetLinkByType(Link::EDIT_MEDIA);
231 ASSERT_TRUE(entry1_edit_link); 254 IF_EXPECT_TRUE(entry1_edit_link) {
232 EXPECT_EQ("https://xml_file_entry_id_edit_media_link/", 255 EXPECT_EQ("https://xml_file_entry_id_edit_media_link/",
233 entry1_edit_link->href().spec()); 256 entry1_edit_link->href().spec());
234 EXPECT_EQ("application/x-tar", entry1_edit_link->mime_type()); 257 EXPECT_EQ("application/x-tar", entry1_edit_link->mime_type());
258 }
235 259
236 const Link* entry1_self_link = entry->GetLinkByType(Link::SELF); 260 const Link* entry1_self_link = entry->GetLinkByType(Link::SELF);
237 ASSERT_TRUE(entry1_self_link); 261 IF_EXPECT_TRUE(entry1_self_link) {
238 EXPECT_EQ("https://xml_file_entry_id_self_link/", 262 EXPECT_EQ("https://xml_file_entry_id_self_link/",
239 entry1_self_link->href().spec()); 263 entry1_self_link->href().spec());
240 EXPECT_EQ("application/atom+xml", entry1_self_link->mime_type()); 264 EXPECT_EQ("application/atom+xml", entry1_self_link->mime_type());
265 EXPECT_EQ("", entry1_self_link->app_id());
266 }
267
268 const Link* entry1_open_with_link = entry->GetLinkByType(Link::OPEN_WITH);
269 IF_EXPECT_TRUE(entry1_open_with_link) {
270 EXPECT_EQ("https://xml_file_entry_open_with_link/",
271 entry1_open_with_link->href().spec());
272 EXPECT_EQ("application/atom+xml", entry1_open_with_link->mime_type());
273 EXPECT_EQ("the_app_id", entry1_open_with_link->app_id());
274 }
275
276 const Link* entry1_unknown_link = entry->GetLinkByType(Link::UNKNOWN);
277 IF_EXPECT_TRUE(entry1_unknown_link) {
278 EXPECT_EQ("https://xml_file_fake_entry_open_with_link/",
279 entry1_unknown_link->href().spec());
280 EXPECT_EQ("application/atom+xml", entry1_unknown_link->mime_type());
281 EXPECT_EQ("", entry1_unknown_link->app_id());
282 }
283 }
241 284
242 // Check a file properties. 285 // Check a file properties.
243 EXPECT_EQ(DocumentEntry::FILE, entry->kind()); 286 EXPECT_EQ(DocumentEntry::FILE, entry->kind());
244 EXPECT_EQ(ASCIIToUTF16("Xml Entry File Name.tar"), entry->filename()); 287 EXPECT_EQ(ASCIIToUTF16("Xml Entry File Name.tar"), entry->filename());
245 EXPECT_EQ(ASCIIToUTF16("Xml Entry Suggested File Name.tar"), 288 EXPECT_EQ(ASCIIToUTF16("Xml Entry Suggested File Name.tar"),
246 entry->suggested_filename()); 289 entry->suggested_filename());
247 EXPECT_EQ("e48f4d5c46a778de263e0e3f4b3d2a7d", entry->file_md5()); 290 EXPECT_EQ("e48f4d5c46a778de263e0e3f4b3d2a7d", entry->file_md5());
248 EXPECT_EQ(26562560, entry->file_size()); 291 EXPECT_EQ(26562560, entry->file_size());
249 } 292 }
250 293
251 TEST_F(GDataParserTest, AccountMetadataFeedParser) { 294 TEST_F(GDataParserTest, AccountMetadataFeedParser) {
252 scoped_ptr<Value> document(LoadJSONFile("account_metadata.json")); 295 scoped_ptr<Value> document(LoadJSONFile("account_metadata.json"));
253 ASSERT_TRUE(document.get()); 296 ASSERT_TRUE(document.get());
254 ASSERT_TRUE(document->GetType() == Value::TYPE_DICTIONARY); 297 ASSERT_EQ(Value::TYPE_DICTIONARY, document->GetType());
255 DictionaryValue* entry_value; 298 DictionaryValue* entry_value = NULL;
256 ASSERT_TRUE(reinterpret_cast<DictionaryValue*>(document.get())->GetDictionary( 299 ASSERT_TRUE(reinterpret_cast<DictionaryValue*>(document.get())->GetDictionary(
257 std::string("entry"), &entry_value)); 300 std::string("entry"), &entry_value));
258 ASSERT_TRUE(entry_value); 301 ASSERT_TRUE(entry_value);
259 302
260 scoped_ptr<AccountMetadataFeed> feed( 303 scoped_ptr<AccountMetadataFeed> feed(
261 AccountMetadataFeed::CreateFrom(*document)); 304 AccountMetadataFeed::CreateFrom(*document));
262 ASSERT_TRUE(feed.get()); 305 ASSERT_TRUE(feed.get());
263 EXPECT_EQ(GG_LONGLONG(6789012345), feed->quota_bytes_used()); 306 EXPECT_EQ(GG_LONGLONG(6789012345), feed->quota_bytes_used());
264 EXPECT_EQ(GG_LONGLONG(9876543210), feed->quota_bytes_total()); 307 EXPECT_EQ(GG_LONGLONG(9876543210), feed->quota_bytes_total());
265 EXPECT_EQ(654321, feed->largest_changestamp()); 308 EXPECT_EQ(654321, feed->largest_changestamp());
266 ASSERT_EQ(2U, feed->installed_apps()->size()); 309 EXPECT_EQ(2U, feed->installed_apps()->size());
267 const InstalledApp* first_app = feed->installed_apps()[0]; 310 const InstalledApp* first_app = feed->installed_apps()[0];
268 const InstalledApp* second_app = feed->installed_apps()[1]; 311 const InstalledApp* second_app = feed->installed_apps()[1];
269 312
270 EXPECT_EQ("Drive App 1", UTF16ToUTF8(first_app->app_name())); 313 IF_EXPECT_TRUE(first_app) {
271 EXPECT_EQ("Drive App Object 1", UTF16ToUTF8(first_app->object_type())); 314 EXPECT_EQ("Drive App 1", UTF16ToUTF8(first_app->app_name()));
272 EXPECT_TRUE(first_app->supports_create()); 315 EXPECT_EQ("Drive App Object 1", UTF16ToUTF8(first_app->object_type()));
273 EXPECT_EQ("https://chrome.google.com/webstore/detail/11111111", 316 EXPECT_TRUE(first_app->supports_create());
274 first_app->GetProductUrl().spec()); 317 EXPECT_EQ("https://chrome.google.com/webstore/detail/11111111",
275 ASSERT_EQ(2U, first_app->primary_mimetypes()->size()); 318 first_app->GetProductUrl().spec());
276 EXPECT_EQ("application/test_type_1", 319 IF_EXPECT_EQ(2U, first_app->primary_mimetypes()->size()) {
277 *first_app->primary_mimetypes()->at(0)); 320 EXPECT_EQ("application/test_type_1",
278 EXPECT_EQ("application/vnd.google-apps.drive-sdk.11111111", 321 *first_app->primary_mimetypes()->at(0));
279 *first_app->primary_mimetypes()->at(1)); 322 EXPECT_EQ("application/vnd.google-apps.drive-sdk.11111111",
280 ASSERT_EQ(1U, first_app->secondary_mimetypes()->size()); 323 *first_app->primary_mimetypes()->at(1));
281 EXPECT_EQ("image/jpeg", *first_app->secondary_mimetypes()->at(0)); 324 }
282 ASSERT_EQ(2U, first_app->primary_extensions()->size()); 325 IF_EXPECT_EQ(1U, first_app->secondary_mimetypes()->size()) {
283 EXPECT_EQ("ext_1", *first_app->primary_extensions()->at(0)); 326 EXPECT_EQ("image/jpeg", *first_app->secondary_mimetypes()->at(0));
284 EXPECT_EQ("ext_2", *first_app->primary_extensions()->at(1)); 327 }
285 ASSERT_EQ(1U, first_app->secondary_extensions()->size()); 328 IF_EXPECT_EQ(2U, first_app->primary_extensions()->size()) {
286 EXPECT_EQ("ext_3", *first_app->secondary_extensions()->at(0)); 329 EXPECT_EQ("ext_1", *first_app->primary_extensions()->at(0));
330 EXPECT_EQ("ext_2", *first_app->primary_extensions()->at(1));
331 }
332 IF_EXPECT_EQ(1U, first_app->secondary_extensions()->size()) {
333 EXPECT_EQ("ext_3", *first_app->secondary_extensions()->at(0));
334 }
335 }
287 336
288 EXPECT_EQ("Drive App 2", UTF16ToUTF8(second_app->app_name())); 337 IF_EXPECT_TRUE(second_app) {
289 EXPECT_EQ("Drive App Object 2", UTF16ToUTF8(second_app->object_type())); 338 EXPECT_EQ("Drive App 2", UTF16ToUTF8(second_app->app_name()));
290 EXPECT_EQ("https://chrome.google.com/webstore/detail/22222222", 339 EXPECT_EQ("Drive App Object 2", UTF16ToUTF8(second_app->object_type()));
291 second_app->GetProductUrl().spec()); 340 EXPECT_EQ("https://chrome.google.com/webstore/detail/22222222",
292 EXPECT_FALSE(second_app->supports_create()); 341 second_app->GetProductUrl().spec());
293 EXPECT_EQ(2U, second_app->primary_mimetypes()->size()); 342 EXPECT_FALSE(second_app->supports_create());
294 EXPECT_EQ(0U, second_app->secondary_mimetypes()->size()); 343 EXPECT_EQ(2U, second_app->primary_mimetypes()->size());
295 EXPECT_EQ(1U, second_app->primary_extensions()->size()); 344 EXPECT_EQ(0U, second_app->secondary_mimetypes()->size());
296 EXPECT_EQ(0U, second_app->secondary_extensions()->size()); 345 EXPECT_EQ(1U, second_app->primary_extensions()->size());
346 EXPECT_EQ(0U, second_app->secondary_extensions()->size());
347 }
297 } 348 }
298 349
299 // Test file extension checking in DocumentEntry::HasDocumentExtension(). 350 // Test file extension checking in DocumentEntry::HasDocumentExtension().
300 TEST_F(GDataParserTest, DocumentEntryHasDocumentExtension) { 351 TEST_F(GDataParserTest, DocumentEntryHasDocumentExtension) {
301 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( 352 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension(
302 FilePath(FILE_PATH_LITERAL("Test.gdoc")))); 353 FilePath(FILE_PATH_LITERAL("Test.gdoc"))));
303 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( 354 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension(
304 FilePath(FILE_PATH_LITERAL("Test.gsheet")))); 355 FilePath(FILE_PATH_LITERAL("Test.gsheet"))));
305 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( 356 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension(
306 FilePath(FILE_PATH_LITERAL("Test.gslides")))); 357 FilePath(FILE_PATH_LITERAL("Test.gslides"))));
307 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( 358 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension(
308 FilePath(FILE_PATH_LITERAL("Test.gdraw")))); 359 FilePath(FILE_PATH_LITERAL("Test.gdraw"))));
309 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( 360 EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension(
310 FilePath(FILE_PATH_LITERAL("Test.gtable")))); 361 FilePath(FILE_PATH_LITERAL("Test.gtable"))));
311 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( 362 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension(
312 FilePath(FILE_PATH_LITERAL("Test.tar.gz")))); 363 FilePath(FILE_PATH_LITERAL("Test.tar.gz"))));
313 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( 364 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension(
314 FilePath(FILE_PATH_LITERAL("Test.txt")))); 365 FilePath(FILE_PATH_LITERAL("Test.txt"))));
315 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( 366 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension(
316 FilePath(FILE_PATH_LITERAL("Test")))); 367 FilePath(FILE_PATH_LITERAL("Test"))));
317 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( 368 EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension(
318 FilePath(FILE_PATH_LITERAL("")))); 369 FilePath(FILE_PATH_LITERAL(""))));
319 } 370 }
320 371
321 } // namespace gdata 372 } // namespace gdata
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698