o
    ۾i(                     @   s.  d dl Z d dlZd dlZd dlZd dlmZmZ d dlm	Z	m
Z
mZ d dlmZmZ d dlmZ d dlmZ d dlmZ d dlmZmZ d d	lmZmZmZmZ d d
lmZ d dlmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z( d dl)m*Z* d dl+m,Z, d dl-Z-dd Z.dd Z/dd Z0dd Z1dd Z2dd Z3dd Z4dd Z5dd Z6d d! Z7d"d# Z8d$d% Z9e: Z;d&d' Z<ej=Z>G d(d) d)e Z?G d*d+ d+e Z@G d,d- d-e@ZAG d.d/ d/e@ZBd0d1 ZCd2d3 ZDG d4d5 d5ee ZEd6d7 ZFd8d9 ZGG d:d; d;ee ZHG d<d= d=e@ZIG d>d? d?e ZJeKd@kre-L  dS dS )A    N)find_setupwithswith_lifting)bypass_contextcall_contextobjmode_context)FunctionIdentityByteCode)Interpreter)errors)
cpu_target)
compile_irDEFAULT_FLAGS)njittypeofobjmodetypes)overload)

MemoryLeakTestCasecaptured_stdoutskip_unless_scipy
linux_onlystrace_supportedstraceexpected_failure_py311expected_failure_py312expected_failure_py313)	PYVERSION)jitclassc                 C   s*   t | }t|d}t|}||}|S )N)func_id)r   from_functionr   r	   	interpret)funcr   bcinterpfunc_ir r&   P/home/ubuntu/.local/lib/python3.10/site-packages/numba/tests/test_withlifting.pyget_func_ir   s
   


r(   c                   C   sF   t d t t d t  W d    n1 sw   Y  t d d S )NABCprintr   br&   r&   r&   r'   lift1"   s   r/   c                  C   s   d} t d|  d} t t d|  | d7 } t  W d    n1 s"w   Y  | d7 } t t d|  t  | d7 } W d    n1 sDw   Y  | d7 } t d|  d S )N   r)   r*   d   r+   
   Dr,   xr&   r&   r'   lift2*   s    



r6   c               	   C   s   d} d}t d| | t0 t d t  | d7 } t t d |d7 }t  W d    n1 s0w   Y  W d    n1 s?w   Y  | d7 } |d7 }t d| | d S )Nr0   r1   r)   r*   r+   i r3   r,   r5   yr&   r&   r'   lift3;   s"   r9   c               
   C   s   d} t d|  | d7 } t7 t d t  | d7 } tdD ]}t t d t  | |7 } W d    n1 s7w   Y  qW d    n1 sGw   Y  t t d t  | r\| d9 } W d    n1 sfw   Y  | d7 } t d|  d S )	Nr   r)   r2   r*   r0   r+   r3   E)r-   r   r.   ranger5   ir&   r&   r'   lift4L   s2   

	r>   c                   C   s   t d d S )Nr)   r-   r&   r&   r&   r'   lift5b      r@   c                  C   sH   d} t d|  t | d7 } W d    n1 sw   Y  t d|  | S )Nr0   r)   r*   r-   r   r4   r&   r&   r'   	liftcall1f   s   


rC   c                  C   s~   d} t d|  t | d7 } W d    n1 sw   Y  t d|  t | d7 } W d    n1 s3w   Y  t d|  | S )Nr0   r)   r*   r2   r+   rB   r4   r&   r&   r'   	liftcall2o   s   




rD   c                  C   s   d} t d|  t | dkr| d7 } W d    n1 sw   Y  t d|  t tdD ]}| |7 } q-W d    n1 s>w   Y  t d|  | S )Nr0   r)   r   r*   r2   r+   )r-   r   r;   r<   r&   r&   r'   	liftcall3{   s   



