summaryrefslogtreecommitdiffstats
path: root/tests/lib/releasenotestest.php
blob: 584f396038b0838a67b950846f1982a99581060c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
<?php
/**
 * @author Victor Dubiniuk <dubiniuk@owncloud.com>
 *
 * @copyright Copyright (c) 2016, ownCloud, Inc.
 * @license AGPL-3.0
 *
 * This code is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * This program 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License, version 3,
 * along with this program.  If not, see <http://www.gnu.org/licenses/>
 *
 */

namespace Test;

class ReleaseNotesTest extends \Test\TestCase {

	/**
	 * @param bool $isMysql
	 * @param int $fileCount
	 * @return \PHPUnit_Framework_MockObject_MockObject|\OC\ReleaseNotes
	 */
	protected function getReleaseNotesMock($isMysql, $fileCount) {
		$query = $this->getMockBuilder('OCP\DB\QueryBuilder\IQueryBuilder')
			->disableOriginalConstructor()
			->getMock();
		$query->expects($this->any())
			->method('getTableName')
			->willReturnCallback(function($tableName) {
				return 'ocx_' . $tableName;
			});

		$dbConnectionMock = $this->getMockBuilder('OCP\IDBConnection')
			->disableOriginalConstructor()
			->getMock();
		$dbConnectionMock->expects($this->any())
			->method('getQueryBuilder')
			->willReturn($query);
		$releaseNotesMock = $this->getMockBuilder('OC\ReleaseNotes')
			->setConstructorArgs([$dbConnectionMock])
			->setMethods(['isMysql', 'countFilecacheEntries'])
			->getMock();

		$releaseNotesMock->expects($this->any())
			->method('isMysql')
			->willReturn($isMysql);
		$releaseNotesMock->expects($this->any())
			->method('countFilecacheEntries')
			->willReturn($fileCount);
		return $releaseNotesMock;
	}

	public function data82to90() {
		return [
			[[], false, 20],
			[[], true, 20],
			[[], false, 1000000],
			[['Hint: You can speed up the upgrade by executing this SQL command manually: ALTER TABLE ocx_filecache ADD COLUMN checksum varchar(255) DEFAULT NULL AFTER permissions;'], true, 1000000],
		];
	}

	/**
	 * @dataProvider data82to90
	 *
	 * @param string[] $expected
	 * @param bool $isMysql
	 * @param int $fileCount
	 */
	public function test82to90($expected, $isMysql, $fileCount) {
		$releaseNotesMock = $this->getReleaseNotesMock($isMysql, $fileCount);
		$actual = $releaseNotesMock->getReleaseNotes('8.2.22', '9.0.1');
		$this->assertEquals($expected, $actual);
	}

	public function data90to91() {
		return [
			[false, 20],
			[true, 20],
			[false, 1000000],
			[true, 1000000],
		];
	}

	/**
	 * @dataProvider data90to91
	 *
	 * @param bool $isMysql
	 * @param int $fileCount
	 */
	public function test90to91($isMysql, $fileCount) {
		$releaseNotesMock = $this->getReleaseNotesMock($isMysql, $fileCount);
		$actual = $releaseNotesMock->getReleaseNotes('9.0.1', '9.1.0');
		$this->assertCount(0, $actual);
	}
}