TripalChadoPropertyAPITest.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. <?php
  2. namespace Tests;
  3. use StatonLab\TripalTestSuite\DBTransaction;
  4. use StatonLab\TripalTestSuite\TripalTestCase;
  5. class TripalChadoPropertyAPITest extends TripalTestCase {
  6. use DBTransaction;
  7. /**
  8. * @group chado
  9. * @group api
  10. *
  11. */
  12. public function test_chado_insert_property() {
  13. $feature = factory('chado.feature')->create();
  14. $term = factory('chado.cvterm')->create();
  15. $value = 'chado_API_test_value';
  16. // Linker column
  17. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  18. $property = [
  19. 'type_id' => $term->cvterm_id,
  20. 'value' => $value,
  21. ];
  22. chado_insert_property($record, $property);
  23. $result = db_select('chado.featureprop', 'f')
  24. ->fields('f')
  25. ->condition('f.feature_id', $feature->feature_id)
  26. ->execute()
  27. ->fetchObject();
  28. $this->assertNotEmpty($result);
  29. $this->assertEquals($value, $result->value);
  30. $this->assertEquals($term->cvterm_id, $result->type_id);
  31. $this->assertEquals('0', $result->rank);
  32. }
  33. /**
  34. * @group chado
  35. * @group api
  36. * @group wip
  37. *
  38. */
  39. public function test_chado_get_property() {
  40. $feature = factory('chado.feature')->create();
  41. $term = factory('chado.cvterm')->create();
  42. $value = 'chado_API_test_value';
  43. // Linker column
  44. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  45. $property = [
  46. 'type_id' => $term->cvterm_id,
  47. 'value' => $value,
  48. ];
  49. $prop = chado_insert_property($record, $property);
  50. $retrieved = chado_get_property($record, $property);
  51. $this->assertNotFalse($retrieved);
  52. $this->assertEquals($value, $retrieved->value);
  53. $record = ['prop_id' => $prop['featureprop_id'], 'table' => 'feature'];
  54. $retrieved = chado_get_property($record, $property);
  55. $this->assertNotFalse($retrieved);
  56. $this->assertEquals($value, $retrieved->value);
  57. }
  58. /**
  59. * @group chado
  60. * @group api
  61. */
  62. public function test_chado_update_property() {
  63. $feature = factory('chado.feature')->create();
  64. $term = factory('chado.cvterm')->create();
  65. $value = 'chado_API_test_value';
  66. $new_value = 'chado_API_new';
  67. // Linker column
  68. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  69. $property = [
  70. 'type_id' => $term->cvterm_id,
  71. 'value' => $value,
  72. ];
  73. chado_insert_property($record, $property);
  74. $property['value'] = $new_value;
  75. chado_update_property($record, $property);
  76. $result = db_select('chado.featureprop', 'f')
  77. ->fields('f')
  78. ->condition('f.feature_id', $feature->feature_id)
  79. ->execute()
  80. ->fetchObject();
  81. $this->assertNotEmpty($result);
  82. $this->assertEquals($new_value, $result->value);
  83. $this->assertEquals($term->cvterm_id, $result->type_id);
  84. $this->assertEquals('0', $result->rank);
  85. }
  86. /**
  87. * @group chado
  88. * @group api
  89. */
  90. public function test_chado_delete_property() {
  91. $feature = factory('chado.feature')->create();
  92. $term = factory('chado.cvterm')->create();
  93. $value = 'chado_API_test_value';
  94. // Linker column
  95. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  96. $property = [
  97. 'type_id' => $term->cvterm_id,
  98. 'value' => $value,
  99. ];
  100. chado_insert_property($record, $property);
  101. chado_delete_property($record, $property);
  102. $result = db_select('chado.featureprop', 'f')
  103. ->fields('f')
  104. ->condition('f.feature_id', $feature->feature_id)
  105. ->execute()
  106. ->fetchObject();
  107. $this->assertFalse($result);
  108. $prop = chado_insert_property($record, $property);
  109. $record = ['prop_id' => $prop['featureprop_id'], 'table' => 'feature'];
  110. chado_delete_property($record, $property);
  111. }
  112. /**
  113. * @group wip
  114. * @group chado
  115. * @group api
  116. */
  117. function test_chado_get_record_with_property() {
  118. // * Get all records in the base table assigned one or more properties.
  119. $feature = factory('chado.feature')->create();
  120. $term = factory('chado.cvterm')->create();
  121. $value = 'chado_API_test_value';
  122. // Linker column
  123. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  124. $property = [
  125. 'type_id' => $term->cvterm_id,
  126. 'value' => $value,
  127. ];
  128. chado_insert_property($record, $property);
  129. unset($record['id']);
  130. $records = chado_get_record_with_property($record, $property);
  131. $this->assertNotEmpty($records);
  132. $this->assertEquals(1, count($records));
  133. $feature = factory('chado.feature')->create();
  134. $record = ['table' => 'feature', 'id' => $feature->feature_id];
  135. chado_insert_property($record, $property);
  136. $records = chado_get_record_with_property($record, $property);
  137. $this->assertNotEmpty($records);
  138. $this->assertEquals(2, count($records));
  139. }
  140. }