Passed
Pull Request — master (#1257)
by René
04:27 queued 47s
created

OptionMapperTest::testFindByPoll()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 3
c 0
b 0
f 0
dl 0
loc 5
rs 10
cc 2
nc 2
nop 1
1
<?php declare(strict_types=1);
2
/**
3
 * @copyright Copyright (c) 2017 Kai Schröer <[email protected]>
4
 *
5
 * @author Kai Schröer <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 *  This program is free software: you can redistribute it and/or modify
10
 *  it under the terms of the GNU Affero General Public License as
11
 *  published by the Free Software Foundation, either version 3 of the
12
 *  License, or (at your option) any later version.
13
 *
14
 *  This program is distributed in the hope that it will be useful,
15
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 *  GNU Affero General Public License for more details.
18
 *
19
 *  You should have received a copy of the GNU Affero General Public License
20
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
24
namespace OCA\Polls\Tests\Unit\Db;
25
26
use OCA\Polls\Db\Poll;
27
use OCA\Polls\Db\PollMapper;
28
use OCA\Polls\Db\Option;
29
use OCA\Polls\Db\OptionMapper;
30
use OCA\Polls\Tests\Unit\UnitTestCase;
31
use OCP\IDBConnection;
32
use League\FactoryMuffin\Faker\Facade as Faker;
33
34
class OptionMapperTest extends UnitTestCase {
35
36
	/** @var IDBConnection */
37
	private $con;
38
39
	/** @var OptionMapper */
40
	private $optionMapper;
41
42
	/** @var PollMapper */
43
	private $pollMapper;
44
45
	/** @var array */
46
	private $polls;
47
48
	/**
49
	 * {@inheritDoc}
50
	 */
51
	protected function setUp(): void {
52
		parent::setUp();
53
		$this->con = \OC::$server->getDatabaseConnection();
54
		$this->optionMapper = new OptionMapper($this->con);
55
		$this->pollMapper = new PollMapper($this->con);
56
		$this->polls = [];
57
58
		$poll = $this->fm->instance('OCA\Polls\Db\Poll');
59
		array_push($this->polls, $this->pollMapper->insert($poll));
60
	}
61
62
	/**
63
	 * Create some fake data and persist them to the database.
64
	 */
65
	public function testCreate() {
66
67
		foreach ($this->polls as $poll) {
68
			/** @var Option $option */
69
			$options = [];
70
			$option = $this->fm->instance('OCA\Polls\Db\Option');
71
72
			$option->setPollId($poll->getId());
73
			array_push($options, $this->optionMapper->insert($option));
74
			$this->assertInstanceOf(Option::class, $options[count($options)-1]);
75
		}
76
		return $options;
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $options seems to be defined by a foreach iteration on line 67. Are you sure the iterator is never empty, otherwise this variable is not defined?
Loading history...
77
	}
78
79
	/**
80
	 * Find the previously created entries from the database.
81
	 *
82
	 * @depends testCreate
83
	 * @return Option[]
84
	 */
85
	public function testFind(array $options) {
86
		foreach ($options as $option) {
87
			$this->assertEquals($this->optionMapper->find($option), $option->getId());
88
		}
89
	}
90
91
	/**
92
	 * Find the previously created entries from the database.
93
	 *
94
	 * @depends testCreate
95
	 * @return Option[]
96
	 */
97
	public function testFindByPoll(array $options) {
98
		foreach ($options as $option) {
99
			$this->assertContains($option, $this->optionMapper->findByPoll($option->getPollId()));
100
		}
101
		return $options;
102
	}
103
104
	/**
105
	 * Update the previously created entry and persist the changes.
106
	 *
107
	 * @depends testCreate
108
	 * @return Option[]
109
	 */
110
	public function testUpdate(array $options) {
111
		foreach ($options as $option) {
112
			$newPollOptionText = Faker::text(255);
113
			$option->setPollOptionText($newPollOptionText());
114
			$this->assertEquals($option, $this->optionMapper->update($option));
115
		}
116
		return $options;
117
	}
118
119
	/**
120
	 * Delete the previously created entries from the database.
121
	 *
122
	 * @depends testUpdate
123
	 */
124
	public function testDelete(array $options) {
125
		foreach ($options as $option) {
126
			$this->assertInstanceOf(Option::class, $this->optionMapper->delete($option));
127
		}
128
	}
129
130
	public function tearDown(): void {
131
		parent::tearDown();
132
		foreach ($this->polls as $poll) {
133
			$this->pollMapper->delete($poll);
134
		}
135
	}
136
}
137