diff options
author | nhiroki@chromium.org <nhiroki@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-17 06:54:24 +0000 |
---|---|---|
committer | nhiroki@chromium.org <nhiroki@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-17 06:54:24 +0000 |
commit | 77c3fcde3f4fce9d1dca8a9b917d4e0a08c1ae2a (patch) | |
tree | 1b10a5937b64c16208d394c9c8a40f88702a7370 /chrome/browser/google_apis/gdata_wapi_parser_unittest.cc | |
parent | 22f5c727b66c8d4802f6a0267d35d00a307a9de0 (diff) | |
download | chromium_src-77c3fcde3f4fce9d1dca8a9b917d4e0a08c1ae2a.zip chromium_src-77c3fcde3f4fce9d1dca8a9b917d4e0a08c1ae2a.tar.gz chromium_src-77c3fcde3f4fce9d1dca8a9b917d4e0a08c1ae2a.tar.bz2 |
Move Drive API files from chrome/browser/chromeos/gdata to chrome/browser/google_apis
Remaining files will be moved in later CLs.
BUG=127855
TEST=pass all existing tests
TBR=estade@chromium.org, ben@chromium.org
Review URL: https://chromiumcodereview.appspot.com/10920091
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@157086 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/google_apis/gdata_wapi_parser_unittest.cc')
-rw-r--r-- | chrome/browser/google_apis/gdata_wapi_parser_unittest.cc | 396 |
1 files changed, 396 insertions, 0 deletions
diff --git a/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc b/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc new file mode 100644 index 0000000..cf65254 --- /dev/null +++ b/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc @@ -0,0 +1,396 @@ +// 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 "base/file_path.h" +#include "base/file_util.h" +#include "base/json/json_file_value_serializer.h" +#include "base/logging.h" +#include "base/path_service.h" +#include "base/string16.h" +#include "base/time.h" +#include "base/utf_string_conversions.h" +#include "base/values.h" +#include "chrome/browser/google_apis/gdata_test_util.h" +#include "chrome/browser/google_apis/gdata_util.h" +#include "chrome/common/chrome_paths.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "third_party/libxml/chromium/libxml_utils.h" + +using base::Value; +using base::DictionaryValue; +using base::ListValue; + +namespace gdata { + +class GDataWAPIParserTest : public testing::Test { + protected: + static DocumentEntry* LoadDocumentEntryFromXml(const std::string& filename) { + FilePath path; + std::string error; + PathService::Get(chrome::DIR_TEST_DATA, &path); + path = path.AppendASCII("chromeos") + .AppendASCII("gdata") + .AppendASCII(filename.c_str()); + EXPECT_TRUE(file_util::PathExists(path)) << + "Couldn't find " << path.value(); + std::string contents; + EXPECT_TRUE(file_util::ReadFileToString(path, &contents)); + XmlReader reader; + if (!reader.Load(contents)) { + NOTREACHED() << "Invalid xml:\n" << contents; + return NULL; + } + scoped_ptr<DocumentEntry> entry; + while (reader.Read()) { + if (reader.NodeName() == "entry") { + entry.reset(DocumentEntry::CreateFromXml(&reader)); + break; + } + } + return entry.release(); + } +}; + +// TODO(nhiroki): Make it possible to run these tests on any platforms after +// moving json files to out of 'chromeos' directory (http://crbug.com/149788). +#if defined(OS_CHROMEOS) +// Test document feed parsing. +TEST_F(GDataWAPIParserTest, DocumentFeedJsonParser) { + std::string error; + scoped_ptr<Value> document = + test_util::LoadJSONFile("gdata/basic_feed.json"); + ASSERT_TRUE(document.get()); + ASSERT_EQ(Value::TYPE_DICTIONARY, document->GetType()); + scoped_ptr<DocumentFeed> feed(DocumentFeed::ExtractAndParse(*document)); + ASSERT_TRUE(feed.get()); + + base::Time update_time; + ASSERT_TRUE(gdata::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(ASCIIToUTF16("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 DocumentEntry* 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(ASCIIToUTF16("Entry 1 Title"), folder_entry->title()); + base::Time entry1_update_time; + base::Time entry1_publish_time; + ASSERT_TRUE(gdata::util::GetTimeFromString("2011-04-01T18:34:08.234Z", + &entry1_update_time)); + ASSERT_TRUE(gdata::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(ASCIIToUTF16("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->content_url().spec()); + EXPECT_EQ("application/atom+xml;type=feed", + folder_entry->content_mime_type()); + + ASSERT_EQ(1U, folder_entry->feed_links().size()); + const FeedLink* feed_link = folder_entry->feed_links()[0]; + ASSERT_TRUE(feed_link); + ASSERT_EQ(FeedLink::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 DocumentEntry* file_entry = feed->entries()[1]; + ASSERT_TRUE(file_entry); + EXPECT_EQ(ENTRY_KIND_FILE, file_entry->kind()); + EXPECT_EQ(ASCIIToUTF16("filename.m4a"), file_entry->filename()); + EXPECT_EQ(ASCIIToUTF16("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(ASCIIToUTF16("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()); + + 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 DocumentEntry* document_entry = feed->entries()[2]; + ASSERT_TRUE(document_entry); + EXPECT_EQ(ENTRY_KIND_DOCUMENT, document_entry->kind()); + EXPECT_TRUE(document_entry->is_hosted_document()); + EXPECT_TRUE(document_entry->is_google_document()); + EXPECT_FALSE(document_entry->is_external_document()); + + // Check an external document entry. + const DocumentEntry* 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_F(GDataWAPIParserTest, DocumentEntryXmlParser) { + scoped_ptr<DocumentEntry> entry(LoadDocumentEntryFromXml("entry.xml")); + ASSERT_TRUE(entry.get()); + + EXPECT_EQ(ENTRY_KIND_FILE, entry->kind()); + EXPECT_EQ("\"HhMOFgcNHSt7ImBr\"", entry->etag()); + EXPECT_EQ("file:xml_file_resource_id", entry->resource_id()); + EXPECT_EQ("https://xml_file_id", entry->id()); + EXPECT_EQ(ASCIIToUTF16("Xml Entry File Title.tar"), entry->title()); + base::Time entry1_update_time; + base::Time entry1_publish_time; + ASSERT_TRUE(gdata::util::GetTimeFromString("2011-04-01T18:34:08.234Z", + &entry1_update_time)); + ASSERT_TRUE(gdata::util::GetTimeFromString("2010-11-07T05:03:54.719Z", + &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(ASCIIToUTF16("entry_tester"), entry->authors()[0]->name()); + EXPECT_EQ("entry_tester@testing.com", entry->authors()[0]->email()); + EXPECT_EQ("https://1_xml_file_entry_content_url/", + entry->content_url().spec()); + EXPECT_EQ("application/x-tar", + entry->content_mime_type()); + + // Check feed links. + ASSERT_EQ(2U, entry->feed_links().size()); + const FeedLink* feed_link_1 = entry->feed_links()[0]; + ASSERT_TRUE(feed_link_1); + EXPECT_EQ(FeedLink::FEED_LINK_ACL, feed_link_1->type()); + + const FeedLink* feed_link_2 = entry->feed_links()[1]; + ASSERT_TRUE(feed_link_2); + EXPECT_EQ(FeedLink::FEED_LINK_REVISIONS, feed_link_2->type()); + + // Check links. + ASSERT_EQ(9U, entry->links().size()); + const Link* entry1_alternate_link = + entry->GetLinkByType(Link::LINK_ALTERNATE); + ASSERT_TRUE(entry1_alternate_link); + EXPECT_EQ("https://xml_file_entry_id_alternate_link/", + 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://xml_file_entry_id_edit_media_link/", + entry1_edit_link->href().spec()); + EXPECT_EQ("application/x-tar", entry1_edit_link->mime_type()); + + const Link* entry1_self_link = entry->GetLinkByType(Link::LINK_SELF); + ASSERT_TRUE(entry1_self_link); + EXPECT_EQ("https://xml_file_entry_id_self_link/", + 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://xml_file_entry_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://xml_file_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(ASCIIToUTF16("Xml Entry File Name.tar"), entry->filename()); + EXPECT_EQ(ASCIIToUTF16("Xml Entry Suggested File Name.tar"), + entry->suggested_filename()); + EXPECT_EQ("e48f4d5c46a778de263e0e3f4b3d2a7d", entry->file_md5()); + EXPECT_EQ(26562560, entry->file_size()); +} + +TEST_F(GDataWAPIParserTest, AccountMetadataFeedParser) { + scoped_ptr<Value> document = + test_util::LoadJSONFile("gdata/account_metadata.json"); + ASSERT_TRUE(document.get()); + ASSERT_EQ(Value::TYPE_DICTIONARY, document->GetType()); + DictionaryValue* entry_value = NULL; + ASSERT_TRUE(reinterpret_cast<DictionaryValue*>(document.get())->GetDictionary( + std::string("entry"), &entry_value)); + ASSERT_TRUE(entry_value); + + scoped_ptr<AccountMetadataFeed> feed( + AccountMetadataFeed::CreateFrom(*document)); + ASSERT_TRUE(feed.get()); + EXPECT_EQ(GG_LONGLONG(6789012345), feed->quota_bytes_used()); + EXPECT_EQ(GG_LONGLONG(9876543210), feed->quota_bytes_total()); + EXPECT_EQ(654321, feed->largest_changestamp()); + EXPECT_EQ(2U, feed->installed_apps().size()); + const InstalledApp* first_app = feed->installed_apps()[0]; + const InstalledApp* second_app = feed->installed_apps()[1]; + + ASSERT_TRUE(first_app); + EXPECT_EQ("Drive App 1", UTF16ToUTF8(first_app->app_name())); + EXPECT_EQ("Drive App Object 1", UTF16ToUTF8(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", UTF16ToUTF8(second_app->app_name())); + EXPECT_EQ("Drive App Object 2", UTF16ToUTF8(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()); +} +#endif // OS_CHROMEOS + +// Test file extension checking in DocumentEntry::HasDocumentExtension(). +TEST_F(GDataWAPIParserTest, DocumentEntryHasDocumentExtension) { + EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.gdoc")))); + EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.gsheet")))); + EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.gslides")))); + EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.gdraw")))); + EXPECT_TRUE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.gtable")))); + EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.tar.gz")))); + EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test.txt")))); + EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("Test")))); + EXPECT_FALSE(DocumentEntry::HasHostedDocumentExtension( + FilePath(FILE_PATH_LITERAL("")))); +} + +TEST_F(GDataWAPIParserTest, DocumentEntryClassifyEntryKind) { + EXPECT_EQ(DocumentEntry::KIND_OF_NONE, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_UNKNOWN)); + EXPECT_EQ(DocumentEntry::KIND_OF_NONE, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_ITEM)); + EXPECT_EQ(DocumentEntry::KIND_OF_NONE, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_SITE)); + EXPECT_EQ(DocumentEntry::KIND_OF_GOOGLE_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_DOCUMENT)); + EXPECT_EQ(DocumentEntry::KIND_OF_GOOGLE_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_SPREADSHEET)); + EXPECT_EQ(DocumentEntry::KIND_OF_GOOGLE_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_PRESENTATION)); + EXPECT_EQ(DocumentEntry::KIND_OF_GOOGLE_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_DRAWING)); + EXPECT_EQ(DocumentEntry::KIND_OF_GOOGLE_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_TABLE)); + EXPECT_EQ(DocumentEntry::KIND_OF_EXTERNAL_DOCUMENT | + DocumentEntry::KIND_OF_HOSTED_DOCUMENT, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_EXTERNAL_APP)); + EXPECT_EQ(DocumentEntry::KIND_OF_FOLDER, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_FOLDER)); + EXPECT_EQ(DocumentEntry::KIND_OF_FILE, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_FILE)); + EXPECT_EQ(DocumentEntry::KIND_OF_FILE, + DocumentEntry::ClassifyEntryKind(ENTRY_KIND_PDF)); +} + +} // namespace gdata |