Skip to content

Commit

Permalink
protein-translation: update tests to v1.1.0 (#1329)
Browse files Browse the repository at this point in the history
* protein-translation: update tests to v1.1.0

* protein-translation: adjust assertion param order (#440)

* protein-translation: remove redundant utilities in tests
  • Loading branch information
mrcfps authored and cmccandless committed Feb 21, 2018
1 parent 0704fa3 commit 6560eaa
Showing 1 changed file with 14 additions and 24 deletions.
38 changes: 14 additions & 24 deletions exercises/protein-translation/protein_translation_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,77 +3,67 @@
from protein_translation import proteins


# Tests adapted from problem-specifications/canonical-data.json @ v1.0.0
# Tests adapted from problem-specifications/canonical-data.json @ v1.1.0

class ProteinTranslationTests(unittest.TestCase):

def test_AUG_translates_to_methionine(self):
self.assertEqual(['Methionine'], proteins('AUG'))
self.assertEqual(proteins('AUG'), ['Methionine'])

def test_identifies_Phenylalanine_codons(self):
for codon in ['UUU', 'UUC']:
self.assertEqual(['Phenylalanine'], proteins(codon))
self.assertEqual(proteins(codon), ['Phenylalanine'])

def test_identifies_Leucine_codons(self):
for codon in ['UUA', 'UUG']:
self.assertEqual(['Leucine'], proteins(codon))
self.assertEqual(proteins(codon), ['Leucine'])

def test_identifies_Serine_codons(self):
for codon in ['UCU', 'UCC', 'UCA', 'UCG']:
self.assertEqual(['Serine'], proteins(codon))
self.assertEqual(proteins(codon), ['Serine'])

def test_identifies_Tyrosine_codons(self):
for codon in ['UAU', 'UAC']:
self.assertEqual(['Tyrosine'], proteins(codon))
self.assertEqual(proteins(codon), ['Tyrosine'])

def test_identifies_Cysteine_codons(self):
for codon in ['UGU', 'UGC']:
self.assertEqual(['Cysteine'], proteins(codon))
self.assertEqual(proteins(codon), ['Cysteine'])

def test_identifies_Tryptophan_codons(self):
self.assertEqual(['Tryptophan'], proteins('UGG'))
self.assertEqual(proteins('UGG'), ['Tryptophan'])

def test_identifies_stop_codons(self):
for codon in ['UAA', 'UAG', 'UGA']:
self.assertEqual([], proteins(codon))
self.assertEqual(proteins(codon), [])

def test_translates_rna_strand_into_correct_protein_list(self):
strand = 'AUGUUUUGG'
expected = ['Methionine', 'Phenylalanine', 'Tryptophan']
self.assertEqual(expected, proteins(strand))
self.assertEqual(proteins(strand), expected)

def test_stops_translation_if_stop_codon_at_beginning_of_sequence(self):
strand = 'UAGUGG'
expected = []
self.assertEqual(expected, proteins(strand))
self.assertEqual(proteins(strand), expected)

def test_stops_translation_if_stop_codon_at_end_of_two_codon_sequence(
self):
strand = 'UGGUAG'
expected = ['Tryptophan']
self.assertEqual(expected, proteins(strand))
self.assertEqual(proteins(strand), expected)

def test_stops_translation_if_stop_codon_at_end_of_three_codon_sequence(
self):
strand = 'AUGUUUUAA'
expected = ['Methionine', 'Phenylalanine']
self.assertEqual(expected, proteins(strand))
self.assertEqual(proteins(strand), expected)

def test_stops_translation_if_stop_codon_in_middle_of_six_codon_sequence(
self):
strand = 'UGGUGUUAUUAAUGGUUU'
expected = ['Tryptophan', 'Cysteine', 'Tyrosine']
self.assertEqual(expected, proteins(strand))

# Utility functions
def setUp(self):
try:
self.assertRaisesRegex
except AttributeError:
self.assertRaisesRegex = self.assertRaisesRegexp

def assertRaisesWithMessage(self, exception):
return self.assertRaisesRegex(exception, r".+")
self.assertEqual(proteins(strand), expected)


if __name__ == '__main__':
Expand Down

0 comments on commit 6560eaa

Please sign in to comment.