rE   c                	   C   s^   t # t  W d    n1 sw   Y  W d    d S W d    d S 1 s(w   Y  d S N)r   r&   r&   r&   r'   	liftcall4   s   "rG   c               	   C   sb   t dD ]*} t t|  | dkrtd 	 W d     | S W d    n1 s)w   Y  q| S )Nr2      r)   )r;   r   r-   )r=   r&   r&   r'   	liftcall5   s   rI   c                   C   *   t 	 W d    d S 1 sw   Y  d S rF   )undefined_global_varr&   r&   r&   r'   lift_undefiend      "rL   c                   C   rJ   rF   )bogus_contextmanagerr&   r&   r&   r'   lift_invalid   rM   rO   c                   @   <   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd ZdS )TestWithFindingc                 C   s(   t |}tt|d }| || d S Nr   )r(   lenr   assertEqual)selfr"   expect_countthe_irctr&   r&   r'   check_num_of_with   s   z!TestWithFinding.check_num_of_withc                 C      | j tdd d S Nr0   rV   )rY   r/   rU   r&   r&   r'   
test_lift1      zTestWithFinding.test_lift1c                 C   rZ   N   r\   )rY   r6   r]   r&   r&   r'   
test_lift2   r_   zTestWithFinding.test_lift2c                 C   rZ   r[   )rY   r9   r]   r&   r&   r'   
test_lift3   r_   zTestWithFinding.test_lift3c                 C   rZ   r`   )rY   r>   r]   r&   r&   r'   
test_lift4   r_   zTestWithFinding.test_lift4c                 C   rZ   )Nr   r\   )rY   r@   r]   r&   r&   r'   
test_lift5   r_   zTestWithFinding.test_lift5N)	__name__
__module____qualname__rY   r^   rb   rc   rd   re   r&   r&   r&   r'   rQ      s    rQ   c                       s.   e Zd Z fddZdd Zd	ddZ  ZS )
BaseTestWithLiftingc                    s(   t t|   tj| _tj| _t| _	d S rF   )
superri   setUpr   typing_context	typingctxtarget_context	targetctxr   flagsr]   	__class__r&   r'   rk      s   
zBaseTestWithLifting.setUpc           	      C   s   t |}t|| j| j| ji d\}}| t|| | |}t }|	  W d    n1 s1w   Y  | |
 | d S Nlocals)r(   r   rm   ro   rp   rT   rS   r   r   entry_pointgetvalue)	rU   r"   rV   expected_stdoutrW   new_ir	extractedcresoutr&   r&   r'   check_extracted_with   s   


z(BaseTestWithLifting.check_extracted_withr&   Nc              	   C   s(   | j }| j}| j}t||||||i dS rs   )rm   ro   rp   r   )rU   rW   argsreturn_typerm   ro   rp   r&   r&   r'   r      s   
zBaseTestWithLifting.compile_ir)r&   N)rf   rg   rh   rk   r}   r   __classcell__r&   r&   rq   r'   ri      s    ri   c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )TestLiftByPassc                 C      | j tddd d S )Nr0   zA
C
rV   rx   )r}   r/   r]   r&   r&   r'   r^         
zTestLiftByPass.test_lift1c                 C   r   )Nra   zA 1
D 3
r   )r}   r6   r]   r&   r&   r'   rb      r   zTestLiftByPass.test_lift2c                 C   r   )Nr0   zA 1 100
D 2 101
r   )r}   r9   r]   r&   r&   r'   rc      r   zTestLiftByPass.test_lift3c                 C   r   )Nra   z	A 0
E 11
r   )r}   r>   r]   r&   r&   r'   rd      r   zTestLiftByPass.test_lift4c                 C   r   )Nr   zA
r   )r}   r@   r]   r&   r&   r'   re      r   zTestLiftByPass.test_lift5N)rf   rg   rh   r^   rb   rc   rd   re   r&   r&   r&   r'   r      s    r   c                   @   sH   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zee	e
dd ZdS )TestLiftCallc                 C   sx   t |}t }|  W d   n1 sw   Y  t }|  W d   n1 s+w   Y  | | |  dS )z2Ensure same semantic with non-jitted code
        N)r   r   rT   rw   )rU   r"   jittedgotexpectr&   r&   r'   check_same_semantic   s   z TestLiftCall.check_same_semanticc                 C      | j tddd | t d S )Nr0   zA 1
B 2
r   )r}   rC   r   r]   r&   r&   r'   test_liftcall1     zTestLiftCall.test_liftcall1c                 C   r   )Nra   zA 1
B 2
C 12
r   )r}   rD   r   r]   r&   r&   r'   test_liftcall2  r   zTestLiftCall.test_liftcall2c                 C   r   )Nra   zA 1
B 2
C 47
r   )r}   rE   r   r]   r&   r&   r'   test_liftcall3  r   zTestLiftCall.test_liftcall3c                 C   sb   t jt jt jt jf}| |}tt  W d    n1 sw   Y  d}| |t	|j
 d S )Nz2compiler re-entrant to the same function signature)r
   TypingErrorNumbaRuntimeErrorNumbaValueErrorCompilerErrorassertRaisesr   rG   assertInstr	exception)rU   acceptraisesmsgr&   r&   r'   test_liftcall4  s   zTestLiftCall.test_liftcall4c                 C   r   )Nr0   z0
1
2
3
4
5
A
r   )r}   rI   r   r]   r&   r&   r'   test_liftcall5  s   zTestLiftCall.test_liftcall5N)rf   rg   rh   r   r   r   r   r   r   r   r   r   r&   r&   r&   r'   r      s    
r   c                        fdd}|S )Nc                    X   |  tj} | g|R i | W d    n1 sw   Y  | dt|j d S )NzDoes not support list typer   r
   r   r   r   r   rU   r~   kwargsr   fnr&   r'   core$     z+expected_failure_for_list_arg.<locals>.corer&   r   r   r&   r   r'   expected_failure_for_list_arg#     r   c                    r   )Nc                    r   )NzDoes not support function typer   r   r   r&   r'   r   -  r   z/expected_failure_for_function_arg.<locals>.corer&   r   r&   r   r'   !expected_failure_for_function_arg,  r   r   c                   @   s  e Z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
edd Zdd Zedd Zdd Zedd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& Zed'd( Zd)d* Zd+d, Zd-d. Zd/d0 Zejd1d2 Zed3d4 Z d5d6 Z!e"d7d8 Z#e$e%e&d9d: Z'ejd;d< Z(d=d> Z)d?d@ Z*dAdB Z+dCdD Z,dEdF Z-dGdH Z.dIdJ Z/dKdL Z0dMdN Z1dOdP Z2dQdR Z3dSdT Z4dUdV Z5e6dWdX Z7dYdZ Z8d[d\ Z9d]d^ Z:d_d` Z;dadb Z<dcS )dTestLiftObjc                 C      t dtj d S Nerrorwarningssimplefilterr
   NumbaWarningr]   r&   r&   r'   rk   7  r_   zTestLiftObj.setUpc                 C      t   d S rF   r   resetwarningsr]   r&   r&   r'   tearDown:  rA   zTestLiftObj.tearDownc                 G   s   t |}t |}t|}t }|| }| }W d    n1 s$w   Y  |ttt| t }|| }	| }
W d    n1 sIw   Y  | 	||
 | 
||	 d S rF   )copydeepcopyr   r   rw   compiletuplemapr   rT   assertPreciseEqual)rU   pyfuncr~   py_argsc_argscfuncstream
expect_res
expect_outgot_resgot_outr&   r&   r'   assert_equal_return_and_stdout=  s   



