コード例 #1
0
                                                     calc.Subtract(num1,
                                                                   num2)))
                except Exception as e:
                    print("#### An error happened")

            elif (menuItem == 3):
                # multiply
                print("\n{:^80}".format("-* Multiplication of two numbers *-"))
                print("_" * 80)

                num1 = input("Enter the first number: ")
                num2 = input("Enter the second number: ")

                try:
                    print("\n{0} * {1} = {2}".format(num1, num2,
                                                     calc.Multiply(num1,
                                                                   num2)))
                except Exception as e:
                    print("#### An error happened")

            elif (menuItem == 4):
                # divide
                print("\n{:^80}".format("-* Division of two numbers *-"))
                print("_" * 80)

                num1 = input("Enter the first number: ")
                num2 = input("Enter the divisor number: ")

                try:
                    if (int(num2) == 0):
                        print(
                            "#### Second number is invalid. Can't divide by 0")
コード例 #2
0
ファイル: main.py プロジェクト: annkapul/calc-logger
from calculator import Calculator
import logging

logging.basicConfig(level=logging.DEBUG, format='%(message)s')

if __name__ == '__main__':
    calc = Calculator()
    logging.info(calc.Divide(4, 2))
    logging.info(calc.Divide(10, 3))
    logging.info(calc.Sum(3.5, 6.7))
    logging.info(calc.Sum('aaaa', 'BB'))
    logging.info(calc.Subtract(10, b=6))
    logging.info(calc.Subtract(-10, b=6))
    logging.info(calc.Multiply(a=6, b=5))
    logging.info(calc.Multiply(-16, 0.00005))

    logging.info(calc.Sum(complex(1, 2), complex(1, 2)))
    logging.info(calc.Divide(complex(1, 10), complex(1, 3)))
    logging.info(calc.Multiply(complex(5, 3), complex(1, 2)))
    logging.info(calc.Subtract(complex(7, 6), complex(1, 2)))

    logging.info(calc.Subtract(complex(-1, -2), -2))

    try:
        logging.info(calc.Divide('110', '10'))
    except BaseException as e:
        print("Can't do operation with binary numbers")
