2017-12-11 16:46:26 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tainacan\Tests;
|
|
|
|
|
2018-01-19 22:39:32 +00:00
|
|
|
/**
|
|
|
|
* @group api
|
|
|
|
*/
|
2017-12-11 16:46:26 +00:00
|
|
|
class TAINACAN_REST_Metadata_Controller extends TAINACAN_UnitApiTestCase {
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_create_metadatum_in_a_collection() {
|
2017-12-11 16:46:26 +00:00
|
|
|
$collection = $this->tainacan_entity_factory->create_entity('collection', '', true);
|
|
|
|
|
2018-03-01 17:46:21 +00:00
|
|
|
$this->tainacan_entity_factory->create_entity(
|
2017-12-11 16:46:26 +00:00
|
|
|
'item',
|
|
|
|
array(
|
2017-12-12 11:59:50 +00:00
|
|
|
'title' => 'No name',
|
2017-12-11 16:46:26 +00:00
|
|
|
'description' => 'No description',
|
2017-12-12 11:59:50 +00:00
|
|
|
'collection' => $collection
|
2017-12-11 16:46:26 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum = json_encode(
|
2017-12-11 16:46:26 +00:00
|
|
|
array(
|
2017-12-12 11:59:50 +00:00
|
|
|
'name' => 'Moeda',
|
2017-12-11 16:46:26 +00:00
|
|
|
'description' => 'Descreve campo moeda.',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2017-12-11 16:46:26 +00:00
|
|
|
)
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2017-12-11 16:46:26 +00:00
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
2017-12-11 16:46:26 +00:00
|
|
|
);
|
2018-06-11 15:10:07 +00:00
|
|
|
$request->set_body($metadatum);
|
2017-12-11 16:46:26 +00:00
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum_added = $response->get_data();
|
|
|
|
$this->assertTrue(is_array($metadatum_added) && array_key_exists('name', $metadatum_added), sprintf('cannot create metadatum, response: %s', print_r($metadatum_added, true)));
|
|
|
|
$this->assertEquals('Moeda', $metadatum_added['name']);
|
2018-03-01 18:02:53 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertNotEquals('default', $metadatum_added['collection_id']);
|
2017-12-11 16:46:26 +00:00
|
|
|
}
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_fetch_a_metadatum_from_a_collection(){
|
2018-03-05 19:23:28 +00:00
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatumA = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-03-05 19:23:28 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-05 19:23:28 +00:00
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$request = new \WP_REST_Request('GET', $this->namespace . '/collection/' . $collection->get_id() . '/metadata/' . $metadatumA->get_id());
|
2018-03-05 19:23:28 +00:00
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals('Data', $data['name']);
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatumA->get_id(), $data['id']);
|
2018-03-05 19:23:28 +00:00
|
|
|
}
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_create_default_metadatum(){
|
|
|
|
$metadatum = json_encode(
|
2018-03-01 17:46:21 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Ano de Publicação',
|
|
|
|
'description' => 'Uma data no formato dd/mm/aaaa.',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-01 17:46:21 +00:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/metadata'
|
2018-03-01 17:46:21 +00:00
|
|
|
);
|
2018-06-11 15:10:07 +00:00
|
|
|
$request->set_body($metadatum);
|
2018-03-01 17:46:21 +00:00
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum_added = $response->get_data();
|
2018-03-01 17:46:21 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertTrue(is_array($metadatum_added) && array_key_exists('name', $metadatum_added), sprintf('cannot create metadatum, response: %s', print_r($metadatum_added, true)));
|
|
|
|
$this->assertEquals('Ano de Publicação', $metadatum_added['name']);
|
2018-03-01 18:02:53 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals('default', $metadatum_added['collection_id']);
|
2018-03-01 17:46:21 +00:00
|
|
|
}
|
2017-12-12 17:17:55 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_fetch_default_metadata(){
|
2018-03-05 18:48:59 +00:00
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatumA = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-03-05 18:48:59 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Data 1',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-05 18:48:59 +00:00
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatumB = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-03-05 18:48:59 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Data 2',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection_id' => 'default',
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-05 18:48:59 +00:00
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$request_fetch_defaults = new \WP_REST_Request('GET', $this->namespace . '/metadata');
|
2018-03-05 18:48:59 +00:00
|
|
|
|
|
|
|
$response_defaults = $this->server->dispatch($request_fetch_defaults);
|
|
|
|
|
|
|
|
$data = $response_defaults->get_data();
|
|
|
|
|
|
|
|
$this->assertCount(1, $data);
|
|
|
|
|
|
|
|
$this->assertEquals('default', $data[0]['collection_id']);
|
|
|
|
$this->assertEquals('Data 2', $data[0]['name']);
|
|
|
|
}
|
|
|
|
|
2017-12-12 17:17:55 +00:00
|
|
|
public function test_get_item_and_collection_metadata(){
|
2018-04-11 14:18:55 +00:00
|
|
|
$Tainacan_Item_Metadata = \Tainacan\Repositories\Item_Metadata::get_instance();
|
2017-12-12 17:17:55 +00:00
|
|
|
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
2017-12-18 12:52:45 +00:00
|
|
|
'name' => 'Statement',
|
2019-10-16 14:05:29 +00:00
|
|
|
'description' => 'No Statement',
|
|
|
|
'status' => 'publish'
|
2017-12-12 17:17:55 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$item = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'item',
|
|
|
|
array(
|
|
|
|
'title' => 'No name',
|
|
|
|
'description' => 'No description',
|
|
|
|
'collection' => $collection
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2017-12-12 17:17:55 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2017-12-12 17:17:55 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$item_metadata = new \Tainacan\Entities\Item_Metadata_Entity($item, $metadatum);
|
2017-12-12 17:17:55 +00:00
|
|
|
$item_metadata->set_value('12/12/2017');
|
|
|
|
|
|
|
|
$item_metadata->validate();
|
|
|
|
$Tainacan_Item_Metadata->insert($item_metadata);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
#################### Get metadatum of collection ######################
|
2017-12-12 17:17:55 +00:00
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
2017-12-12 17:17:55 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadata_names = array_map(function($metadatum) {return $metadatum['name'];}, $data);
|
2017-12-12 17:17:55 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertContains('Data', $metadata_names);
|
2017-12-12 17:17:55 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
################### Get metadatum of item with value #######################
|
2017-12-12 17:17:55 +00:00
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
2018-01-31 15:50:10 +00:00
|
|
|
$this->namespace . '/item/' . $item->get_id() . '/metadata'
|
2017-12-12 17:17:55 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertTrue(is_array($data) && array_key_exists(0, $data), sprintf('cannot read metadatum, response: %s', print_r($data, true)));
|
2017-12-12 17:17:55 +00:00
|
|
|
|
2018-02-19 16:29:43 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadata_names = array_map(function($item_metadata) {return $item_metadata['metadatum']['name'];}, $data);
|
2018-02-19 16:29:43 +00:00
|
|
|
$values = array_map(function($item_metadata) {return $item_metadata['value'];}, $data);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertContains('Data', $metadata_names);
|
2018-02-19 16:29:43 +00:00
|
|
|
$this->assertContains('12/12/2017', $values);
|
2017-12-12 17:17:55 +00:00
|
|
|
}
|
|
|
|
|
2018-01-19 14:55:39 +00:00
|
|
|
public function test_update_metadata(){
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
2019-10-16 14:05:29 +00:00
|
|
|
'description' => 'No Statement',
|
|
|
|
'status' => 'publish'
|
2018-01-19 14:55:39 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$item = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'item',
|
|
|
|
array(
|
|
|
|
'title' => 'No name',
|
|
|
|
'description' => 'No description',
|
|
|
|
'collection' => $collection
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-01-19 14:55:39 +00:00
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve o dado do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-02-14 18:52:50 +00:00
|
|
|
'multiple' => 'yes'
|
2018-01-19 14:55:39 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$meta_values = json_encode(
|
|
|
|
array(
|
2018-02-14 18:52:50 +00:00
|
|
|
'values' => array(
|
2018-02-15 13:27:45 +00:00
|
|
|
'19/01/2018',
|
|
|
|
'19/02/2018',
|
2018-02-14 18:52:50 +00:00
|
|
|
)
|
2018-01-19 14:55:39 +00:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'PATCH',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/item/' . $item->get_id() . '/metadata/' . $metadatum->get_id()
|
2018-01-19 14:55:39 +00:00
|
|
|
);
|
|
|
|
$request->set_body($meta_values);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$item_metadata_updated = $response->get_data();
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum_updated = $item_metadata_updated['metadatum'];
|
2018-01-19 14:55:39 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatum->get_id(), $metadatum_updated['id']);
|
2018-01-19 14:55:39 +00:00
|
|
|
|
2018-02-15 11:24:44 +00:00
|
|
|
$this->assertEquals('19/01/2018', $item_metadata_updated['value'][0]);
|
|
|
|
$this->assertEquals('19/02/2018', $item_metadata_updated['value'][1]);
|
2018-01-19 16:56:36 +00:00
|
|
|
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
#### UPDATE METADATUM IN COLLECTION ####
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2018-01-19 16:56:36 +00:00
|
|
|
$values = json_encode([
|
2018-03-06 14:01:35 +00:00
|
|
|
'name' => 'Dia/Mês/Ano',
|
|
|
|
'description' => 'Continua descrevendo o dado do campo.'
|
2018-01-19 16:56:36 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'PATCH',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata/' . $metadatum->get_id()
|
2018-01-19 16:56:36 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$request->set_body($values);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatum->get_id(), $data['id']);
|
2018-01-22 11:48:51 +00:00
|
|
|
$this->assertEquals('Dia/Mês/Ano', $data['name']);
|
2018-01-19 16:56:36 +00:00
|
|
|
|
|
|
|
// Mantém-se o valor antigo no item
|
|
|
|
$metav = get_post_meta($item->get_id(), $data['id'], true);
|
|
|
|
|
|
|
|
$this->assertEquals('19/01/2018', $metav);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2018-01-19 14:55:39 +00:00
|
|
|
}
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_trash_metadatum_in_collection(){
|
2018-02-23 14:59:13 +00:00
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-02-23 14:59:13 +00:00
|
|
|
array(
|
2018-06-11 15:10:07 +00:00
|
|
|
'name' => 'Metadatum Statement',
|
2018-02-23 14:59:13 +00:00
|
|
|
'description' => 'No Statement',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-02-23 14:59:13 +00:00
|
|
|
'multiple' => 'yes'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$trash_metadatum_request = new \WP_REST_Request(
|
2018-02-23 14:59:13 +00:00
|
|
|
'DELETE',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/collection/'. $collection->get_id() . '/metadata/' . $metadatum->get_id()
|
2018-02-23 14:59:13 +00:00
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$trash_metadatum_response = $this->server->dispatch($trash_metadatum_request);
|
|
|
|
$data1 = $trash_metadatum_response->get_data();
|
2018-02-23 14:59:13 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatum->get_id(), $data1['id']);
|
2018-02-23 14:59:13 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum_trashed = get_post($data1['id']);
|
|
|
|
$this->assertEquals('trash', $metadatum_trashed->post_status);
|
2018-02-23 14:59:13 +00:00
|
|
|
}
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_trash_default_metadatum(){
|
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-03-01 17:46:21 +00:00
|
|
|
array(
|
2018-06-11 15:10:07 +00:00
|
|
|
'name' => 'Metadatum Statement',
|
2018-03-01 17:46:21 +00:00
|
|
|
'description' => 'No Statement',
|
|
|
|
'collection_id' => 'default',
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-01 17:46:21 +00:00
|
|
|
'multiple' => 'yes'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$trash_metadatum_request = new \WP_REST_Request(
|
2018-03-01 17:46:21 +00:00
|
|
|
'DELETE',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/metadata/' . $metadatum->get_id()
|
2018-03-01 17:46:21 +00:00
|
|
|
);
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$trash_metadatum_response = $this->server->dispatch($trash_metadatum_request);
|
|
|
|
$data1 = $trash_metadatum_response->get_data();
|
2018-03-01 17:46:21 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatum->get_id(), $data1['id']);
|
2018-03-01 17:46:21 +00:00
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$metadatum_trashed = get_post($data1['id']);
|
|
|
|
$this->assertEquals('trash', $metadatum_trashed->post_status);
|
2018-03-01 17:46:21 +00:00
|
|
|
}
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
public function test_update_default_metadatum(){
|
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
2018-03-01 17:46:21 +00:00
|
|
|
array(
|
2018-06-11 15:10:07 +00:00
|
|
|
'name' => 'Metadatum Statement',
|
2018-03-01 17:46:21 +00:00
|
|
|
'description' => 'No Statement',
|
|
|
|
'collection_id' => 'default',
|
|
|
|
'status' => 'publish',
|
2018-06-11 17:57:50 +00:00
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
2018-03-01 17:46:21 +00:00
|
|
|
'multiple' => 'no'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$new_attributes = json_encode([
|
2018-03-06 14:01:35 +00:00
|
|
|
'name' => 'No name',
|
|
|
|
'description' => 'NOP!'
|
2018-03-01 17:46:21 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'PATCH',
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->namespace . '/metadata/' . $metadatum->get_id()
|
2018-03-01 17:46:21 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$request->set_body($new_attributes);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
2018-06-11 15:10:07 +00:00
|
|
|
$this->assertEquals($metadatum->get_id(), $data['id']);
|
2018-03-01 17:46:21 +00:00
|
|
|
$this->assertEquals('No name', $data['name']);
|
|
|
|
}
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
public function test_return_metadata_type_options_in_get_item() {
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$collection1 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$collection2 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$core1 = $collection1->get_core_title_metadatum();
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$meta_relationship = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'relationship',
|
|
|
|
'status' => 'publish',
|
|
|
|
'collection' => $collection2,
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Relationship',
|
|
|
|
'metadata_type_options' => [
|
|
|
|
'repeated' => 'yes',
|
|
|
|
'collection_id' => $collection1->get_id(),
|
|
|
|
'search' => $core1->get_id()
|
|
|
|
]
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
|
|
|
$this->namespace . '/metadata/' . $meta_relationship->get_id()
|
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals($meta_relationship->get_id(), $data['id']);
|
|
|
|
$this->assertEquals('relationship', $data['name']);
|
|
|
|
$this->assertEquals('yes', $data['metadata_type_options']['repeated']);
|
|
|
|
$this->assertEquals($collection1->get_id(), $data['metadata_type_options']['collection_id']);
|
|
|
|
$this->assertEquals($core1->get_id(), $data['metadata_type_options']['search']);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
}
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
public function test_return_metadata_type_options_in_get_items() {
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$collection1 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$collection2 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$core1 = $collection1->get_core_title_metadatum();
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$meta_relationship = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'relationship',
|
|
|
|
'status' => 'publish',
|
|
|
|
'collection' => $collection2,
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Relationship',
|
|
|
|
'metadata_type_options' => [
|
|
|
|
'repeated' => 'yes',
|
|
|
|
'collection_id' => $collection1->get_id(),
|
|
|
|
'search' => $core1->get_id()
|
|
|
|
]
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
|
|
|
$this->namespace . '/collection/' . $collection2->get_id() . '/metadata'
|
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
//var_dump($data, $this->namespace . '/collection/' . $collection2->get_id() . '/metadata/');
|
|
|
|
foreach ($data as $d) {
|
|
|
|
if ($d['id'] == $meta_relationship->get_id()) {
|
|
|
|
$meta = $d;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$this->assertEquals($meta_relationship->get_id(), $meta['id']);
|
|
|
|
$this->assertEquals('relationship', $meta['name']);
|
|
|
|
$this->assertEquals('yes', $meta['metadata_type_options']['repeated']);
|
|
|
|
$this->assertEquals($collection1->get_id(), $meta['metadata_type_options']['collection_id']);
|
|
|
|
$this->assertEquals($core1->get_id(), $meta['metadata_type_options']['search']);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
}
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
public function test_return_metadata_type_options_in_get_item_default_option() {
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$collection1 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$tax = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'taxonomy',
|
|
|
|
array(
|
|
|
|
'name' => 'tax_test',
|
|
|
|
'collections' => [$collection1],
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$meta = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'tax',
|
|
|
|
'status' => 'publish',
|
|
|
|
'collection' => $collection1,
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Taxonomy',
|
|
|
|
'metadata_type_options' => [
|
|
|
|
'taxonomy_id' => $tax->get_id(),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
|
|
|
$this->namespace . '/metadata/' . $meta->get_id()
|
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals($meta->get_id(), $data['id']);
|
|
|
|
$this->assertEquals('tax', $data['name']);
|
|
|
|
$this->assertEquals($tax->get_id(), $data['metadata_type_options']['taxonomy_id']);
|
|
|
|
$this->assertEquals('no', $data['metadata_type_options']['allow_new_terms']);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-10-16 14:05:29 +00:00
|
|
|
}
|
2018-03-01 17:46:21 +00:00
|
|
|
|
2019-11-06 14:33:40 +00:00
|
|
|
public function test_update_taxonomy_metadata() {
|
|
|
|
$Tainacan_Item_Metadata = \Tainacan\Repositories\Item_Metadata::get_instance();
|
|
|
|
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'test_col',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-11-06 14:33:40 +00:00
|
|
|
$tax = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'taxonomy',
|
|
|
|
array(
|
|
|
|
'name' => 'tax_test',
|
|
|
|
'collections' => [$collection],
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->tainacan_entity_factory->create_entity(
|
|
|
|
'term',
|
|
|
|
array(
|
|
|
|
'taxonomy' => $tax->get_db_identifier(),
|
|
|
|
'name' => 'Rock',
|
|
|
|
'user' => 56
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->tainacan_entity_factory->create_entity(
|
|
|
|
'term',
|
|
|
|
array(
|
|
|
|
'taxonomy' => $tax->get_db_identifier(),
|
|
|
|
'name' => 'Samba',
|
|
|
|
'user' => 56
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-11-06 14:33:40 +00:00
|
|
|
$metadatum = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'tax',
|
|
|
|
'status' => 'publish',
|
|
|
|
'collection' => $collection,
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Taxonomy',
|
|
|
|
'metadata_type_options' => [
|
|
|
|
'taxonomy_id' => $tax->get_id(),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$i1 = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'item',
|
|
|
|
array(
|
|
|
|
'title' => 'item teste',
|
|
|
|
'description' => 'adasdasdsa',
|
|
|
|
'collection' => $collection
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$itemMeta1 = new \Tainacan\Entities\Item_Metadata_Entity($i1, $metadatum);
|
|
|
|
$itemMeta1->set_value('Rock');
|
|
|
|
$itemMeta1->validate();
|
|
|
|
$Tainacan_Item_Metadata->insert($itemMeta1);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2019-11-06 14:33:40 +00:00
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'GET',
|
|
|
|
$this->namespace . '/item/' . $i1->get_id() . '/metadata/' . $metadatum->get_id()
|
|
|
|
);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals(false, empty($data['value']));
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'PATCH',
|
|
|
|
$this->namespace . '/item/' . $i1->get_id() . '/metadata/' . $metadatum->get_id()
|
|
|
|
);
|
|
|
|
$attributes = json_encode(['values' => '']);
|
|
|
|
$request->set_body($attributes);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals(true, empty($data['value']));
|
|
|
|
}
|
|
|
|
|
2020-02-03 19:53:23 +00:00
|
|
|
public function test_visibility_the_metadatum_from_in_collection(){
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumA = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumB = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'private',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
wp_logout();
|
|
|
|
wp_set_current_user(0);
|
|
|
|
|
|
|
|
$requestA = new \WP_REST_Request('GET', $this->namespace . '/metadata/' . $metadatumA->get_id());
|
|
|
|
$requestB = new \WP_REST_Request('GET', $this->namespace . '/metadata/' . $metadatumB->get_id());
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($requestA);
|
|
|
|
$status = $response->status;
|
|
|
|
$this->assertEquals(200, $status);
|
2020-02-11 14:00:01 +00:00
|
|
|
|
2020-02-03 19:53:23 +00:00
|
|
|
$response = $this->server->dispatch($requestB);
|
|
|
|
$status = $response->status;
|
|
|
|
$this->assertEquals(401, $status);
|
|
|
|
}
|
|
|
|
|
2020-02-11 13:09:45 +00:00
|
|
|
public function test_private_filter_ids_not_in_metadata_list(){
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement',
|
|
|
|
'status' => 'publish',
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumA = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumB = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'private',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
wp_logout();
|
|
|
|
wp_set_current_user(0);
|
|
|
|
|
|
|
|
$requestA = new \WP_REST_Request('GET', $this->namespace . '/metadata/' . $metadatumA->get_id());
|
|
|
|
$requestB = new \WP_REST_Request('GET', $this->namespace . '/metadata/' . $metadatumB->get_id());
|
|
|
|
$requestC = new \WP_REST_Request('GET', $this->namespace . '/collection/' . $collection->get_id() . '/metadata');
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($requestA);
|
|
|
|
$status = $response->status;
|
|
|
|
$this->assertEquals(200, $status);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($requestB);
|
|
|
|
$status = $response->status;
|
|
|
|
$this->assertEquals(401, $status);
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($requestC);
|
|
|
|
$data = $response->get_data();
|
|
|
|
$this->assertEquals(3, count($data));
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data[0]['id']);
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data[1]['id']);
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data[2]['id']);
|
|
|
|
}
|
|
|
|
|
2020-02-11 13:52:26 +00:00
|
|
|
public function test_private_meta_ids_not_in_metadata_order(){
|
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'Statement',
|
|
|
|
'description' => 'No Statement',
|
|
|
|
'status' => 'publish',
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumA = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatumB = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'metadatum',
|
|
|
|
array(
|
|
|
|
'name' => 'Data',
|
|
|
|
'description' => 'Descreve valor do campo data.',
|
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'private',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Text',
|
|
|
|
), true
|
|
|
|
);
|
|
|
|
|
|
|
|
$order = array();
|
|
|
|
|
|
|
|
$metas = $collection->get_metadata();
|
|
|
|
|
|
|
|
foreach ( $metas as $m ) {
|
|
|
|
$order[] = [
|
|
|
|
'id' => $m->get_id(),
|
|
|
|
'enabled' => true,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$collection->set_metadata_order($order);
|
|
|
|
$collection->validate();
|
|
|
|
\tainacan_collections()->insert($collection);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request('GET', $this->namespace . '/collections/' . $collection->get_id());
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
2020-04-17 12:29:11 +00:00
|
|
|
$this->assertEquals(4, count($data['metadata_order']));
|
2020-02-11 13:52:26 +00:00
|
|
|
|
|
|
|
wp_logout();
|
|
|
|
wp_set_current_user(0);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request('GET', $this->namespace . '/collections/' . $collection->get_id());
|
|
|
|
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$data = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertEquals(3, count($data['metadata_order']));
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data['metadata_order'][0]['id']);
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data['metadata_order'][1]['id']);
|
|
|
|
$this->assertNotEquals($metadatumB->get_id(), $data['metadata_order'][2]['id']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-03-05 14:04:44 +00:00
|
|
|
/**
|
|
|
|
* @group compound_metadatum
|
|
|
|
*/
|
|
|
|
public function test_create_compound_metadatum_API() {
|
2020-03-05 17:02:48 +00:00
|
|
|
$collection = $this->tainacan_entity_factory->create_entity(
|
|
|
|
'collection',
|
|
|
|
array(
|
|
|
|
'name' => 'quadrado',
|
|
|
|
'status' => 'publish'
|
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
2020-03-05 14:04:44 +00:00
|
|
|
|
|
|
|
$this->tainacan_entity_factory->create_entity(
|
|
|
|
'item',
|
|
|
|
array(
|
|
|
|
'title' => 'No name',
|
|
|
|
'description' => 'No description',
|
2020-03-05 17:02:48 +00:00
|
|
|
'collection' => $collection,
|
|
|
|
'status' => 'publish'
|
2020-03-05 14:04:44 +00:00
|
|
|
),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$metadatum_compound = json_encode(
|
|
|
|
array(
|
|
|
|
'name' => 'quadrado',
|
|
|
|
'description' => 'Descrição de um quadrado.',
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Compound',
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
|
|
|
);
|
|
|
|
$request->set_body($metadatum_compound);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
|
|
|
|
$metadatum_compound_added = $response->get_data();
|
|
|
|
$this->assertTrue(is_array($metadatum_compound_added) && array_key_exists('name', $metadatum_compound_added), sprintf('cannot create metadatum, response: %s', print_r($metadatum_compound_added, true)));
|
|
|
|
$this->assertEquals('quadrado', $metadatum_compound_added['name']);
|
|
|
|
$this->assertNotEquals('default', $metadatum_compound_added['collection_id']);
|
|
|
|
|
|
|
|
|
|
|
|
$metadatum_largura = json_encode(
|
|
|
|
array(
|
|
|
|
'name' => 'largura',
|
|
|
|
'description' => 'largura.',
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Numeric',
|
|
|
|
'parent' => $metadatum_compound_added['id']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$metadatum_altura = json_encode(
|
|
|
|
array(
|
|
|
|
'name' => 'altura',
|
|
|
|
'description' => 'altura',
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Numeric',
|
|
|
|
'parent' => $metadatum_compound_added['id']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
|
|
|
);
|
|
|
|
$request->set_body($metadatum_largura);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$metadatum_largura = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertTrue(is_array($metadatum_largura) && array_key_exists('name', $metadatum_largura), sprintf('cannot create metadatum, response: %s', print_r($metadatum_largura, true)));
|
|
|
|
$this->assertEquals('largura', $metadatum_largura['name']);
|
|
|
|
$this->assertNotEquals('default', $metadatum_largura['collection_id']);
|
|
|
|
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
|
|
|
);
|
|
|
|
$request->set_body($metadatum_altura);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$metadatum_altura = $response->get_data();
|
|
|
|
|
|
|
|
$this->assertTrue(is_array($metadatum_altura) && array_key_exists('name', $metadatum_altura), sprintf('cannot create metadatum, response: %s', print_r($metadatum_altura, true)));
|
|
|
|
$this->assertEquals('altura', $metadatum_altura['name']);
|
|
|
|
$this->assertNotEquals('default', $metadatum_altura['collection_id']);
|
|
|
|
|
|
|
|
|
|
|
|
$metadatum_multiplo = json_encode(
|
|
|
|
array(
|
|
|
|
'name' => 'multiplo',
|
|
|
|
'description' => 'multiplo.',
|
|
|
|
'multiple' => 'yes',
|
|
|
|
'status' => 'publish',
|
|
|
|
'metadata_type' => 'Tainacan\Metadata_Types\Numeric',
|
|
|
|
'parent' => $metadatum_compound_added['id']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$request = new \WP_REST_Request(
|
|
|
|
'POST',
|
|
|
|
$this->namespace . '/collection/' . $collection->get_id() . '/metadata'
|
|
|
|
);
|
|
|
|
$request->set_body($metadatum_multiplo);
|
|
|
|
$response = $this->server->dispatch($request);
|
|
|
|
$metadatum_multiplo_data = $response->get_data();
|
|
|
|
$this->assertEquals(400, $response->get_status(), sprintf('cannot create metadatum, response: %s', print_r($metadatum_multiplo_data, true)) );
|
|
|
|
}
|
2020-02-11 13:09:45 +00:00
|
|
|
|
2017-12-11 16:46:26 +00:00
|
|
|
}
|
|
|
|
|
2020-02-11 14:00:01 +00:00
|
|
|
?>
|