2017-12-28 04:57:38 -06:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* UpdateControllerTest.php
|
|
|
|
* Copyright (c) 2017 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This file is part of Firefly III.
|
|
|
|
*
|
|
|
|
* Firefly III is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Firefly III is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace Tests\Feature\Controllers\Admin;
|
|
|
|
|
2017-12-28 12:16:27 -06:00
|
|
|
use Carbon\Carbon;
|
2017-12-28 04:57:38 -06:00
|
|
|
use FireflyConfig;
|
2017-12-28 12:55:10 -06:00
|
|
|
use FireflyIII\Exceptions\FireflyException;
|
2017-12-28 04:57:38 -06:00
|
|
|
use FireflyIII\Models\Configuration;
|
2017-12-28 12:16:27 -06:00
|
|
|
use FireflyIII\Services\Github\Object\Release;
|
2017-12-28 11:39:17 -06:00
|
|
|
use FireflyIII\Services\Github\Request\UpdateRequest;
|
2018-03-02 10:07:32 -06:00
|
|
|
use Log;
|
2017-12-28 12:47:58 -06:00
|
|
|
use Mockery;
|
2017-12-28 04:57:38 -06:00
|
|
|
use Tests\TestCase;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class UpdateControllerTest
|
|
|
|
*
|
|
|
|
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
|
|
|
|
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
|
|
|
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
|
|
|
|
*/
|
2017-12-28 11:39:17 -06:00
|
|
|
class UpdateControllerTest extends TestCase
|
2017-12-28 04:57:38 -06:00
|
|
|
{
|
2018-02-28 13:18:47 -06:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
2018-03-24 00:08:50 -05:00
|
|
|
Log::debug(sprintf('Now in %s.', get_class($this)));
|
2018-02-28 13:18:47 -06:00
|
|
|
}
|
|
|
|
|
2017-12-28 04:57:38 -06:00
|
|
|
/**
|
2017-12-28 11:39:17 -06:00
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::index
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::__construct
|
2017-12-28 04:57:38 -06:00
|
|
|
*/
|
|
|
|
public function testIndex()
|
|
|
|
{
|
|
|
|
$this->be($this->user());
|
|
|
|
|
2017-12-28 11:39:17 -06:00
|
|
|
$config = new Configuration;
|
2017-12-28 04:57:38 -06:00
|
|
|
$config->data = -1;
|
|
|
|
|
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
|
2017-12-28 11:39:17 -06:00
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['permission_update_check', -1])->once()->andReturn($config);
|
2017-12-28 04:57:38 -06:00
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
|
|
|
|
|
|
|
$response = $this->get(route('admin.update-check'));
|
|
|
|
$response->assertStatus(200);
|
|
|
|
|
|
|
|
// has bread crumb
|
|
|
|
$response->assertSee('<ol class="breadcrumb">');
|
|
|
|
}
|
|
|
|
|
2017-12-28 11:39:17 -06:00
|
|
|
/**
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::post
|
|
|
|
*/
|
|
|
|
public function testPost()
|
|
|
|
{
|
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
|
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
|
|
|
FireflyConfig::shouldReceive('set')->withArgs(['permission_update_check', 1])->once()->andReturn(new Configuration);
|
2017-12-28 12:47:58 -06:00
|
|
|
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
|
2017-12-28 11:39:17 -06:00
|
|
|
$this->be($this->user());
|
|
|
|
$response = $this->post(route('admin.update-check.post'), ['check_for_updates' => 1]);
|
|
|
|
$response->assertSessionHas('success');
|
|
|
|
$response->assertStatus(302);
|
|
|
|
$response->assertRedirect(route('admin.update-check'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::updateCheck
|
|
|
|
*/
|
|
|
|
public function testUpdateCheck()
|
|
|
|
{
|
2017-12-28 12:16:27 -06:00
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
2017-12-28 12:47:58 -06:00
|
|
|
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
|
2017-12-28 11:39:17 -06:00
|
|
|
|
2017-12-28 12:16:27 -06:00
|
|
|
$version = config('firefly.version');
|
2017-12-28 11:39:17 -06:00
|
|
|
$releases = [
|
2017-12-28 12:16:27 -06:00
|
|
|
new Release(['id' => 'x', 'title' => $version . '.1', 'content' => '', 'updated' => new Carbon]),
|
|
|
|
];
|
|
|
|
$updater = $this->mock(UpdateRequest::class);
|
|
|
|
$updater->shouldReceive('call')->andReturnNull();
|
|
|
|
$updater->shouldReceive('getReleases')->andReturn($releases);
|
|
|
|
|
|
|
|
// expect a new release (because of .1)
|
|
|
|
$this->be($this->user());
|
|
|
|
$response = $this->post(route('admin.update-check.manual'));
|
|
|
|
$response->assertStatus(200);
|
|
|
|
$response->assertSee($version);
|
|
|
|
$response->assertSee('which was released on');
|
|
|
|
$response->assertSee($version . '.1');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::updateCheck
|
|
|
|
*/
|
|
|
|
public function testUpdateCheckCurrent()
|
|
|
|
{
|
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
2017-12-28 12:47:58 -06:00
|
|
|
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
|
2017-12-28 11:39:17 -06:00
|
|
|
|
2017-12-28 12:16:27 -06:00
|
|
|
$version = config('firefly.version');
|
|
|
|
$releases = [
|
|
|
|
new Release(['id' => 'x', 'title' => $version, 'content' => '', 'updated' => new Carbon]),
|
2017-12-28 11:39:17 -06:00
|
|
|
];
|
2017-12-28 12:16:27 -06:00
|
|
|
$updater = $this->mock(UpdateRequest::class);
|
2017-12-28 11:39:17 -06:00
|
|
|
$updater->shouldReceive('call')->andReturnNull();
|
2017-12-28 12:16:27 -06:00
|
|
|
$updater->shouldReceive('getReleases')->andReturn($releases);
|
|
|
|
|
|
|
|
// expect a new release (because of .1)
|
|
|
|
$this->be($this->user());
|
|
|
|
$response = $this->post(route('admin.update-check.manual'));
|
|
|
|
$response->assertStatus(200);
|
|
|
|
$response->assertSee($version);
|
|
|
|
$response->assertSee('the latest available release');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::updateCheck
|
|
|
|
*/
|
2017-12-29 02:05:35 -06:00
|
|
|
public function testUpdateCheckError()
|
2017-12-28 12:16:27 -06:00
|
|
|
{
|
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
2017-12-28 11:39:17 -06:00
|
|
|
|
2017-12-28 12:16:27 -06:00
|
|
|
$version = config('firefly.version') . '-alpha';
|
|
|
|
$releases = [
|
|
|
|
new Release(['id' => 'x', 'title' => $version, 'content' => '', 'updated' => new Carbon]),
|
|
|
|
];
|
|
|
|
$updater = $this->mock(UpdateRequest::class);
|
2017-12-29 02:05:35 -06:00
|
|
|
$updater->shouldReceive('call')->andThrow(FireflyException::class, 'Something broke.');
|
2017-12-28 12:16:27 -06:00
|
|
|
$updater->shouldReceive('getReleases')->andReturn($releases);
|
2017-12-28 11:39:17 -06:00
|
|
|
|
2017-12-28 12:16:27 -06:00
|
|
|
// expect a new release (because of .1)
|
2017-12-28 11:39:17 -06:00
|
|
|
$this->be($this->user());
|
|
|
|
$response = $this->post(route('admin.update-check.manual'));
|
|
|
|
$response->assertStatus(200);
|
2017-12-29 02:05:35 -06:00
|
|
|
$response->assertSee('An error occurred while checking');
|
2017-12-28 11:39:17 -06:00
|
|
|
}
|
2017-12-28 12:55:10 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController::updateCheck
|
|
|
|
*/
|
2017-12-29 02:05:35 -06:00
|
|
|
public function testUpdateCheckNewer()
|
2017-12-28 12:55:10 -06:00
|
|
|
{
|
|
|
|
$falseConfig = new Configuration;
|
|
|
|
$falseConfig->data = false;
|
|
|
|
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
|
2017-12-29 02:05:35 -06:00
|
|
|
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
|
2017-12-28 12:55:10 -06:00
|
|
|
|
|
|
|
$version = config('firefly.version') . '-alpha';
|
|
|
|
$releases = [
|
|
|
|
new Release(['id' => 'x', 'title' => $version, 'content' => '', 'updated' => new Carbon]),
|
|
|
|
];
|
|
|
|
$updater = $this->mock(UpdateRequest::class);
|
2017-12-29 02:05:35 -06:00
|
|
|
$updater->shouldReceive('call')->andReturnNull();
|
2017-12-28 12:55:10 -06:00
|
|
|
$updater->shouldReceive('getReleases')->andReturn($releases);
|
|
|
|
|
|
|
|
// expect a new release (because of .1)
|
|
|
|
$this->be($this->user());
|
|
|
|
$response = $this->post(route('admin.update-check.manual'));
|
|
|
|
$response->assertStatus(200);
|
2017-12-29 02:05:35 -06:00
|
|
|
$response->assertSee($version);
|
|
|
|
$response->assertSee('which is newer than the');
|
2017-12-28 12:55:10 -06:00
|
|
|
}
|
2017-12-28 04:57:38 -06:00
|
|
|
}
|