Skip to content
Snippets Groups Projects
test_emulated.py 3.06 KiB
Newer Older
import logging
import time
import pytest
from telemetry.backend.drivers.emulated.EmulatedDriver import EmulatedDriver
from telemetry.backend.tests.messages_emulated import (
    create_test_configuration,
    create_specific_config_keys,
    create_config_for_delete,
    create_test_subscriptions,
)

logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)

@pytest.fixture
def setup_driver():
    """Sets up an EmulatedDriver instance for testing."""
    yield EmulatedDriver(address="127.0.0.1", port=8080)

@pytest.fixture
def connected_configured_driver(setup_driver):
    driver = setup_driver # EmulatedDriver(address="127.0.0.1", port=8080)
    driver.Connect()
    driver.SetConfig(create_test_configuration())
    yield driver
    driver.Disconnect()

def test_connect(setup_driver):
    logger.info(">>> test_connect <<<")
    driver = setup_driver
    assert driver.Connect() is True
    assert driver.connected is True

def test_disconnect(setup_driver):
    logger.info(">>> test_disconnect <<<")
    driver = setup_driver
    driver.Connect()
    assert driver.Disconnect() is True
    assert driver.connected is False

def test_set_config(setup_driver):
    logger.info(">>> test_set_config <<<")
    driver = setup_driver
    driver.Connect()

    config = create_test_configuration()

    results = driver.SetConfig(config)
    assert all(result is True for result in results)

def test_get_config(connected_configured_driver):
    logger.info(">>> test_get_config <<<")
    resource_keys = create_specific_config_keys() 
    results = connected_configured_driver.GetConfig(resource_keys)

    for key, value in results:
        assert key in create_specific_config_keys()
        assert value is not None

def test_delete_config(connected_configured_driver):
    logger.info(">>> test_delete_config <<<")
    resource_keys = create_config_for_delete() 

    results = connected_configured_driver.DeleteConfig(resource_keys)
    assert all(result is True for result in results)

def test_subscribe_state(connected_configured_driver):
    logger.info(">>> test_subscribe_state <<<")
    subscriptions = create_test_subscriptions() 

    results = connected_configured_driver.SubscribeState(subscriptions)
    assert all(result is True for result in results)

def test_unsubscribe_state(connected_configured_driver):
    logger.info(">>> test_unsubscribe_state <<<")
    subscriptions = create_test_subscriptions()

    connected_configured_driver.SubscribeState(subscriptions)
    results = connected_configured_driver.UnsubscribeState(subscriptions)
    assert all(result is True for result in results)

def test_get_state(connected_configured_driver):
    logger.info(">>> test_get_state <<<")
    subscriptions = create_test_subscriptions()

    connected_configured_driver.SubscribeState(subscriptions)
    logger.info(f"Subscribed to state: {subscriptions}. waiting for 3 seconds ...")
    time.sleep(3)

    state_iterator = connected_configured_driver.GetState(blocking=False)
    states = list(state_iterator)

    assert len(states) > 0