Merge branch 'develop' into matthewpi/server-details-patch-1
This commit is contained in:
commit
8241ea5f98
3 changed files with 2 additions and 163 deletions
|
@ -25,7 +25,7 @@ I would like to extend my sincere thanks to the following sponsors for helping f
|
||||||
| [**MineStrator**](https://minestrator.com/) | Looking for a French highend hosting company for you minecraft server? More than 14,000 members on our discord, trust us. |
|
| [**MineStrator**](https://minestrator.com/) | Looking for a French highend hosting company for you minecraft server? More than 14,000 members on our discord, trust us. |
|
||||||
| [**DedicatedMC**](https://dedicatedmc.io/) | DedicatedMC provides Raw Power hosting at affordable pricing, making sure to never compromise on your performance and giving you the best performance money can buy. |
|
| [**DedicatedMC**](https://dedicatedmc.io/) | DedicatedMC provides Raw Power hosting at affordable pricing, making sure to never compromise on your performance and giving you the best performance money can buy. |
|
||||||
| [**Skynode**](https://www.skynode.pro/) | Skynode provides blazing fast game servers along with a top-notch user experience. Whatever our clients are looking for, we're able to provide it! |
|
| [**Skynode**](https://www.skynode.pro/) | Skynode provides blazing fast game servers along with a top-notch user experience. Whatever our clients are looking for, we're able to provide it! |
|
||||||
| [**XCORE-SERVER.de**](https://xcore-server.de/) | XCORE-SERVER.de offers High-End Servers for hosting and gaming since 2012. Fast, excellent and well-known for eSports Gaming. |
|
| [**XCORE**](https://xcore-server.de/) | XCORE offers High-End Servers for hosting and gaming since 2012. Fast, excellent and well-known for eSports Gaming. |
|
||||||
| [**RoyaleHosting**](https://royalehosting.net/) | Build your dreams and deploy them with RoyaleHosting’s reliable servers and network. Easy to use, provisioned in a couple of minutes. |
|
| [**RoyaleHosting**](https://royalehosting.net/) | Build your dreams and deploy them with RoyaleHosting’s reliable servers and network. Easy to use, provisioned in a couple of minutes. |
|
||||||
| [**Spill Hosting**](https://spillhosting.no/) | Spill Hosting is a Norwegian hosting service, which aims to cheap services on quality servers. Premium i9-9900K processors will run your game like a dream. |
|
| [**Spill Hosting**](https://spillhosting.no/) | Spill Hosting is a Norwegian hosting service, which aims to cheap services on quality servers. Premium i9-9900K processors will run your game like a dream. |
|
||||||
| [**DeinServerHost**](https://deinserverhost.de/) | DeinServerHost offers Dedicated, vps and Gameservers for many popular Games like Minecraft and Rust in Germany since 2013. |
|
| [**DeinServerHost**](https://deinserverhost.de/) | DeinServerHost offers Dedicated, vps and Gameservers for many popular Games like Minecraft and Rust in Germany since 2013. |
|
||||||
|
|
|
@ -131,7 +131,7 @@ export default ({ database, className }: Props) => {
|
||||||
</div>
|
</div>
|
||||||
</Can>
|
</Can>
|
||||||
<div css={tw`mt-6`}>
|
<div css={tw`mt-6`}>
|
||||||
<Label>JBDC Connection String</Label>
|
<Label>JDBC Connection String</Label>
|
||||||
<CopyOnClick text={`jdbc:mysql://${database.username}:${database.password}@${database.connectionString}/${database.name}`}>
|
<CopyOnClick text={`jdbc:mysql://${database.username}:${database.password}@${database.connectionString}/${database.name}`}>
|
||||||
<Input
|
<Input
|
||||||
type={'text'}
|
type={'text'}
|
||||||
|
|
|
@ -1,161 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace Tests\Unit\Commands\Server;
|
|
||||||
|
|
||||||
use Mockery as m;
|
|
||||||
use Pterodactyl\Models\Node;
|
|
||||||
use GuzzleHttp\Psr7\Response;
|
|
||||||
use Pterodactyl\Models\Server;
|
|
||||||
use Illuminate\Support\Collection;
|
|
||||||
use Illuminate\Validation\Factory;
|
|
||||||
use Tests\Unit\Commands\CommandTestCase;
|
|
||||||
use Illuminate\Validation\ValidationException;
|
|
||||||
use Pterodactyl\Repositories\Wings\DaemonPowerRepository;
|
|
||||||
use Pterodactyl\Console\Commands\Server\BulkPowerActionCommand;
|
|
||||||
use Pterodactyl\Contracts\Repository\ServerRepositoryInterface;
|
|
||||||
|
|
||||||
class BulkPowerActionCommandTest extends CommandTestCase
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @var \Mockery\MockInterface
|
|
||||||
*/
|
|
||||||
private $powerRepository;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var \Mockery\MockInterface
|
|
||||||
*/
|
|
||||||
private $repository;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Setup test.
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
parent::setUp();
|
|
||||||
|
|
||||||
$this->powerRepository = m::mock(DaemonPowerRepository::class);
|
|
||||||
$this->repository = m::mock(ServerRepositoryInterface::class);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test that an action can be sent to all servers.
|
|
||||||
*/
|
|
||||||
public function testSendAction()
|
|
||||||
{
|
|
||||||
/** @var \Pterodactyl\Models\Server[] $servers */
|
|
||||||
$servers = factory(Server::class)->times(2)->make();
|
|
||||||
|
|
||||||
foreach ($servers as &$server) {
|
|
||||||
$server->setRelation('node', factory(Node::class)->make());
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->repository->expects('getServersForPowerActionCount')->with([], [])->andReturn(2);
|
|
||||||
$this->repository->expects('getServersForPowerAction')->with([], [])->andReturn($servers);
|
|
||||||
|
|
||||||
for ($i = 0; $i < count($servers); $i++) {
|
|
||||||
$this->powerRepository->expects('setServer->send')->with('kill')->andReturnNull();
|
|
||||||
}
|
|
||||||
|
|
||||||
$display = $this->runCommand($this->getCommand(), ['action' => 'kill'], ['yes']);
|
|
||||||
|
|
||||||
$this->assertNotEmpty($display);
|
|
||||||
$this->assertStringContainsString('2/2', $display);
|
|
||||||
$this->assertStringContainsString(trans('command/messages.server.power.confirm', ['action' => 'kill', 'count' => 2]), $display);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test filtering servers and nodes.
|
|
||||||
*/
|
|
||||||
public function testSendWithFilters()
|
|
||||||
{
|
|
||||||
$server = factory(Server::class)->make();
|
|
||||||
$server->setRelation('node', $node = factory(Node::class)->make());
|
|
||||||
|
|
||||||
$this->repository->expects('getServersForPowerActionCount')
|
|
||||||
->with([1, 2], [3, 4])
|
|
||||||
->andReturn(1);
|
|
||||||
|
|
||||||
$this->repository->expects('getServersForPowerAction')
|
|
||||||
->with([1, 2], [3, 4])
|
|
||||||
->andReturn(Collection::make([$server]));
|
|
||||||
|
|
||||||
$this->powerRepository->expects('setNode')->with($node)->andReturnSelf();
|
|
||||||
$this->powerRepository->expects('setServer')->with($server)->andReturnSelf();
|
|
||||||
$this->powerRepository->expects('send')->with('kill')->andReturn(new Response);
|
|
||||||
|
|
||||||
$display = $this->runCommand($this->getCommand(), [
|
|
||||||
'action' => 'kill',
|
|
||||||
'--servers' => '1,2',
|
|
||||||
'--nodes' => '3,4',
|
|
||||||
], ['yes']);
|
|
||||||
|
|
||||||
$this->assertNotEmpty($display);
|
|
||||||
$this->assertStringContainsString('1/1', $display);
|
|
||||||
$this->assertStringContainsString(trans('command/messages.server.power.confirm', ['action' => 'kill', 'count' => 1]), $display);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test that sending empty options returns the expected results.
|
|
||||||
*/
|
|
||||||
public function testSendWithEmptyOptions()
|
|
||||||
{
|
|
||||||
$server = factory(Server::class)->make();
|
|
||||||
$server->setRelation('node', factory(Node::class)->make());
|
|
||||||
|
|
||||||
$this->repository->expects('getServersForPowerActionCount')
|
|
||||||
->with([], [])
|
|
||||||
->andReturn(1);
|
|
||||||
|
|
||||||
$this->repository->expects('getServersForPowerAction')->with([], [])->andReturn(Collection::make([$server]));
|
|
||||||
$this->powerRepository->expects('setServer->send')->with('kill')->andReturnNull();
|
|
||||||
|
|
||||||
$display = $this->runCommand($this->getCommand(), [
|
|
||||||
'action' => 'kill',
|
|
||||||
'--servers' => '',
|
|
||||||
'--nodes' => '',
|
|
||||||
], ['yes']);
|
|
||||||
|
|
||||||
$this->assertNotEmpty($display);
|
|
||||||
$this->assertStringContainsString('1/1', $display);
|
|
||||||
$this->assertStringContainsString(trans('command/messages.server.power.confirm', ['action' => 'kill', 'count' => 1]), $display);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Test that validation occurs correctly.
|
|
||||||
*
|
|
||||||
* @param array $data
|
|
||||||
*
|
|
||||||
* @dataProvider validationFailureDataProvider
|
|
||||||
*/
|
|
||||||
public function testValidationErrors(array $data)
|
|
||||||
{
|
|
||||||
$this->expectException(ValidationException::class);
|
|
||||||
$this->runCommand($this->getCommand(), $data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Provide invalid data for the command.
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function validationFailureDataProvider(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
[['action' => 'hodor']],
|
|
||||||
[['action' => 'hodor', '--servers' => 'hodor']],
|
|
||||||
[['action' => 'kill', '--servers' => 'hodor']],
|
|
||||||
[['action' => 'kill', '--servers' => '1,2,3', '--nodes' => 'hodor']],
|
|
||||||
[['action' => 'kill', '--servers' => '1,2,3', '--nodes' => '1,2,test']],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return an instance of the command with mocked dependencies.
|
|
||||||
*
|
|
||||||
* @return \Pterodactyl\Console\Commands\Server\BulkPowerActionCommand
|
|
||||||
*/
|
|
||||||
private function getCommand(): BulkPowerActionCommand
|
|
||||||
{
|
|
||||||
return new BulkPowerActionCommand($this->powerRepository, $this->repository, $this->app->make(Factory::class));
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue