import os import pytest_twisted import requests from cryptography.hazmat.primitives import serialization from twisted.internet import threads from nucypher.characters import Ursula from nucypher.utilities.blockchain import make_ursulas def test_alice_enacts_policies_in_policy_group_via_rest(enacted_federated_policy): """ Now that Alice has made a PolicyGroup, she can enact its policies, using Ursula's Public Key to encrypt each offer and transmitting them via REST. """ arrangement = list(enacted_federated_policy._accepted_arrangements)[0] ursula = arrangement.ursula policy_arrangement = ursula.datastore.get_policy_arrangement(arrangement.id.hex().encode()) assert bool(policy_arrangement) # TODO: This can be a more poignant assertion. @pytest_twisted.inlineCallbacks def test_nodes_connect_via_tls_and_verify(): node = make_ursulas(1).pop() node_deployer = node.get_deployer() node_deployer.addServices() node_deployer.catalogServers(node_deployer.hendrix) node_deployer.start() cert = node_deployer.cert.to_cryptography() cert_bytes = cert.public_bytes(serialization.Encoding.PEM) def check_node_with_cert(node, cert_file): response = requests.get("https://{}/public_information".format(node.rest_url()), verify=cert_file) ursula = Ursula.from_bytes(response.content, federated_only=True) assert ursula == node try: with open("test-cert", "wb") as f: # f.write(cert.tbs_certificate_bytes.hex()) f.write(cert_bytes) yield threads.deferToThread(check_node_with_cert, node, "test-cert") finally: os.remove("test-cert") # # def test_node_metadata_contains_proper_cert():