File: test_bitstring.py

package info (click to toggle)
pypy3 7.3.19%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 212,236 kB
  • sloc: python: 2,098,316; ansic: 540,565; sh: 21,462; asm: 14,419; cpp: 4,451; makefile: 4,209; objc: 761; xml: 530; exp: 499; javascript: 314; pascal: 244; lisp: 45; csh: 12; awk: 4
file content (25 lines) | stat: -rw-r--r-- 866 bytes parent folder | download | duplicates (8)
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
from rpython.tool.algo.bitstring import *
from hypothesis import given, strategies

def test_make():
    assert make_bitstring([]) == ''
    assert make_bitstring([0]) == '\x01'
    assert make_bitstring([7]) == '\x80'
    assert make_bitstring([8]) == '\x00\x01'
    assert make_bitstring([2, 4, 20]) == '\x14\x00\x10'

def test_bitcheck():
    assert bitcheck('\x01', 0) is True
    assert bitcheck('\x01', 1) is False
    assert bitcheck('\x01', 10) is False
    assert [n for n in range(32) if bitcheck('\x14\x00\x10', n)] == [2, 4, 20]

@given(strategies.lists(strategies.integers(min_value=0, max_value=299)))
def test_random(lst):
    bitstring = make_bitstring(lst)
    assert set([n for n in range(300) if bitcheck(bitstring, n)]) == set(lst)

def test_num_bits():
    assert num_bits('') == 0
    assert num_bits('a') == 8
    assert num_bits('bcd') == 24