/** * @dataProvider providerLog */ public function testLog($level, $expected) { $runName = uniqid('', true); $fileName = 'testfile_log_' . date('Ymd_His') . '_' . $runName . '.log'; if (file_exists('test_data/' . $fileName)) { $filesystem = new Filesystem(); $filesystem->remove('test_data/' . $fileName); } $log = new Logger('tester'); $log->pushHandler(new StreamHandler('test_data/' . $fileName, $level)); $log->debug('test1'); $log->info('test2'); $log->notice('test3'); $log->warning('test4'); $log->error('test5'); $log->critical('test6'); $log->alert('test7'); $log->emergency('test8'); $this->assertRegExp('/^' . $expected . '/s', file_get_contents('test_data/' . $fileName)); }
private function sendGenTestDataBridge() { $dirName1 = 'testdir_client1_' . date('Ymd_His') . '_' . uniqid('', true); $dirName2 = 'testdir_client2_' . date('Ymd_His') . '_' . uniqid('', true); $dirName3 = 'testdir_client3_' . date('Ymd_His') . '_' . uniqid('', true); $filesystem = new Filesystem(); $filesystem->mkdir('test_data/' . $dirName1, $mode = 0777); $filesystem->mkdir('test_data/' . $dirName2, $mode = 0777); $filesystem->mkdir('test_data/' . $dirName3, $mode = 0777); file_put_contents('test_data/' . $dirName1 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV1); file_put_contents('test_data/' . $dirName1 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB1); file_put_contents('test_data/' . $dirName2 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV2); file_put_contents('test_data/' . $dirName2 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB2); file_put_contents('test_data/' . $dirName3 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV3); file_put_contents('test_data/' . $dirName3 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB3); $localNode1 = new Node(); $localNode1->setUri('tcp://127.0.0.1:25000'); $localNode1->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1738'); $table1 = new Table('test_data/' . $dirName1 . '/table.yml'); $table1->setDatadirBasePath('test_data/' . $dirName1); $table1->setLocalNode($localNode1); $table1->setDataChanged(true); $table1->save(); $localNode2 = new Node(); $localNode2->setUri('tcp://127.0.0.2:25000'); $localNode2->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1739'); $table2 = new Table('test_data/' . $dirName2 . '/table.yml'); $table2->setDatadirBasePath('test_data/' . $dirName2); $table2->setLocalNode($localNode2); $table2->setDataChanged(true); $table2->save(); $localNode3 = new Node(); $localNode3->setUri('tcp://127.0.0.3:25000'); $localNode3->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1740'); $table3 = new Table('test_data/' . $dirName3 . '/table.yml'); $table3->setDatadirBasePath('test_data/' . $dirName3); $table3->setLocalNode($localNode3); $table3->setDataChanged(true); $table3->save(); $settings1 = new Settings(); $settings1->data['datadir'] = 'test_data/' . $dirName1; $settings1->data['firstRun'] = false; $settings1->data['timeCreated'] = time(); $settings1->data['node']['uriLocal'] = 'tcp://127.0.0.1'; $settings1->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB1); $settings1->data['node']['sslKeyPrvPass'] = '******'; $settings1->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName1 . '/id_rsa.prv'; $settings1->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName1 . '/id_rsa.pub'; $settings1->data['user']['nickname'] = 'user1'; $settings1->data['node']['bridge']['client']['enabled'] = true; $settings2 = new Settings(); $settings2->data['datadir'] = 'test_data/' . $dirName2; $settings2->data['firstRun'] = false; $settings2->data['timeCreated'] = time(); $settings2->data['node']['uriLocal'] = 'tcp://127.0.0.2'; $settings2->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB2); $settings2->data['node']['sslKeyPrvPass'] = '******'; $settings2->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName2 . '/id_rsa.prv'; $settings2->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName2 . '/id_rsa.pub'; $settings2->data['user']['nickname'] = 'user2'; $settings2->data['node']['bridge']['server']['enabled'] = true; $settings3 = new Settings(); $settings3->data['datadir'] = 'test_data/' . $dirName3; $settings3->data['firstRun'] = false; $settings3->data['timeCreated'] = time(); $settings3->data['node']['uriLocal'] = 'tcp://127.0.0.3'; $settings3->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB2); $settings3->data['node']['sslKeyPrvPass'] = '******'; $settings3->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName3 . '/id_rsa.prv'; $settings3->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName3 . '/id_rsa.pub'; $settings3->data['user']['nickname'] = 'user3'; $settings3->data['node']['bridge']['client']['enabled'] = true; $log1 = new Logger('client_1'); $log1->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $log2 = new Logger('client_2'); $log2->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $log3 = new Logger('client_2'); $log3->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $kernel1 = new Kernel(); $kernel1->setLog($log1); $kernel1->setSettings($settings1); $kernel1->init(); $kernel2 = new Kernel(); $kernel2->setLog($log2); $kernel2->setSettings($settings2); $kernel2->init(); $kernel3 = new Kernel(); $kernel3->setLog($log3); $kernel3->setSettings($settings3); $kernel3->init(); $server1 = $kernel1->getServer(); $server1->setLog($log1); $server2 = $kernel2->getServer(); $server2->setLog($log2); $server3 = $kernel3->getServer(); $server3->setLog($log3); $client1 = new Client(); $client1->debug = true; $client1->setSslPrv($settings1->data['node']['sslKeyPrvPath'], $settings1->data['node']['sslKeyPrvPass']); $client1->setId(1); $client1->setUri($settings1->data['node']['uriLocal']); $client1->setServer($server1); $this->assertEquals($settings1->data['node']['uriLocal'], 'tcp://' . $client1->getUri()->getHost()); #fwrite(STDOUT, 'ip1: /'.$client1->getUri()->getHost().'/'."\n"); $client2 = new Client(); $client2->debug = true; $client2->setSslPrv($settings2->data['node']['sslKeyPrvPath'], $settings2->data['node']['sslKeyPrvPass']); $client2->setId(2); $client2->setUri($settings2->data['node']['uriLocal']); $client2->setServer($server2); $this->assertEquals($settings2->data['node']['uriLocal'], 'tcp://' . $client2->getUri()->getHost()); #fwrite(STDOUT, 'ip2: /'.$client2->getUri()->getHost().'/'."\n"); $client3 = new Client(); $client3->debug = true; $client3->setSslPrv($settings3->data['node']['sslKeyPrvPath'], $settings3->data['node']['sslKeyPrvPass']); $client3->setId(3); $client3->setUri($settings3->data['node']['uriLocal']); $client3->setServer($server3); $this->assertEquals($settings3->data['node']['uriLocal'], 'tcp://' . $client3->getUri()->getHost()); #fwrite(STDOUT, 'ip3: /'.$client3->getUri()->getHost().'/'."\n"); return array($client1, $client2, $client3); }
exit(1); } require_once __DIR__ . '/vendor/autoload.php'; use Rhumsaa\Uuid\Uuid; use Rhumsaa\Uuid\Exception\UnsatisfiedDependencyException; use Symfony\Component\Filesystem\Filesystem; use Zend\Uri\UriFactory; use TheFox\Logger\Logger; use TheFox\Logger\StreamHandler; use TheFox\PhpChat\Settings; use TheFox\Dht\Kademlia\Node; $filesystem = new Filesystem(); $filesystem->mkdir('log', 0700); $filesystem->mkdir('pid', 0700); $log = new Logger('main'); $log->pushHandler(new StreamHandler('php://stdout', Logger::INFO)); $log->pushHandler(new StreamHandler('log/bootstrap.log', Logger::DEBUG)); UriFactory::registerScheme('tcp', 'TheFox\\PhpChat\\TcpUri'); UriFactory::registerScheme('http', 'TheFox\\PhpChat\\HttpUri'); $settings = new Settings(__DIR__ . '/settings.yml'); if (isset($settings->data['datadir']) && !file_exists($settings->data['datadir'])) { $log->info('create datadir: ' . $settings->data['datadir']); $filesystem->mkdir($settings->data['datadir'], 0700); } if (!$settings->data['node']['sslKeyPrvPass']) { $sslKeyPrvPass = ''; try { $log->info('ssl: generate private key password'); $sslKeyPrvPass = (string) Uuid::uuid4(); } catch (UnsatisfiedDependencyException $e) { $log->critical('uuid4: ' . $e->getMessage());