z*TestLiftObj.assert_equal_return_and_stdoutc                    s<   dd   fdd} fdd}|  |d |  |d d S )Nc                 S   s   t dd| d i d S )Nzival =ivalra   r?   r   r&   r&   r'   barP     z0TestLiftObj.test_lift_objmode_basic.<locals>.barc                    sB   | d7 } t   |  W d    | d S 1 sw   Y  | d S Nr0   r   r   r   r&   r'   fooS  s   

z0TestLiftObj.test_lift_objmode_basic.<locals>.fooc                    sD   | d7 } t j  |  W d    | d S 1 sw   Y  | d S r   numbar   r   r   r&   r'   foo_nonglobalY  s   

z:TestLiftObj.test_lift_objmode_basic.<locals>.foo_nonglobal{   r   )rU   r   r   r&   r   r'   test_lift_objmode_basicO  s
   z#TestLiftObj.test_lift_objmode_basicc                    (   dd   fdd}d}|  || d S )Nc                 S   s   t d| d i | d9 } d S )Narrra   r?   )r   r&   r&   r'   r   c  s   z3TestLiftObj.test_lift_objmode_array_in.<locals>.barc                    sL   t | t j}t  | W d    |d S 1 sw   Y  |d S r   )nparangeastypeint64r   )nelemr   r   r&   r'   r   h  s   

z3TestLiftObj.test_lift_objmode_array_in.<locals>.foor2   r   )rU   r   r   r&   r   r'   test_lift_objmode_array_inb  s   z&TestLiftObj.test_lift_objmode_array_inc                    r   )Nc                 S   s   t |  d S rF   r?   r8   r&   r&   r'   r   s  rA   z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.barc                    sF   t   d|  }t|} | W d    | S 1 sw   Y  | S Nra   )r   r   r   )r5   r8   ar   r&   r'   r   v  s   


z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.foor   r   rU   r   argr&   r   r'   #test_lift_objmode_define_new_unusedr  s   z/TestLiftObj.test_lift_objmode_define_new_unusedc                    s@   dd   fdd} fdd}d}|  || |  || d S )Nc                 S      t |  d|  S r   r?   r4   r&   r&   r'   inverse     z<TestLiftObj.test_lift_objmode_return_simple.<locals>.inversec                    s@   t dd  | }W d    | |fS 1 sw   Y  | |fS Nfloat64r   r   r7   r   r&   r'   r     s   

z8TestLiftObj.test_lift_objmode_return_simple.<locals>.fooc                    sB   t jdd  | }W d    | |fS 1 sw   Y  | |fS r   r   r7   r   r&   r'   r     s   

zBTestLiftObj.test_lift_objmode_return_simple.<locals>.foo_nonglobalr   r   )rU   r   r   r   r&   r   r'   test_lift_objmode_return_simple  s   z+TestLiftObj.test_lift_objmode_return_simplec                    s6   dd   fdd}t jddt jd}| || d S )Nc                 S   r   r   r?   r4   r&   r&   r'   r     r   z;TestLiftObj.test_lift_objmode_return_array.<locals>.inversec                    sJ   t ddd  | }t|d }W d    n1 sw   Y  | ||fS )N
float64[:]r   )r8   zr   )r   intr5   r8   r   r   r&   r'   r     s
   
z7TestLiftObj.test_lift_objmode_return_array.<locals>.foor0   r2   dtype)r   r   r   r   r   r&   r   r'   test_lift_objmode_return_array  s   z*TestLiftObj.test_lift_objmode_return_arrayc                 C   s    dd }g d}|  || d S )Nc                 S   sp   t dd' t|  d| d< t|  g d|  }tdd |D }W d    | |fS 1 s/w   Y  | |fS )Nr   r      r   r0   ra      c                 S   s   g | ]}d | qS )r0   r&   ).0r=   r&   r&   r'   
<listcomp>  s    zITestLiftObj.test_lift_objmode_using_list.<locals>.foo.<locals>.<listcomp>)r   r-   r   asarrayr7   r&   r&   r'   r     s   
z5TestLiftObj.test_lift_objmode_using_list.<locals>.foor   r   r   r&   r&   r'   test_lift_objmode_using_list  s   	z(TestLiftObj.test_lift_objmode_using_listc                 C   s   dd }d}|  || d S )Nc                 S   s   t | D ]} q| r| d7 } tdd$ t|  | d8 } t|  t | D ]
}| |7 } t|  q#W d    | S 1 s9w   Y  | S )Nr0   intpr4   )r;   r   r-   r<   r&   r&   r'   r     s    

z4TestLiftObj.test_lift_objmode_var_redef.<locals>.foor   r   r   r&   r&   r'   test_lift_objmode_var_redef  s   z'TestLiftObj.test_lift_objmode_var_redefc                 C   s   dd }|  |g dd d S )Nc                 S   v   || d< t   t|  W d    n1 sw   Y  t   d| | d< t|  W d    | S 1 s4w   Y  | S r   r   r-   r5   r   r&   r&   r'   r        


z=TestLiftObj.test_case01_mutate_list_ahead_of_ctx.<locals>.foor      r   rU   r   r&   r&   r'   $test_case01_mutate_list_ahead_of_ctx  s   z0TestLiftObj.test_case01_mutate_list_ahead_of_ctxc                 C   s(   dd }t g d}| ||d d S )Nc                 S   r   r   r   r   r&   r&   r'   r     r   z>TestLiftObj.test_case02_mutate_array_ahead_of_ctx.<locals>.foor   r   r   arrayr   rU   r   r5   r&   r&   r'   %test_case02_mutate_array_ahead_of_ctx  s   z1TestLiftObj.test_case02_mutate_array_ahead_of_ctxc                 C   s   dd }|  |d d S )Nc                 S   f   t dd g d}W d    n1 sw   Y  t   d|d< W d    |S 1 s,w   Y  |S NzList(int64)r   r   r2   ra   r   r7   r&   r&   r'   r        


