| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 | 
							- <?php
 
- namespace Tests;
 
- use StatonLab\TripalTestSuite\DBTransaction;
 
- use StatonLab\TripalTestSuite\TripalTestCase;
 
- class ChadoQueryTest extends TripalTestCase {
 
-   // Uncomment to auto start and rollback db transactions per test method.
 
-   use DBTransaction;
 
-   /**
 
-    * @group filter
 
-    * See PR 827.
 
-    */
 
-   public function test_filter_level() {
 
-     $stock = factory('chado.stock')->create(['uniquename' => 'octopus_core_test_name']);
 
-     // Test 1. Pass a single filter.
 
-     $selector = [
 
-       'stock_id' => $stock->stock_id,
 
-       'uniquename' => [
 
-         'op' => 'LIKE',
 
-         'data' => 'octopus%',
 
-       ],
 
-     ];
 
-     $object = chado_generate_var('stock', $selector);
 
-     $this->assertNotNull($object->stock_id);
 
-     $this->assertEquals($stock->stock_id, $object->stock_id);
 
-     // Test 2 Pass an array of filters with a single item.
 
-     $selector = [
 
-       'stock_id' => $stock->stock_id,
 
-       'uniquename' => [
 
-         [
 
-           'op' => 'LIKE',
 
-           'data' => 'octopus%',
 
-         ],
 
-       ],
 
-     ];
 
-     $object = chado_generate_var('stock', $selector);
 
-     $this->assertNotNull($object->stock_id);
 
-     $this->assertEquals($stock->stock_id, $object->stock_id);
 
-     // Test 3 Pass an array of filters with multiple items.
 
-     $selector = [
 
-       'type_id' => [
 
-         [
 
-           'op' => '>',
 
-           'data' => ($stock->type_id - 1),
 
-         ],
 
-         [
 
-           'op' => '<',
 
-           'data' => ($stock->type_id + 1),
 
-         ],
 
-       ],
 
-     ];
 
-     $object = chado_generate_var('stock', $selector);
 
-     $this->assertNotNull($object->stock_id);
 
-     $this->assertEquals($stock->stock_id, $object->stock_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_chado_db_select_works_for_chado_tables() {
 
-     $analysis_record = factory('chado.analysis')->create();
 
-     $id = $analysis_record->analysis_id;
 
-     // Test passing a table name without brackets or braces.
 
-     $query = chado_db_select('analysis', 't');
 
-     $analysis = $query
 
-       ->condition('analysis_id', $id)
 
-       ->fields('t')
 
-       ->execute()
 
-       ->fetchObject();
 
-     $this->assertNotFalse($analysis);
 
-     $this->assertNotEmpty($analysis);
 
-     $this->assertEquals($id, $analysis->analysis_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_chado_db_select_should_throw_an_exception_if_table_is_undefined() {
 
-     $this->expectException(\Exception::class);
 
-     chado_db_select('some_nonexistent_table', 'd')->execute();
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_chado_db_select_recognizes_non_chado_tables() {
 
-     $query = chado_db_select('users', 'u');
 
-     $query->fields('u');
 
-     $query->range(0, 1);
 
-     $results = $query->execute()->fetchAll();
 
-     $this->assertNotEmpty($results);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_chado_db_select_handles_aliases_correctly() {
 
-     $query = chado_db_select('public.users');
 
-     $query->fields('public_users');
 
-     $query->range(0, 1);
 
-     $results = $query->execute()->fetchAll();
 
-     $this->assertNotEmpty($results);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_joining_chado_tables_in_chado_db_select() {
 
-     $feature = factory('chado.feature')->create();
 
-     $cvterm = factory('chado.cvterm')->create();
 
-     $pub = factory('chado.pub')->create();
 
-     $feature_cvterm = chado_insert_record('feature_cvterm', [
 
-       'feature_id' => $feature->feature_id,
 
-       'cvterm_id' => $cvterm->cvterm_id,
 
-       'pub_id' => $pub->pub_id,
 
-     ]);
 
-     $query = chado_db_select('feature', 'f');
 
-     $query->join('feature_cvterm', 'fcvt', 'f.feature_id = fcvt.feature_id');
 
-     $query->fields('f', ['name']);
 
-     $query->fields('fcvt', ['cvterm_id']);
 
-     $query->condition('f.feature_id', $feature->feature_id);
 
-     $found = $query->execute()->fetchObject();
 
-     $this->assertNotEmpty($found);
 
-     $this->assertEquals($feature_cvterm['cvterm_id'], $found->cvterm_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_left_joining_chado_tables_in_chado_db_select() {
 
-     $feature = factory('chado.feature')->create();
 
-     $cvterm = factory('chado.cvterm')->create();
 
-     $pub = factory('chado.pub')->create();
 
-     $feature_cvterm = chado_insert_record('feature_cvterm', [
 
-       'feature_id' => $feature->feature_id,
 
-       'cvterm_id' => $cvterm->cvterm_id,
 
-       'pub_id' => $pub->pub_id,
 
-     ]);
 
-     $query = chado_db_select('feature', 'f');
 
-     $query->leftJoin('feature_cvterm', 'fcvt', 'f.feature_id = fcvt.feature_id');
 
-     $query->fields('f', ['name']);
 
-     $query->fields('fcvt', ['cvterm_id']);
 
-     $query->condition('f.feature_id', $feature->feature_id);
 
-     $found = $query->execute()->fetchObject();
 
-     $this->assertNotEmpty($found);
 
-     $this->assertEquals($feature_cvterm['cvterm_id'], $found->cvterm_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_right_joining_chado_tables_in_chado_db_select() {
 
-     $feature = factory('chado.feature')->create();
 
-     $cvterm = factory('chado.cvterm')->create();
 
-     $pub = factory('chado.pub')->create();
 
-     $feature_cvterm = chado_insert_record('feature_cvterm', [
 
-       'feature_id' => $feature->feature_id,
 
-       'cvterm_id' => $cvterm->cvterm_id,
 
-       'pub_id' => $pub->pub_id,
 
-     ]);
 
-     $query = chado_db_select('feature', 'f');
 
-     $query->rightJoin('feature_cvterm', 'fcvt', 'f.feature_id = fcvt.feature_id');
 
-     $query->fields('f', ['name']);
 
-     $query->fields('fcvt', ['cvterm_id']);
 
-     $query->condition('f.feature_id', $feature->feature_id);
 
-     $found = $query->execute()->fetchObject();
 
-     $this->assertNotEmpty($found);
 
-     $this->assertEquals($feature_cvterm['cvterm_id'], $found->cvterm_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_inner_joining_chado_tables_in_chado_db_select() {
 
-     $feature = factory('chado.feature')->create();
 
-     $cvterm = factory('chado.cvterm')->create();
 
-     $pub = factory('chado.pub')->create();
 
-     $feature_cvterm = chado_insert_record('feature_cvterm', [
 
-       'feature_id' => $feature->feature_id,
 
-       'cvterm_id' => $cvterm->cvterm_id,
 
-       'pub_id' => $pub->pub_id,
 
-     ]);
 
-     $query = chado_db_select('feature', 'f');
 
-     $query->innerJoin('feature_cvterm', 'fcvt', 'f.feature_id = fcvt.feature_id');
 
-     $query->fields('f', ['name']);
 
-     $query->fields('fcvt', ['cvterm_id']);
 
-     $query->condition('f.feature_id', $feature->feature_id);
 
-     $found = $query->execute()->fetchObject();
 
-     $this->assertNotEmpty($found);
 
-     $this->assertEquals($feature_cvterm['cvterm_id'], $found->cvterm_id);
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_is_chado_table_returns_correct_results() {
 
-     $this->assertTrue(\ChadoPrefixExtender::isChadoTable('analysis'));
 
-     $this->assertTrue(\ChadoPrefixExtender::isChadoTable('feature_cvtermprop'));
 
-     $this->assertFalse(\ChadoPrefixExtender::isChadoTable('users'));
 
-   }
 
-   /**
 
-    * @group api
 
-    * @group chado
 
-    * @group chado_db_select
 
-    */
 
-   public function test_get_real_schema_returns_correct_results() {
 
-     $chado = chado_get_schema_name('chado');
 
-     $public = chado_get_schema_name('drupal');
 
-     $this->assertEquals($chado . '.analysis', \ChadoPrefixExtender::getRealSchema('chado.analysis'));
 
-     $this->assertEquals($public . '.users', \ChadoPrefixExtender::getRealSchema('public.users'));
 
-     $this->assertEquals('users', \ChadoPrefixExtender::getRealSchema('users'));
 
-   }
 
- }
 
 
  |