File: multiplication_operator_unittest.txt

package info (click to toggle)
python-hypothesis 6.140.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,324 kB
  • sloc: python: 63,481; ruby: 1,107; sh: 261; makefile: 41; javascript: 6
file content (40 lines) | stat: -rw-r--r-- 1,507 bytes parent folder | download | duplicates (2)
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
# This test code was written by the `hypothesis.extra.ghostwriter` module
# and is provided under the Creative Commons Zero public domain dedication.

import operator
import unittest
from hypothesis import given, strategies as st

# TODO: replace st.nothing() with an appropriate strategy


class TestBinaryOperationmul(unittest.TestCase):
    mul_operands = st.nothing()

    @given(a=mul_operands, b=mul_operands, c=mul_operands)
    def test_associative_binary_operation_mul(self, a, b, c):
        left = operator.mul(a, operator.mul(b, c))
        right = operator.mul(operator.mul(a, b), c)
        self.assertEqual(left, right)

    @given(a=mul_operands, b=mul_operands)
    def test_commutative_binary_operation_mul(self, a, b):
        left = operator.mul(a, b)
        right = operator.mul(b, a)
        self.assertEqual(left, right)

    @given(a=mul_operands)
    def test_identity_binary_operation_mul(self, a):
        identity = 1
        self.assertEqual(a, operator.mul(a, identity))
        self.assertEqual(a, operator.mul(identity, a))

    @given(a=mul_operands, b=mul_operands, c=mul_operands)
    def test_add_distributes_over_binary_operation_mul(self, a, b, c):
        left = operator.mul(a, operator.add(b, c))
        ldist = operator.add(operator.mul(a, b), operator.mul(a, c))
        self.assertEqual(ldist, left)

        right = operator.mul(operator.add(a, b), c)
        rdist = operator.add(operator.mul(a, c), operator.mul(b, c))
        self.assertEqual(rdist, right)