Rajout de doctrine/orm
[zf2.biz/galerie.git] / vendor / doctrine / dbal / tests / Doctrine / Tests / DBAL / Sharding / SQLAzure / SQLAzureFederationsSynchronizerTest.php
1 <?php
2 namespace Doctrine\Tests\DBAL\Sharding\SQLAzure;
3
4 use Doctrine\DBAL\Schema\Schema;
5 use Doctrine\DBAL\Sharding\SQLAzure\SQLAzureFederationsSynchronizer;
6
7 class SQLAzureFederationsSynchronizerTest extends AbstractTestCase
8 {
9     public function testCreateSchema()
10     {
11         $schema = $this->createShopSchema();
12
13         $synchronizer = new SQLAzureFederationsSynchronizer($this->conn, $this->sm);
14         $sql = $synchronizer->getCreateSchema($schema);
15
16         $this->assertEquals(array (
17             "--Create Federation\nCREATE FEDERATION Orders_Federation (CustID INT  RANGE)",
18             "USE FEDERATION Orders_Federation (CustID = 0) WITH RESET, FILTERING = OFF;",
19             "CREATE TABLE Products (ProductID INT NOT NULL, SupplierID INT NOT NULL, ProductName NVARCHAR(255) NOT NULL, Price NUMERIC(12, 2) NOT NULL, PRIMARY KEY (ProductID))",
20             "CREATE TABLE Customers (CustomerID INT NOT NULL, CompanyName NVARCHAR(255) NOT NULL, FirstName NVARCHAR(255) NOT NULL, LastName NVARCHAR(255) NOT NULL, PRIMARY KEY (CustomerID))",
21             "CREATE TABLE Orders (CustomerID INT NOT NULL, OrderID INT NOT NULL, OrderDate DATETIME2(6) NOT NULL, PRIMARY KEY (CustomerID, OrderID))",
22             "CREATE TABLE OrderItems (CustomerID INT NOT NULL, OrderID INT NOT NULL, ProductID INT NOT NULL, Quantity INT NOT NULL, PRIMARY KEY (CustomerID, OrderID, ProductID))",
23         ), $sql);
24     }
25
26     public function testUpdateSchema()
27     {
28         $schema = $this->createShopSchema();
29
30         $synchronizer = new SQLAzureFederationsSynchronizer($this->conn, $this->sm);
31         $synchronizer->dropAllSchema();
32
33         $sql = $synchronizer->getUpdateSchema($schema);
34
35         $this->assertEquals(array(), $sql);
36     }
37
38     public function testDropSchema()
39     {
40         $schema = $this->createShopSchema();
41
42         $synchronizer = new SQLAzureFederationsSynchronizer($this->conn, $this->sm);
43         $synchronizer->dropAllSchema();
44         $synchronizer->createSchema($schema);
45         $sql = $synchronizer->getDropSchema($schema);
46
47         $this->assertEQuals(5, count($sql));
48     }
49 }
50