本文整理匯總了PHP中usingLog函數的典型用法代碼示例。如果您正苦於以下問題:PHP usingLog函數的具體用法?PHP usingLog怎麽用?PHP usingLog使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了usingLog函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: writeToLog
public function writeToLog($msg)
{
// what are we doing?
$log = usingLog()->startAction($msg);
// all done
$log->endAction();
}
示例2: get
/**
* get
*
* @param mixed $url URL to request
* @param array $params GET params to add to the URL
* @param array $headers HTTP headers to use
*
* @return object|string Response sent by the server. If it's JSON, we'll decode it
*/
public function get($url, $params = array(), $headers = array())
{
if (count($headers)) {
// "FromCurl does not support headers yet"
throw new E5xx_NotImplemented(__METHOD__);
}
// create the full URL
if (count($params) > 0) {
$url = $url . '?' . http_build_query($params);
}
// what are we doing?
$log = usingLog()->startAction("HTTP GET '{$url}'");
// create a new cURL resource
$ch = curl_init();
// set URL and other appropriate options
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, 0);
// grab URL and pass it to the browser
$response = curl_exec($ch);
$error = curl_error($ch);
// close cURL resource, and free up system resources
curl_close($ch);
if ($error) {
throw new E5xx_ActionFailed(__METHOD__ . ': ' . $error);
}
// Try and decode it
$decoded = json_decode($response);
if ($decoded) {
$response = $decoded;
}
// all done
$log->endAction();
return $response;
}
示例3: reportShouldAlwaysSucceed
public function reportShouldAlwaysSucceed()
{
// what are we doing?
$log = usingLog()->startAction("this story is expected to always succeed");
// all done
$log->endAction();
}
示例4: writeDataToFile
public function writeDataToFile($params)
{
// shorthand
$filename = $this->args[0];
// what are we doing?
$printer = new DataPrinter();
$logParams = $printer->convertToString($params);
$log = usingLog()->startAction("create YAML file '{$filename}' with contents '{$logParams}'");
// create an instance of the Symfony YAML writer
$writer = new Dumper();
// create the YAML data
$yamlData = $writer->dump($params, 2);
if (!is_string($yamlData) || strlen($yamlData) < 6) {
throw new E5xx_ActionFailed(__METHOD__, "unable to convert data to YAML");
}
// prepend the YAML marker
$yamlData = '---' . PHP_EOL . $yamlData;
// write the file
//
// the loose FALSE test here is exactly what we want, because we want to catch
// both the situation when the write fails, and when there's zero bytes written
if (!file_put_contents($filename, $yamlData)) {
throw new E5xx_ActionFailed(__METHOD__, "unable to write file '{$filename}'");
}
// all done
$log->endAction();
}
示例5: getDataFor
public function getDataFor($metric, $startTime, $endTime)
{
// when are we looking for?
$humanStartTime = date('Y-m-d H:i:s', $startTime);
$humanEndTime = date('Y-m-d H:i:s', $endTime);
// what are we doing?
$log = usingLog()->startAction("get raw data from graphite for '{$metric}' between '{$humanStartTime}' and '{$humanEndTime}'");
// find out where graphite is
$graphiteUrl = fromConfig()->getModuleSetting('graphite.url');
if (substr($graphiteUrl, -1, 1) !== '/') {
$graphiteUrl .= '/';
}
// get the requested data
$response = fromHttp()->get("{$graphiteUrl}render?format=json&target={$metric}&from={$startTime}&until={$endTime}");
// are there any stats in the response?
assertsArray($response->chunks)->isExpectedType();
assertsArray($response->chunks)->isNotEmpty();
// assemble the raw chunks into one string to decode
$rawStats = implode("", $response->chunks);
assertsString($rawStats)->isValidJson();
$stats = json_decode($rawStats);
// all done
$log->endAction();
return $stats;
}
示例6: getProgramIsRunning
public function getProgramIsRunning($programName)
{
// what are we doing?
$log = usingLog()->startAction("is program '{$programName}' running under supervisor on host '{$this->args[0]}'?");
// get the host details
$hostDetails = $this->getHostDetails();
//run the supervisorctl command
$result = usingHost($hostDetails->hostId)->runCommandAndIgnoreErrors("sudo supervisorctl status");
// |egrep '^$programName' | awk '{print \\$2}'");
// did the command succeed?
if ($result->didCommandFail()) {
$msg = "command failed with return code '{$result->returnCode}' and output '{$result->output}'";
$log->endAction($msg);
throw new E5xx_ActionFailed(__METHOD__);
}
// reduce the output down
$lines = explode("\n", $result->output);
$lines = FilterForMatchingRegex::against($lines, "/^{$programName} /");
$lines = FilterColumns::from($lines, "1", ' ');
if (empty($lines)) {
$log->endAction("supervisor does not know about '{$programName}'");
return false;
}
// what happened?
if ($lines[0] == 'RUNNING') {
$log->endAction('current status is RUNNING');
return true;
}
// if we get here, then the program is not RUNNING, and we
// treat that as a failure
$log->endAction('current status is ' . $lines[0]);
return false;
}
示例7: createVm
public function createVm($vmName, $osName, $amiId, $instanceType, $securityGroup)
{
// what are we doing?
$log = usingLog()->startAction("start EC2 VM '{$vmName}', running guest OS '{$osName}', using AMI ID '{$amiId}' and security group '{$securityGroup}'");
// get the aws settings
$awsSettings = fromConfig()->getModuleSetting('aws');
// put the details into an array
$vmDetails = new Ec2VmDetails();
$vmDetails->hostId = $vmName;
$vmDetails->environment = $this->st->getTestEnvironmentName();
$vmDetails->osName = $osName;
$vmDetails->amiId = $amiId;
$vmDetails->type = 'Ec2Vm';
$vmDetails->instanceType = $instanceType;
$vmDetails->securityGroup = $securityGroup;
$vmDetails->keyPairName = $awsSettings->ec2->keyPairName;
$vmDetails->sshUsername = $awsSettings->ec2->sshUsername;
$vmDetails->sshKeyFile = $awsSettings->ec2->sshKeyFile;
$vmDetails->sshOptions = array("-i '" . $awsSettings->ec2->sshKeyFile . "'");
$vmDetails->scpOptions = array("-i '" . $awsSettings->ec2->sshKeyFile . "'");
// create our host adapter
$host = HostLib::getHostAdapter($this->st, $vmDetails->type);
// create our virtual machine
$host->createHost($vmDetails);
// all done
$log->endAction();
}
示例8: query
public function query($sql)
{
// what are we doing?
$log = usingLog()->startAction(["run SQL against '{$this->args[0]}':", $sql]);
// connect
$conn = new mysqli($this->args[0], $this->args[1], $this->args[2]);
if ($conn->connect_errno) {
$log->endAction('unable to connect to database :( - ' . $conn->connect_error);
throw new E5xx_ActionFailed(__METHOD__);
}
// switch database
if (isset($this->args[2])) {
if (!$conn->select_db($this->args[3])) {
$log->endAction("unable to switch to database '{$this->args[2]}' - " . $conn->error);
throw new E5xx_ActionFailed(__METHOD__);
}
}
// run the SQL
$result = $conn->query($sql);
// what happened?
if (!$result) {
$log->endAction("failed to run query");
throw new E5xx_ActionFailed(__METHOD__, "query failed - " . $conn->error);
}
// success
$log->endAction();
return $result;
}
示例9: runSilently
public function runSilently($cmd)
{
// enforce our inputs
Contract::RequiresValue($cmd, is_string($cmd));
// what are we doing?
$log = usingLog()->startAction("run command: {$cmd}");
// the output that we will return to the caller
$output = '';
// how we will talk with the command
$pipesSpec = [['file', 'php://stdin', 'r'], ['pipe', 'w'], ['pipe', 'w']];
$pipes = [];
// start the process
$process = proc_open($cmd, $pipesSpec, $pipes);
// was there a problem?
//
// NOTE: this only occurs when something like a fork() failure
// happens, which makes it very difficult to test for in a
// unit test
// @codeCoverageIgnoreStart
if (!$process) {
$return = new CommandResult(255, '');
return $return;
}
// @codeCoverageIgnoreEnd
// we do not want to block whilst reading from the child process's
// stdout and stderr
stream_set_blocking($pipes[1], 0);
stream_set_blocking($pipes[2], 0);
// at this point, our command may be running ...
// OR our command may have failed with an error
//
// best thing to do is to keep reading from our pipes until
// the pipes no longer exist
while (!feof($pipes[1]) || !feof($pipes[2])) {
// block until there is something to read, or until the
// timeout has happened
//
// this makes sure that we do not burn CPU for the sake of it
$readable = [$pipes[1], $pipes[2]];
$writeable = $except = [];
stream_select($readable, $writeable, $except, 1);
// check all the streams for output
if ($line = fgets($pipes[1])) {
$log->captureOutput(rtrim($line));
$output = $output . $line;
}
if ($line = fgets($pipes[2])) {
$log->captureOutput(rtrim($line));
$output = $output . $line;
}
}
// at this point, our pipes have been closed
// we can assume that the child process has finished
$retval = proc_close($process);
// all done
$log->endAction("return code is '{$retval}'");
$result = new CommandResult($retval, $output);
return $result;
}
示例10: createDefinition
public function createDefinition()
{
// what are we doing?
$log = usingLog()->startAction("create empty provisioning definition");
// all done
$log->endAction();
return new ProvisioningDefinition();
}
示例11: removeCurrentTestEnvironment
/**
* @return void
*/
public function removeCurrentTestEnvironment()
{
// what are we doing?
$log = usingLog()->startAction("remove current test environment from targets table");
// get the details to remove
$testEnvName = $this->st->getTestEnvironmentName();
// remove it
usingRuntimeTable($this->entryKey)->removeItem($testEnvName);
// all done
$log->endAction();
}
示例12: generateUuid
public function generateUuid()
{
// what are we doing?
$log = usingLog()->startAction("generate a UUID");
// do we have the UUID extension?
$uuid = uuid_create();
// log it
$log->endAction("'{$uuid}'");
// all done
return $uuid;
}
示例13: getTmpFileName
public function getTmpFileName()
{
// what are we doing?
$log = usingLog()->startAction("generate a temporary filename");
// create it
$filename = tempnam(null, 'storyplayer-data-');
// log it
$log->endAction("'{$filename}'");
// all done
return $filename;
}
示例14: __call
public function __call($moduleName, $params)
{
// what are we doing?
$log = usingLog()->startAction("for each host with role '{$this->roleName}' ...");
// get the hosts details
$hostsDetails = $this->retrieveHostsDetails();
// build the iterator that we're going to use
$return = new DelayedHostsModuleIterator($this->st, $hostsDetails, $moduleName);
// all done
$log->endAction();
return $return;
}
示例15: startHornetDrone
public function startHornetDrone($clientName, $clientParams)
{
// what are we doing?
$log = usingLog()->startAction("start hornet-drone '{$clientName}' with params '(" . implode(', ', $clientParams) . ")");
// build the command to run
$appSettings = fromStoryplayer()->getAppSettings('hornet');
$command = $appSettings->path . '/hornet-drone ' . implode(' ', $clientParams);
// run the command in a screen session
usingShell()->startInScreen($clientName, $command);
// all done
$log->endAction();
}