o
    iP+                     @   s   d dl Z d dlZd dlZd dlZd dlZd dlZd dlZd dlmZ d dl	Z	d dl
mZ d dlmZ d dlmZ d dlmZmZ G dd deZG d	d
 d
eZG dd deZG dd deZdd Zdd Zdd Zdd Zedkrze  dS dS )    N)get_context)TypingError)TestCase)resolve_dispatcher_from_strdumpsloadsc                   @   s   e Zd Zdd Zejdd Zdd Zdd Zd	d
 Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& Zd'd( Zd)S )*TestDispatcherPicklingc                 O   s.   t tjd D ]}||g|R i | qd S )N   )rangepickleHIGHEST_PROTOCOL)selfmethargskwargsproto r   W/home/ubuntu/veenaModal/venv/lib/python3.10/site-packages/numba/tests/test_serialize.pyrun_with_protocols   s   z)TestDispatcherPickling.run_with_protocolsc                 c   s@    d}t |}|j}t|j||_z	d V  W ||_d S ||_w )Ncpu)r   targetdescrtype)r   hwstrdispatcher_cls	old_descrr   r   r   simulate_fresh_target   s   z,TestDispatcherPickling.simulate_fresh_targetc                    sd    fdd}|| t ||}  t |}|| W d    d S 1 s+w   Y  d S )Nc                    s@   t trttrj| g R   d S |    d S )N)
isinstancer   
issubclass	ExceptionassertRaisesassertPreciseEqual)funcr   expected_resultr   r   r   check_result&   s
   
z7TestDispatcherPickling.check_call.<locals>.check_result)r   r   r   r   )r   r   r"   r$   r   r%   picklednew_funcr   r#   r   
check_call%   s   