z6TestLiftObj.test_case03_create_and_mutate.<locals>.foor0   r   r   r&   r&   r'   test_case03_create_and_mutate  s   z)TestLiftObj.test_case03_create_and_mutatec                 C   h   dd }t g d}t|}| tj}|| W d    n1 s$w   Y  | dt|j d S )Nc                 S   s8   t dd t|  W d    | S 1 sw   Y  | S )Nr   kr   r4   r&   r&   r'   r        

z=TestLiftObj.test_case04_bogus_variable_type_info.<locals>.foor   z1Invalid type annotation on non-outgoing variables)	r   r   r   r   r
   r   r   r   r   rU   r   r5   cfoor   r&   r&   r'   $test_case04_bogus_variable_type_info  s   
z0TestLiftObj.test_case04_bogus_variable_type_infoc                 C   sf   dd }t g d}t|}| t}||}W d    n1 s#w   Y  | dt|j d S )Nc                 S   8   t dd | d }W d    |S 1 sw   Y  |S )Nr   r   y              ?r   r   r&   r&   r'   r     s   

z4TestLiftObj.test_case05_bogus_type_info.<locals>.foor   zXcan't unbox array from PyObject into native value.  The object maybe of a different type)r   r   r   r   	TypeErrorr   r   r   )rU   r   r5   r  r   r   r&   r&   r'   test_case05_bogus_type_info   s   
z'TestLiftObj.test_case05_bogus_type_infoc                 C   sZ   dd }|  tj}t|d W d    n1 sw   Y  d}| t|j| d S )Nc              	   S   sj   t  ( t   t|  W d    n1 sw   Y  W d    | S W d    | S 1 s.w   Y  | S rF   r   r4   r&   r&   r'   r     s   


z3TestLiftObj.test_case06_double_objmode.<locals>.foor   z@During: resolving callee type: type\(ObjModeLiftedWith\(<.*>\)\))r   r
   r   r   assertRegexr   r   )rU   r   r   patr&   r&   r'   test_case06_double_objmode  s   	z&TestLiftObj.test_case06_double_objmodec                 C   sx   dd }t g d}t|}| tj}|| W d    n1 s$w   Y  t|j}| d| | d| d S )Nc                 S   s<   t   d| i}d}W d    n1 sw   Y  | ||fS )Nr   r   r   )r5   tur&   r&   r'   r   &  s
   
z6TestLiftObj.test_case07_mystery_key_error.<locals>.foor   z;Missing type annotation on outgoing variable(s): ['t', 'u']z9Example code: with objmode(t='<add_type_as_string_here>'))	r   r   r   r   r
   r   r   r   r   )rU   r   r5   r  r   exstrr&   r&   r'   test_case07_mystery_key_error$  s   

z)TestLiftObj.test_case07_mystery_key_errorc                    sp   t    fdd}tg d}t|}| t}|| W d    n1 s(w   Y  | t|jd d S )Nc              	      s`   t t| D ]'}t  t|}| | }| |< t d  W d    n1 s(w   Y  q| S )N2)r;   rS   r   r   r-   )r5   r=   r	  vdr&   r'   r   >  s   z8TestLiftObj.test_case08_raise_from_external.<locals>.foor   z'2')	dictr   r   r   r   KeyErrorrT   r   r   r  r&   r  r'   test_case08_raise_from_external9  s   	
z+TestLiftObj.test_case08_raise_from_externalc                 C   r  )Nc                 S   s"   t   t 1 s
w   Y  | S rF   )r   
ValueErrorr4   r&   r&   r'   r   N  s   z3TestLiftObj.test_case09_explicit_raise.<locals>.foor   zBunsupported control flow due to raise statements inside with block)	r   r   r   r   r
   r   r   r   r   r  r&   r&   r'   test_case09_explicit_raiseM  s   
z&TestLiftObj.test_case09_explicit_raisec                 C   &   dd }t g d}| || d S )Nc                 S   r  r  r   r7   r&   r&   r'   r   `  r  z;TestLiftObj.test_case10_mutate_across_contexts.<locals>.foor   r   r  r&   r&   r'   "test_case10_mutate_across_contexts]  s   z.TestLiftObj.test_case10_mutate_across_contextsc                 C   r"  )Nc                 S   sp   t dd tjg ddd}W d    n1 sw   Y  t   d|d< W d    |S 1 s1w   Y  |S )Nint64[:]r   r   r   r   r2   ra   )r   r   r   r7   r&   r&   r'   r   l  s   

