Chromium Code Reviews| Index: chrome/service/cloud_print/cloud_print_helpers_unittest.cc |
| diff --git a/chrome/service/cloud_print/cloud_print_helpers_unittest.cc b/chrome/service/cloud_print/cloud_print_helpers_unittest.cc |
| index 429b3f55f84fd6283740b1f81280606bfc8e11d9..6ed24ab1aa25262ce8c050b5e976e13c8f03aca2 100644 |
| --- a/chrome/service/cloud_print/cloud_print_helpers_unittest.cc |
| +++ b/chrome/service/cloud_print/cloud_print_helpers_unittest.cc |
| @@ -4,101 +4,97 @@ |
| #include "chrome/service/cloud_print/cloud_print_helpers.h" |
| +#include "base/md5.h" |
| #include "base/stringprintf.h" |
| +#include "base/sys_info.h" |
| +#include "chrome/common/chrome_version_info.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| -namespace { |
| +namespace cloud_print { |
| -void CheckURLs(const GURL& server_base_url) { |
| - GURL url = CloudPrintHelpers::GetUrlForPrinterRegistration(server_base_url); |
| +void CheckJobStatusURLs(const GURL& server_base_url) { |
|
msw
2012/11/29 19:57:36
ditto optional nit: put locals in anon namespace i
Chen Yu
2012/11/30 17:35:46
Done.
|
| std::string expected_url_base = server_base_url.spec(); |
| - if (expected_url_base[expected_url_base.length() - 1] != '/') { |
| + if (expected_url_base[expected_url_base.length() - 1] != '/') |
| expected_url_base += "/"; |
| - } |
| - std::string expected_url = base::StringPrintf("%sregister", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForPrinterUpdate(server_base_url, |
| - "printeridfoo"); |
| - expected_url = base::StringPrintf("%supdate?printerid=printeridfoo", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForPrinterDelete(server_base_url, |
| - "printeridbar", "deleted"); |
| - expected_url = base::StringPrintf( |
| - "%sdelete?printerid=printeridbar&reason=deleted", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForPrinterList(server_base_url, "demoproxy"); |
| - expected_url = base::StringPrintf("%slist?proxy=demoproxy", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForJobFetch(server_base_url, |
| - "myprinter", |
| - "nogoodreason"); |
| - expected_url = base::StringPrintf( |
| - "%sfetch?printerid=myprinter&deb=nogoodreason", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForJobStatusUpdate( |
| - server_base_url, "12345678", cloud_print::PRINT_JOB_STATUS_IN_PROGRESS); |
| - expected_url = base::StringPrintf( |
| - "%scontrol?jobid=12345678&status=IN_PROGRESS", expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForJobStatusUpdate( |
| - server_base_url, "12345678", cloud_print::PRINT_JOB_STATUS_ERROR); |
| - expected_url = base::StringPrintf("%scontrol?jobid=12345678&status=ERROR", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForJobStatusUpdate( |
| - server_base_url, "12345678", cloud_print::PRINT_JOB_STATUS_COMPLETED); |
| - expected_url = base::StringPrintf("%scontrol?jobid=12345678&status=DONE", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - cloud_print::PrintJobDetails details; |
| - details.status = cloud_print::PRINT_JOB_STATUS_IN_PROGRESS; |
| + |
| + EXPECT_EQ(base::StringPrintf("%scontrol?jobid=87654321&status=ERROR", |
| + expected_url_base.c_str()), |
| + GetUrlForJobStatusUpdate(server_base_url, "87654321", |
| + cloud_print::PRINT_JOB_STATUS_ERROR).spec()); |
| + |
| + PrintJobDetails details; |
| + details.status = PRINT_JOB_STATUS_IN_PROGRESS; |
| details.platform_status_flags = 2; |
| details.status_message = "Out of Paper"; |
| details.total_pages = 345; |
| details.pages_printed = 47; |
| - url = CloudPrintHelpers::GetUrlForJobStatusUpdate(server_base_url, |
| - "87654321", details); |
| - expected_url = base::StringPrintf( |
| - "%scontrol?jobid=87654321&status=IN_PROGRESS&code=2" |
| - "&message=Out%%20of%%20Paper&numpages=345&pagesprinted=47", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForUserMessage(server_base_url, |
| - "blahmessageid"); |
| - expected_url = base::StringPrintf("%smessage?code=blahmessageid", |
| - expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| - |
| - url = CloudPrintHelpers::GetUrlForGetAuthCode( |
| - server_base_url, |
| - "fooclientid.apps.googleusercontent.com", |
| - "test_proxy"); |
| - expected_url = base::StringPrintf( |
| - "%screaterobot?oauth_client_id=fooclientid.apps.googleusercontent.com&" |
| - "proxy=test_proxy", expected_url_base.c_str()); |
| - EXPECT_EQ(expected_url, url.spec()); |
| + EXPECT_EQ(base::StringPrintf( |
| + "%scontrol?jobid=87654321&status=IN_PROGRESS&code=2" |
| + "&message=Out%%20of%%20Paper&numpages=345&pagesprinted=47", |
| + expected_url_base.c_str()), |
| + GetUrlForJobStatusUpdate( |
| + server_base_url, "87654321", details).spec()); |
| } |
| -} // namespace |
| +TEST(CloudPrintServiceHelpersTest, GetURLs) { |
| + CheckJobStatusURLs(GURL("https://www.google.com/cloudprint")); |
| + CheckJobStatusURLs(GURL("https://www.google.com/cloudprint/")); |
| + CheckJobStatusURLs(GURL("http://www.myprinterserver.com")); |
| + CheckJobStatusURLs(GURL("http://www.myprinterserver.com/")); |
| +} |
| + |
| +TEST(CloudPrintServiceHelpersTest, GetHashOfPrinterInfo) { |
| + printing::PrinterBasicInfo printer_info; |
| + printer_info.options["tag1"] = std::string("value1"); |
| + printer_info.options["tag2"] = std::string("value2"); |
| + |
| + chrome::VersionInfo version_info; |
| + std::string expected_list_string = StringPrintf( |
| + "chrome_version%ssystem_name%ssystem_version%stag1value1tag2value2", |
| + version_info.CreateVersionString().c_str(), |
| + base::SysInfo::OperatingSystemName().c_str(), |
| + base::SysInfo::OperatingSystemVersion().c_str()); |
| + EXPECT_EQ(base::MD5String(expected_list_string), |
| + GetHashOfPrinterInfo(printer_info)); |
| +} |
| -TEST(CloudPrintHelpersTest, URLGetters) { |
| - CheckURLs(GURL("https://www.google.com/cloudprint")); |
| - CheckURLs(GURL("https://www.google.com/cloudprint/")); |
| - CheckURLs(GURL("http://www.myprinterserver.com")); |
| - CheckURLs(GURL("http://www.myprinterserver.com/")); |
| +TEST(CloudPrintServiceHelpersTest, GetPostDataForPrinterInfo) { |
| + printing::PrinterBasicInfo printer_info; |
| + printer_info.options["tag1"] = std::string("value1"); |
| + printer_info.options["tag2"] = std::string("value2"); |
| + |
| + chrome::VersionInfo version_info; |
| + std::string expected = base::StringPrintf( |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__chrome_version=%s\r\n" |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__system_name=%s\r\n" |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__system_version=%s\r\n" |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__tag1=value1\r\n" |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__tag2=value2\r\n" |
| + "--test_mime_boundary\r\nContent-Disposition: form-data; name=\"tag\"" |
| + "\r\n\r\n__cp__tagshash=%s\r\n", |
| + version_info.CreateVersionString().c_str(), |
| + base::SysInfo::OperatingSystemName().c_str(), |
| + base::SysInfo::OperatingSystemVersion().c_str(), |
| + GetHashOfPrinterInfo(printer_info).c_str()); |
| + |
| + EXPECT_EQ(expected, GetPostDataForPrinterInfo( |
| + printer_info, std::string("test_mime_boundary"))); |
| } |
| +TEST(CloudPrintServiceHelpersTest, IsDryRunJob) { |
| + std::vector<std::string> tags_not_dry_run; |
| + tags_not_dry_run.push_back("tag_1"); |
| + EXPECT_FALSE(IsDryRunJob(tags_not_dry_run)); |
| + |
| + std::vector<std::string> tags_dry_run; |
| + tags_dry_run.push_back("__cp__dry_run"); |
| + EXPECT_TRUE(IsDryRunJob(tags_dry_run)); |
| +} |
| + |
| +} // namespace cloud_print |
| + |