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 #ifndef CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 5 #ifndef CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
6 #define CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 6 #define CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
47 | 47 |
48 protected: | 48 protected: |
49 | 49 |
50 // Returns the path variable encoded at the |i|th index (0-based) in the | 50 // Returns the path variable encoded at the |i|th index (0-based) in the |
51 // request URL for this command. If the index is out of bounds, an empty | 51 // request URL for this command. If the index is out of bounds, an empty |
52 // string will be returned. | 52 // string will be returned. |
53 inline std::string GetPathVariable(const size_t i) const { | 53 inline std::string GetPathVariable(const size_t i) const { |
54 return i < path_segments_.size() ? path_segments_.at(i) : ""; | 54 return i < path_segments_.size() ? path_segments_.at(i) : ""; |
55 } | 55 } |
56 | 56 |
57 // Returns the command parameter with the given |key| as a UTF-16 string. | 57 // Provides the command parameter with the given |key| as a UTF-16 string. |
58 // Returns true on success. | 58 // Returns true on success. |
59 bool GetStringParameter(const std::string& key, string16* out) const; | 59 bool GetStringParameter(const std::string& key, string16* out) const; |
60 | 60 |
61 // Returns the command parameter with the given |key| as a UTF-8 string. | 61 // Provides the command parameter with the given |key| as a UTF-8 string. |
62 // Returns true on success. | 62 // Returns true on success. |
63 bool GetStringParameter(const std::string& key, std::string* out) const; | 63 bool GetStringParameter(const std::string& key, std::string* out) const; |
64 | 64 |
65 // Returns the command parameter with the given |key| as a ASCII string. | 65 // Provides the command parameter with the given |key| as a ASCII string. |
66 // Returns true on success. | 66 // Returns true on success. |
67 bool GetStringASCIIParameter(const std::string& key, std::string* out) const; | 67 bool GetStringASCIIParameter(const std::string& key, std::string* out) const; |
68 | 68 |
69 // Returns the command parameter with the given |key| as a boolean. Returns | 69 // Provides the command parameter with the given |key| as a boolean. Returns |
70 // false if there is no such parameter, or if it is not a boolean. | 70 // false if there is no such parameter, or if it is not a boolean. |
71 bool GetBooleanParameter(const std::string& key, bool* out) const; | 71 bool GetBooleanParameter(const std::string& key, bool* out) const; |
72 | 72 |
73 // Returns the command parameter with the given |key| as a int. Returns | 73 // Provides the command parameter with the given |key| as a int. Returns |
74 // false if there is no such parameter, or if it is not a int. | 74 // false if there is no such parameter, or if it is not a int. |
75 bool GetIntegerParameter(const std::string& key, int* out) const; | 75 bool GetIntegerParameter(const std::string& key, int* out) const; |
76 | 76 |
77 // Returns the command parameter with the given |key| as a list. Returns | 77 // Provides the command parameter with the given |key| as a Dictionary. |
| 78 // Returns false if there is no such parameter, or if it is not a Dictionary. |
| 79 bool GetDictionaryParameter(const std::string& key, |
| 80 DictionaryValue** out) const; |
| 81 |
| 82 // Provides the command parameter with the given |key| as a list. Returns |
78 // false if there is no such parameter, or if it is not a list. | 83 // false if there is no such parameter, or if it is not a list. |
79 bool GetListParameter(const std::string& key, ListValue** out) const; | 84 bool GetListParameter(const std::string& key, ListValue** out) const; |
80 | 85 |
81 private: | 86 private: |
82 const std::vector<std::string> path_segments_; | 87 const std::vector<std::string> path_segments_; |
83 const scoped_ptr<const DictionaryValue> parameters_; | 88 const scoped_ptr<const DictionaryValue> parameters_; |
84 | 89 |
85 // An autorelease pool must exist on any thread where Objective C is used, | 90 // An autorelease pool must exist on any thread where Objective C is used, |
86 // even implicitly. Otherwise the warning: | 91 // even implicitly. Otherwise the warning: |
87 // "Objects autoreleased with no pool in place." | 92 // "Objects autoreleased with no pool in place." |
88 // is printed for every object deallocted. Since every incomming command to | 93 // is printed for every object deallocted. Since every incomming command to |
89 // chrome driver is allocated a new thread, the release pool is declared here. | 94 // chrome driver is allocated a new thread, the release pool is declared here. |
90 base::mac::ScopedNSAutoreleasePool autorelease_pool; | 95 base::mac::ScopedNSAutoreleasePool autorelease_pool; |
91 | 96 |
92 DISALLOW_COPY_AND_ASSIGN(Command); | 97 DISALLOW_COPY_AND_ASSIGN(Command); |
93 }; | 98 }; |
94 | 99 |
95 } // namespace webdriver | 100 } // namespace webdriver |
96 | 101 |
97 #endif // CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 102 #endif // CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
98 | 103 |
OLD | NEW |