/**
  * Tests CRUD.
  */
 public function testCRUD()
 {
     /** @var \Drupal\node\NodeInterface $node */
     /** @var \Drupal\field_collection\FieldCollectionItemInterface $field_collection_item */
     list($node, $field_collection_item) = $this->createNodeWithFieldCollection('article');
     $this->assertEqual($field_collection_item->id(), $node->{$this->field_collection_name}->value);
     $this->assertEqual($field_collection_item->revision_id->value, $node->{$this->field_collection_name}->revision_id);
     // Test adding an additional field_collection_item.
     $field_collection_item_2 = FieldCollectionItem::create(['field_name' => $this->field_collection_name]);
     $field_collection_item_2->{$this->inner_field_name}->setValue(2);
     $node->{$this->field_collection_name}[1] = array('field_collection_item' => $field_collection_item_2);
     $node->save();
     $this->nodeStorage->resetCache([$node->id()]);
     $node = Node::load($node->id());
     $this->assertTrue(!empty($field_collection_item_2->id()) && !empty($field_collection_item_2->getRevisionId()));
     $this->assertEqual(count(FieldCollectionItem::loadMultiple()), 2);
     $this->assertEqual($field_collection_item->id(), $node->{$this->field_collection_name}->value);
     $this->assertEqual($field_collection_item->getRevisionId(), $node->{$this->field_collection_name}[0]->revision_id);
     $this->assertEqual($field_collection_item_2->id(), $node->{$this->field_collection_name}[1]->value);
     $this->assertEqual($field_collection_item_2->getRevisionId(), $node->{$this->field_collection_name}[1]->revision_id);
     // Make sure deleting the field collection item removes the reference.
     $field_collection_item_2->delete();
     $this->nodeStorage->resetCache([$node->id()]);
     $node = Node::load($node->id());
     $this->assertTrue(!isset($node->{$this->field_collection_name}[1]));
     // Make sure field_collections are removed during deletion of the host.
     $node->delete();
     $this->assertIdentical(FieldCollectionItem::loadMultiple(), array());
     // Try deleting nodes with collections without any values.
     $node = $this->drupalCreateNode(array('type' => 'article'));
     $node->delete();
     $this->nodeStorage->resetCache([$node->id()]);
     $node = Node::load($node->id());
     $this->assertFalse($node);
     // Test creating a field collection entity with a not-yet saved host entity.
     $node = $this->drupalCreateNode(array('type' => 'article'));
     $field_collection_item = FieldCollectionItem::create(['field_name' => $this->field_collection_name]);
     $field_collection_item->{$this->inner_field_name}->setValue(3);
     $field_collection_item->setHostEntity($node);
     $field_collection_item->save();
     // Now the node should have been saved with the collection and the link
     // should have been established.
     $this->assertTrue(!empty($node->id()));
     $this->assertTrue(count($node->{$this->field_collection_name}) == 1 && !empty($node->{$this->field_collection_name}[0]->value) && !empty($node->{$this->field_collection_name}[0]->revision_id));
     // Again, test creating a field collection with a not-yet saved host entity,
     // but this time save both entities via the host.
     $node = $this->drupalCreateNode(array('type' => 'article'));
     $field_collection_item = FieldCollectionItem::create(array('field_name' => $this->field_collection_name));
     $field_collection_item->{$this->inner_field_name}->setValue(4);
     $field_collection_item->setHostEntity($node);
     $node->save();
     $this->assertTrue(!empty($field_collection_item->id()) && !empty($field_collection_item->getRevisionId()));
     $this->assertTrue(count($node->{$this->field_collection_name}) == 1 && !empty($node->{$this->field_collection_name}[0]->value) && !empty($node->{$this->field_collection_name}[0]->revision_id));
 }
Пример #2
0
 /**
  * Tests deleting a search server via the UI.
  */
 protected function deleteServer()
 {
     $server = Server::load($this->serverId);
     // Load confirmation form.
     $this->drupalGet('admin/config/search/search-api/server/' . $this->serverId . '/delete');
     $this->assertResponse(200, 'Server delete page exists');
     $this->assertRaw(t('Are you sure you want to delete the search server %name?', array('%name' => $server->label())), 'Deleting a server sks for confirmation.');
     $this->assertText(t('Deleting a server will disable all its indexes and their searches.'), 'Correct warning is displayed when deleting a server.');
     // Confirm deletion.
     $this->drupalPostForm(NULL, NULL, t('Delete'));
     $this->assertRaw(t('The search server %name has been deleted.', array('%name' => $server->label())), 'The server was deleted.');
     $this->assertFalse(Server::load($this->serverId), 'Server could not be found anymore.');
     $this->assertUrl('admin/config/search/search-api', array(), 'Correct redirect to search api overview page.');
     // Confirm that the index hasn't been deleted.
     $this->indexStorage->resetCache(array($this->indexId));
     /** @var $index \Drupal\search_api\IndexInterface */
     $index = $this->indexStorage->load($this->indexId);
     if ($this->assertTrue($index, 'The index associated with the server was not deleted.')) {
         $this->assertFalse($index->status(), 'The index associated with the server was disabled.');
         $this->assertNull($index->getServerId(), 'The index was removed from the server.');
     }
 }