コード例 #3
0
class TestCalculator(unittest.TestCase):
    '''
    This is the test class for the calculator
    Args: (unittest.TestCase) : receives the unit test case class
    '''
    def setUp(self):
        self.calc = Calculator()

    def testAddReturnCorrectResult(self):
        self.assertEqual(4, self.calc.Add(2, 2))
        self.assertEqual(1, self.calc.Add(0, 1))
        self.assertEqual(-2, self.calc.Add(-4, 2))
        self.assertEqual(-6, self.calc.Add(-2, -4))
        self.assertEqual(0, self.calc.Add(0, 0))

    def testAddReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Add, 'one', 'two')

    def testCosineReturnCorrectResult(self):
        self.assertEqual(0.65, self.calc.Cosine(6 / 7))
        self.assertEqual(0.53, self.calc.Cosine(45))
        self.assertEqual(0.53, self.calc.Cosine(-45))
        self.assertEqual(-0.95, self.calc.Cosine(60))
        self.assertEqual(1, self.calc.Cosine(0))

    def testCoineReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Cosine, 'thirteen')

    def testDivideReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Divide(1, 1))
        self.assertEqual(0.5, self.calc.Divide(1, 2))
        self.assertEqual(1, self.calc.Divide(2, 2))
        self.assertEqual(2, self.calc.Divide(4, 2))
        self.assertEqual(10, self.calc.Divide(20, 2))
        self.assertEqual(0, self.calc.Divide(0, 4))
        self.assertEqual(-1, self.calc.Divide(-2, 2))
        self.assertEqual(0.75, self.calc.Divide(-3, -4))
        self.assertNotEqual(-12, self.calc.Divide(-3, -4))

    def testDivideReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Divide, 'seven', 'eight')

    def testDivideReturnException(self):
        self.assertRaises(Exception, self.calc.Divide, 3, 0)

    def testLogBase10ReturnCorrectResult(self):
        self.assertEqual(0, self.calc.LogBase10(1))
        self.assertEqual(0.30, self.calc.LogBase10(2))
        self.assertEqual(1, self.calc.LogBase10(10))
        self.assertEqual(2, self.calc.LogBase10(100))
        self.assertEqual(-1, self.calc.LogBase10(0.1))
        self.assertEqual(-2, self.calc.LogBase10(0.01))

    def testLogBase10ReturnException(self):
        self.assertRaises(Exception, self.calc.LogBase10, 0)
        self.assertRaises(Exception, self.calc.LogBase10, -2)

    def testLogBase10ReturnValueError(self):
        self.assertRaises(ValueError, self.calc.LogBase10, 'fifteen')

    def testMultiplyReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Multiply(1, 1))
        self.assertEqual(2, self.calc.Multiply(1, 2))
        self.assertEqual(4, self.calc.Multiply(2, 2))
        self.assertEqual(10, self.calc.Multiply(2, 5))
        self.assertEqual(0, self.calc.Multiply(0, 4))
        self.assertEqual(-4, self.calc.Multiply(-2, 2))
        self.assertEqual(12, self.calc.Multiply(-3, -4))
        self.assertNotEqual(-12, self.calc.Multiply(-3, -4))

    def testMultiplyReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Multiply, 'five', 'six')

    def testPowerReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Power(1, 1))
        self.assertEqual(1, self.calc.Power(2, 0))
        self.assertNotEqual(0, self.calc.Power(2, 0))
        self.assertEqual(4, self.calc.Power(2, 2))
        self.assertEqual(16, self.calc.Power(2, 4))
        self.assertEqual(4, self.calc.Power(-2, 2))
        self.assertEqual(0.25, self.calc.Power(2, -2))

    def testPowerReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Power, 'nine', 'ten')

    def testSquareRootReturnCorrectResult(self):
        self.assertEqual(1, self.calc.SquareRoot(1))
        self.assertEqual(0, self.calc.SquareRoot(0))
        self.assertEqual(5, self.calc.SquareRoot(25))
        self.assertEqual(9, self.calc.SquareRoot(81))

    def testSquareRootReturnTypeError(self):
        self.assertRaises(ValueError, self.calc.SquareRoot, 'eleven')

    def testSquareRootReturnValueError(self):
        self.assertRaises(Exception, self.calc.SquareRoot, -9)

    def testSineReturnCorrectResult(self):
        self.assertEqual(0.28, self.calc.Sine(2 / 7))
        self.assertEqual(0.85, self.calc.Sine(45))
        self.assertEqual(-0.85, self.calc.Sine(-45))
        self.assertEqual(-0.3, self.calc.Sine(60))
        self.assertEqual(0, self.calc.Sine(0))

    def testSineReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Sine, 'twelve')

    def testSubtractReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Subtract(3, 2))
        self.assertEqual(3, self.calc.Subtract(3, 0))
        self.assertEqual(0, self.calc.Subtract(5, 5))
        self.assertEqual(-2, self.calc.Subtract(0, 2))
        self.assertEqual(-2, self.calc.Subtract(2, 4))
        self.assertEqual(1, self.calc.Subtract(-2, -3))

    def testSubtractReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Subtract, 'three', 'four')

    def testTangentReturnCorrectResult(self):
        self.assertEqual(0.35, self.calc.Tangent(2 / 6))
        self.assertEqual(1.62, self.calc.Tangent(45))
        self.assertEqual(-1.62, self.calc.Tangent(-45))
        self.assertEqual(0.32, self.calc.Tangent(60))
        self.assertEqual(0, self.calc.Tangent(0))

    def testSineReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Tangent, 'fourteen')
