File: CUTG.t

package info (click to toggle)
bioperl 1.6.1-2
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 40,768 kB
  • ctags: 12,005
  • sloc: perl: 174,299; xml: 13,923; sh: 1,941; lisp: 1,803; asm: 109; makefile: 53
file content (91 lines) | stat: -rwxr-xr-x 3,037 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
# -*-Perl-*- Test Harness script for Bioperl
# $Id: CUTG.t 15112 2008-12-08 18:12:38Z sendu $

use strict;

BEGIN {
	use lib '.';
	use Bio::Root::Test;
	
	test_begin(-tests => 37,
			   -requires_modules => [qw(IO::String LWP::UserAgent)]);
	
	use_ok('Bio::DB::CUTG');
	use_ok('Bio::CodonUsage::Table');
	use_ok('Bio::CodonUsage::IO');
    use_ok('Bio::SeqIO');
    use_ok('Bio::Tools::SeqStats');
}

my $outfile = test_output_file();
my $verbose = test_debug();

# try reading from file
ok my $io = Bio::CodonUsage::IO->new
  (-file=> test_input_file('MmCT'));
ok  my $cut2 = $io->next_data();
is int($cut2->aa_frequency('LEU')), 10;

# write
ok $io = Bio::CodonUsage::IO->new(-file => ">$outfile");
$io->write_data($cut2);
ok -e $outfile;

# can we read what we've written?
ok $io = Bio::CodonUsage::IO->new(-file => "$outfile");
ok $cut2 = $io->next_data();
is int($cut2->aa_frequency('LEU')), 10;

# now try making a user defined CUT from a sequence
ok my $seqobj = Bio::SeqIO->new (-file =>test_input_file('HUMBETGLOA.fa'),
				                        -format => 'fasta')->next_seq;
is $seqobj->subseq(10,20), 'TTGACACCACT';
ok my $codcont_Ref = Bio::Tools::SeqStats->count_codons($seqobj);
is $codcont_Ref->{'TGA'}, 16;
ok my $cut = Bio::CodonUsage::Table->new(-data=>$codcont_Ref);
is $cut->codon_rel_frequency('CTG'), 0.18;
is $cut->codon_abs_frequency('CTG'), 2.6;
is $cut->codon_count('CTG'), 26;
is $cut->get_coding_gc(1), "39.70";
ok my $ref = $cut->probable_codons(20);

# requiring Internet access, set env BIOPERLDEBUG to 1 to run
SKIP: {
	test_skip(-tests => 14, -requires_networking => 1);
	ok my $tool = Bio::WebAgent->new(-verbose => $verbose);
	ok $tool->sleep;
	is $tool->delay(1), 1;
	ok $tool->sleep;

	# get CUT from web
	ok my $db = Bio::DB::CUTG->new();
	$db->verbose($verbose ? $verbose : -1);
	my $cdtable;
	eval {$cdtable = $db->get_request(-sp =>'Pan troglodytes');};
	skip "Server/network problems? Skipping those tests\n$@", 5 if $@;
	
	# tests for Table.pm, the answers seem to change with time, so not specific
	cmp_ok($cdtable->cds_count(), '>', 10);
	cmp_ok(int($cdtable->aa_frequency('LEU')), '>', 1);
	ok $cdtable->get_coding_gc('all');
	cmp_ok($cdtable->codon_rel_frequency('ttc'), '<', 1); 
    
	## now lets enter a non-existent species ans check handling..
	## should default to human...
	my $db2 = Bio::DB::CUTG->new();
	$db2->verbose($verbose ? $verbose : -1);
	eval {$cut2 = $db2->get_request(-sp =>'Wookie magnus');};
	skip "Server/network problems? Skipping those tests\n$@", 1 if $@;
	is $cut2->species(), 'Homo sapiens';
	
	$db = Bio::DB::CUTG->new();
	$db->verbose($verbose ? $verbose : -1);
	eval {$cdtable = $db->get_request(-sp =>'Homo sapiens');};
	skip "Server/network problems? Skipping those tests\n$@", 4 if $@;
	
	# tests for Table.pm, the answers seem to change with time, so not specific
	cmp_ok($cdtable->cds_count(), '>', 10);
	cmp_ok(int($cdtable->aa_frequency('LEU')), '>', 1);
	ok $cdtable->get_coding_gc('all');
	cmp_ok($cdtable->codon_rel_frequency('ttc'), '<', 1); 
}