summaryrefslogtreecommitdiffstats
path: root/chrome/browser/google_apis/gdata_wapi_parser_unittest.cc
diff options
context:
space:
mode:
authornhiroki@chromium.org <nhiroki@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-09-17 06:54:24 +0000
committernhiroki@chromium.org <nhiroki@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-09-17 06:54:24 +0000
commit77c3fcde3f4fce9d1dca8a9b917d4e0a08c1ae2a (patch)
tree1b10a5937b64c16208d394c9c8a40f88702a7370 /chrome/browser/google_apis/gdata_wapi_parser_unittest.cc
parent22f5c727b66c8d4802f6a0267d35d00a307a9de0 (diff)
downloadchromium_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.cc396
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