Skip to content

Latest commit

 

History

History
89 lines (68 loc) · 1.92 KB

README.md

File metadata and controls

89 lines (68 loc) · 1.92 KB

cat-php

About

CAT was created by Frankie Wu and youyong205 in DaZhongDianPing (大众点评). This copy is translated from the Java version for PHP project.

Usage

use Message\Message;


function __autoload($class)
{
    $path = str_replace("\\", "/", $class);
    require_once($path . '.php');
}



class ExceptionTest
{
    function methodThrowsException()
    {
        throw new Exception;
    }

    public function run()
    {
        try {
            $a = $this->methodThrowsException();
            echo $a;
            echo "hello, world!!!\n";
        } catch (Exception $e) {
            Cat::logError('Error', get_class($e), $e);
        }
    }
}


$test = new ExceptionTest();
$test->run();

class TransactionTest
{
    public function run()
    {
        $transaction = Cat::newTransaction("URL", "/hello/world");

        {
            $t1 = Cat::newTransaction('Invoke', 'method1()');
            sleep(2);
            $t1->setStatus(Message::SUCCESS);
            $t1->addData("Hello", "world");
            $t1->complete();
        }

        {
            $t2 = Cat::newTransaction('Invoke', 'method2()');
            sleep(2);
            $t2->setStatus(Message::SUCCESS);
            $t2->complete();
        }

        {
            $t3 = Cat::newTransaction('Invoke', 'method3()');
            sleep(1);
            {
                $t4 = Cat::newTransaction('Invoke', 'method4()');
                sleep(2);
                $t4->setStatus(Message::SUCCESS);
                $t4->complete();
            }

            $t3->setStatus(Message::SUCCESS);
            $t3->complete();
        }

        $transaction->setStatus(Message::SUCCESS);
        $transaction->addData("Hello, world!");
        $transaction->complete();
    }
}


$test = new TransactionTest();
$test->run();