zATestLiftObj.test_case10_mutate_array_across_contexts.<locals>.foor   r   r  r&   r&   r'   (test_case10_mutate_array_across_contextsj     z4TestLiftObj.test_case10_mutate_array_across_contextsc                 C   sf   dd }t g d}t|}| t}|| W d    n1 s#w   Y  | dt|j d S )Nc                 S   s4   t   dd }W d    | S 1 sw   Y  | S )Nc                 S      | d S r   r&   r   r&   r&   r'   r   {     zLTestLiftObj.test_case11_define_function_in_context.<locals>.foo.<locals>.barr   r5   r   r&   r&   r'   r   y  s   

z?TestLiftObj.test_case11_define_function_in_context.<locals>.foor   z global name 'bar' is not defined)r   r   r   r   	NameErrorr   r   r   r  r&   r&   r'   &test_case11_define_function_in_contextw  s   
z2TestLiftObj.test_case11_define_function_in_contextc                    s2   dd   fdd}t g d}| || d S )Nc                 S   r'  r   r&   r   r&   r&   r'   r     r(  z>TestLiftObj.test_case12_njit_inside_a_objmode_ctx.<locals>.barc                    sJ   t dd t | d}W d    | | S 1 sw   Y  | | S )Nr$  r   r   )r   r   r   r7   r   r&   r'   r     s   
z>TestLiftObj.test_case12_njit_inside_a_objmode_ctx.<locals>.foor   r   r  r&   r   r'   %test_case12_njit_inside_a_objmode_ctx  s   z1TestLiftObj.test_case12_njit_inside_a_objmode_ctxc                 C   s6   dd }|t g d}t jt g d| d S )Nc                 S   s:   t dd | d7 } | W  d    S 1 sw   Y  d S )Nr$  r4   r0   r   r4   r&   r&   r'   r     s   $zCTestLiftObj.test_case14_return_direct_from_objmode_ctx.<locals>.foor   )ra   r   r   )r   r   testingassert_array_equal)rU   r   resultr&   r&   r'   *test_case14_return_direct_from_objmode_ctx  s   z6TestLiftObj.test_case14_return_direct_from_objmode_ctxc                 C   r"  )Nc                    s   d  fdd}|| d S )Nr2   c                    s>   t dd t|  |   W  d    S 1 sw   Y  d S )Nr$  r4   r   r4   jr&   r'   r     s   $zHTestLiftObj.test_case15_close_over_objmode_ctx.<locals>.foo.<locals>.barra   r&   r)  r&   r1  r'   r     s   z;TestLiftObj.test_case15_close_over_objmode_ctx.<locals>.foor   r   r  r&   r&   r'   "test_case15_close_over_objmode_ctx  s   z.TestLiftObj.test_case15_close_over_objmode_ctxc                    s6   ddl m   fdd}tg d}| || d S )Nr   )sparsec                    sP   t dd t|   | }t|d }W d    |S 1 s!w   Y  |S )Nr   r  )r   r   )r   r-   
csr_matrixr   r   )r5   spxr	  spr&   r'   r     s   

z>TestLiftObj.test_case16_scipy_call_in_objmode_ctx.<locals>.foor   )scipyr4  r   r   r   r  r&   r7  r'   %test_case16_scipy_call_in_objmode_ctx  s   	z1TestLiftObj.test_case16_scipy_call_in_objmode_ctxc                    s4   dd l   fddtg d}| | d S )Nr   c                    s6   t     W d    d S 1 sw   Y  d S rF   )r   disr4   r;  r   r&   r'   r     s   "z7TestLiftObj.test_case17_print_own_bytecode.<locals>.foor   )r;  r   r   r   )rU   r5   r&   r<  r'   test_case17_print_own_bytecode  s   z*TestLiftObj.test_case17_print_own_bytecodec                 C   s4   dd }t g d}tdd }| ||| d S )Nc                 S   s8   t   | |d  W d    d S 1 sw   Y  d S rR   r   )r"   r5   r&   r&   r'   r     s   "zCTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.foor   c                 S   r'  )NrH   r&   r  r&   r&   r'   <lambda>  s    zHTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.<lambda>)r   r   r   r   )rU   r   r5   r   r&   r&   r'   *test_case18_njitfunc_passed_to_objmode_ctx  s   z6TestLiftObj.test_case18_njitfunc_passed_to_objmode_ctxc                    sr    fdd |  tjtjf}t }|tg d W d    n1 s'w   Y  d}| |t|j	 d S )Nc                    sP   t   | dkr	 W d    dS W d    n1 sw   Y   | d }|S )Nr      r0   r   )r5   retr   r&   r'   r     s   z.TestLiftObj.test_case19_recursion.<locals>.foor   zUntyped global name 'foo')
r   r
   r   r   r   r   r   r   r   r   )rU   r   r  r   r&   rB  r'   test_case19_recursion  s   z!TestLiftObj.test_case19_recursionc                 C   r"  )Nc                 S   sV   t jd t j }tdd t j }W d    n1 s w   Y  | | | S Nr   r   r  r   randomseedrandr   r   r&   r&   r'   r     s   
z1TestLiftObj.test_case20_rng_works_ok.<locals>.foor   r   r  r&   r&   r'   test_case20_rng_works_ok  r&  z$TestLiftObj.test_case20_rng_works_okc                 C   r"  )Nc                 S   sb   t jd t j }tdd t jd t j }W d    n1 s&w   Y  | | | S rD  rE  r   r&   r&   r'   r     s   
z6TestLiftObj.test_case21_rng_seed_works_ok.<locals>.foor   r   r  r&   r&   r'   test_case21_rng_seed_works_ok  s   	z)TestLiftObj.test_case21_rng_seed_works_okc                    s:   dd  t  fdd}| | |  | tt d S )Nc                 S   s   t tt|  S rF   )r   r   listreversedtolistr4   r&   r&   r'   r     r   z'TestLiftObj.test_example01.<locals>.barc                     sF   t d} tdd |  |  }W d    |S 1 sw   Y  |S )NrH   zintp[:]r   )r   r   r   r7   r   r&   r'   r     s   

z'TestLiftObj.test_example01.<locals>.foo)r   r   py_funcassertIsr   r   r   r&   r   r'   test_example01  s
   zTestLiftObj.test_example01c                    s<   dd  t  dd }tj fdd}| | d d S )Nc                 S      d S rF   r&   )sr&   r&   r'   r        z1TestLiftObj.test_objmode_in_overload.<locals>.fooc                 S   s   dd }|S )Nc                 S   r  )Nr   r|   r   r   )rR  r|   r&   r&   r'   impl     

