- sfTesterResponse.class.php
- class sfTesterResponse extends sfTester
- {
- protected
- $response = null,
- $dom = null,
- $domCssSelector = null;
-
- public function prepare()
- {
- }
-
- public function initialize()
- {
- $this->response = $this->browser->getResponse();
- $this->dom = null;
- $this->domCssSelector = null;
- if (preg_match('/(x|ht)ml/i', $this->response->getContentType(), $matches))
- {
- $this->dom = new DOMDocument('1.0', $this->response->getCharset());
- $this->dom->validateOnParse = true;
- if ('x' == $matches[1])
- {
- @$this->dom->loadXML($this->response->getContent());
- }
- else
- {
- @$this->dom->loadHTML($this->response->getContent());
- }
- $this->domCssSelector = new sfDomCssSelector($this->dom);
- }
- }
-
- public function checkElement($selector, $value = true, $options = array())
- {
- if (null === $this->dom)
- {
- throw new LogicException('The DOM is not accessible because the browser response content type is not HTML.');
- }
- if (is_object($selector))
- {
- $values = $selector->getValues();
- }
- else
- {
- $values = $this->domCssSelector->matchAll($selector)->getValues();
- }
- if (false === $value)
- {
- $this->tester->is(count($values), 0, sprintf('response selector "%s" does not exist', $selector));
- }
- else if (true === $value)
- {
- $this->tester->cmp_ok(count($values), '>', 0, sprintf('response selector "%s" exists', $selector));
- }
- else if (is_int($value))
- {
- $this->tester->is(count($values), $value, sprintf('response selector "%s" matches "%s" times', $selector, $value));
- }
- else if (preg_match('/^(!)?([^a-zA-Z0-9\\\\]).+?\\2[ims]?$/', $value, $match))
- {
- $position = isset($options['position']) ? $options['position'] : 0;
- if ($match[1] == '!')
- {
- $this->tester->unlike(@$values[$position], substr($value, 1), sprintf('response selector "%s" does not match regex "%s"', $selector, substr($value, 1)));
- }
- else
- {
- $this->tester->like(@$values[$position], $value, sprintf('response selector "%s" matches regex "%s"', $selector, $value));
- }
- }
- else
- {
- $position = isset($options['position']) ? $options['position'] : 0;
- $this->tester->is(@$values[$position], $value, sprintf('response selector "%s" matches "%s"', $selector, $value));
- }
- if (isset($options['count']))
- {
- $this->tester->is(count($values), $options['count'], sprintf('response selector "%s" matches "%s" times', $selector, $options['count']));
- }
- return $this->getObjectToReturn();
- }
-
- public function checkForm($form, $selector = 'form')
- {
- if (!$form instanceof sfForm)
- {
- $form = new $form();
- }
- $rendered = array();
- foreach ($this->domCssSelector->matchAll(sprintf('%1$s input, %1$s textarea, %1$s select', $selector))->getNodes() as $element)
- {
- $rendered[] = $element->getAttribute('name');
- }
- foreach ($form as $field => $widget)
- {
- $dom = new DOMDocument('1.0', sfConfig::get('sf_charset'));
- $dom->loadHTML((string) $widget);
- foreach ($dom->getElementsByTagName('*') as $element)
- {
- if (in_array($element->tagName, array('input', 'select', 'textarea')))
- {
- if (false !== $pos = array_search($element->getAttribute('name'), $rendered))
- {
- unset($rendered[$pos]);
- }
- $this->tester->ok(false !== $pos, sprintf('response includes "%s" form "%s" field - "%s %s[name=%s]"', get_class($form), $field, $selector, $element->tagName, $element->getAttribute('name')));
- }
- }
- }
- return $this->getObjectToReturn();
- }
-
- public function isValid($checkDTD = false)
- {
- if (preg_match('/(x|ht)ml/i', $this->response->getContentType()))
- {
- $revert = libxml_use_internal_errors(true);
- $dom = new DOMDocument('1.0', $this->response->getCharset());
- $content = $this->response->getContent();
- if (true === $checkDTD)
- {
- $cache = sfConfig::get('sf_cache_dir').'/sf_tester_response/w3';
- if ($cache[1] == ':')
- {
-
-
-
-
-
-
-
- $local = 'file://'.substr(str_replace(DIRECTORY_SEPARATOR, '/', $cache), 2);
- }
- else
- {
- $local = 'file://'.$cache;
- }
- if (!file_exists($cache.'/TR/xhtml11/DTD/xhtml11.dtd'))
- {
- $filesystem = new sfFilesystem();
- $finder = sfFinder::type('any')->discard('.sf');
- $filesystem->mirror(dirname(__FILE__).'/w3', $cache, $finder);
- $finder = sfFinder::type('file');
- $filesystem->replaceTokens($finder->in($cache), '##', '##', array('LOCAL_W3' => $local));
- }
- $content = preg_replace('#(<!DOCTYPE[^>]+")http://www.w3.org(.*")#i', '\\1'.$local.'\\2', $content);
- $dom->validateOnParse = $checkDTD;
- }
- $dom->loadXML($content);
- switch (pathinfo($checkDTD, PATHINFO_EXTENSION))
- {
- case 'xsd':
- $dom->schemaValidate($checkDTD);
- $message = sprintf('response validates per XSD schema "%s"', basename($checkDTD));
- break;
- case 'rng':
- case 'rnc':
- $dom->relaxNGValidate($checkDTD);
- $message = sprintf('response validates per relaxNG schema "%s"', basename($checkDTD));
- break;
- default:
- $message = $dom->validateOnParse ? sprintf('response validates as "%s"', $dom->doctype->name) : 'response is well-formed "xml"';
- }
- if (count($errors = libxml_get_errors()))
- {
- $lines = explode(PHP_EOL, $this->response->getContent());
- $this->tester->fail($message);
- foreach ($errors as $error)
- {
- $this->tester->diag(' '.trim($error->message));
- if (preg_match('/line (\d+)/', $error->message, $match) && $error->line != $match[1])
- {
- $this->tester->diag(' '.str_pad($match[1].':', 6).trim($lines[$match[1] - 1]));
- }
- $this->tester->diag(' '.str_pad($error->line.':', 6).trim($lines[$error->line - 1]));
- }
- }
- else
- {
- $this->tester->pass($message);
- }
- libxml_use_internal_errors($revert);
- }
- else
- {
- throw new LogicException(sprintf('Unable to validate responses of content type "%s"', $this->response->getContentType()));
- }
- return $this->getObjectToReturn();
- }
-
- public function isHeader($key, $value)
- {
- $headers = explode(', ', $this->response->getHttpHeader($key));
- $ok = false;
- $regex = false;
- $mustMatch = true;
- if (preg_match('/^(!)?([^a-zA-Z0-9\\\\]).+?\\2[ims]?$/', $value, $match))
- {
- $regex = $value;
- if ($match[1] == '!')
- {
- $mustMatch = false;
- $regex = substr($value, 1);
- }
- }
- foreach ($headers as $header)
- {
- if (false !== $regex)
- {
- if ($mustMatch)
- {
- if (preg_match($regex, $header))
- {
- $ok = true;
- $this->tester->pass(sprintf('response header "%s" matches "%s" (%s)', $key, $value, $this->response->getHttpHeader($key)));
- break;
- }
- }
- else
- {
- if (preg_match($regex, $header))
- {
- $ok = true;
- $this->tester->fail(sprintf('response header "%s" does not match "%s" (%s)', $key, $value, $this->response->getHttpHeader($key)));
- break;
- }
- }
- }
- else if ($header == $value)
- {
- $ok = true;
- $this->tester->pass(sprintf('response header "%s" is "%s" (%s)', $key, $value, $this->response->getHttpHeader($key)));
- break;
- }
- }
- if (!$ok)
- {
- if (!$mustMatch)
- {
- $this->tester->pass(sprintf('response header "%s" matches "%s" (%s)', $key, $value, $this->response->getHttpHeader($key)));
- }
- else
- {
- $this->tester->fail(sprintf('response header "%s" matches "%s" (%s)', $key, $value, $this->response->getHttpHeader($key)));
- }
- }
- return $this->getObjectToReturn();
- }
-
- public function setsCookie($name, $value = null, $attributes = array())
- {
- foreach ($this->response->getCookies() as $cookie)
- {
- if ($name == $cookie['name'])
- {
- if (null === $value)
- {
- $this->tester->pass(sprintf('response sets cookie "%s"', $name));
- }
- else
- {
- $this->tester->ok($value == $cookie['value'], sprintf('response sets cookie "%s" to "%s"', $name, $value));
- }
- foreach ($attributes as $attributeName => $attributeValue)
- {
- if (!array_key_exists($attributeName, $cookie))
- {
- throw new LogicException(sprintf('The cookie attribute "%s" is not valid.', $attributeName));
- }
- $this->tester->is($cookie[$attributeName], $attributeValue, sprintf('"%s" cookie "%s" attribute is "%s"', $name, $attributeName, $attributeValue));
- }
- return $this->getObjectToReturn();
- }
- }
- $this->tester->fail(sprintf('response sets cookie "%s"', $name));
- return $this->getObjectToReturn();
- }
-
- public function matches($regex)
- {
- if (!preg_match('/^(!)?([^a-zA-Z0-9\\\\]).+?\\2[ims]?$/', $regex, $match))
- {
- throw new InvalidArgumentException(sprintf('"%s" is not a valid regular expression.', $regex));
- }
- if ($match[1] == '!')
- {
- $this->tester->unlike($this->response->getContent(), substr($regex, 1), sprintf('response content does not match regex "%s"', substr($regex, 1)));
- }
- else
- {
- $this->tester->like($this->response->getContent(), $regex, sprintf('response content matches regex "%s"', $regex));
- }
- return $this->getObjectToReturn();
- }
-
- public function isStatusCode($statusCode = 200)
- {
- $this->tester->is($this->response->getStatusCode(), $statusCode, sprintf('status code is "%s"', $statusCode));
- return $this->getObjectToReturn();
- }
-
- public function isRedirected($boolean = true)
- {
- if ($location = $this->response->getHttpHeader('location'))
- {
- $boolean ? $this->tester->pass(sprintf('page redirected to "%s"', $location)) : $this->tester->fail(sprintf('page redirected to "%s"', $location));
- }
- else
- {
- $boolean ? $this->tester->fail('page redirected') : $this->tester->pass('page not redirected');
- }
- return $this->getObjectToReturn();
- }
-
- public function debug($realOutput = false)
- {
- print $this->tester->error('Response debug');
- if (!$realOutput && null !== sfException::getLastException())
- {
-
- $this->tester->comment('WARNING');
- $this->tester->comment('An error occurred when processing this request.');
- $this->tester->comment('The real response content has been replaced with the exception message to ease debugging.');
- }
- printf("HTTP/1.X %s\n", $this->response->getStatusCode());
- foreach ($this->response->getHttpHeaders() as $name => $value)
- {
- printf("%s: %s\n", $name, $value);
- }
- foreach ($this->response->getCookies() as $cookie)
- {
- vprintf("Set-Cookie: %s=%s; %spath=%s%s%s%s\n", array(
- $cookie['name'],
- $cookie['value'],
- null === $cookie['expire'] ? '' : sprintf('expires=%s; ', date('D d-M-Y H:i:s T', $cookie['expire'])),
- $cookie['path'],
- $cookie['domain'] ? sprintf('; domain=%s', $cookie['domain']) : '',
- $cookie['secure'] ? '; secure' : '',
- $cookie['httpOnly'] ? '; HttpOnly' : '',
- ));
- }
- echo "\n";
- if (!$realOutput && null !== $exception = sfException::getLastException())
- {
- echo $exception;
- }
- else
- {
- echo $this->response->getContent();
- }
- echo "\n";
- exit(1);
- }
- }
Configuration
- debug
- xdebug
- logging
- cache
- compression
- tokenizer
- eaccelerator
- apc
- xcache
Request 
options:
path_info_key: PATH_INFO
path_info_array: SERVER
default_format: null
logging: '1'
relative_url_root: null
formats: { txt: text/plain, js: [application/javascript, application/x-javascript, text/javascript], css: text/css, json: [application/json, application/x-json], xml: [text/xml, application/xml, application/x-xml], rdf: application/rdf+xml, atom: application/atom+xml }
no_script_name: false
parameterHolder:
action: index
class: sfTesterResponse
method: ''
module: sfCodeView
attributeHolder:
sf_route: 'sfRoute Object()'
Response 
status:
code: 200
text: OK
options:
http_protocol: HTTP/1.1
logging: '1'
charset: utf-8
send_http_headers: false
content_type: 'text/html; charset=utf-8'
cookies: { }
httpHeaders:
Content-Type: 'text/html; charset=utf-8'
javascripts:
'http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js': { }
/sfCodeViewPlugin/js/sfCodeViewPlugin.js: { }
stylesheets:
main.css: { }
/sfCodeViewPlugin/css/sfCodeViewPlugin.css: { }
metas: { }
httpMetas:
Content-Type: 'text/html; charset=utf-8'
User 
options:
auto_shutdown: false
culture: null
default_culture: en
use_flash: true
logging: '1'
timeout: 1800
attributeHolder:
symfony/user/sfUser/attributes: { history: [sfTesterResponse, sfTesterRequest, sfTesterMailer, sfTesterForm, sfTester, sfTestUnitTask, sfTestFunctionalTask, sfTestFunctional, sfTestCoverageTask, sfTestBrowser] }
culture: en
Settings 
app_sfCodeViewPlugin_javascripts:
- /sfCodeViewPlugin/js/sfCodeViewPlugin.js
app_sfCodeViewPlugin_stylesheets:
- /sfCodeViewPlugin/css/sfCodeViewPlugin.css
mod_sfcodeview_enabled: true
mod_sfcodeview_view_class: sfPHP
sf_admin_module_web_dir: /sfDoctrinePlugin
sf_admin_web_dir: /sf/sf_admin
sf_app: frontend
sf_app_base_cache_dir: /www/redotheoffice/codeview/cache/frontend
sf_app_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev
sf_app_config_dir: /www/redotheoffice/codeview/apps/frontend/config
sf_app_dir: /www/redotheoffice/codeview/apps/frontend
sf_app_i18n_dir: /www/redotheoffice/codeview/apps/frontend/i18n
sf_app_lib_dir: /www/redotheoffice/codeview/apps/frontend/lib
sf_app_module_dir: /www/redotheoffice/codeview/apps/frontend/modules
sf_app_template_dir: /www/redotheoffice/codeview/apps/frontend/templates
sf_apps_dir: /www/redotheoffice/codeview/apps
sf_cache: false
sf_cache_dir: /www/redotheoffice/codeview/cache
sf_charset: utf-8
sf_check_lock: false
sf_compressed: false
sf_config_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev/config
sf_config_dir: /www/redotheoffice/codeview/config
sf_csrf_secret: 220ab365e581d678efc07c41371dbc49a1fdcec3
sf_data_dir: /www/redotheoffice/codeview/data
sf_debug: true
sf_default_culture: en
sf_enabled_modules:
- default
- sfCodeView
sf_environment: dev
sf_error_404_action: error404
sf_error_404_module: default
sf_error_reporting: 8191
sf_escaping_method: ESC_SPECIALCHARS
sf_escaping_strategy: true
sf_etag: false
sf_file_link_format: null
sf_i18n: false
sf_i18n_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev/i18n
sf_lib_dir: /www/redotheoffice/codeview/lib
sf_log_dir: /www/redotheoffice/codeview/log
sf_logging_enabled: true
sf_login_action: login
sf_login_module: default
sf_module_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev/modules
sf_module_disabled_action: disabled
sf_module_disabled_module: default
sf_no_script_name: false
sf_orm: doctrine
sf_plugins_dir: /www/redotheoffice/codeview/plugins
sf_root_dir: /www/redotheoffice/codeview
sf_secure_action: secure
sf_secure_module: default
sf_standard_helpers:
- Partial
- Cache
sf_symfony_lib_dir: /www/redotheoffice/lib/symfony/1.4/lib
sf_template_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev/template
sf_test_cache_dir: /www/redotheoffice/codeview/cache/frontend/dev/test
sf_test_dir: /www/redotheoffice/codeview/test
sf_upload_dir: /www/redotheoffice/codeview/web/uploads
sf_use_database: true
sf_web_debug: true
sf_web_debug_web_dir: /sf/sf_web_debug
sf_web_dir: /www/redotheoffice/codeview/web
symfony.asset.javascripts_included: true
symfony.asset.stylesheets_included: true
Globals 
cookie:
symfony: igbg1vov0kr106fi7q336aqd75
env: { }
files: { }
get: { }
post: { }
server:
DOCUMENT_ROOT: /Library/WebServer/Documents
GATEWAY_INTERFACE: CGI/1.1
HTTP_ACCEPT: 'text/html,application/xhtml+xml,text/xml;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5'
HTTP_ACCEPT_CHARSET: 'ISO-8859-1,utf-8;q=0.7,*;q=0.7'
HTTP_ACCEPT_ENCODING: gzip
HTTP_ACCEPT_LANGUAGE: 'en-us,en;q=0.5'
HTTP_CACHE_CONTROL: no-cache
HTTP_CONNECTION: close
HTTP_COOKIE: symfony=igbg1vov0kr106fi7q336aqd75
HTTP_HOST: codeview.redotheoffice.com
HTTP_PRAGMA: no-cache
HTTP_USER_AGENT: 'CCBot/1.0 (+http://www.commoncrawl.org/bot.html)'
HTTP_X_CC_ID: ccc04-02
PATH: '/usr/bin:/bin:/usr/sbin:/sbin'
PATH_INFO: /sfCodeView/sfTesterResponse
PATH_TRANSLATED: 'redirect:/www/redotheoffice/codeview/web/index.php/sfTesterResponse'
PHP_SELF: /index.php/sfCodeView/sfTesterResponse
QUERY_STRING: ''
REMOTE_ADDR: 38.107.179.243
REMOTE_PORT: '46539'
REQUEST_METHOD: GET
REQUEST_TIME: 1337462567
REQUEST_URI: /index.php/sfCodeView/sfTesterResponse
SCRIPT_FILENAME: /www/redotheoffice/codeview/web/index.php
SCRIPT_NAME: /index.php
SERVER_ADDR: 192.168.0.108
SERVER_ADMIN: webmaster@weett.nl
SERVER_NAME: codeview.redotheoffice.com
SERVER_PORT: '80'
SERVER_PROTOCOL: HTTP/1.1
SERVER_SIGNATURE: ''
SERVER_SOFTWARE: 'Apache/2.2.21 (Unix) mod_ssl/2.2.21 OpenSSL/0.9.8r DAV/2 PHP/5.3.6'
session:
symfony/user/sfUser/attributes: { symfony/user/sfUser/attributes: { history: [sfTesterRequest, sfTesterMailer, sfTesterForm, sfTester, sfTestUnitTask, sfTestFunctionalTask, sfTestFunctional, sfTestCoverageTask, sfTestBrowser, sfTestBaseTask] } }
symfony/user/sfUser/authenticated: false
symfony/user/sfUser/credentials: { }
symfony/user/sfUser/culture: en
symfony/user/sfUser/lastRequest: 1337462538
Php 
php: 5.3.6
os: 'Darwin Mac-mini-van-Sjoerd-de-Jong.local 10.8.0 Darwin Kernel Version 10.8.0: Tue Jun 7 16:33:36 PDT 2011; root:xnu-1504.15.3~1/RELEASE_I386 i386'
extensions:
54: apache2handler
33: 'apc (3.1.7)'
8: bcmath
9: bz2
10: calendar
0: 'Core (5.3.6)'
11: ctype
56: curl
1: 'date (5.3.6)'
12: 'dom (20031129)'
2: ereg
42: 'exif (1.4 $Id: exif.c 308362 2011-02-15 14:02:26Z pajoye $)'
14: 'fileinfo (1.0.5-dev)'
15: 'filter (0.11.0)'
16: ftp
17: gd
18: gettext
13: 'hash (1.0)'
20: iconv
36: imap
57: 'intl (1.1.0)'
22: 'json (1.2.1)'
23: ldap
3: libxml
24: mbstring
58: mcrypt
59: 'memcache (3.0.4)'
60: 'memcached (1.0.1)'
71: mhash
61: 'mongo (1.1.4)'
62: mssql
29: 'mysql (1.0)'
27: 'mysqli (0.1)'
26: 'mysqlnd (mysqlnd 5.0.8-dev - 20102224 - $Revision: 308673 $)'
63: 'OAuth (1.0-dev)'
28: 'odbc (1.0)'
4: openssl
5: pcre
30: 'PDO (1.0.4dev)'
64: 'pdo_dblib (1.0.1)'
31: 'pdo_mysql (1.0.2)'
65: 'pdo_pgsql (1.0.2)'
32: 'pdo_sqlite (1.0.1)'
66: pgsql
55: 'Phar (2.0.1)'
34: posix
35: 'Reflection ($Revision: 307971 $)'
21: session
37: shmop
38: 'SimpleXML (0.1)'
39: soap
40: sockets
67: 'solr (0.9.11)'
19: 'SPL (0.2)'
41: 'SQLite (2.0-dev)'
6: 'sqlite3 (0.7-dev)'
25: 'standard (5.3.6)'
43: sysvmsg
44: sysvsem
45: sysvshm
46: 'tidy (2.0)'
47: 'tokenizer (0.1)'
68: 'uploadprogress (1.0.1)'
48: wddx
72: 'xdebug (2.2.0-dev)'
69: 'xhprof (0.9.2)'
49: xml
50: 'xmlreader (0.1)'
51: 'xmlrpc (0.51)'
52: 'xmlwriter (0.1)'
70: 'xsl (0.1)'
53: 'zip (1.9.1)'
7: 'zlib (1.1)'
Symfony 
version: 1.4.2-DEV
path: /www/redotheoffice/lib/symfony/1.4/lib
View Layer
Template: sfCodeView … indexSuccess.php 
Parameters:
$class (string)
$method (NULL)
$viewer (sfCodeViewer)
$history (array)
Logs
| # |
type |
message |
| 1 | sfPatternRouting | Match route "sfCodeView" (/sfCodeView/:class/:method) for /sfCodeView/sfTesterResponse with parameters array ( 'module' => 'sfCodeView', 'action' => 'index', 'class' => 'sfTesterResponse', 'method' => '',) |
| 2 | sfFilterChain | Executing filter "sfRenderingFilter" |
| 3 | sfFilterChain | Executing filter "sfExecutionFilter" |
| 4 | sfCodeViewActions | Call "sfCodeViewActions->executeIndex()" |
| 5 | sfPHPView | Render "sf_root_dir/plugins/sfCodeViewPlugin/modules/sfCodeView/templates/indexSuccess.php" |
| 6 | sfPHPView | Decorate content with "sf_app_dir/templates/layout.php" |
| 7 | sfPHPView | Render "sf_app_dir/templates/layout.php" |
| 8 | sfWebResponse | Send status "HTTP/1.1 200 OK" |
| 9 | sfWebResponse | Send header "Content-Type: text/html; charset=utf-8" |
Timers
| type | calls | time (ms) | time (%) |
|---|
| Configuration | 11 | 33.26 | 5 |
| Factories | 1 | 6.48 | 1 |
| Action "sfCodeView/index" | 1 | 392.00 | 63 |
| View "Success" for "sfCodeView/index" | 1 | 184.78 | 29 |
View php class code
Enter the name of a class you want to view in the toolbar and hit 'enter' to view its code, or click one of the available classes below.
User classes
- apps/frontend/config
- apps/frontend/lib
- config
- lib/form
- plugins/sfCodeViewPlugin/config
- plugins/sfCodeViewPlugin/lib
- plugins/sfCodeViewPlugin/modules/sfCodeView/actions
- plugins/sfCodeViewPlugin/modules/sfCodeView/lib
Symfony classes
- action
- addon
- autoload
- cache
- command
- config
- controller
- database
- debug
- escaper
- exception
- filter
- form/addon
- form
- generator
- i18n/Gettext
- i18n/extract
- i18n
- log
- mailer
- plugin
- request
- response
- routing
- storage
- task/app
- task/cache
- task/configure
- task/generator
- task/help
- task/i18n
- task/log
- task/plugin
- task/project
- task/project/validation
- task
- task/symfony
- task/test
- test
- user
- util
- validator/i18n
- validator
- view
- widget/i18n
- widget