getConnection()->createCommand()->flushIndex(); } public function setUp() { parent::setUp(); /** @var Connection $db */ $db = ActiveRecord::$db = $this->getConnection(); // delete all indexes $db->http()->delete('_all')->send(); $db->http()->post('items', null, Json::encode([ 'mappings' => [ "item" => [ "_source" => [ "enabled" => true ], "properties" => [ // allow proper sorting by name "name" => ["type" => "string", "index" => "not_analyzed"], ] ] ], ]))->send(); $db->http()->post('customers', null, Json::encode([ 'mappings' => [ "item" => [ "_source" => [ "enabled" => true ], "properties" => [ // this is for the boolean test "status" => ["type" => "boolean"], ] ] ], ]))->send(); $customer = new Customer(); $customer->id = 1; $customer->setAttributes(['email' => 'user1@example.com', 'name' => 'user1', 'address' => 'address1', 'status' => 1], false); $customer->save(false); $customer = new Customer(); $customer->id = 2; $customer->setAttributes(['email' => 'user2@example.com', 'name' => 'user2', 'address' => 'address2', 'status' => 1], false); $customer->save(false); $customer = new Customer(); $customer->id = 3; $customer->setAttributes(['email' => 'user3@example.com', 'name' => 'user3', 'address' => 'address3', 'status' => 2], false); $customer->save(false); // INSERT INTO tbl_category (name) VALUES ('Books'); // INSERT INTO tbl_category (name) VALUES ('Movies'); $item = new Item(); $item->id = 1; $item->setAttributes(['name' => 'Agile Web Application Development with Yii1.1 and PHP5', 'category_id' => 1], false); $item->save(false); $item = new Item(); $item->id = 2; $item->setAttributes(['name' => 'Yii 1.1 Application Development Cookbook', 'category_id' => 1], false); $item->save(false); $item = new Item(); $item->id = 3; $item->setAttributes(['name' => 'Ice Age', 'category_id' => 2], false); $item->save(false); $item = new Item(); $item->id = 4; $item->setAttributes(['name' => 'Toy Story', 'category_id' => 2], false); $item->save(false); $item = new Item(); $item->id = 5; $item->setAttributes(['name' => 'Cars', 'category_id' => 2], false); $item->save(false); $order = new Order(); $order->id = 1; $order->setAttributes(['customer_id' => 1, 'create_time' => 1325282384, 'total' => 110.0], false); $order->save(false); $order = new Order(); $order->id = 2; $order->setAttributes(['customer_id' => 2, 'create_time' => 1325334482, 'total' => 33.0], false); $order->save(false); $order = new Order(); $order->id = 3; $order->setAttributes(['customer_id' => 2, 'create_time' => 1325502201, 'total' => 40.0], false); $order->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 1, 'item_id' => 1, 'quantity' => 1, 'subtotal' => 30.0], false); $orderItem->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 1, 'item_id' => 2, 'quantity' => 2, 'subtotal' => 40.0], false); $orderItem->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 2, 'item_id' => 4, 'quantity' => 1, 'subtotal' => 10.0], false); $orderItem->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 2, 'item_id' => 5, 'quantity' => 1, 'subtotal' => 15.0], false); $orderItem->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 2, 'item_id' => 3, 'quantity' => 1, 'subtotal' => 8.0], false); $orderItem->save(false); $orderItem = new OrderItem(); $orderItem->setAttributes(['order_id' => 3, 'item_id' => 2, 'quantity' => 1, 'subtotal' => 40.0], false); $orderItem->save(false); Customer::getDb()->createCommand()->flushIndex(); } public function testGetDb() { $this->mockApplication(['components' => ['elasticsearch' => Connection::className()]]); $this->assertInstanceOf(Connection::className(), ActiveRecord::getDb()); } public function testGet() { $this->assertInstanceOf(Customer::className(), Customer::get(1)); $this->assertNull(Customer::get(5)); } public function testMget() { $this->assertEquals([], Customer::mget([])); $records = Customer::mget([1]); $this->assertEquals(1, count($records)); $this->assertInstanceOf(Customer::className(), reset($records)); $records = Customer::mget([5]); $this->assertEquals(0, count($records)); $records = Customer::mget([1,3,5]); $this->assertEquals(2, count($records)); $this->assertInstanceOf(Customer::className(), $records[0]); $this->assertInstanceOf(Customer::className(), $records[1]); } public function testFindLazy() { /** @var $customer Customer */ $customer = Customer::find(2); $orders = $customer->orders; $this->assertEquals(2, count($orders)); $orders = $customer->getOrders()->where(['between', 'create_time', 1325334000, 1325400000])->all(); $this->assertEquals(1, count($orders)); $this->assertEquals(2, $orders[0]->id); } public function testFindEagerViaRelation() { // this test is currently failing randomly because of https://github.com/yiisoft/yii2/issues/1310 $orders = Order::find()->with('items')->orderBy('create_time')->all(); $this->assertEquals(3, count($orders)); $order = $orders[0]; $this->assertEquals(1, $order->id); $this->assertEquals(2, count($order->items)); $this->assertEquals(1, $order->items[0]->id); $this->assertEquals(2, $order->items[1]->id); } public function testInsertNoPk() { $this->assertEquals([ActiveRecord::PRIMARY_KEY_NAME], Customer::primaryKey()); $pkName = ActiveRecord::PRIMARY_KEY_NAME; $customer = new Customer; $customer->email = 'user4@example.com'; $customer->name = 'user4'; $customer->address = 'address4'; $this->assertNull($customer->primaryKey); $this->assertNull($customer->oldPrimaryKey); $this->assertNull($customer->$pkName); $this->assertTrue($customer->isNewRecord); $customer->save(); $this->assertNotNull($customer->primaryKey); $this->assertNotNull($customer->oldPrimaryKey); $this->assertNotNull($customer->$pkName); $this->assertEquals($customer->primaryKey, $customer->oldPrimaryKey); $this->assertEquals($customer->primaryKey, $customer->$pkName); $this->assertFalse($customer->isNewRecord); } public function testInsertPk() { $pkName = ActiveRecord::PRIMARY_KEY_NAME; $customer = new Customer; $customer->$pkName = 5; $customer->email = 'user5@example.com'; $customer->name = 'user5'; $customer->address = 'address5'; $this->assertTrue($customer->isNewRecord); $customer->save(); $this->assertEquals(5, $customer->primaryKey); $this->assertEquals(5, $customer->oldPrimaryKey); $this->assertEquals(5, $customer->$pkName); $this->assertFalse($customer->isNewRecord); } public function testUpdatePk() { $pkName = ActiveRecord::PRIMARY_KEY_NAME; $pk = [$pkName => 2]; $orderItem = Order::find($pk); $this->assertEquals(2, $orderItem->primaryKey); $this->assertEquals(2, $orderItem->oldPrimaryKey); $this->assertEquals(2, $orderItem->$pkName); $this->setExpectedException('yii\base\InvalidCallException'); $orderItem->$pkName = 13; $orderItem->save(); } public function testFindLazyVia2() { /** @var TestCase|ActiveRecordTestTrait $this */ /** @var Order $order */ $orderClass = $this->getOrderClass(); $pkName = ActiveRecord::PRIMARY_KEY_NAME; $order = new $orderClass(); $order->$pkName = 100; $this->assertEquals([], $order->items); } public function testUpdateCounters() { // Update Counters is not supported by elasticsearch // $this->setExpectedException('yii\base\NotSupportedException'); // ActiveRecordTestTrait::testUpdateCounters(); } /** * Some PDO implementations(e.g. cubrid) do not support boolean values. * Make sure this does not affect AR layer. */ public function testBooleanAttribute() { $db = $this->getConnection(); $db->createCommand()->deleteIndex('customers'); $db->http()->post('customers', null, Json::encode([ 'mappings' => [ "item" => [ "_source" => [ "enabled" => true ], "properties" => [ // this is for the boolean test "status" => ["type" => "boolean"], ] ] ], ]))->send(); $customerClass = $this->getCustomerClass(); $customer = new $customerClass(); $customer->name = 'boolean customer'; $customer->email = 'mail@example.com'; $customer->status = true; $customer->save(false); $customer->refresh(); $this->assertEquals(true, $customer->status); $customer->status = false; $customer->save(false); $customer->refresh(); $this->assertEquals(false, $customer->status); $customer = new Customer(); $customer->setAttributes(['email' => 'user2b@example.com', 'name' => 'user2b', 'status' => true], false); $customer->save(false); $customer = new Customer(); $customer->setAttributes(['email' => 'user3b@example.com', 'name' => 'user3b', 'status' => false], false); $customer->save(false); $this->afterSave(); $customers = $this->callCustomerFind()->where(['status' => true])->all(); $this->assertEquals(1, count($customers)); $customers = $this->callCustomerFind()->where(['status' => false])->all(); $this->assertEquals(2, count($customers)); } }