Complex classes like Driver_Phantomjs often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes. You can also have a look at the cohesion graph to spot any un-connected, or weakly-connected components.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
While breaking up the class, it is a good idea to analyze how other classes use Driver_Phantomjs, and based on these observations, apply Extract Interface, too.
| 1 | <?php | ||
| 14 | class Driver_Phantomjs extends Driver { | ||
| 15 | |||
| 16 | /** | ||
| 17 | * Driver name | ||
| 18 | * @var string | ||
| 19 | */ | ||
| 20 | public $name = 'phantomjs'; | ||
| 21 | |||
| 22 | /** | ||
| 23 | * Array containing parameters to be added on the next request | ||
| 24 | * @var array | ||
| 25 | */ | ||
| 26 | public $_next_query = array(); | ||
| 27 | |||
| 28 | /** | ||
| 29 | * User agent string cache | ||
| 30 | * @var string | ||
| 31 | */ | ||
| 32 | protected $_user_agent; | ||
| 33 | |||
| 34 | /** | ||
| 35 | * Variable holding the current Driver_Phantomjs_Connection | ||
| 36 | * @var Driver_Phantomjs_Connection | ||
| 37 | */ | ||
| 38 | protected $_connection; | ||
| 39 | |||
| 40 | /** | ||
| 41 | * The base URL, to be prefixed on each request | ||
| 42 | * @var string | ||
| 43 | */ | ||
| 44 | protected $_base_url = ''; | ||
| 45 | |||
| 46 | /** | ||
| 47 | * Getter / Setter of the base_url, that will be prefixed on each request | ||
| 48 | * @param string $base_url | ||
| 49 | * @return string|Driver_PHantomjs | ||
| 50 | */ | ||
| 51 | public function base_url($base_url = NULL) | ||
| 60 | |||
| 61 | /** | ||
| 62 | * Getter / Setter of the Driver_Phantomjs_Connection object. | ||
| 63 | * Use this to customize the connection, otherwise a default one on a random port will be used | ||
| 64 | * | ||
| 65 | * @param Driver_Phantomjs_Connection $connection | ||
| 66 | * @return Driver_Phantomjs_Connection|Driver_Phantomjs | ||
| 67 | */ | ||
| 68 | 1 | public function connection(Driver_Phantomjs_Connection $connection = NULL) | |
| 84 | |||
| 85 | /** | ||
| 86 | * If a connection has been started, stop it | ||
| 87 | */ | ||
| 88 | public function __destruct() | ||
| 95 | |||
| 96 | /** | ||
| 97 | * Clear the connection by deleting all cookies | ||
| 98 | */ | ||
| 99 | public function clear() | ||
| 103 | |||
| 104 | /** | ||
| 105 | * Getter of the raw content html, this driver does not allow "setting" | ||
| 106 | * | ||
| 107 | * @param string $content | ||
| 108 | * @return string | ||
| 109 | */ | ||
| 110 | public function content($content = NULL) | ||
| 114 | |||
| 115 | /** | ||
| 116 | * NODE GETTERS | ||
| 117 | * ===================================== | ||
| 118 | */ | ||
| 119 | |||
| 120 | /** | ||
| 121 | * Get the tag name of a Node with id. e.g. DIV, SPAN ... | ||
| 122 | * @param string $id | ||
| 123 | * @return string | ||
| 124 | */ | ||
| 125 | 1 | public function tag_name($id) | |
| 129 | |||
| 130 | /** | ||
| 131 | * Get the attribute of a Node with id. If the attribute does not exist, returns NULL | ||
| 132 | * @param string $id | ||
| 133 | * @param string $name | ||
| 134 | * @return string | ||
| 135 | */ | ||
| 136 | public function attribute($id, $name) | ||
| 140 | |||
| 141 | /** | ||
| 142 | * Return the raw html of a Node with id, along with all of its children. | ||
| 143 | * @param string $id | ||
| 144 | * @return string | ||
| 145 | */ | ||
| 146 | public function html($id) | ||
| 153 | |||
| 154 | /** | ||
| 155 | * Return the text of a Node with id, with all the spaces collapsed, similar to browser rendering. | ||
| 156 | * @param string $id | ||
| 157 | * @return string | ||
| 158 | */ | ||
| 159 | public function text($id) | ||
| 165 | |||
| 166 | /** | ||
| 167 | * Return the value of a Node of a form element, e.g. INPUT, TEXTAREA or SELECT | ||
| 168 | * @param string $id | ||
| 169 | * @return string | ||
| 170 | */ | ||
| 171 | public function value($id) | ||
| 175 | |||
| 176 | /** | ||
| 177 | * Check if a Node with id is visible. | ||
| 178 | * @param string $id | ||
| 179 | * @return boolean | ||
| 180 | */ | ||
| 181 | public function is_visible($id) | ||
| 185 | |||
| 186 | /** | ||
| 187 | * Check if a Node with id of an option element is selected | ||
| 188 | * @param string $id | ||
| 189 | * @return boolean | ||
| 190 | */ | ||
| 191 | public function is_selected($id) | ||
| 195 | |||
| 196 | /** | ||
| 197 | * Check if a Node with id of an input element (radio or checkbox) is checked | ||
| 198 | * @param string $id | ||
| 199 | * @return boolean | ||
| 200 | */ | ||
| 201 | public function is_checked($id) | ||
| 205 | |||
| 206 | /** | ||
| 207 | * Set the value of a Node with id of a form element | ||
| 208 | * @param string $id | ||
| 209 | * @param string $value | ||
| 210 | */ | ||
| 211 | public function set($id, $value) | ||
| 240 | |||
| 241 | /** | ||
| 242 | * Set the option value that is selected of a Node of a select element | ||
| 243 | * @param string $id | ||
| 244 | * @param string $value | ||
| 245 | */ | ||
| 246 | public function select_option($id, $value) | ||
| 250 | |||
| 251 | /** | ||
| 252 | * Click on a Node with id, triggering a link or form submit | ||
| 253 | * @param string $id | ||
| 254 | * @throws Exception_Driver If not a clickable element | ||
| 255 | */ | ||
| 256 | public function click($id) | ||
| 260 | |||
| 261 | /** | ||
| 262 | * Go to a given url address, use next_query along with the provided query array | ||
| 263 | * @param string $uri | ||
| 264 | * @param array $query | ||
| 265 | */ | ||
| 266 | public function visit($uri, array $query = array()) | ||
| 283 | |||
| 284 | /** | ||
| 285 | * Get the current path (without host and protocol) | ||
| 286 | * @return string | ||
| 287 | */ | ||
| 288 | public function current_path() | ||
| 294 | |||
| 295 | /** | ||
| 296 | * Get the current url | ||
| 297 | * @return string | ||
| 298 | */ | ||
| 299 | public function current_url() | ||
| 303 | |||
| 304 | /** | ||
| 305 | * Find all ids of a given XPath | ||
| 306 | * @param string $xpath | ||
| 307 | * @param string $parent id of the parent node | ||
| 308 | * @return array | ||
| 309 | */ | ||
| 310 | 1 | public function all($xpath, $parent = NULL) | |
| 314 | |||
| 315 | /** | ||
| 316 | * Setter for the next_query variable, to be added to the next visit's query | ||
| 317 | * @param array $query | ||
| 318 | */ | ||
| 319 | public function next_query(array $query) | ||
| 323 | |||
| 324 | /** | ||
| 325 | * Check if a connection is active | ||
| 326 | * @return boolean | ||
| 327 | */ | ||
| 328 | public function is_page_active() | ||
| 332 | |||
| 333 | /** | ||
| 334 | * Return all javascript errors for the current page | ||
| 335 | * @return array | ||
| 336 | */ | ||
| 337 | public function javascript_errors() | ||
| 341 | |||
| 342 | /** | ||
| 343 | * Return all console messages for the current page | ||
| 344 | * @return array | ||
| 345 | */ | ||
| 346 | public function javascript_messages() | ||
| 350 | |||
| 351 | /** | ||
| 352 | * Do a screenshot of the current page into a file | ||
| 353 | * @param string $file | ||
| 354 | */ | ||
| 355 | public function screenshot($file) | ||
| 359 | |||
| 360 | /** | ||
| 361 | * Get the current user agent | ||
| 362 | * @return string | ||
| 363 | */ | ||
| 364 | public function user_agent() | ||
| 374 | |||
| 375 | /** | ||
| 376 | 	 * Execute raw javascript. it will be executed in the context of a given node ('this' will point to the node) and the return of the script will be the return of this method | ||
| 377 | * @param string $id | ||
| 378 | * @param string $script | ||
| 379 | * @return mixed | ||
| 380 | */ | ||
| 381 | public function execute($id, $script) | ||
| 388 | |||
| 389 | /** | ||
| 390 | * Return all the current cookies | ||
| 391 | * @return array | ||
| 392 | */ | ||
| 393 | public function cookies() | ||
| 397 | |||
| 398 | /** | ||
| 399 | * Set a cookie. Use parameters to set "expires", "path", "domain", "secure" and "httponly" | ||
| 400 | * @param string $name | ||
| 401 | * @param mixed $value | ||
| 402 | * @param array $parameters | ||
| 403 | */ | ||
| 404 | public function cookie($name, $value, array $parameters = array()) | ||
| 416 | } | ||
| 417 | 
It seems like the method you are trying to call exists only in some of the possible types.
Let’s take a look at an example:
Available Fixes
Add an additional type-check:
Only allow a single type to be passed if the variable comes from a parameter: