File: test_2693_to_buffers_placeholders.py

package info (click to toggle)
python-awkward 2.8.9-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,932 kB
  • sloc: python: 178,875; cpp: 33,828; sh: 432; makefile: 21; javascript: 8
file content (37 lines) | stat: -rw-r--r-- 1,013 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
37
# BSD 3-Clause License; see https://github.com/scikit-hep/awkward/blob/main/LICENSE

from __future__ import annotations

import pickle

import numpy as np

import awkward as ak
from awkward._nplikes.numpy import Numpy
from awkward.typetracer import PlaceholderArray

nplike = Numpy.instance()


def test_round_trip_placeholder():
    layout = ak.contents.RecordArray(
        [
            ak.contents.NumpyArray(
                PlaceholderArray(nplike, (4,), np.dtype(np.float64))
            ),
            ak.contents.NumpyArray([1, 2, 3, 4]),
        ],
        ["x", "y"],
    )

    form, length, container = ak.to_buffers(layout)
    result = ak.from_buffers(form, length, container, highlevel=False)

    assert isinstance(result.content("x").data, PlaceholderArray)

    assert result.content("x").data.shape == layout.content("x").data.shape
    assert result.content("x").data.dtype == layout.content("x").data.dtype


def test_pickle_nplike():
    assert pickle.loads(pickle.dumps(nplike)) is nplike