mirror of
https://github.com/php/php-src.git
synced 2026-04-12 18:43:37 +02:00
This patch adds missing newlines, trims multiple redundant final newlines into a single one, and trims redundant leading newlines in all *.phpt sections. According to POSIX, a line is a sequence of zero or more non-' <newline>' characters plus a terminating '<newline>' character. [1] Files should normally have at least one final newline character. C89 [2] and later standards [3] mention a final newline: "A source file that is not empty shall end in a new-line character, which shall not be immediately preceded by a backslash character." Although it is not mandatory for all files to have a final newline fixed, a more consistent and homogeneous approach brings less of commit differences issues and a better development experience in certain text editors and IDEs. [1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206 [2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2 [3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
117 lines
2.7 KiB
PHP
117 lines
2.7 KiB
PHP
--TEST--
|
|
Test session_set_save_handler() : basic class wrapping existing handler
|
|
--INI--
|
|
session.use_strict_mode=1
|
|
session.name=PHPSESSID
|
|
session.save_handler=files
|
|
--SKIPIF--
|
|
<?php include('skipif.inc'); ?>
|
|
--FILE--
|
|
<?php
|
|
|
|
ob_start();
|
|
|
|
/*
|
|
* Prototype : bool session_set_save_handler(SessionHandler $handler [, bool $register_shutdown_function = true])
|
|
* Description : Sets user-level session storage functions
|
|
* Source code : ext/session/session.c
|
|
*/
|
|
|
|
echo "*** Testing session_set_save_handler() : basic class wrapping existing handler ***\n";
|
|
|
|
class MySession extends SessionHandler {
|
|
public $i = 0;
|
|
public function open($path, $name) {
|
|
++$this->i;
|
|
echo 'Open ', session_id(), "\n";
|
|
return parent::open($path, $name);
|
|
}
|
|
public function create_sid() {
|
|
// This method should be removed when 5.5 become unsupported.
|
|
++$this->i;
|
|
echo 'Old Create SID ', session_id(), "\n";
|
|
return parent::create_sid();
|
|
}
|
|
public function read($key) {
|
|
++$this->i;
|
|
echo 'Read ', session_id(), "\n";
|
|
return parent::read($key);
|
|
}
|
|
public function write($key, $data) {
|
|
++$this->i;
|
|
echo 'Write ', session_id(), "\n";
|
|
return parent::write($key, $data);
|
|
}
|
|
public function close() {
|
|
++$this->i;
|
|
echo 'Close ', session_id(), "\n";
|
|
return parent::close();
|
|
}
|
|
public function createSid() {
|
|
// User should use this rather than create_sid()
|
|
// If both create_sid() and createSid() exists,
|
|
// createSid() is used.
|
|
++$this->i;
|
|
echo 'New Create ID ', session_id(), "\n";
|
|
return parent::create_sid();
|
|
}
|
|
public function validateId($key) {
|
|
++$this->i;
|
|
echo 'Validate ID ', session_id(), "\n";
|
|
return TRUE;
|
|
// User must implement their own method and
|
|
// cannot call parent as follows.
|
|
// return parent::validateSid($key);
|
|
}
|
|
public function updateTimestamp($key, $data) {
|
|
++$this->i;
|
|
echo 'Update Timestamp ', session_id(), "\n";
|
|
return parent::write($key, $data);
|
|
// User must implement their own method and
|
|
// cannot call parent as follows
|
|
// return parent::updateTimestamp($key, $data);
|
|
}
|
|
}
|
|
|
|
$oldHandler = ini_get('session.save_handler');
|
|
$handler = new MySession;
|
|
session_set_save_handler($handler);
|
|
session_start();
|
|
|
|
var_dump(session_id(), $oldHandler, ini_get('session.save_handler'), $handler->i, $_SESSION);
|
|
|
|
$_SESSION['foo'] = "hello";
|
|
|
|
session_write_close();
|
|
session_unset();
|
|
|
|
session_start();
|
|
var_dump($_SESSION);
|
|
|
|
session_write_close();
|
|
session_unset();
|
|
var_dump($handler->i);
|
|
--EXPECTF--
|
|
*** Testing session_set_save_handler() : basic class wrapping existing handler ***
|
|
Open
|
|
Old Create SID
|
|
Read %s
|
|
string(%d) "%s"
|
|
string(5) "files"
|
|
string(4) "user"
|
|
int(3)
|
|
array(0) {
|
|
}
|
|
Write %s
|
|
Close %s
|
|
Open %s
|
|
Validate ID %s
|
|
Read %s
|
|
array(1) {
|
|
["foo"]=>
|
|
string(5) "hello"
|
|
}
|
|
Update Timestamp %s
|
|
Close %s
|
|
int(10)
|