File: test_coverup_11.py

package info (click to toggle)
scalene 1.5.51-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 15,528 kB
  • sloc: cpp: 22,930; python: 13,403; javascript: 11,769; ansic: 817; makefile: 196; sh: 45
file content (36 lines) | stat: -rw-r--r-- 785 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
# file scalene/runningstats.py:12-24
# lines [12, 13, 14, 15, 16, 20, 21, 23, 24]
# branches ['14->15', '14->23']

import pytest
from scalene.runningstats import RunningStats

@pytest.fixture
def cleanup():
    # No cleanup needed for this test
    yield
    # No cleanup code required

def test_runningstats_add(cleanup):
    rs1 = RunningStats()
    rs1._n = 10
    rs1._m1 = 5.0
    rs1._peak = 7.0

    rs2 = RunningStats()
    rs2._n = 20
    rs2._m1 = 3.0
    rs2._peak = 8.0

    rs3 = rs1 + rs2

    assert rs3._n == rs1._n + rs2._n
    assert rs3._m1 == (rs1._m1 * rs1._n + rs2._m1 * rs2._n) / (rs1._n + rs2._n)
    assert rs3._peak == max(rs1._peak, rs2._peak)

    # Test when other._n is 0
    rs4 = RunningStats()
    rs4._n = 0
    rs5 = rs1 + rs4

    assert rs5 is rs1