zHTestLiftObj.test_objmode_in_overload.<locals>.foo_overload.<locals>.implr&   )rR  rV  r&   r&   r'   foo_overload  s   z:TestLiftObj.test_objmode_in_overload.<locals>.foo_overloadc                      s    dS r   r&   r&   rB  r&   r'   f     z/TestLiftObj.test_objmode_in_overload.<locals>.fr   )r   r   r   rT   )rU   rX  rY  r&   rB  r'   test_objmode_in_overload  s   
z$TestLiftObj.test_objmode_in_overloadc                 C   s.   t dd }| }| |t | |d d S )Nc                  S   4   t td d} W d    | S 1 sw   Y  | S Nval皙(@)r   gv_typer^  r&   r&   r'   
global_var     
z8TestLiftObj.test_objmode_gv_variable.<locals>.global_var   )r   assertIsInstancer   rT   )rU   rb  rA  r&   r&   r'   test_objmode_gv_variable  s
   
z$TestLiftObj.test_objmode_gv_variablec                 C   F   t dd }| tjd |  W d    d S 1 sw   Y  d S )Nc                  S   r\  )Nr^  r   )r   gv_type2r^  r&   r&   r'   rb  +  rc  z>TestLiftObj.test_objmode_gv_variable_error.<locals>.global_varzHError handling objmode argument 'val'. Global 'gv_type2' is not defined.r   assertRaisesRegexr
   r   )rU   rb  r&   r&   r'   test_objmode_gv_variable_error*  s   
"z*TestLiftObj.test_objmode_gv_variable_errorc              	   C   sx   t dd }t dd }||fD ])}| jt|d | }| |t | |d W d    n1 s4w   Y  qd S )Nc                  S   6   t tjd d} W d    | S 1 sw   Y  | S r]  )r   r   r   r^  r&   r&   r'   modattr19     
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr1c                  S   s8   t tjjd d} W d    | S 1 sw   Y  | S r]  )r   r   r   r   r^  r&   r&   r'   modattr2?  s   
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr2r   rd  )r   subTestr   re  r   rT   )rU   rm  ro  r   rA  r&   r&   r'   test_objmode_gv_mod_attr8  s   

z$TestLiftObj.test_objmode_gv_mod_attrc                 C   rg  )Nc                  S   rl  r]  )r   r   THIS_DOES_NOT_EXISTr^  r&   r&   r'   moderrorM  rn  z<TestLiftObj.test_objmode_gv_mod_attr_error.<locals>.moderrorzQError handling objmode argument 'val'. Getattr cannot be resolved at compile-timeri  rU   rs  r&   r&   r'   test_objmode_gv_mod_attr_errorL  s   
"z*TestLiftObj.test_objmode_gv_mod_attr_errorc                 C   rg  )Nc                  S   sF   t tjtjtjd d} d}d}W d    tS 1 sw   Y  tS )Nv1v2v3r`  )r   r   r   rr  float32r_  rv  r&   r&   r'   rs  Z  s   

zETestLiftObj.test_objmode_gv_mod_attr_error_multiple.<locals>.moderrorzPError handling objmode argument 'v2'. Getattr cannot be resolved at compile-timeri  rt  r&   r&   r'   'test_objmode_gv_mod_attr_error_multipleY  s   
"z3TestLiftObj.test_objmode_gv_mod_attr_error_multiplec                    sH   dd  t  dd }t fdd}| | tdtj d S )Nc                   S   rQ  rF   r&   r&   r&   r&   r'   r   j  rS  z>TestLiftObj.test_objmode_closure_type_in_overload.<locals>.fooc                     s   t jd d    fdd} | S )Nc                     B   t  d tdtj} W d    | S 1 sw   Y  | S NrT  r2   r   r   r   r   r   rT  	shrubberyr&   r'   rV  p     
zUTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overload.<locals>.implr   r   rV  r&   r  r'   rX  m  s   zGTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overloadc                           S rF   r&   r&   rB  r&   r'   r   v     z>TestLiftObj.test_objmode_closure_type_in_overload.<locals>.barr2   )r   r   r   r   r   r   r   rU   rX  r   r&   rB  r'   %test_objmode_closure_type_in_overloadi  s   
 z1TestLiftObj.test_objmode_closure_type_in_overloadc                    sb   dd  t  dd }t fdd}| tjd |  W d    d S 1 s*w   Y  d S )Nc                   S   rQ  rF   r&   r&   r&   r&   r'   r   }  rS  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.fooc                     s    t jd d    fdd}  | S )Nc                     r|  r}  r~  rT  r  r&   r'   rV    r  z[TestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overload.<locals>.implr  r  r&   r  r'   rX    s   zMTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overloadc                      r  rF   r&   r&   rB  r&   r'   r     r  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.barzIError handling objmode argument 'out'. Freevar 'shrubbery' is not defined)r   r   rj  r
   r   r  r&   rB  r'   +test_objmode_closure_type_in_overload_error|  s   
