Welcome to mirror list, hosted at ThFree Co, Russian Federation.

DbLockTest.php « integration « tests - github.com/nextcloud/jsxc.nextcloud.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: d157b487b2da80100bdbc908520a286dd37907dd (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
104
105
<?php
namespace OCA\OJSXC;

use OCP\AppFramework\Db\DoesNotExistException;
use Test\TestCase;
use OCA\OJSXC\AppInfo\Application;
use OCA\OJSXC\DbLock;

$time = 0;

function time() {
	global $time;
	return $time;
}

/**
 * @group DB
 */
class DbLockTest extends TestCase {

	/**
	 * @var \OCA\OJSXC\DbLock
	 */
	private $dbLock;

	/**
	 * @var \OCA\OJSXC\DbLock
	 */
	private $dbLock2;

	/**
	 * @var \OCP\IDb
	 */
	private $con;


	/**
	 * @var \OCP\AppFramework\IAppContainer
	 */
	private $container;

	public function setUp() {
		parent::setUp();
		$app = new Application();
		$this->container = $app->getContainer();
		$this->con = $this->container->getServer()->getDatabaseConnection();
		$this->con->executeQuery("DELETE FROM `*PREFIX*preferences` WHERE `appid`='ojsxc' AND `configkey`='longpolling'");
	}

	/**
	 * Tests the setLock and stillLocked function by setting up and lock
	 * and then setting a new lock.
	 */
	public function testLock() {
		global $time;
		$time = 4;
		$this->dbLock = new DbLock(
			'john',
			$this->container->getServer()->getConfig(),
			$this->container->getServer()->getDatabaseConnection()
		);
		$this->dbLock->setLock();
		$result = $this->fetchLocks();
		$this->assertCount(1, $result);
		$this->assertEquals($result[0]['userid'], 'john');
		$this->assertEquals($result[0]['appid'], 'ojsxc');
		$this->assertEquals($result[0]['configkey'], 'longpolling');
		$this->assertEquals($result[0]['configvalue'], '4');
		$this->assertTrue($this->dbLock->stillLocked());


		$time = 5;
		$this->dbLock2 = new DbLock(
			'john',
			$this->container->getServer()->getConfig(),
			$this->container->getServer()->getDatabaseConnection()
		); // simulate new lock/request
		$this->dbLock2->setLock();

		$this->assertFalse($this->dbLock->stillLocked());
		$this->assertTrue($this->dbLock2->stillLocked());
		$result = $this->fetchLocks();
		$this->assertCount(1, $result);
		$this->assertEquals($result[0]['userid'], 'john');
		$this->assertEquals($result[0]['appid'], 'ojsxc');
		$this->assertEquals($result[0]['configkey'], 'longpolling');
		$this->assertEquals($result[0]['configvalue'], '5');
		$this->assertTrue($this->dbLock2->stillLocked());

	}

	private function  fetchLocks() {
		$stmt = $this->con->executeQuery("SELECT * FROM `*PREFIX*preferences` WHERE `appid`='ojsxc' AND `configkey`='longpolling'");

		$reuslt = [];

		while($row = $stmt->fetch()){
			$result[] = $row;
		}


		return $result;
	}

}