コード例 #4
0
class TestCalculator(unittest.TestCase):
    '''
    This is the test class for the calculator
    Args: (unittest.TestCase) : receives the unit test case class
    '''

    def setUp(self):
        self.calc = Calculator()

    def testAddReturnCorrectResult(self):
        self.assertEqual(6, self.calc.Add([1,2,3]))
        self.assertEqual(1, self.calc.Add([0,1,0,0]))
        self.assertEqual(-2, self.calc.Add([-4,2,0]))
        self.assertEqual(-6, self.calc.Add([-2,-4]))
        self.assertEqual(0, self.calc.Add([0,0]))

    def testAddReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Add, {'one','two'})

    def testCosineReturnCorrectResult(self):
        self.assertEqual([0.65], self.calc.Cosine([6/7]))
        self.assertEqual([0.53], self.calc.Cosine([45]))
        self.assertEqual([0.53], self.calc.Cosine([-45]))
        self.assertEqual([-0.95], self.calc.Cosine([60]))
        self.assertEqual([1], self.calc.Cosine([0]))

    def testCoineReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Cosine, {'thirteen'})

    def testDivideReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Divide([1,1]))
        self.assertEqual(0.5, self.calc.Divide([1,2]))
        self.assertEqual(1, self.calc.Divide([2,2]))
        self.assertEqual(2, self.calc.Divide([4,2]))
        self.assertEqual(10, self.calc.Divide([20,2]))
        self.assertEqual(0, self.calc.Divide([0,4]))
        self.assertEqual(-1, self.calc.Divide([-2,2]))
        self.assertEqual(0.75, self.calc.Divide([-3,-4]))
        self.assertEqual(2, self.calc.Divide([12,3,2]))
        self.assertNotEqual(-12, self.calc.Divide([-3,-4]))

    def testDivideReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Divide, ['seven', 'eight'])

    def testDivideReturnException(self):
        self.assertRaises(Exception, self.calc.Divide, [3,0])        


    def testLogBase10ReturnCorrectResult(self):
        self.assertEqual([0], self.calc.LogBase10([1]))
        self.assertEqual([0.30], self.calc.LogBase10([2]))
        self.assertEqual([1], self.calc.LogBase10([10]))
        self.assertEqual([2], self.calc.LogBase10([100]))
        self.assertEqual([-1], self.calc.LogBase10([0.1]))
        self.assertEqual([-2], self.calc.LogBase10([0.01]))

    def testLogBase10ReturnException(self):
        self.assertRaises(Exception, self.calc.LogBase10, [0])
        self.assertRaises(Exception, self.calc.LogBase10, [-2])

    def testLogBase10ReturnValueError(self):
        self.assertRaises(ValueError, self.calc.LogBase10, ['fifteen'])    

    def testMultiplyReturnCorrectResult(self):
        self.assertEqual(1.0, self.calc.Multiply([1,1,1,1]))
        self.assertEqual(4.0, self.calc.Multiply([1,2,2]))
        self.assertEqual(4.0, self.calc.Multiply([2,2]))
        self.assertEqual(10.0, self.calc.Multiply([2,5]))
        self.assertEqual(0.0, self.calc.Multiply([0,4,0]))
        self.assertEqual(-4.0, self.calc.Multiply([-2,2]))
        self.assertEqual(12.0, self.calc.Multiply([-3,-4]))
        self.assertNotEqual(-12.0, self.calc.Multiply([-3,-4]))

    def testMultiplyReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Multiply, ['five', 'six'])        

    def testPowerReturnCorrectResult(self):
        self.assertEqual(1, self.calc.Power([1,1]))
        self.assertEqual(1, self.calc.Power([2,0]))
        self.assertNotEqual(0, self.calc.Power([2,0]))
        self.assertEqual(4, self.calc.Power([2,2]))
        self.assertEqual(16, self.calc.Power([2,4]))
        self.assertEqual(4, self.calc.Power([-2,2]))
        self.assertEqual(0.25, self.calc.Power([2,-2]))

    def testPowerReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Power, ['nine', 'ten'])

    def testSquareRootReturnCorrectResult(self):
        self.assertEqual([1], self.calc.SquareRoot([1]))
        self.assertEqual([0], self.calc.SquareRoot([0]))
        self.assertEqual([5], self.calc.SquareRoot([25]))
        self.assertEqual([9], self.calc.SquareRoot([81]))

    def testSquareRootReturnTypeError(self):
        self.assertRaises(ValueError, self.calc.SquareRoot, ['eleven'])

    def testSquareRootReturnValueError(self):
        self.assertRaises(Exception, self.calc.SquareRoot, [-9]) 

    def testSineReturnCorrectResult(self):
        self.assertEqual([0.28], self.calc.Sine([2/7]))
        self.assertEqual([0.85], self.calc.Sine([45]))
        self.assertEqual([-0.85], self.calc.Sine([-45]))
        self.assertEqual([-0.3], self.calc.Sine([60]))
        self.assertEqual([0], self.calc.Sine([0]))

    def testSineReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Sine, {'twelve'})      

    def testSubtractReturnCorrectResult(self):
        self.assertEqual(1.0, self.calc.Subtract([3,2]))
        self.assertEqual(3.0, self.calc.Subtract([3,0]))
        self.assertEqual(0.0, self.calc.Subtract([5,5]))
        self.assertEqual(-2.0, self.calc.Subtract([0,2]))
        self.assertEqual(-2.0, self.calc.Subtract([2,4]))
        self.assertEqual(1.0, self.calc.Subtract([-2,-3]))

    def testSubtractReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Subtract, {'three', 'four'})               

    def testTangentReturnCorrectResult(self):
        self.assertEqual([0.35], self.calc.Tangent([2/6]))
        self.assertEqual([1.62], self.calc.Tangent([45]))
        self.assertEqual([-1.62], self.calc.Tangent([-45]))
        self.assertEqual([0.32], self.calc.Tangent([60]))
        self.assertEqual([0], self.calc.Tangent([0]))

    def testTangentReturnValueError(self):
        self.assertRaises(ValueError, self.calc.Tangent, ['fourteen'])