"z7TestLiftObj.test_objmode_closure_type_in_overload_errorc                 C   rg  )Nc                  S   s4   t dd d} W d    tS 1 sw   Y  tS )Nra   )badr0   )r   r_  rT  r&   r&   r'   rs    rc  z6TestLiftObj.test_objmode_invalid_use.<locals>.moderrorzError handling objmode argument 'bad'. The value must be a compile-time constant either as a non-local variable or a getattr expression that refers to a Numba type.ri  rt  r&   r&   r'   test_objmode_invalid_use  s   
"z$TestLiftObj.test_objmode_invalid_usec                    s`   t jd d   t fdd}| \}}}| |d | |d | |tdtj d S )Nc                     sR   t dt d d} | }tdtj}W d    n1 sw   Y  | ||fS )Nr   t1t2t3    :(ArH   )r   ra  r   r   r   int32r  array_tyr&   r'   r     s   
z5TestLiftObj.test_objmode_multi_type_args.<locals>.foor  i  rH   )r   r  r   r   r   r   r   )rU   r   r  r  r  r&   r  r'   test_objmode_multi_type_args  s   
z(TestLiftObj.test_objmode_multi_type_argsc                    s   dt jfdt jd d  fg}t|G dd dt d} |dd t fdd	}tfd
d}| }| |  | |	ddd t
jdt
jdd }| |j| d S )Nvaluer   c                   @   s4   e Zd Zdd Zedd Zdd Zedd Zd	S )
z.TestLiftObj.test_objmode_jitclass.<locals>.Bagc                 S   s   || _ tj|tjd| _d S )Nr   )r  r   zerosrz  r   )rU   r  r&   r&   r'   __init__  s   z7TestLiftObj.test_objmode_jitclass.<locals>.Bag.__init__c                 S   s   | j jS rF   )r   sizer]   r&   r&   r'   r    rZ  z3TestLiftObj.test_objmode_jitclass.<locals>.Bag.sizec                 S   s(   t | jD ]}| j|  |7  < q| jS rF   )r;   r  r   )rU   r_  r=   r&   r&   r'   	increment  s   z8TestLiftObj.test_objmode_jitclass.<locals>.Bag.incrementc                 S   s   | | S rF   r&   r7   r&   r&   r'   add  rZ  z2TestLiftObj.test_objmode_jitclass.<locals>.Bag.addN)	rf   rg   rh   r  propertyr  r  staticmethodr  r&   r&   r&   r'   Bag  s    
r     c                   S   rQ  rF   r&   r&   r&   r&   r'   r     rS  z.TestLiftObj.test_objmode_jitclass.<locals>.fooc                     s   j   fdd} | S )Nc                     sB   t d  d} | d W d    | S 1 sw   Y  | S )NrT  r   r   )r   r  rT  )r  r  r&   r'   rV    s   
zETestLiftObj.test_objmode_jitclass.<locals>.foo_overload.<locals>.impl)_numba_type_r  )r  mybagr  r'   rX    s   z7TestLiftObj.test_objmode_jitclass.<locals>.foo_overloadc                      r  rF   r&   r&   rB  r&   r'   r     r  z.TestLiftObj.test_objmode_jitclass.<locals>.barra   r   rH   r   r   )r   r  rz  r   objectr   r   re  rT   r  r   r  r   r   )rU   specnrX  r   r   	exp_arrayr&   )r  r   r  r'   test_objmode_jitclass  s"   	z!TestLiftObj.test_objmode_jitclassc                 C   8   t dd | d }W d    |S 1 sw   Y  |S Nr   outputr2   rU  r5   r  r&   r&   r'   case_objmode_cache  r
  zTestLiftObj.case_objmode_cachec                    sd   t g d t fdd}| tj}|  W d    n1 s"w   Y  | t|jd d S )Nr0   ra   r   r   rH   c                     s8   t  d g d} W d    | S 1 sw   Y  | S )NrT  r  rU  rT  ret_typer&   r'   test2  r
  z6TestLiftObj.test_objmode_reflected_list.<locals>.test2zObjmode context failed. Argument 'out' is declared as an unsupported type: reflected list\(int(32|64)\)<iv=None>. Reflected types are not supported.r   r   r   r
   r   r  r   r   rU   r  r   r&   r  r'   test_objmode_reflected_list     z'TestLiftObj.test_objmode_reflected_listc                    sd   t h d t fdd}| tj}|  W d    n1 s"w   Y  | t|jd d S )N   r0   ra   r   r   rH   c                     s8   t  d h d} W d    | S 1 sw   Y  | S )Nr/  r  rU  r  r  r&   r'   r    r
  z5TestLiftObj.test_objmode_reflected_set.<locals>.test2zObjmode context failed. Argument 'result' is declared as an unsupported type: reflected set\(int(32|64)\). Reflected types are not supported.r  r  r&   r  r'   test_objmode_reflected_set  r  z&TestLiftObj.test_objmode_reflected_setc                    sf   t t jt j t fdd}| t}|  W d    n1 s#w   Y  | dt|j	 d S )Nc                     s:   t  d ddd} W d    | S 1 sw   Y  | S )Nresr0   ra   )r)   r*   rU  r  r  r&   r'   test4  s   
z2TestLiftObj.test_objmode_typed_dict.<locals>.test4zFcan't unbox a <class 'dict'> as a <class 'numba.typed.typeddict.Dict'>)
r   DictTypeunicode_typer   r   r   r  r   r   r   rU   r  r   r&   r  r'   test_objmode_typed_dict  s   z#TestLiftObj.test_objmode_typed_dictc                    sb   t t j t fdd}| t}|  W d    n1 s!w   Y  | t|jd d S )Nc                     s8   t  d ddg} W d    | S 1 sw   Y  | S )Nr  r0   ra   rU  r  r  r&   r'   r  (  r
  z2TestLiftObj.test_objmode_typed_list.<locals>.test4zLcan't unbox a <class 'list'> as a (<class ')?numba.typed.typedlist.List('>)?)	r   ListTyper   r   r   r  r  r   r   r  r&   r  r'   test_objmode_typed_list&  s   z#TestLiftObj.test_objmode_typed_listc                 C   sB   t dd }tdtjd}||}||}| || d S )Nc                 S   s<   t jdd | d}W d    |S 1 sw   Y  |S )Nz
int64[::1]r   r   )r   r   viewr7   r&   r&   r'   r   9  s   
z1TestLiftObj.test_objmode_use_of_view.<locals>.foor0   r   )r   r   onesr   r  rN  r   )rU   r   r   expectedr   r&   r&   r'   test_objmode_use_of_view6  s   

