| Server IP : 170.10.162.208 / Your IP : 216.73.216.181 Web Server : LiteSpeed System : Linux altar19.supremepanel19.com 4.18.0-553.69.1.lve.el8.x86_64 #1 SMP Wed Aug 13 19:53:59 UTC 2025 x86_64 User : deltahospital ( 1806) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /tmp/ |
Upload File : |
--TEST--
Bug https://github.com/scoutapp/scout-apm-php-ext/issues/49 - only record arguments for fopen if it returns a resource
--SKIPIF--
<?php if (!extension_loaded("scoutapm")) die("skip scoutapm extension required."); ?>
--FILE--
<?php
scoutapm_enable_instrumentation(true);
// Note, in PHP 8 the warning changed from "failed to open stream" to "Failed to open stream" hence the %c
var_dump(fopen('/this/file/should/not/exist', 'r'));
var_dump(scoutapm_get_calls());
?>
--EXPECTF--
Warning: fopen(%s): %cailed to open stream: No such file or directory in %s
bool(false)
array(0) {
}
--TEST--
Running evaled code does not crash
--SKIPIF--
<?php if (!extension_loaded("scoutapm")) die("skip scoutapm extension required."); ?>
--FILE--
<?php
scoutapm_enable_instrumentation(true);
eval('echo "Evaled code called.\n";');
echo "End.\n";
?>
--EXPECTF--
Evaled code called.
End.
--TEST--
Calls to file_get_contents are logged
--SKIPIF--
<?php if (!extension_loaded("scoutapm")) die("skip scoutapm extension required."); ?>
--FILE--
<?php
var_dump(in_array('file_get_contents', scoutapm_list_instrumented_functions()));
scoutapm_enable_instrumentation(true);
file_get_contents(__FILE__);
$call = scoutapm_get_calls()[0];
var_dump($call['function']);
var_dump($call['entered']);
var_dump($call['exited']);
var_dump($call['time_taken']);
var_dump($call['exited'] > $call['entered']);
var_dump($call['argv']);
?>
--EXPECTF--
bool(true)
string(17) "file_get_contents"
float(%f)
float(%f)
float(%f)
bool(true)
array(1) {
[0]=>
string(%d) "%s%etests%e002-file_get_contents.php"
}
--TEST--
Calls to fwrite and fread are logged with handle from tmpfile()
--SKIPIF--
<?php if (!extension_loaded("scoutapm")) die("skip scoutapm extension required."); ?>
--FILE--
<?php
var_dump(in_array('fread', scoutapm_list_instrumented_functions()));
var_dump(in_array('fwrite', scoutapm_list_instrumented_functions()));
scoutapm_enable_instrumentation(true);
$fh = tmpfile();
fwrite($fh, "fread/fwrite test\n");
fseek($fh, 0);
echo fread($fh, 18);
fclose($fh);
$calls = scoutapm_get_calls();
var_dump($calls[0]['function']);
var_dump($calls[0]['argv']);
var_dump($calls[1]['function']);
var_dump($calls[1]['argv']);
?>
--EXPECTF--
bool(true)
bool(true)
fread/fwrite test
string(6) "fwrite"
array(2) {
[0]=>
string(%d) "resource(%d)"
[1]=>
string(18) "fread/fwrite test
"
}
string(5) "fread"
array(2) {
[0]=>
string(%d) "resource(%d)"
[1]=>
int(18)
}
--TEST--
Memcached C extension functions are instrumented
--SKIPIF--
<?php
if (!extension_loaded("scoutapm")) die("skip scoutapm extension required.");
if (!extension_loaded("memcached")) die("skip memcached extension required.");
if (!getenv('CI')) {
// Check Memcached is running & can connect to it
// Run with: docker run --rm --name memcached -p 11211:11211 -d memcached
$m = new Memcached();
$m->addServer('localhost', 11211);
if (!$m->flush()) {
die("skip Could not connect to Memcached - is it running?");
}
}
?>
--FILE--
<?php
echo implode("\n", array_intersect(
[
'memcached->add',
'memcached->addbykey',
'memcached->append',
'memcached->appendbykey',
'memcached->cas',
'memcached->decrement',
'memcached->decrementbykey',
'memcached->delete',
'memcached->deletebykey',
'memcached->deletemulti',
'memcached->deletemultibykey',
'memcached->flush',
'memcached->get',
'memcached->getallkeys',
'memcached->getbykey',
'memcached->getmulti',
'memcached->getmultibykey',
'memcached->increment',
'memcached->incrementbykey',
'memcached->prepend',
'memcached->prependbykey',
'memcached->replace',
'memcached->replacebykey',
'memcached->set',
'memcached->setbykey',
'memcached->setmulti',
'memcached->setmultibykey',
],
scoutapm_list_instrumented_functions()
)) . "\n";
scoutapm_enable_instrumentation(true);
$m = new Memcached();
$m->addServer('localhost', 11211);
$m->setOption(Memcached::OPT_COMPRESSION, false);
$m->set('foo', 'bar');
var_dump($m->get('foo'));
$m->append('foo', 'baz');
$m->prepend('foo', 'gaz');
$m->replace('foo', 'bar');
$m->cas(0, 'foo', 'bar');
$m->add('num', 1);
$m->decrement('num');
$m->increment('num');
$m->delete('num');
$m->setMulti(['a' => 'a', 'b' => 'b']);
$m->getMulti(['a', 'b']);
$m->deleteMulti(['a', 'b']);
$m->setByKey('key', 'foo', 'bar');
$m->getByKey('key', 'foo');
$m->appendByKey('key', 'foo', 'baz');
$m->prependByKey('key', 'foo', 'gaz');
$m->replaceByKey('key', 'foo', 'bar');
$m->casByKey(0, 'key', 'foo', 'bar');
$m->addByKey('key', 'num', 1);
$m->decrementByKey('key', 'num');
$m->incrementByKey('key', 'num');
$m->deleteByKey('key', 'num');
$m->setMultiByKey('key', ['a' => 'a', 'b' => 'b']);
$m->getMultiByKey('key', ['a', 'b']);
$m->deleteMultiByKey('key', ['a', 'b']);
$m->getAllKeys();
$m->flush();
$calls = scoutapm_get_calls();
var_dump(array_column($calls, 'function'));
?>
--EXPECTF--
memcached->add
memcached->addbykey
memcached->append
memcached->appendbykey
memcached->cas
memcached->decrement
memcached->decrementbykey
memcached->delete
memcached->deletebykey
memcached->deletemulti
memcached->deletemultibykey
memcached->flush
memcached->get
memcached->getallkeys
memcached->getbykey
memcached->getmulti
memcached->getmultibykey
memcached->increment
memcached->incrementbykey
memcached->prepend
memcached->prependbykey
memcached->replace
memcached->replacebykey
memcached->set
memcached->setbykey
memcached->setmulti
memcached->setmultibykey
string(%s) "bar"
array(%d) {
[%d]=>
string(%d) "Memcached->set"
[%d]=>
string(%d) "Memcached->get"
[%d]=>
string(%d) "Memcached->append"
[%d]=>
string(%d) "Memcached->prepend"
[%d]=>
string(%d) "Memcached->replace"
[%d]=>
string(%d) "Memcached->cas"
[%d]=>
string(%d) "Memcached->add"
[%d]=>
string(%d) "Memcached->decrement"
[%d]=>
string(%d) "Memcached->increment"
[%d]=>
string(%d) "Memcached->delete"
[%d]=>
string(%d) "Memcached->setMulti"
[%d]=>
string(%d) "Memcached->getMulti"
[%d]=>
string(%d) "Memcached->deleteMulti"
[%d]=>
string(%d) "Memcached->setByKey"
[%d]=>
string(%d) "Memcached->getByKey"
[%d]=>
string(%d) "Memcached->appendByKey"
[%d]=>
string(%d) "Memcached->prependByKey"
[%d]=>
string(%d) "Memcached->replaceByKey"
[%d]=>
string(%d) "Memcached->casByKey"
[%d]=>
string(%d) "Memcached->addByKey"
[%d]=>
string(%d) "Memcached->decrementByKey"
[%d]=>
string(%d) "Memcached->incrementByKey"
[%d]=>
string(%d) "Memcached->deleteByKey"
[%d]=>
string(%d) "Memcached->setMultiByKey"
[%d]=>
string(%d) "Memcached->getMultiByKey"
[%d]=>
string(%d) "Memcached->deleteMultiByKey"
[%d]=>
string(%d) "Memcached->getAllKeys"
[%d]=>
string(%d) "Memcached->flush"
}
--TEST--
Check Scout APM extension is loaded
--FILE--
<?php
ob_start();
phpinfo(INFO_GENERAL);
$phpinfo = ob_get_clean();
foreach (explode("\n", $phpinfo) as $line) {
if (stripos($line, ' with scoutapm') === 0) {
var_dump($line);
}
}
var_dump(extension_loaded('scoutapm'));
?>
--EXPECTF--
string(%d) " with scoutapm v%s, Copyright %d, by Scout APM"
bool(true)