import unittest import io import re from unittest import mock import math import student_X as main #Replace student_X with your filename import sys import io from io import StringIO class PrintSphereVolumeRadius8Tests(unittest.TestCase): def test_default_case(self): function = main.print_sphere_volume_radius_8 try: doc = function.__doc__ except: doc = "" correct = doc.strip() != "" message = "docstring is blank." self.assertTrue(correct, message) with mock.patch('sys.stdout', new=io.StringIO()) as fake_stdout: function() output = fake_stdout.getvalue().strip() regex = ".* radius 8 has .*" feedback = "Doesn't have the radius included in the output." correct = re.match(regex, output) self.assertTrue(correct, feedback) regex = "A sphere with radius 8 has volume [1234567890\.]* *\.?" feedback = "Text of the output is incorrect." correct = re.match(regex, output) self.assertTrue(correct, feedback) regex = "[A-Za-z ]* 8 [A-Za-z ]*2144\.660584850632 *\.?" feedback = "Doesn't print out the correct volume." correct = re.match(regex, output) self.assertTrue(correct, feedback) correct = output.endswith('.') feedback = "Doesn't end with a period." self.assertTrue(correct, feedback) if __name__ == "__main__": tests = PrintSphereVolumeRadius8Tests() tests.test_default_case()