z$TestLiftObj.test_objmode_use_of_viewN)=rf   rg   rh   rk   r   r   r   r   r   r   r   r   r   r   r   r  r  r  r  r  r  r  r!  r#  r%  r+  r,  r0  unittestexpectedFailurer3  r   r:  r=  r   r?  r   r   r   rC  rI  rJ  rP  r[  rf  rk  rq  ru  r{  r  r  r  r  r  r  r  r  r  r  r  r  r&   r&   r&   r'   r   5  s|    


	



	
	
4
r   c                 C      | d S Nr2   r&   r4   r&   r&   r'   case_inner_pyfuncE  r(  r  c                 C   s8   t dd t| }W d    |S 1 sw   Y  |S Nr   r  )r   r  r  r&   r&   r'   r  I  rW  r  c                   @   rP   )TestLiftObjCachingc                 C   r   r   r   r]   r&   r&   r'   rk   R  r_   zTestLiftObjCaching.setUpc                 C   r   rF   r   r]   r&   r&   r'   r   U  rA   zTestLiftObjCaching.tearDownc                 C   sX   t dd|}| |dd t dd|}| |j | |dd | |j d S )NT)cacher   r`  )r   rT   assertFalse_cache_hits
assertTrue)rU   rN  firstsecondr&   r&   r'   checkX  s   zTestLiftObjCaching.checkc                 C   s   dd }|  | d S )Nc                 S   r  r  rU  r  r&   r&   r'   r   b  rW  z=TestLiftObjCaching.test_objmode_caching_basic.<locals>.pyfuncr  rU   r   r&   r&   r'   test_objmode_caching_basica  s   z-TestLiftObjCaching.test_objmode_caching_basicc                    s"   dd   fdd}|  | d S )Nc                 S   r  r  r&   r4   r&   r&   r'   other_pyfuncj  r(  zNTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.other_pyfuncc                    s8   t dd  | }W d    |S 1 sw   Y  |S r  rU  r  r  r&   r'   r   m  rW  zHTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.pyfuncr  r  r&   r  r'   %test_objmode_caching_call_closure_badi  s   z8TestLiftObjCaching.test_objmode_caching_call_closure_badc                 C   s   |  t d S rF   )r  r  r]   r&   r&   r'   &test_objmode_caching_call_closure_goodt  s   z9TestLiftObjCaching.test_objmode_caching_call_closure_goodN)	rf   rg   rh   rk   r   r  r  r  r  r&   r&   r&   r'   r  O  s    	r  c                   @   s$   e Zd Zdd Zdd Zdd ZdS )TestBogusContextc                 C   b   t t}| tj}t|| j| j| ji d W d    n1 s!w   Y  | 	dt
|j d S )Nrt   z*Undefined variable used as context manager)r(   rL   r   r
   r   r   rm   ro   rp   r   r   r   rU   rW   r   r&   r&   r'   test_undefined_globaly     z&TestBogusContext.test_undefined_globalc                 C   r  )Nrt   z"Unsupported context manager in use)r(   rO   r   r
   r   r   rm   ro   rp   r   r   r   r  r&   r&   r'   test_invalid  r  zTestBogusContext.test_invalidc                 C   s\   t dd }| tj}|  W d    n1 sw   Y  t|j}d}| || d S )Nc                  S   s.   t d	} W d    d S 1 sw   Y  d S )N )openrY  r&   r&   r'   r        
"z;TestBogusContext.test_with_as_fails_gracefully.<locals>.foozGThe 'with (context manager) as (variable):' construct is not supported.)r   r   r
   UnsupportedBytecodeErrorr   r   r   )rU   r   r   excstrr   r&   r&   r'   test_with_as_fails_gracefully  s   

z.TestBogusContext.test_with_as_fails_gracefullyN)rf   rg   rh   r  r  r  r&   r&   r&   r'   r  x  s    r  c                   @   s"   e Zd ZdZeejdd ZdS )TestMiscFc                 C   s8   t  s| d dd }g d}t||}| | d S )Nzstrace support missingc                  S   s   t ddd } d S )Nzvoid()c                   S   s.   t  	 W d    d S 1 sw   Y  d S rF   r   r&   r&   r&   r'   rY    r  zFTestMisc.test_no_fork_in_compilation.<locals>.force_compile.<locals>.f)r   r  r&   r&   r'   force_compile  s   z;TestMisc.test_no_fork_in_compilation.<locals>.force_compile)forkcloneexecve)r   skipTestr   r  )rU   r  syscallsstrace_datar&   r&   r'   test_no_fork_in_compilation  s   	

z$TestMisc.test_no_fork_in_compilationN)rf   rg   rh   _numba_parallel_test_r   r   run_test_in_subprocessr  r&   r&   r&   r'   r    s
    r  __main__)Mr   r   numpyr   r   numba.core.transformsr   r   numba.core.withcontextsr   r   r   numba.core.bytecoder   r   numba.core.interpreterr	   
numba.corer
   numba.core.registryr   numba.core.compilerr   r   r   r   r   r   numba.core.extendingr   numba.tests.supportr   r   r   r   r   r   r   r   r   r   numba.core.utilsr   numba.experimentalr   r  r(   r/   r6   r9   r>   r@   rC   rD   rE   rG   rI   rL   r  rN   rO   r   ra  rQ   ri   r   r   r   r   r   r  r  r  r  r  rf   mainr&   r&   r&   r'   <module>   sj    0	
0		      )(
 