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

Unified Diff: chrome/test/webdriver/commands/cookie_commands.cc

Issue 6330012: Cookie commands for the webdriver protocol (Closed) Base URL: http://git.chromium.org/git/chromium.git@trunk
Patch Set: update Created 9 years, 11 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 side-by-side diff with in-line comments
Download patch
Index: chrome/test/webdriver/commands/cookie_commands.cc
diff --git a/chrome/test/webdriver/commands/cookie_commands.cc b/chrome/test/webdriver/commands/cookie_commands.cc
new file mode 100644
index 0000000000000000000000000000000000000000..13c46682403ee7c73972b489d136a4a766ccf7a8
--- /dev/null
+++ b/chrome/test/webdriver/commands/cookie_commands.cc
@@ -0,0 +1,188 @@
+// Copyright (c) 2010 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/test/webdriver/commands/cookie_commands.h"
+#include "chrome/test/webdriver/cookie.h"
+
+#include <string>
+#include <vector>
+
+namespace webdriver {
+
+void tokenize(const std::string& s, const char& delimiter,
John Grabowski 2011/02/04 02:40:23 seems like something to put in an anonymous namesp
kkania 2011/02/04 17:04:44 hmm, looks like you forgot to fix this on the firs
Joe 2011/02/09 06:32:10 Done.
Joe 2011/02/09 06:32:10 Done.
+ std::vector<std::string>& tokens) {
+ size_t start = 0;
+ size_t end = s.find(delimiter);
+
John Grabowski 2011/02/04 02:40:23 Hmm. Might it be better to create a static method
Joe 2011/02/09 06:32:10 Done.
+ while (end != std::string::npos) {
+ if (end - start > 0) {
+ tokens.push_back(s.substr(start, end - start));
+ }
+ start = end + 1;
+ end = s.find(delimiter, start);
+ }
+
+ if ((s.length() - start) > 0) {
+ tokens.push_back(s.substr(start, s.length()));
+ }
+}
+
+bool CookieCommand::Init(Response* const response) {
+ if (WebDriverCommand::Init(response)) {
+ if (tab_->GetCurrentURL(&current_url_)) {
+ return true;
+ }
+ SET_WEBDRIVER_ERROR(response, "Failed to query current page URL",
+ kInternalServerError);
+ return false;
+ }
+
+ SET_WEBDRIVER_ERROR(response, "Failed to init Cookie Command",
+ kInternalServerError);
+ return false;
+}
+
+void CookieCommand::ExecuteGet(Response* const response) {
+ // TODO(JMikhail): Add GetJSONCookies to automation proxy since
+ // GetCookies does not return the necessary information
+ std::string cookies;
+ std::vector<std::string> tokens;
+
+ if (!tab_->GetCookies(current_url_, &cookies)) {
+ response->set_status(kUnknownError);
+ response->set_value(new StringValue("Failed to fetch cookies"));
+ return;
+ }
+
+ tokenize(cookies, ';', tokens);
+ ListValue* l = new ListValue();
+ for (std::vector<std::string>::iterator i = tokens.begin();
+ i != tokens.end(); ++i) {
+ Cookie cookie(*i);
+ if (cookie.IsValid()) {
+ l->Append(cookie.ToJSON());
+ } else {
+ LOG(ERROR) << "Failed to parse cookie: " << *i;
+ }
+ }
+
+ response->set_status(kSuccess);
+ response->set_value(l);
+}
+
+void CookieCommand::ExecutePost(Response* const response) {
+ std::string cookie_string;
+ DictionaryValue* cookie_dict;
+ scoped_ptr<Cookie> cookie;
+
+ // Check to see if the cookie was passed in as a string.
+ if (GetStringASCIIParameter("cookie", &cookie_string)) {
+ cookie.reset(new Cookie(cookie_string));
+ } else {
+ // Check to see if the cookie was passed in as a JSON onject.
+ if (GetDictionaryParameter("cookie", &cookie_dict)) {
+ cookie.reset(new Cookie(*cookie_dict));
+ } else {
+ // No valid cookie sent.
+ response->set_value(new StringValue("Cookie key not found"));
+ response->set_status(kBadRequest);
+ return;
+ }
+ }
+
+ // Make sure the cookie is formated preoperly.
+ if (!cookie->IsValid()) {
+ response->set_value(new StringValue("Invalid cookie"));
+ response->set_status(kBadRequest);
+ return;
+ }
+
+ if (!tab_->SetCookie(current_url_, cookie->ToString())) {
+ response->set_status(kUnableToSetCookie);
+ response->set_value(new StringValue("Failed to set cookie"));
+ return;
+ }
+
+ response->set_status(kSuccess);
+ response->set_value(new StringValue(cookie->ToString()));
+}
+
+void CookieCommand::ExecuteDelete(Response* const response) {
+ std::string cookies;
+ std::vector<std::string> tokens;
+
+ if (!tab_->GetCookies(current_url_, &cookies)) {
+ response->set_status(kUnknownError);
+ response->set_value(new StringValue("Failed to fetch cookies"));
+ return;
+ }
+
+ tokenize(cookies, ':', tokens);
John Grabowski 2011/02/04 02:40:23 On line 58 you tokenize cookes on ;. Here you toke
+ for (std::vector<std::string>::iterator i = tokens.begin();
+ i != tokens.end(); ++i) {
+ Cookie cookie(*i);
+ if (cookie.IsValid()) {
+ if (!tab_->DeleteCookie(current_url_, cookie.get_name())) {
+ LOG(INFO) << "Could not delete cookie: " << cookie.get_name() << "\n"
+ << "Contents of cookie: " << cookie.ToString();
+ SET_WEBDRIVER_ERROR(response, "Could not delete all cookies",
+ kInternalServerError);
+ return;
+ }
+ } else {
+ LOG(ERROR) << "Failed to parse cookie: " << *i;
+ }
+ }
+
+ response->set_status(kSuccess);
+ response->set_value(new StringValue("Cookies delete"));
+}
+
+bool NamedCookieCommand::Init(Response* const response) {
+ if (WebDriverCommand::Init(response)) {
+ if (!tab_->GetCurrentURL(&current_url_)) {
+ SET_WEBDRIVER_ERROR(response, "Failed to query current page URL",
+ kInternalServerError);
+ return false;
+ }
+
+ // There should be at least 5 segments to match
+ // /session/:sessionId/cookie/:name
+ cookie_name_ = GetPathVariable(4);
+ SET_WEBDRIVER_ERROR(response, "No cookie name specified",
+ kBadRequest);
+ return false;
+ }
+
+ SET_WEBDRIVER_ERROR(response, "Failed to init Named Cookie Command",
+ kInternalServerError);
+ return false;
+}
+
+void NamedCookieCommand::ExecuteGet(Response* const response) {
+ std::string cookie;
+
+ if (!tab_->GetCookieByName(current_url_, cookie_name_, &cookie)) {
+ response->set_status(kUnknownError);
+ response->set_value(new StringValue("Failed to fetch cookie"));
+ return;
+ }
+
+ response->set_status(kSuccess);
+ response->set_value(new StringValue(cookie));
+}
+
+void NamedCookieCommand::ExecuteDelete(Response* const response) {
+ if (!tab_->DeleteCookie(current_url_, cookie_name_)) {
+ response->set_status(kUnknownError);
+ response->set_value(new StringValue("Failed to delete cookie"));
+ return;
+ }
+
+ response->set_status(kSuccess);
+ response->set_value(new StringValue("Cookie deleted"));
+}
+
+} // namespace webdriver
+

Powered by Google App Engine
This is Rietveld 408576698