Files
firefly-iii/tests/Feature/Controllers/Admin/UpdateControllerTest.php

228 lines
9.2 KiB
PHP
Raw Normal View History

<?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 19:16:27 +01:00
use Carbon\Carbon;
use FireflyConfig;
2017-12-28 19:55:10 +01:00
use FireflyIII\Exceptions\FireflyException;
use FireflyIII\Models\Configuration;
2018-09-03 18:52:46 +02:00
use FireflyIII\Repositories\User\UserRepositoryInterface;
2017-12-28 19:16:27 +01:00
use FireflyIII\Services\Github\Object\Release;
2017-12-28 18:39:17 +01:00
use FireflyIII\Services\Github\Request\UpdateRequest;
use Log;
use Mockery;
use Tests\TestCase;
/**
* Class UpdateControllerTest
*/
2017-12-28 18:39:17 +01:00
class UpdateControllerTest extends TestCase
{
2018-02-28 20:18:47 +01:00
/**
*
*/
2018-09-02 20:27:26 +02:00
public function setUp(): void
2018-02-28 20:18:47 +01:00
{
parent::setUp();
2018-09-03 18:52:46 +02:00
Log::info(sprintf('Now in %s.', \get_class($this)));
2018-02-28 20:18:47 +01:00
}
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
*/
2018-05-11 19:58:10 +02:00
public function testIndex(): void
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$this->be($this->user());
2017-12-28 18:39:17 +01:00
$config = new Configuration;
$config->data = -1;
$falseConfig = new Configuration;
$falseConfig->data = false;
2017-12-28 18:39:17 +01:00
FireflyConfig::shouldReceive('get')->withArgs(['permission_update_check', -1])->once()->andReturn($config);
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 18:39:17 +01:00
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
2017-12-28 18:39:17 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testPost(): void
2017-12-28 18:39:17 +01:00
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'demo'])->andReturn(false)->atLeast()->once();
2017-12-28 18:39:17 +01:00
$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);
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
2017-12-28 18:39:17 +01: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'));
}
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
2018-08-30 20:58:07 +02:00
* @covers \FireflyIII\Helpers\Update\UpdateTrait
2017-12-28 18:39:17 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testUpdateCheck(): void
2017-12-28 18:39:17 +01:00
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'demo'])->andReturn(false)->atLeast()->once();
2017-12-28 19:16:27 +01:00
$falseConfig = new Configuration;
$falseConfig->data = false;
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
2017-12-28 18:39:17 +01:00
2018-08-06 19:14:30 +02:00
$version = config('firefly.version');
$date = new Carbon;
2018-03-28 19:38:20 +02:00
$date->subDays(5);
2017-12-28 18:39:17 +01:00
$releases = [
2018-03-28 19:38:20 +02:00
new Release(['id' => 'x', 'title' => $version . '.1', 'content' => '', 'updated' => $date]),
2017-12-28 19:16:27 +01:00
];
$updater = $this->mock(UpdateRequest::class);
$updater->shouldReceive('call')->andReturnNull();
$updater->shouldReceive('getReleases')->andReturn($releases);
$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');
}
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
2018-08-30 20:58:07 +02:00
* @covers \FireflyIII\Helpers\Update\UpdateTrait
2017-12-28 19:16:27 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testUpdateCheckCurrent(): void
2017-12-28 19:16:27 +01:00
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'demo'])->andReturn(false)->atLeast()->once();
2017-12-28 19:16:27 +01:00
$falseConfig = new Configuration;
$falseConfig->data = false;
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
2017-12-28 18:39:17 +01:00
2018-03-28 19:38:20 +02:00
$date = new Carbon;
$date->subDays(5);
2017-12-28 19:16:27 +01:00
$version = config('firefly.version');
$releases = [
2018-03-28 19:38:20 +02:00
new Release(['id' => 'x', 'title' => $version, 'content' => '', 'updated' => $date]),
2017-12-28 18:39:17 +01:00
];
2017-12-28 19:16:27 +01:00
$updater = $this->mock(UpdateRequest::class);
2017-12-28 18:39:17 +01:00
$updater->shouldReceive('call')->andReturnNull();
2017-12-28 19:16:27 +01:00
$updater->shouldReceive('getReleases')->andReturn($releases);
$this->be($this->user());
$response = $this->post(route('admin.update-check.manual'));
$response->assertStatus(200);
$response->assertSee($version);
$response->assertSee('the latest available release');
}
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
2018-08-30 20:58:07 +02:00
* @covers \FireflyIII\Helpers\Update\UpdateTrait
2017-12-28 19:16:27 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testUpdateCheckError(): void
2017-12-28 19:16:27 +01:00
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'demo'])->andReturn(false)->atLeast()->once();
2017-12-28 19:16:27 +01:00
$falseConfig = new Configuration;
$falseConfig->data = false;
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
2018-07-08 12:08:53 +02:00
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
2017-12-28 18:39:17 +01:00
2017-12-28 19:16:27 +01:00
$version = config('firefly.version') . '-alpha';
2018-07-08 12:08:53 +02:00
$releases = [];
2017-12-28 19:16:27 +01:00
$updater = $this->mock(UpdateRequest::class);
2017-12-29 09:05:35 +01:00
$updater->shouldReceive('call')->andThrow(FireflyException::class, 'Something broke.');
2017-12-28 19:16:27 +01:00
$updater->shouldReceive('getReleases')->andReturn($releases);
2017-12-28 18:39:17 +01:00
$this->be($this->user());
$response = $this->post(route('admin.update-check.manual'));
$response->assertStatus(200);
2017-12-29 09:05:35 +01:00
$response->assertSee('An error occurred while checking');
2017-12-28 18:39:17 +01:00
}
2017-12-28 19:55:10 +01:00
/**
2018-07-01 09:27:22 +02:00
* @covers \FireflyIII\Http\Controllers\Admin\UpdateController
2018-08-30 20:58:07 +02:00
* @covers \FireflyIII\Helpers\Update\UpdateTrait
2017-12-28 19:55:10 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testUpdateCheckNewer(): void
2017-12-28 19:55:10 +01:00
{
2018-09-03 18:52:46 +02:00
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->andReturn(true)->atLeast()->once();
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'demo'])->andReturn(false)->atLeast()->once();
2017-12-28 19:55:10 +01:00
$falseConfig = new Configuration;
$falseConfig->data = false;
FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->once()->andReturn($falseConfig);
2017-12-29 09:05:35 +01:00
FireflyConfig::shouldReceive('set')->withArgs(['last_update_check', Mockery::any()])->once()->andReturn(new Configuration);
2017-12-28 19:55:10 +01: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 09:05:35 +01:00
$updater->shouldReceive('call')->andReturnNull();
2017-12-28 19:55:10 +01: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 09:05:35 +01:00
$response->assertSee($version);
$response->assertSee('which is newer than the');
2017-12-28 19:55:10 +01:00
}
}