The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use Test::More;
use Webservice::InterMine::Bio qw/GFF3 FASTA BED/;
use Webservice::InterMine::Bio::RegionQuery;
use Webservice::InterMine;

unless ($ENV{RELEASE_TESTING}) {
    plan skip_all => "Live test for release testing only";
} else {
    my $service = Webservice::InterMine->get_service('flymine');
    my $query = $service->new_query(with => GFF3);

    $query->add_sequence_features(qw/Gene Gene.exons Gene.exons.transcripts/);

    $query->add_constraint(qw/Gene.chromosome.primaryIdentifier = 4/);

    $query->print_gff3(to => '/tmp/out-uncompressed.gff3');
    $query->print_gff3(to => '/tmp/out-compressed.gff3.gz');

    $query->print_gff3;

    my $db = $query->get_feature_store;

    print $_ for ($db->get_features_by_type('ncRNA'));

    my $faq = $service->new_query(with => FASTA);

    $faq->add_sequence_features(qw/Gene.exons/);

    $faq->add_constraint(qw/Gene.chromosome.primaryIdentifier = 4/);

    $faq->print_fasta(to => '/tmp/out-uncompressed.fa');
    $faq->print_fasta;

    my $seqio = $faq->get_seq_io;
    my $out = Bio::SeqIO->new(-file => '>-', -format => 'EMBL'); 

    while (my $seq = $seqio->next_seq() ) {
        $out->write_seq($seq);
    }

    $query = $service->new_query(class => 'Gene', with => BED);
    $query->add_sequence_features("Gene", "Gene.exons", "Gene.transcripts");
    $query->add_constraint("symbol" => [qw/h H eve zen/]);

    $query->print_bed;

    my $beta_service = Webservice::InterMine->get_service('squirrel.flymine.org/flymine', 
        'C1o3t1e0d4V06ep8xb47DdlFVMr');
    my $region_query = Webservice::InterMine::Bio::RegionQuery->new(
        service => $beta_service, 
        organism => "D. melanogaster", 
        regions => ["2L:14614843..14619614", "Foo",],
        feature_types => ["Exon", "Transcript"],
    );

    print $region_query->bed;
    print $region_query->fasta;
    print $region_query->gff3;

    print "Making a list...", "\n";
    my $list = $beta_service->new_list(content => $region_query);

    print $list, "\n";

    $region_query->feature_types([qw/Intron Gene/]);
    print my $list_b = $beta_service->new_list(content => $region_query), "\n";

    print $list | $list_b, "\n";

    print $list | $region_query, "\n";

}