"z!TestDispatcherPickling.check_callc                 C   s4   ddl m} | | j|dd | | j|dd d S )Nr
   )add_with_sig   r
      )333333?g@)serialize_usecasesr)   r   r(   )r   r)   r   r   r   test_call_with_sig4   s   z)TestDispatcherPickling.test_call_with_sigc                 C   sF   ddl m} | | j|dd | | j|dd | | j|dd d S )	Nr
   )add_without_sigr*   r+         @r-   g333333@abc)abc)r.   r0   r   r(   )r   r0   r   r   r   test_call_without_sig:   s   z,TestDispatcherPickling.test_call_without_sigc                 C   s<   ddl m} | | j|dd | | j|tt t f d S )Nr
   )add_nopythonr1   r2   )r.   r7   r   r(   r   object)r   r7   r   r   r   test_call_nopythonA   s   z)TestDispatcherPickling.test_call_nopythonc                 C   s"   ddl m} | | j|td d S )Nr
   )add_nopython_fail)r
      )r.   r:   r   r(   r   )r   r:   r   r   r   test_call_nopython_failG      z.TestDispatcherPickling.test_call_nopython_failc                 C   "   ddl m} | | j|dd d S )Nr
   )get_global_objmodeg      @)g      @)r.   r?   r   r(   )r   r?   r   r   r   test_call_objmode_with_globalL   s   z4TestDispatcherPickling.test_call_objmode_with_globalc                 C   s*   ddl m} |d}| | j|dd d S )Nr
   closure   )r;      )r.   rB   r   r(   )r   rB   innerr   r   r   test_call_closureP      z(TestDispatcherPickling.test_call_closurec                 K   s0   ddl m} |di |}| | j|dd d S )Nr
   )closure_with_globals      @g      @      @)rI   )r.   rH   r   r(   )r   jit_argsrH   rE   r   r   r   check_call_closure_with_globalsU   s   z6TestDispatcherPickling.check_call_closure_with_globalsc                 C      | j dd d S )NT)nopythonrM   r   r   r   r   'test_call_closure_with_globals_nopythonZ      z>TestDispatcherPickling.test_call_closure_with_globals_nopythonc                 C   rN   )NT)forceobjrP   rQ   r   r   r   &test_call_closure_with_globals_objmode]   rS   z=TestDispatcherPickling.test_call_closure_with_globals_objmodec                 C   *   ddl m} |d}| | j|dd d S )Nr
   )closure_calling_other_functionrI   g      &@)rK   g      @)r.   rW   r   r(   )r   rW   rE   r   r   r   (test_call_closure_calling_other_function`   rG   z?TestDispatcherPickling.test_call_closure_calling_other_functionc                 C   rV   )Nr
   closure_calling_other_closurerI   g       @rJ   )r.   rZ   r   r(   )r   rZ   rE   r   r   r   'test_call_closure_calling_other_closuree   rG   z>TestDispatcherPickling.test_call_closure_calling_other_closurec                 C   r>   )Nr
   )dyn_func$   rC   )r.   r\   r   r(   )r   r\   r   r   r   test_call_dyn_funcj   r=   z)TestDispatcherPickling.test_call_dyn_funcc                 C   r>   )Nr
   )dyn_func_objmoder]   r^   )r.   r`   r   r(   )r   r`   r   r   r   test_call_dyn_func_objmodeo   r=   z1TestDispatcherPickling.test_call_dyn_func_objmodec                 C   s*   ddl m} |d}| | j||d d S )Nr
   )get_renamed_module        )rc   )r.   rb   r   r(   )r   rb   expectedr   r   r   test_renamed_modulet   s
   
z*TestDispatcherPickling.test_renamed_modulec                 C   sF   ddl m} |d}t|}djdi t }ttj	d|g dS )z}
        Check that reconstructing doesn't depend on resources already
        instantiated in the original process.
        r
   rY   rI   zif 1:
            import pickle

            data = {pickled!r}
            func = pickle.loads(data)
            res = func(4.0)
            assert res == 8.0, res
            -cNr   )
r.   rZ   r   r   formatlocals
subprocessr(   sys
executable)r   rZ   r"   r&   coder   r   r   test_other_process|   s   
z)TestDispatcherPickling.test_other_processc           	      C   s  ddl m} |d}t|}|d}t|}t|}t|}t|}| || | |ddd |  | |ddd	 | || | |ddd	 |d
}|dd t|}~t	
  t|}t|}| || | |ddd |  | |ddd dS )z
        Check that deserializing the same function multiple times re-uses
        the same dispatcher object.

        Note that "same function" is intentionally under-specified.
        r
   rA   r*   rC   r;   rD   
   r,         *   +         N)r.   rB   r   r   r   assertIsassertEqualdisable_compileassertIsNotgccollect)	r   rB   r"   r&   func2pickled2fghr   r   r   
test_reuse   s2   








z!TestDispatcherPickling.test_reusec                 C   s   d}t tjd|g dS )zN
        The imp module was deprecated in v3.4 in favour of importlib
        a  if 1:
            import pickle
            import warnings
            with warnings.catch_warnings(record=True) as w:
                warnings.simplefilter('always', DeprecationWarning)
                from numba import njit
                @njit
                def foo(x):
                    return x + 1
                foo(1)
                serialized_foo = pickle.dumps(foo)
            for x in w:
                if 'serialize.py' in x.filename:
                    assert "the imp module is deprecated" not in x.msg
        rf   N)ri   r(   rj   rk   )r   rl   r   r   r   test_imp_deprecation   s   z+TestDispatcherPickling.test_imp_deprecationN)__name__
__module____qualname__r   
contextlibcontextmanagerr   r(   r/   r6   r9   r<   r@   rF   rM   rR   rU   rX   r[   r_   ra   re   rm   r   r   r   r   r   r   r	      s,    
&r	   c                   @   s   e Zd Zdd ZdS )TestSerializationMiscc                 C   s`   ddl m} t }t|}t|}|t|||}| || |t|||}| || d S )Nr   )_numba_unpickle)	numba.core.serializer   r8   r   r   hashidrx   ru   )r   r   
random_objbytebufhashedgot1got2r   r   r   test_numba_unpickle   s   
z)TestSerializationMisc.test_numba_unpickleN)r   r   r   r   r   r   r   r   r      s    r   c                   @   sD   e Zd ZdZdZdd Zee dkddd Zd	d
 Z	dd Z
