nucypher/tests/integration/cli/test_cli_config.py

127 lines
4.0 KiB
Python

import json
from pathlib import Path
import pytest
from nucypher.blockchain.eth.registry import ContractRegistry
from nucypher.cli.main import nucypher_cli
from nucypher.config.characters import UrsulaConfiguration
from nucypher.config.constants import (
NUCYPHER_ENVVAR_KEYSTORE_PASSWORD,
TEMPORARY_DOMAIN_NAME,
)
from tests.constants import (
FAKE_PASSWORD_CONFIRMED,
INSECURE_DEVELOPMENT_PASSWORD,
MOCK_CUSTOM_INSTALLATION_PATH,
MOCK_ETH_PROVIDER_URI,
MOCK_IP_ADDRESS,
TEST_ETH_PROVIDER_URI,
YES,
)
CONFIG_CLASSES = (UrsulaConfiguration, )
ENV = {NUCYPHER_ENVVAR_KEYSTORE_PASSWORD: INSECURE_DEVELOPMENT_PASSWORD}
@pytest.mark.usefixtures("mock_registry_sources")
@pytest.mark.parametrize("config_class", CONFIG_CLASSES)
def test_initialize_via_cli(
config_class,
custom_filepath: Path,
click_runner,
monkeypatch,
):
command = config_class.CHARACTER_CLASS.__name__.lower()
# Use a custom local filepath for configuration
init_args = (
command,
"init",
"--domain",
TEMPORARY_DOMAIN_NAME,
"--eth-endpoint",
MOCK_ETH_PROVIDER_URI,
"--polygon-endpoint",
TEST_ETH_PROVIDER_URI,
"--config-root",
str(custom_filepath.absolute()),
)
if config_class == UrsulaConfiguration:
init_args += ('--rest-host', MOCK_IP_ADDRESS)
result = click_runner.invoke(nucypher_cli,
init_args,
input=FAKE_PASSWORD_CONFIRMED + YES,
catch_exceptions=False,
env=ENV)
assert result.exit_code == 0, result.output
# CLI Output
assert str(MOCK_CUSTOM_INSTALLATION_PATH) in result.output, "Configuration not in system temporary directory"
# Files and Directories
assert custom_filepath.is_dir(), 'Configuration file does not exist'
assert (custom_filepath / 'keystore').is_dir(), 'Keystore does not exist'
# TODO: Only using in-memory node storage for now
# assert (custom_filepath / 'known_nodes').is_dir(), 'known_nodes directory does not exist'
assert not (custom_filepath / 'known_nodes').is_dir(), 'known_nodes directory does not exist'
@pytest.mark.parametrize("config_class", CONFIG_CLASSES)
def test_reconfigure_via_cli(
click_runner, custom_filepath: Path, config_class, monkeypatch, test_registry
):
def fake_get_latest_registry(*args, **kwargs):
return test_registry
monkeypatch.setattr(
ContractRegistry, "from_latest_publication", fake_get_latest_registry
)
custom_config_filepath = custom_filepath / config_class.generate_filename()
view_args = (config_class.CHARACTER_CLASS.__name__.lower(), 'config',
'--config-file', str(custom_config_filepath.absolute()),
'--debug')
result = click_runner.invoke(nucypher_cli, view_args, env=ENV)
assert result.exit_code == 0, result.output
# Ensure all config fields are displayed
config = config_class.from_configuration_file(custom_config_filepath)
analog_payload = json.loads(config.serialize())
for field in analog_payload:
assert field in result.output
# Read pre-edit state
config = config_class.from_configuration_file(custom_config_filepath)
assert config.eth_endpoint != TEST_ETH_PROVIDER_URI
del config
# Write
view_args = (
config_class.CHARACTER_CLASS.__name__.lower(),
"config",
"--config-file",
str(custom_config_filepath.absolute()),
"--eth-endpoint",
TEST_ETH_PROVIDER_URI,
)
result = click_runner.invoke(nucypher_cli, view_args, env=ENV)
assert result.exit_code == 0
# Read again
config = config_class.from_configuration_file(custom_config_filepath)
analog_payload = json.loads(config.serialize())
for field in analog_payload:
assert field in result.output
assert str(custom_filepath) in result.output
# After editing the fields have been updated
assert config.eth_endpoint == TEST_ETH_PROVIDER_URI