|
@@ -1,8 +1,12 @@
|
|
|
-from panda3d.core import BitArray
|
|
|
|
|
|
|
+from panda3d.core import BitArray, SparseArray
|
|
|
import pickle
|
|
import pickle
|
|
|
import pytest
|
|
import pytest
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+def test_bitarray_type():
|
|
|
|
|
+ assert BitArray.get_class_type().name == "BitArray"
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
def test_bitarray_constructor():
|
|
def test_bitarray_constructor():
|
|
|
assert BitArray().is_zero()
|
|
assert BitArray().is_zero()
|
|
|
assert BitArray(0).is_zero()
|
|
assert BitArray(0).is_zero()
|
|
@@ -18,8 +22,31 @@ def test_bitarray_constructor():
|
|
|
assert BitArray(-10000000000000000000)
|
|
assert BitArray(-10000000000000000000)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+def test_bitarray_constructor_sparse():
|
|
|
|
|
+ # Create a BitArray from a SparseArray.
|
|
|
|
|
+ ba = BitArray(SparseArray.all_on())
|
|
|
|
|
+ assert ba.is_all_on()
|
|
|
|
|
+
|
|
|
|
|
+ ba = BitArray(SparseArray())
|
|
|
|
|
+ assert ba.is_zero()
|
|
|
|
|
+
|
|
|
|
|
+ sa = SparseArray()
|
|
|
|
|
+ sa.set_range(3, 64)
|
|
|
|
|
+ sa.set_range(0, 1)
|
|
|
|
|
+ sa.clear_range(60, 2)
|
|
|
|
|
+ ba = BitArray(sa)
|
|
|
|
|
+ exp = 0b1111100111111111111111111111111111111111111111111111111111111111001
|
|
|
|
|
+ assert ba.__getstate__() == exp
|
|
|
|
|
+
|
|
|
|
|
+ sa.invert_in_place()
|
|
|
|
|
+ ba = BitArray(sa)
|
|
|
|
|
+ assert ba.__getstate__() == ~exp
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
def test_bitarray_allon():
|
|
def test_bitarray_allon():
|
|
|
assert BitArray.all_on().is_all_on()
|
|
assert BitArray.all_on().is_all_on()
|
|
|
|
|
+ assert BitArray.all_on().get_highest_on_bit() == -1
|
|
|
|
|
+ assert BitArray.all_on().get_highest_off_bit() == -1
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_bitarray_nonzero():
|
|
def test_bitarray_nonzero():
|
|
@@ -36,6 +63,41 @@ def test_bitarray_invert():
|
|
|
assert ~~BitArray(123) == BitArray(123)
|
|
assert ~~BitArray(123) == BitArray(123)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+def test_bitarray_set_word():
|
|
|
|
|
+ # Non-inverted
|
|
|
|
|
+ expected = 9876 | (123456 << (BitArray.num_bits_per_word * 3))
|
|
|
|
|
+ ba = BitArray(0)
|
|
|
|
|
+ ba.set_word(0, 9876)
|
|
|
|
|
+ ba.set_word(3, 123456)
|
|
|
|
|
+ assert ba.__getstate__() == expected
|
|
|
|
|
+ assert not ba.is_all_on()
|
|
|
|
|
+
|
|
|
|
|
+ # Inverted
|
|
|
|
|
+ ba = BitArray(0)
|
|
|
|
|
+ ba.invert_in_place()
|
|
|
|
|
+ ba.set_word(2, 1234)
|
|
|
|
|
+ full_word = (1 << BitArray.num_bits_per_word) - 1
|
|
|
|
|
+ expected = ~((full_word & ~1234) << (BitArray.num_bits_per_word * 2))
|
|
|
|
|
+ assert ba.__getstate__() == expected
|
|
|
|
|
+ assert not ba.is_all_on()
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+def test_bitarray_clear():
|
|
|
|
|
+ ba = BitArray(1234)
|
|
|
|
|
+ ba.clear()
|
|
|
|
|
+ assert ba.is_zero()
|
|
|
|
|
+ assert not ba.is_all_on()
|
|
|
|
|
+ assert ba.get_highest_on_bit() == -1
|
|
|
|
|
+ assert ba.get_highest_off_bit() == -1
|
|
|
|
|
+
|
|
|
|
|
+ ba = BitArray.all_on()
|
|
|
|
|
+ ba.clear()
|
|
|
|
|
+ assert ba.is_zero()
|
|
|
|
|
+ assert not ba.is_all_on()
|
|
|
|
|
+ assert ba.get_highest_on_bit() == -1
|
|
|
|
|
+ assert ba.get_highest_off_bit() == -1
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
def test_bitarray_getstate():
|
|
def test_bitarray_getstate():
|
|
|
assert BitArray().__getstate__() == 0
|
|
assert BitArray().__getstate__() == 0
|
|
|
assert BitArray(0).__getstate__() == 0
|
|
assert BitArray(0).__getstate__() == 0
|