OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/test/webdriver/webdriver_capabilities_parser.h" | 5 #include "chrome/test/webdriver/webdriver_capabilities_parser.h" |
6 | 6 |
7 #include "base/base64.h" | |
8 #include "base/file_util.h" | 7 #include "base/file_util.h" |
9 #include "base/format_macros.h" | 8 #include "base/format_macros.h" |
10 #include "base/stringprintf.h" | 9 #include "base/stringprintf.h" |
11 #include "base/string_util.h" | 10 #include "base/string_util.h" |
12 #include "base/values.h" | 11 #include "base/values.h" |
13 #include "chrome/common/chrome_switches.h" | 12 #include "chrome/common/chrome_switches.h" |
14 #include "chrome/common/zip.h" | |
15 #include "chrome/test/webdriver/webdriver_error.h" | 13 #include "chrome/test/webdriver/webdriver_error.h" |
16 #include "chrome/test/webdriver/webdriver_util.h" | 14 #include "chrome/test/webdriver/webdriver_util.h" |
17 | 15 |
18 using base::DictionaryValue; | 16 using base::DictionaryValue; |
19 using base::Value; | 17 using base::Value; |
20 | 18 |
21 namespace webdriver { | 19 namespace webdriver { |
22 | 20 |
23 namespace { | 21 namespace { |
24 | 22 |
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
189 if (!option->GetAsList(&extensions)) | 187 if (!option->GetAsList(&extensions)) |
190 return CreateBadInputError("extensions", Value::TYPE_LIST, option); | 188 return CreateBadInputError("extensions", Value::TYPE_LIST, option); |
191 for (size_t i = 0; i < extensions->GetSize(); ++i) { | 189 for (size_t i = 0; i < extensions->GetSize(); ++i) { |
192 std::string extension_base64; | 190 std::string extension_base64; |
193 if (!extensions->GetString(i, &extension_base64)) { | 191 if (!extensions->GetString(i, &extension_base64)) { |
194 return new Error(kBadRequest, | 192 return new Error(kBadRequest, |
195 "Each extension must be a base64 encoded string"); | 193 "Each extension must be a base64 encoded string"); |
196 } | 194 } |
197 FilePath extension = root_.AppendASCII( | 195 FilePath extension = root_.AppendASCII( |
198 base::StringPrintf("extension%" PRIuS ".crx", i)); | 196 base::StringPrintf("extension%" PRIuS ".crx", i)); |
199 std::string error_msg; | 197 std::string decoded_extension; |
200 if (!DecodeAndWriteFile(extension, extension_base64, false /* unzip */, | 198 if (!Base64Decode(extension_base64, &decoded_extension)) |
201 &error_msg)) { | 199 return new Error(kUnknownError, "Failed to base64 decode extension"); |
202 return new Error( | 200 int size = static_cast<int>(decoded_extension.length()); |
203 kUnknownError, | 201 if (file_util::WriteFile( |
204 "Error occurred while parsing extension: " + error_msg); | 202 extension, decoded_extension.c_str(), size) != size) |
205 } | 203 return new Error(kUnknownError, "Failed to write extension file"); |
206 caps_->extensions.push_back(extension); | 204 caps_->extensions.push_back(extension); |
207 } | 205 } |
208 return NULL; | 206 return NULL; |
209 } | 207 } |
210 | 208 |
211 Error* CapabilitiesParser::ParseLoadAsync(const Value* option) { | 209 Error* CapabilitiesParser::ParseLoadAsync(const Value* option) { |
212 if (!option->GetAsBoolean(&caps_->load_async)) | 210 if (!option->GetAsBoolean(&caps_->load_async)) |
213 return CreateBadInputError("loadAsync", Value::TYPE_BOOLEAN, option); | 211 return CreateBadInputError("loadAsync", Value::TYPE_BOOLEAN, option); |
214 return NULL; | 212 return NULL; |
215 } | 213 } |
(...skipping 28 matching lines...) Expand all Loading... |
244 return CreateBadInputError("nativeEvents", Value::TYPE_BOOLEAN, option); | 242 return CreateBadInputError("nativeEvents", Value::TYPE_BOOLEAN, option); |
245 return NULL; | 243 return NULL; |
246 } | 244 } |
247 | 245 |
248 Error* CapabilitiesParser::ParseProfile(const Value* option) { | 246 Error* CapabilitiesParser::ParseProfile(const Value* option) { |
249 std::string profile_base64; | 247 std::string profile_base64; |
250 if (!option->GetAsString(&profile_base64)) | 248 if (!option->GetAsString(&profile_base64)) |
251 return CreateBadInputError("profile", Value::TYPE_STRING, option); | 249 return CreateBadInputError("profile", Value::TYPE_STRING, option); |
252 std::string error_msg; | 250 std::string error_msg; |
253 caps_->profile = root_.AppendASCII("profile"); | 251 caps_->profile = root_.AppendASCII("profile"); |
254 if (!DecodeAndWriteFile(caps_->profile, profile_base64, true /* unzip */, | 252 if (!Base64DecodeAndUnzip(caps_->profile, profile_base64, &error_msg)) |
255 &error_msg)) | |
256 return new Error(kUnknownError, "unable to unpack profile: " + error_msg); | 253 return new Error(kUnknownError, "unable to unpack profile: " + error_msg); |
257 return NULL; | 254 return NULL; |
258 } | 255 } |
259 | 256 |
260 Error* CapabilitiesParser::ParseProxy(const base::Value* option) { | 257 Error* CapabilitiesParser::ParseProxy(const base::Value* option) { |
261 const DictionaryValue* options; | 258 const DictionaryValue* options; |
262 if (!option->GetAsDictionary(&options)) | 259 if (!option->GetAsDictionary(&options)) |
263 return CreateBadInputError("proxy", Value::TYPE_DICTIONARY, option); | 260 return CreateBadInputError("proxy", Value::TYPE_DICTIONARY, option); |
264 | 261 |
265 // Quick check of proxy capabilities. | 262 // Quick check of proxy capabilities. |
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
403 return NULL; | 400 return NULL; |
404 } | 401 } |
405 | 402 |
406 Error* CapabilitiesParser::ParseNoWebsiteTestingDefaults(const Value* option) { | 403 Error* CapabilitiesParser::ParseNoWebsiteTestingDefaults(const Value* option) { |
407 if (!option->GetAsBoolean(&caps_->no_website_testing_defaults)) | 404 if (!option->GetAsBoolean(&caps_->no_website_testing_defaults)) |
408 return CreateBadInputError("noWebsiteTestingDefaults", | 405 return CreateBadInputError("noWebsiteTestingDefaults", |
409 Value::TYPE_BOOLEAN, option); | 406 Value::TYPE_BOOLEAN, option); |
410 return NULL; | 407 return NULL; |
411 } | 408 } |
412 | 409 |
413 bool CapabilitiesParser::DecodeAndWriteFile( | |
414 const FilePath& path, | |
415 const std::string& base64, | |
416 bool unzip, | |
417 std::string* error_msg) { | |
418 std::string data; | |
419 if (!base::Base64Decode(base64, &data)) { | |
420 *error_msg = "Could not decode base64 data"; | |
421 return false; | |
422 } | |
423 if (unzip) { | |
424 FilePath temp_file(root_.AppendASCII(GenerateRandomID())); | |
425 if (!file_util::WriteFile(temp_file, data.c_str(), data.length())) { | |
426 *error_msg = "Could not write file"; | |
427 return false; | |
428 } | |
429 if (!zip::Unzip(temp_file, path)) { | |
430 *error_msg = "Could not unzip archive"; | |
431 return false; | |
432 } | |
433 } else { | |
434 if (!file_util::WriteFile(path, data.c_str(), data.length())) { | |
435 *error_msg = "Could not write file"; | |
436 return false; | |
437 } | |
438 } | |
439 return true; | |
440 } | |
441 | |
442 } // namespace webdriver | 410 } // namespace webdriver |
OLD | NEW |