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

Unified Diff: chrome/browser/google_apis/gdata_wapi_parser_unittest.cc

Issue 96413002: Move c/b/google_apis to google_apis/drive. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 7 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/google_apis/gdata_wapi_parser.cc ('k') | chrome/browser/google_apis/gdata_wapi_requests.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/google_apis/gdata_wapi_parser_unittest.cc
diff --git a/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc b/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc
deleted file mode 100644
index 4c5d6117c9aec4a6d1335ba181f05c318f4127ac..0000000000000000000000000000000000000000
--- a/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc
+++ /dev/null
@@ -1,389 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "chrome/browser/google_apis/gdata_wapi_parser.h"
-
-#include <string>
-
-#include "base/files/file_path.h"
-#include "base/json/json_file_value_serializer.h"
-#include "base/logging.h"
-#include "base/time/time.h"
-#include "base/values.h"
-#include "chrome/browser/google_apis/test_util.h"
-#include "chrome/browser/google_apis/time_util.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace google_apis {
-
-// TODO(nhiroki): Move json files to out of 'chromeos' directory
-// (http://crbug.com/149788).
-// Test document feed parsing.
-TEST(GDataWAPIParserTest, ResourceListJsonParser) {
- std::string error;
- scoped_ptr<base::Value> document =
- test_util::LoadJSONFile("gdata/basic_feed.json");
- ASSERT_TRUE(document.get());
- ASSERT_EQ(base::Value::TYPE_DICTIONARY, document->GetType());
- scoped_ptr<ResourceList> feed(ResourceList::ExtractAndParse(*document));
- ASSERT_TRUE(feed.get());
-
- base::Time update_time;
- ASSERT_TRUE(util::GetTimeFromString("2011-12-14T01:03:21.151Z",
- &update_time));
-
- EXPECT_EQ(1, feed->start_index());
- EXPECT_EQ(1000, feed->items_per_page());
- EXPECT_EQ(update_time, feed->updated_time());
-
- // Check authors.
- ASSERT_EQ(1U, feed->authors().size());
- EXPECT_EQ("tester", feed->authors()[0]->name());
- EXPECT_EQ("tester@testing.com", feed->authors()[0]->email());
-
- // Check links.
- ASSERT_EQ(6U, feed->links().size());
- const Link* self_link = feed->GetLinkByType(Link::LINK_SELF);
- ASSERT_TRUE(self_link);
- EXPECT_EQ("https://self_link/", self_link->href().spec());
- EXPECT_EQ("application/atom+xml", self_link->mime_type());
-
- const Link* resumable_link =
- feed->GetLinkByType(Link::LINK_RESUMABLE_CREATE_MEDIA);
- ASSERT_TRUE(resumable_link);
- EXPECT_EQ("https://resumable_create_media_link/",
- resumable_link->href().spec());
- EXPECT_EQ("application/atom+xml", resumable_link->mime_type());
-
- // Check entries.
- ASSERT_EQ(4U, feed->entries().size());
-
- // Check a folder entry.
- const ResourceEntry* folder_entry = feed->entries()[0];
- ASSERT_TRUE(folder_entry);
- EXPECT_EQ(ENTRY_KIND_FOLDER, folder_entry->kind());
- EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", folder_entry->etag());
- EXPECT_EQ("folder:sub_sub_directory_folder_id", folder_entry->resource_id());
- EXPECT_EQ("https://1_folder_id", folder_entry->id());
- EXPECT_EQ("Entry 1 Title", folder_entry->title());
- base::Time entry1_update_time;
- base::Time entry1_publish_time;
- ASSERT_TRUE(util::GetTimeFromString("2011-04-01T18:34:08.234Z",
- &entry1_update_time));
- ASSERT_TRUE(util::GetTimeFromString("2010-11-07T05:03:54.719Z",
- &entry1_publish_time));
- EXPECT_EQ(entry1_update_time, folder_entry->updated_time());
- EXPECT_EQ(entry1_publish_time, folder_entry->published_time());
-
- ASSERT_EQ(1U, folder_entry->authors().size());
- EXPECT_EQ("entry_tester", folder_entry->authors()[0]->name());
- EXPECT_EQ("entry_tester@testing.com", folder_entry->authors()[0]->email());
- EXPECT_EQ("https://1_folder_content_url/",
- folder_entry->download_url().spec());
- EXPECT_EQ("application/atom+xml;type=feed",
- folder_entry->content_mime_type());
-
- ASSERT_EQ(1U, folder_entry->resource_links().size());
- const ResourceLink* feed_link = folder_entry->resource_links()[0];
- ASSERT_TRUE(feed_link);
- ASSERT_EQ(ResourceLink::FEED_LINK_ACL, feed_link->type());
-
- const Link* entry1_alternate_link =
- folder_entry->GetLinkByType(Link::LINK_ALTERNATE);
- ASSERT_TRUE(entry1_alternate_link);
- EXPECT_EQ("https://1_folder_alternate_link/",
- entry1_alternate_link->href().spec());
- EXPECT_EQ("text/html", entry1_alternate_link->mime_type());
-
- const Link* entry1_edit_link = folder_entry->GetLinkByType(Link::LINK_EDIT);
- ASSERT_TRUE(entry1_edit_link);
- EXPECT_EQ("https://1_edit_link/", entry1_edit_link->href().spec());
- EXPECT_EQ("application/atom+xml", entry1_edit_link->mime_type());
-
- // Check a file entry.
- const ResourceEntry* file_entry = feed->entries()[1];
- ASSERT_TRUE(file_entry);
- EXPECT_EQ(ENTRY_KIND_FILE, file_entry->kind());
- EXPECT_EQ("filename.m4a", file_entry->filename());
- EXPECT_EQ("sugg_file_name.m4a", file_entry->suggested_filename());
- EXPECT_EQ("3b4382ebefec6e743578c76bbd0575ce", file_entry->file_md5());
- EXPECT_EQ(892721, file_entry->file_size());
- const Link* file_parent_link = file_entry->GetLinkByType(Link::LINK_PARENT);
- ASSERT_TRUE(file_parent_link);
- EXPECT_EQ("https://file_link_parent/", file_parent_link->href().spec());
- EXPECT_EQ("application/atom+xml", file_parent_link->mime_type());
- EXPECT_EQ("Medical", file_parent_link->title());
- const Link* file_open_with_link =
- file_entry->GetLinkByType(Link::LINK_OPEN_WITH);
- ASSERT_TRUE(file_open_with_link);
- EXPECT_EQ("https://xml_file_entry_open_with_link/",
- file_open_with_link->href().spec());
- EXPECT_EQ("application/atom+xml", file_open_with_link->mime_type());
- EXPECT_EQ("the_app_id", file_open_with_link->app_id());
- EXPECT_EQ(654321, file_entry->changestamp());
-
- const Link* file_unknown_link = file_entry->GetLinkByType(Link::LINK_UNKNOWN);
- ASSERT_TRUE(file_unknown_link);
- EXPECT_EQ("https://xml_file_fake_entry_open_with_link/",
- file_unknown_link->href().spec());
- EXPECT_EQ("application/atom+xml", file_unknown_link->mime_type());
- EXPECT_EQ("", file_unknown_link->app_id());
-
- // Check a file entry.
- const ResourceEntry* resource_entry = feed->entries()[2];
- ASSERT_TRUE(resource_entry);
- EXPECT_EQ(ENTRY_KIND_DOCUMENT, resource_entry->kind());
- EXPECT_TRUE(resource_entry->is_hosted_document());
- EXPECT_TRUE(resource_entry->is_google_document());
- EXPECT_FALSE(resource_entry->is_external_document());
-
- // Check an external document entry.
- const ResourceEntry* app_entry = feed->entries()[3];
- ASSERT_TRUE(app_entry);
- EXPECT_EQ(ENTRY_KIND_EXTERNAL_APP, app_entry->kind());
- EXPECT_TRUE(app_entry->is_hosted_document());
- EXPECT_TRUE(app_entry->is_external_document());
- EXPECT_FALSE(app_entry->is_google_document());
-}
-
-
-// Test document feed parsing.
-TEST(GDataWAPIParserTest, ResourceEntryJsonParser) {
- std::string error;
- scoped_ptr<base::Value> document =
- test_util::LoadJSONFile("gdata/file_entry.json");
- ASSERT_TRUE(document.get());
- ASSERT_EQ(base::Value::TYPE_DICTIONARY, document->GetType());
- scoped_ptr<ResourceEntry> entry(ResourceEntry::ExtractAndParse(*document));
- ASSERT_TRUE(entry.get());
-
- EXPECT_EQ(ENTRY_KIND_FILE, entry->kind());
- EXPECT_EQ("\"HhMOFgxXHit7ImBr\"", entry->etag());
- EXPECT_EQ("file:2_file_resource_id", entry->resource_id());
- EXPECT_EQ("2_file_id", entry->id());
- EXPECT_EQ("File 1.mp3", entry->title());
- base::Time entry1_update_time;
- base::Time entry1_publish_time;
- ASSERT_TRUE(util::GetTimeFromString("2011-12-14T00:40:47.330Z",
- &entry1_update_time));
- ASSERT_TRUE(util::GetTimeFromString("2011-12-13T00:40:47.330Z",
- &entry1_publish_time));
- EXPECT_EQ(entry1_update_time, entry->updated_time());
- EXPECT_EQ(entry1_publish_time, entry->published_time());
-
- EXPECT_EQ(1U, entry->authors().size());
- EXPECT_EQ("tester", entry->authors()[0]->name());
- EXPECT_EQ("tester@testing.com", entry->authors()[0]->email());
- EXPECT_EQ("https://file_content_url/",
- entry->download_url().spec());
- EXPECT_EQ("audio/mpeg",
- entry->content_mime_type());
-
- // Check feed links.
- ASSERT_EQ(1U, entry->resource_links().size());
- const ResourceLink* feed_link_1 = entry->resource_links()[0];
- ASSERT_TRUE(feed_link_1);
- EXPECT_EQ(ResourceLink::FEED_LINK_REVISIONS, feed_link_1->type());
-
- // Check links.
- ASSERT_EQ(8U, entry->links().size());
- const Link* entry1_alternate_link =
- entry->GetLinkByType(Link::LINK_ALTERNATE);
- ASSERT_TRUE(entry1_alternate_link);
- EXPECT_EQ("https://file_link_alternate/",
- entry1_alternate_link->href().spec());
- EXPECT_EQ("text/html", entry1_alternate_link->mime_type());
-
- const Link* entry1_edit_link = entry->GetLinkByType(Link::LINK_EDIT_MEDIA);
- ASSERT_TRUE(entry1_edit_link);
- EXPECT_EQ("https://file_edit_media/",
- entry1_edit_link->href().spec());
- EXPECT_EQ("audio/mpeg", entry1_edit_link->mime_type());
-
- const Link* entry1_self_link = entry->GetLinkByType(Link::LINK_SELF);
- ASSERT_TRUE(entry1_self_link);
- EXPECT_EQ("https://file1_link_self/file%3A2_file_resource_id",
- entry1_self_link->href().spec());
- EXPECT_EQ("application/atom+xml", entry1_self_link->mime_type());
- EXPECT_EQ("", entry1_self_link->app_id());
-
- const Link* entry1_open_with_link =
- entry->GetLinkByType(Link::LINK_OPEN_WITH);
- ASSERT_TRUE(entry1_open_with_link);
- EXPECT_EQ("https://entry1_open_with_link/",
- entry1_open_with_link->href().spec());
- EXPECT_EQ("application/atom+xml", entry1_open_with_link->mime_type());
- EXPECT_EQ("the_app_id", entry1_open_with_link->app_id());
-
- const Link* entry1_unknown_link = entry->GetLinkByType(Link::LINK_UNKNOWN);
- ASSERT_TRUE(entry1_unknown_link);
- EXPECT_EQ("https://entry1_fake_entry_open_with_link/",
- entry1_unknown_link->href().spec());
- EXPECT_EQ("application/atom+xml", entry1_unknown_link->mime_type());
- EXPECT_EQ("", entry1_unknown_link->app_id());
-
- // Check a file properties.
- EXPECT_EQ(ENTRY_KIND_FILE, entry->kind());
- EXPECT_EQ("File 1.mp3", entry->filename());
- EXPECT_EQ("File 1.mp3", entry->suggested_filename());
- EXPECT_EQ("3b4382ebefec6e743578c76bbd0575ce", entry->file_md5());
- EXPECT_EQ(892721, entry->file_size());
-
- // WAPI doesn't provide image metadata, but these fields are available
- // since this class can wrap data received from Drive API (via a converter).
- EXPECT_EQ(-1, entry->image_width());
- EXPECT_EQ(-1, entry->image_height());
- EXPECT_EQ(-1, entry->image_rotation());
-}
-
-TEST(GDataWAPIParserTest, AccountMetadataParser) {
- scoped_ptr<base::Value> document =
- test_util::LoadJSONFile("gdata/account_metadata.json");
- ASSERT_TRUE(document.get());
- base::DictionaryValue* document_dict = NULL;
- base::DictionaryValue* entry_value = NULL;
- ASSERT_TRUE(document->GetAsDictionary(&document_dict));
- ASSERT_TRUE(document_dict->GetDictionary(std::string("entry"), &entry_value));
- ASSERT_TRUE(entry_value);
-
- scoped_ptr<AccountMetadata> metadata(
- AccountMetadata::CreateFrom(*document));
- ASSERT_TRUE(metadata.get());
- EXPECT_EQ(GG_LONGLONG(6789012345), metadata->quota_bytes_used());
- EXPECT_EQ(GG_LONGLONG(9876543210), metadata->quota_bytes_total());
- EXPECT_EQ(654321, metadata->largest_changestamp());
- EXPECT_EQ(2U, metadata->installed_apps().size());
- const InstalledApp* first_app = metadata->installed_apps()[0];
- const InstalledApp* second_app = metadata->installed_apps()[1];
-
- ASSERT_TRUE(first_app);
- EXPECT_EQ("Drive App 1", first_app->app_name());
- EXPECT_EQ("Drive App Object 1", first_app->object_type());
- EXPECT_TRUE(first_app->supports_create());
- EXPECT_EQ("https://chrome.google.com/webstore/detail/abcdefabcdef",
- first_app->GetProductUrl().spec());
-
- ASSERT_EQ(2U, first_app->primary_mimetypes().size());
- EXPECT_EQ("application/test_type_1",
- *first_app->primary_mimetypes()[0]);
- EXPECT_EQ("application/vnd.google-apps.drive-sdk.11111111",
- *first_app->primary_mimetypes()[1]);
-
- ASSERT_EQ(1U, first_app->secondary_mimetypes().size());
- EXPECT_EQ("image/jpeg", *first_app->secondary_mimetypes()[0]);
-
- ASSERT_EQ(2U, first_app->primary_extensions().size());
- EXPECT_EQ("ext_1", *first_app->primary_extensions()[0]);
- EXPECT_EQ("ext_2", *first_app->primary_extensions()[1]);
-
- ASSERT_EQ(1U, first_app->secondary_extensions().size());
- EXPECT_EQ("ext_3", *first_app->secondary_extensions()[0]);
-
- ASSERT_EQ(1U, first_app->app_icons().size());
- EXPECT_EQ(AppIcon::ICON_DOCUMENT, first_app->app_icons()[0]->category());
- EXPECT_EQ(16, first_app->app_icons()[0]->icon_side_length());
- GURL icon_url = first_app->app_icons()[0]->GetIconURL();
- EXPECT_EQ("https://www.google.com/images/srpr/logo3w.png", icon_url.spec());
- InstalledApp::IconList icons =
- first_app->GetIconsForCategory(AppIcon::ICON_DOCUMENT);
- EXPECT_EQ("https://www.google.com/images/srpr/logo3w.png",
- icons[0].second.spec());
- icons = first_app->GetIconsForCategory(AppIcon::ICON_SHARED_DOCUMENT);
- EXPECT_TRUE(icons.empty());
-
- ASSERT_TRUE(second_app);
- EXPECT_EQ("Drive App 2", second_app->app_name());
- EXPECT_EQ("Drive App Object 2", second_app->object_type());
- EXPECT_EQ("https://chrome.google.com/webstore/detail/deadbeefdeadbeef",
- second_app->GetProductUrl().spec());
- EXPECT_FALSE(second_app->supports_create());
- EXPECT_EQ(2U, second_app->primary_mimetypes().size());
- EXPECT_EQ(0U, second_app->secondary_mimetypes().size());
- EXPECT_EQ(1U, second_app->primary_extensions().size());
- EXPECT_EQ(0U, second_app->secondary_extensions().size());
-}
-
-TEST(GDataWAPIParserTest, ClassifyEntryKindByFileExtension) {
- EXPECT_EQ(
- ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.gdoc"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.gsheet"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.gslides"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.gdraw"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.gtable"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_EXTERNAL_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.glink"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.tar.gz"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test.txt"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath(FILE_PATH_LITERAL("Test"))));
- EXPECT_EQ(
- ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKindByFileExtension(
- base::FilePath()));
-}
-
-TEST(GDataWAPIParserTest, ResourceEntryClassifyEntryKind) {
- EXPECT_EQ(ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_UNKNOWN));
- EXPECT_EQ(ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_ITEM));
- EXPECT_EQ(ResourceEntry::KIND_OF_NONE,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_SITE));
- EXPECT_EQ(ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_DOCUMENT));
- EXPECT_EQ(ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_SPREADSHEET));
- EXPECT_EQ(ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_PRESENTATION));
- EXPECT_EQ(ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_DRAWING));
- EXPECT_EQ(ResourceEntry::KIND_OF_GOOGLE_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_TABLE));
- EXPECT_EQ(ResourceEntry::KIND_OF_EXTERNAL_DOCUMENT |
- ResourceEntry::KIND_OF_HOSTED_DOCUMENT,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_EXTERNAL_APP));
- EXPECT_EQ(ResourceEntry::KIND_OF_FOLDER,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_FOLDER));
- EXPECT_EQ(ResourceEntry::KIND_OF_FILE,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_FILE));
- EXPECT_EQ(ResourceEntry::KIND_OF_FILE,
- ResourceEntry::ClassifyEntryKind(ENTRY_KIND_PDF));
-}
-
-} // namespace google_apis
« no previous file with comments | « chrome/browser/google_apis/gdata_wapi_parser.cc ('k') | chrome/browser/google_apis/gdata_wapi_requests.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698