Archive for the ‘php’ tag
Backtrace in PHP
I have been developing in PHP from the last 4-5 years. Since the introduction of OOP concepts in PHP5, the language is getting matured and more ready for large applications.
While working with large projects, one can not avoid logging for error / debug to later diagnose the issues one might face in production. So beside logging some general information and simple errors which PHP throws and we could get from PHP we could also capture the whole backtrace for the code we are running in such case.
It could be easily incorporated in your application. Follow are some modified examples from PHP’s documentation debug_print_backtrace:
//This is backtrace_include.php
//This function modifies the output which PHP provides for debug_print_backtrace
//by dany dot dylan at gmail dot com
function debug_string_backtrace()
{
ob_start();
debug_print_backtrace();
$trace = ob_get_contents();
ob_end_clean();
// Remove first item from backtrace as it's this function which
// is redundant.
$trace = preg_replace ('/^#0\s+' . __FUNCTION__ . "[^\n]*\n/", '', $trace, 1);
// Renumber backtrace items.
$trace = preg_replace ('/^#(\d+)/me', '\'#\' . ($1 - 1)', $trace);
return $trace;
}
function a()
{
return b();
}
function b()
{
return c();
}
function c()
{
return debug_string_backtrace();
}
$trace = a();
echo $trace;
Save the above file as backtrace_include.php and call in the following file:
//This is backtrace_test.php include 'backtrace_include.php';
This will print the following:
#0 c() called at [/home/www/backtrace_include.php:29] #1 b() called at [/home/www/backtrace_include.php:24] #2 a() called at [/home/www/backtrace_include.php:37] #3 include(/home/www/backtrace_include.php) called at [/home/www/backtrace_test.php:3]
Usually in production websites, we don’t print such trace on screen and log this in a file. We will also log such information only in a situation when an error occurs while executing the code.
Array comparison in PHP
While working on a recent project, I had to do some array comparison. I did array comparison by doing the following:
$firstArr = array(2,4,8); $secondArr = array(2,8,4);
According to my requirements the above two arrays are same but if we compare it in PHP, it would not think so due to the presence of value on different indexes. To solve that, I first sorted and then compared these arrays, which gave me the required result.
//sort the arrays using php's sort function
sort($firstArr);
sort($secondArr);
//compare the arrays
if ( $firstArr === $secondArr)
{
echo "Yes. They are equal";
}
else
{
echo "No. They are not.";
}
PHP’s empty and isset function
The best way to check if a variable consists any value or is empty is to use empty function from PHP itself.
$myVar = 0;
if (empty($myVar))
{
echo '$myVar is either 0, empty, or not set at all';
}
Though, while coding in PHP it shouldn’t be confused with isset which checks if a variable is set or not set, whether that variable is empty.
$myVar = 0;
if (isset($myVar))
{
echo '$myVar is set even though it is empty';
}
Testing Automation Setup
On a continuation to my previous post regarding Testing Automation Tools, I will try to write the process through which I went while writing the testing scripts.
The application for which I wanted to do the automated testing is a web based application written in PHP on top of Zend Framework. As Zend Framework follows the MVC pattern, we followed the same pattern. For database, we wrote our own layer and didn’t use the layer which Zend Framework provided.
For testing automation I followed the same design rules, which I followed while designing and writing this application. I wrote testing scripts for each entity in their own files. Then I called them in one main file, which I run when I want to run the regression test. Following is an example configuration file:
//include all files, which are required to run the test cases
_include("webadmin_login.sah");
_include("webadmin_company.sah");
_include("webadmin_user.sah");
_include("webadmin_group.sah");
_include("webadmin_homepage.sah")
_include("webadmin_sysconfig.sah")
//global variables
_setGlobal("companyname", "Test_1");
// login
login("admin", "admin");
// create company info
createCompany("Test_1");
createUser("test1_user1");
createUser("test1_user2");
createUser("test1_user3");
createUser("test1_user4");
createGroup("test1_group");
// homepage
startAll();
stopAll();
refresh();
// logout
logout();
I treat this main script as my main configuration file. Where I declare some global variables, call those scripts which I need to run during my test run. I can include the scripts, which I need to run and can exclude those scripts which I don’t need.
I will continue with this series with further updates on how I wrote automated tests for every individual entity.