ConnectionTest.php 3.53 KB
Newer Older
Jens Segers's avatar
Jens Segers committed
1 2
<?php

3
class ConnectionTest extends TestCase {
Jens Segers's avatar
Jens Segers committed
4

5
	public function testConnection()
Jens Segers's avatar
Jens Segers committed
6
	{
7 8 9 10 11
		$connection = DB::connection('mongodb');
		$this->assertInstanceOf('Jenssegers\Mongodb\Connection', $connection);

		$c1 = DB::connection('mongodb');
		$c2 = DB::connection('mongodb');
12
		$this->assertEquals(spl_object_hash($c1), spl_object_hash($c2));
13 14 15

		$c1 = DB::connection('mongodb');
		$c2 = DB::reconnect('mongodb');
16
		$this->assertNotEquals(spl_object_hash($c1), spl_object_hash($c2));
Jens Segers's avatar
Jens Segers committed
17 18 19 20
	}

	public function testDb()
	{
21
		$connection = DB::connection('mongodb');
22
		$this->assertInstanceOf('MongoDB', $connection->getMongoDB());
23 24 25

		$connection = DB::connection('mongodb');
		$this->assertInstanceOf('MongoClient', $connection->getMongoClient());
Jens Segers's avatar
Jens Segers committed
26 27 28 29
	}

	public function testCollection()
	{
30
		$collection = DB::connection('mongodb')->getCollection('unittest');
Jens Segers's avatar
Jens Segers committed
31 32
		$this->assertInstanceOf('MongoCollection', $collection);

33
		$collection = DB::connection('mongodb')->collection('unittests');
Jens Segers's avatar
Jens Segers committed
34
		$this->assertInstanceOf('Jenssegers\Mongodb\Query\Builder', $collection);
Jens Segers's avatar
Jens Segers committed
35

36
		$collection = DB::connection('mongodb')->table('unittests');
Jens Segers's avatar
Jens Segers committed
37
		$this->assertInstanceOf('Jenssegers\Mongodb\Query\Builder', $collection);
Jens Segers's avatar
Jens Segers committed
38 39 40 41
	}

	public function testDynamic()
	{
42
		$dbs = DB::connection('mongodb')->listCollections();
Jens Segers's avatar
Jens Segers committed
43
		$this->assertTrue(is_array($dbs));
Jens Segers's avatar
Jens Segers committed
44 45
	}

46
	/*public function testMultipleConnections()
47 48 49 50 51
	{
		global $app;

		# Add fake host
		$db = $app['config']['database.connections']['mongodb'];
52
		$db['host'] = array($db['host'], '1.2.3.4');
53 54 55 56 57 58

		$connection = new Connection($db);
		$mongoclient = $connection->getMongoClient();

		$hosts = $mongoclient->getHosts();
		$this->assertEquals(1, count($hosts));
59
	}*/
60

Jens Segers's avatar
Jens Segers committed
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
	public function testQueryLog()
	{
		$this->assertEquals(0, count(DB::getQueryLog()));

		DB::collection('items')->get();
		$this->assertEquals(1, count(DB::getQueryLog()));

		DB::collection('items')->insert(array('name' => 'test'));
		$this->assertEquals(2, count(DB::getQueryLog()));

		DB::collection('items')->count();
		$this->assertEquals(3, count(DB::getQueryLog()));

		DB::collection('items')->where('name', 'test')->update(array('name' => 'test'));
		$this->assertEquals(4, count(DB::getQueryLog()));

		DB::collection('items')->where('name', 'test')->delete();
		$this->assertEquals(5, count(DB::getQueryLog()));
	}

Jens Segers's avatar
Jens Segers committed
81 82 83 84 85 86
	public function testSchemaBuilder()
	{
		$schema = DB::connection('mongodb')->getSchemaBuilder();
		$this->assertInstanceOf('Jenssegers\Mongodb\Schema\Builder', $schema);
	}

87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
	public function testDriverName()
	{
		$driver = DB::connection('mongodb')->getDriverName();
		$this->assertEquals('mongodb', $driver);
	}

	public function testAuth()
	{
		Config::set('database.connections.mongodb.username', 'foo');
		Config::set('database.connections.mongodb.password', 'bar');
		$host = Config::get('database.connections.mongodb.host');
		$port = Config::get('database.connections.mongodb.port', 27017);
		$database = Config::get('database.connections.mongodb.database');

		$this->setExpectedException('MongoConnectionException', "Failed to connect to: $host:$port: Authentication failed on database '$database' with username 'foo': auth fails");
		$connection = DB::connection('mongodb');
	}

	public function testCustomPort()
	{
		$port = 27000;
		Config::set('database.connections.mongodb.port', $port);
		$host = Config::get('database.connections.mongodb.host');
		$database = Config::get('database.connections.mongodb.database');

		$this->setExpectedException('MongoConnectionException', "Failed to connect to: $host:$port: Connection refused");
		$connection = DB::connection('mongodb');
	}

116
}