mirror of
				https://github.com/open-quantum-safe/liboqs.git
				synced 2025-11-04 00:02:35 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			41 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
import helpers
 | 
						|
import os
 | 
						|
import os.path
 | 
						|
import pytest
 | 
						|
import platform
 | 
						|
from hashlib import sha256
 | 
						|
 | 
						|
@helpers.filtered_test
 | 
						|
@pytest.mark.parametrize('kem_name', helpers.available_kems_by_name())
 | 
						|
def test_kem(kem_name):
 | 
						|
    kats = helpers.get_kats("kem")
 | 
						|
    if not(helpers.is_kem_enabled_by_name(kem_name)): pytest.skip('Not enabled')
 | 
						|
    output = helpers.run_subprocess(
 | 
						|
        [helpers.path_to_executable('kat_kem'), kem_name],
 | 
						|
    )
 | 
						|
    output = output.replace("\r\n", "\n")
 | 
						|
    h256 = sha256()
 | 
						|
    h256.update(output.encode())
 | 
						|
 | 
						|
    assert(kats[kem_name] == h256.hexdigest())
 | 
						|
 | 
						|
@helpers.filtered_test
 | 
						|
@pytest.mark.parametrize('sig_name', helpers.available_sigs_by_name())
 | 
						|
def test_sig(sig_name):
 | 
						|
    kats = helpers.get_kats("sig")
 | 
						|
    if not(helpers.is_sig_enabled_by_name(sig_name)): pytest.skip('Not enabled')
 | 
						|
    output = helpers.run_subprocess(
 | 
						|
        [helpers.path_to_executable('kat_sig'), sig_name],
 | 
						|
    )
 | 
						|
    output = output.replace("\r\n", "\n")
 | 
						|
    h256 = sha256()
 | 
						|
    h256.update(output.encode())
 | 
						|
 | 
						|
    assert(kats[sig_name] == h256.hexdigest())
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
    import sys
 | 
						|
    pytest.main(sys.argv)
 |