dS )TestCloudPickleIssueszOThis test case includes issues specific to the cloudpickle implementation.
    Fc                    s\   G dd d  fdd} fdd}t  }|  |  t| |  t| |  d S )Nc                   @      e Zd ZdZdS )zITestCloudPickleIssues.test_dynamic_class_reset_on_unpickle.<locals>.KlassNr   r   r   classvarr   r   r   r   Klass       r   c                      s
   d _ d S Nd   )r   r   r   r   r   mutator   s   
zKTestCloudPickleIssues.test_dynamic_class_reset_on_unpickle.<locals>.mutatorc                      s     jd d S r   )rv   r   r   r   r   r   r   check   s   zITestCloudPickleIssues.test_dynamic_class_reset_on_unpickle.<locals>.checkr   )r   r   r   savedr   r   r   $test_dynamic_class_reset_on_unpickle   s   
z:TestCloudPickleIssues.test_dynamic_class_reset_on_unpickle__main__z*Test cannot run as when module is __main__c                 C   s:   t d}|jtd}|  |jdd | |jd d S )Nspawn)target<   timeoutr   )r   Process"check_main_class_reset_on_unpicklestartjoinrv   exitcode)r   mpprocr   r   r   !test_main_class_reset_on_unpickle   s
   z7TestCloudPickleIssues.test_main_class_reset_on_unpicklec                 C   sT   G dd d}t |}td}|jt|fd}|  |jdd | |jd d S )Nc                   @   r   )zRTestCloudPickleIssues.test_dynamic_class_reset_on_unpickle_new_proc.<locals>.KlassNr   r   r   r   r   r      r   r   r   )r   r   r   r   r   )r   r   r   !check_unpickle_dyn_class_new_procr   r   rv   r   )r   r   r   r   r   r   r   r   -test_dynamic_class_reset_on_unpickle_new_proc   s   zCTestCloudPickleIssues.test_dynamic_class_reset_on_unpickle_new_procc                 C   s   t t}| | d d S )N)r   r   )numbanjit
issue_7356rv   )r   cfuncr   r   r   test_dynamic_class_issue_7356  s   
z3TestCloudPickleIssues.test_dynamic_class_issue_7356N)r   r   r   __doc___numba_parallel_test_r   unittestskipIfr   r   r   r   r   r   r   r      s    

r   c                   @   r   )DynClassN)r   r   r   r4   r   r   r   r   r     s    r   c                  C   sx   t jdd dt_tj} W d    n1 sw   Y  t jdd tj}W d    | |fS 1 s3w   Y  | |fS )Nintp)beforer   )after)r   objmoder   r4   )r   r   r   r   r   r     s   
r   c                  C   sN   t jddd} | d }|jdksJ |jdksJ t|}d|_t|| d S )Nz"numba.tests.cloudpickle_main_classr   )run_namer   r   )runpy
run_moduler   r   r   _check_dyn_class)glbsr   r   r   r   r   r     s   r   c                 C   s*   t | }|jdksJ d|_t||  d S r   )r   r   r   )r   r   r   r   r   r   0  s   r   c                    sR    fdd}|  t |}| urtd|  t |}| ur$td|  d S )Nc                      s    j dkr	tdd S )Nr   zCheck failed. Klass reset.)r   AssertionErrorr   r   r   r   r   :  s   
z_check_dyn_class.<locals>.checkzExpected reuse)r   r   )r   r   r   loadedr   r   r   r   9  s   
r   r   )r   ry   r   r   ri   rj   r   multiprocessingr   r   numba.core.errorsr   numba.tests.supportr   numba.core.target_extensionr   numba.cloudpickler   r   r	   r   r   r8   r   r   r   r   r   r   mainr   r   r   r   <module>   s2     :6		