Initial commit
This commit is contained in:
commit
7a34be0f09
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
__pycache__
|
||||||
|
.venv
|
||||||
|
*.egg-info/
|
71
README.md
Normal file
71
README.md
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
# NuCon (Nucleares Controller)
|
||||||
|
|
||||||
|
NuCon is a Python library designed to interface with and control parameters in the game Nucleares, a nuclear reactor simulation game. This library provides a robust and type-safe way to interact with various reactor components and systems.
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
- Enum-based parameter system for type safety and code clarity
|
||||||
|
- Support for various parameter types including floats, integers, booleans, strings, and custom enums
|
||||||
|
- Read and write capabilities for game parameters
|
||||||
|
- Custom truthy values for status enums to simplify conditional logic
|
||||||
|
- Dummy mode for testing without connecting to the game
|
||||||
|
- Batch operations for getting multiple parameters at once
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
To install NuCon, clone this repository and install the required dependencies:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone https://github.com/yourusername/nucon.git
|
||||||
|
cd nucon
|
||||||
|
pip install -r requirements.txt
|
||||||
|
```
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
Here's a basic example of how to use NuCon:
|
||||||
|
|
||||||
|
```python
|
||||||
|
from nucon import Nucon, BreakerStatus
|
||||||
|
|
||||||
|
# Set the base URL for the game's API (if different from default)
|
||||||
|
Nucon.set_base_url("http://localhost:8080/")
|
||||||
|
|
||||||
|
# Enable dummy mode for testing (optional)
|
||||||
|
Nucon.set_dummy_mode(True)
|
||||||
|
|
||||||
|
# Read a parameter
|
||||||
|
core_temp = Nucon.CORE_TEMP.value
|
||||||
|
print(f"Core Temperature: {core_temp}")
|
||||||
|
|
||||||
|
# Read a parameter with an enum type
|
||||||
|
pump_status = Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_STATUS.value
|
||||||
|
print(f"Pump 0 Status: {pump_status}")
|
||||||
|
|
||||||
|
# Write to a parameter
|
||||||
|
Nucon.GENERATOR_0_BREAKER.value = BreakerStatus.OPEN # or True
|
||||||
|
print(f"Generator 0 Breaker Status: {Nucon.GENERATOR_0_BREAKER.value}")
|
||||||
|
|
||||||
|
# Use custom truthy values
|
||||||
|
if Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_STATUS.value:
|
||||||
|
print("Pump 0 is active")
|
||||||
|
```
|
||||||
|
|
||||||
|
## API Reference
|
||||||
|
|
||||||
|
The `Nucon` enum contains all available parameters. Each parameter is defined with:
|
||||||
|
- An ID (string)
|
||||||
|
- A type (float, int, bool, str, or a custom Enum)
|
||||||
|
- A boolean indicating whether it's writable
|
||||||
|
|
||||||
|
Key methods:
|
||||||
|
- `Nucon.set_base_url(url)`: Set the base URL for the game's API
|
||||||
|
- `Nucon.set_dummy_mode(bool)`: Enable or disable dummy mode for testing
|
||||||
|
- `Nucon.get_all()`: Get all parameter values
|
||||||
|
- `Nucon.get_multiple(params)`: Get values for multiple specified parameters
|
||||||
|
|
||||||
|
For a full list of parameters and their details, refer to the `Nucon` enum in the source code.
|
||||||
|
|
||||||
|
## Disclaimer
|
||||||
|
|
||||||
|
NuCon is an unofficial tool and is not affiliated with or endorsed by the creators of Nucleares.
|
1
nucon/__init__.py
Normal file
1
nucon/__init__.py
Normal file
@ -0,0 +1 @@
|
|||||||
|
from nucon.core import *
|
255
nucon/core.py
Normal file
255
nucon/core.py
Normal file
@ -0,0 +1,255 @@
|
|||||||
|
from enum import Enum, IntEnum
|
||||||
|
import requests
|
||||||
|
from typing import Union, Dict, Type, List
|
||||||
|
|
||||||
|
class NuconConfig:
|
||||||
|
base_url = "http://localhost:8080/"
|
||||||
|
dummy_mode = False
|
||||||
|
|
||||||
|
class PumpStatus(IntEnum):
|
||||||
|
INACTIVE = 0
|
||||||
|
ACTIVE_NO_SPEED_REACHED = 1
|
||||||
|
ACTIVE_SPEED_REACHED = 2
|
||||||
|
REQUIRES_MAINTENANCE = 3
|
||||||
|
NOT_INSTALLED = 4
|
||||||
|
INSUFFICIENT_ENERGY = 5
|
||||||
|
|
||||||
|
def __bool__(self):
|
||||||
|
return self.value in (1, 2)
|
||||||
|
|
||||||
|
class PumpDryStatus(IntEnum):
|
||||||
|
ACTIVE_WITHOUT_FLUID = 1
|
||||||
|
INACTIVE_OR_ACTIVE_WITH_FLUID = 4
|
||||||
|
|
||||||
|
def __bool__(self):
|
||||||
|
return self.value == 4
|
||||||
|
|
||||||
|
class PumpOverloadStatus(IntEnum):
|
||||||
|
ACTIVE_AND_OVERLOAD = 1
|
||||||
|
INACTIVE_OR_ACTIVE_NO_OVERLOAD = 4
|
||||||
|
|
||||||
|
def __bool__(self):
|
||||||
|
return self.value == 4
|
||||||
|
|
||||||
|
class BreakerStatus(Enum):
|
||||||
|
OPEN = True
|
||||||
|
CLOSED = False
|
||||||
|
|
||||||
|
def __bool__(self):
|
||||||
|
return self.value
|
||||||
|
|
||||||
|
class Nucon(Enum):
|
||||||
|
CORE_TEMP = ("CORE_TEMP", float, False)
|
||||||
|
CORE_TEMP_OPERATIVE = ("CORE_TEMP_OPERATIVE", float, False)
|
||||||
|
CORE_TEMP_MAX = ("CORE_TEMP_MAX", float, False)
|
||||||
|
CORE_TEMP_MIN = ("CORE_TEMP_MIN", float, False)
|
||||||
|
CORE_TEMP_RESIDUAL = ("CORE_TEMP_RESIDUAL", float, False)
|
||||||
|
CORE_PRESSURE = ("CORE_PRESSURE", float, False)
|
||||||
|
CORE_PRESSURE_MAX = ("CORE_PRESSURE_MAX", float, False)
|
||||||
|
CORE_PRESSURE_OPERATIVE = ("CORE_PRESSURE_OPERATIVE", float, False)
|
||||||
|
CORE_INTEGRITY = ("CORE_INTEGRITY", float, False)
|
||||||
|
CORE_WEAR = ("CORE_WEAR", float, False)
|
||||||
|
CORE_STATE = ("CORE_STATE", int, False)
|
||||||
|
CORE_STATE_CRITICALITY = ("CORE_STATE_CRITICALITY", float, False)
|
||||||
|
CORE_CRITICAL_MASS_REACHED = ("CORE_CRITICAL_MASS_REACHED", bool, False)
|
||||||
|
CORE_CRITICAL_MASS_REACHED_COUNTER = ("CORE_CRITICAL_MASS_REACHED_COUNTER", int, False)
|
||||||
|
CORE_IMMINENT_FUSION = ("CORE_IMMINENT_FUSION", bool, False)
|
||||||
|
CORE_READY_FOR_START = ("CORE_READY_FOR_START", bool, False)
|
||||||
|
CORE_STEAM_PRESENT = ("CORE_STEAM_PRESENT", bool, False)
|
||||||
|
CORE_HIGH_STEAM_PRESENT = ("CORE_HIGH_STEAM_PRESENT", bool, False)
|
||||||
|
|
||||||
|
TIME = ("TIME", float, False)
|
||||||
|
TIME_STAMP = ("TIME_STAMP", str, False)
|
||||||
|
|
||||||
|
COOLANT_CORE_STATE = ("COOLANT_CORE_STATE", int, False)
|
||||||
|
COOLANT_CORE_PRESSURE = ("COOLANT_CORE_PRESSURE", float, False)
|
||||||
|
COOLANT_CORE_MAX_PRESSURE = ("COOLANT_CORE_MAX_PRESSURE", float, False)
|
||||||
|
COOLANT_CORE_VESSEL_TEMPERATURE = ("COOLANT_CORE_VESSEL_TEMPERATURE", float, False)
|
||||||
|
COOLANT_CORE_QUANTITY_IN_VESSEL = ("COOLANT_CORE_QUANTITY_IN_VESSEL", float, False)
|
||||||
|
COOLANT_CORE_PRIMARY_LOOP_LEVEL = ("COOLANT_CORE_PRIMARY_LOOP_LEVEL", float, False)
|
||||||
|
COOLANT_CORE_FLOW_SPEED = ("COOLANT_CORE_FLOW_SPEED", float, False)
|
||||||
|
COOLANT_CORE_FLOW_ORDERED_SPEED = ("COOLANT_CORE_FLOW_ORDERED_SPEED", float, True)
|
||||||
|
COOLANT_CORE_FLOW_REACHED_SPEED = ("COOLANT_CORE_FLOW_REACHED_SPEED", float, False)
|
||||||
|
COOLANT_CORE_QUANTITY_CIRCULATION_PUMPS_PRESENT = ("COOLANT_CORE_QUANTITY_CIRCULATION_PUMPS_PRESENT", int, False)
|
||||||
|
COOLANT_CORE_QUANTITY_FREIGHT_PUMPS_PRESENT = ("COOLANT_CORE_QUANTITY_FREIGHT_PUMPS_PRESENT", int, False)
|
||||||
|
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_0_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_0_STATUS", PumpStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_1_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_1_STATUS", PumpStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_2_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_2_STATUS", PumpStatus, False)
|
||||||
|
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_0_DRY_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_0_DRY_STATUS", PumpDryStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_1_DRY_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_1_DRY_STATUS", PumpDryStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_2_DRY_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_2_DRY_STATUS", PumpDryStatus, False)
|
||||||
|
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_0_OVERLOAD_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_0_OVERLOAD_STATUS", PumpOverloadStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_1_OVERLOAD_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_1_OVERLOAD_STATUS", PumpOverloadStatus, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_2_OVERLOAD_STATUS = ("COOLANT_CORE_CIRCULATION_PUMP_2_OVERLOAD_STATUS", PumpOverloadStatus, False)
|
||||||
|
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_0_ORDERED_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_0_ORDERED_SPEED", float, True)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_1_ORDERED_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_1_ORDERED_SPEED", float, True)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_2_ORDERED_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_2_ORDERED_SPEED", float, True)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_0_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_0_SPEED", float, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_1_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_1_SPEED", float, False)
|
||||||
|
COOLANT_CORE_CIRCULATION_PUMP_2_SPEED = ("COOLANT_CORE_CIRCULATION_PUMP_2_SPEED", float, False)
|
||||||
|
|
||||||
|
RODS_STATUS = ("RODS_STATUS", int, False)
|
||||||
|
RODS_MOVEMENT_SPEED = ("RODS_MOVEMENT_SPEED", float, False)
|
||||||
|
RODS_MOVEMENT_SPEED_DECREASED_HIGH_TEMPERATURE = ("RODS_MOVEMENT_SPEED_DECREASED_HIGH_TEMPERATURE", bool, False)
|
||||||
|
RODS_DEFORMED = ("RODS_DEFORMED", bool, False)
|
||||||
|
RODS_TEMPERATURE = ("RODS_TEMPERATURE", float, False)
|
||||||
|
RODS_MAX_TEMPERATURE = ("RODS_MAX_TEMPERATURE", float, False)
|
||||||
|
RODS_POS_ORDERED = ("RODS_POS_ORDERED", float, True)
|
||||||
|
RODS_POS_ACTUAL = ("RODS_POS_ACTUAL", float, False)
|
||||||
|
RODS_POS_REACHED = ("RODS_POS_REACHED", bool, False)
|
||||||
|
RODS_QUANTITY = ("RODS_QUANTITY", int, False)
|
||||||
|
RODS_ALIGNED = ("RODS_ALIGNED", bool, False)
|
||||||
|
|
||||||
|
GENERATOR_0_KW = ("GENERATOR_0_KW", float, False)
|
||||||
|
GENERATOR_1_KW = ("GENERATOR_1_KW", float, False)
|
||||||
|
GENERATOR_2_KW = ("GENERATOR_2_KW", float, False)
|
||||||
|
GENERATOR_0_V = ("GENERATOR_0_V", float, False)
|
||||||
|
GENERATOR_1_V = ("GENERATOR_1_V", float, False)
|
||||||
|
GENERATOR_2_V = ("GENERATOR_2_V", float, False)
|
||||||
|
GENERATOR_0_A = ("GENERATOR_0_A", float, False)
|
||||||
|
GENERATOR_1_A = ("GENERATOR_1_A", float, False)
|
||||||
|
GENERATOR_2_A = ("GENERATOR_2_A", float, False)
|
||||||
|
GENERATOR_0_HERTZ = ("GENERATOR_0_HERTZ", float, False)
|
||||||
|
GENERATOR_1_HERTZ = ("GENERATOR_1_HERTZ", float, False)
|
||||||
|
GENERATOR_2_HERTZ = ("GENERATOR_2_HERTZ", float, False)
|
||||||
|
GENERATOR_0_BREAKER = ("GENERATOR_0_BREAKER", BreakerStatus, True)
|
||||||
|
GENERATOR_1_BREAKER = ("GENERATOR_1_BREAKER", BreakerStatus, True)
|
||||||
|
GENERATOR_2_BREAKER = ("GENERATOR_2_BREAKER", BreakerStatus, True)
|
||||||
|
|
||||||
|
STEAM_TURBINE_0_RPM = ("STEAM_TURBINE_0_RPM", float, False)
|
||||||
|
STEAM_TURBINE_1_RPM = ("STEAM_TURBINE_1_RPM", float, False)
|
||||||
|
STEAM_TURBINE_2_RPM = ("STEAM_TURBINE_2_RPM", float, False)
|
||||||
|
STEAM_TURBINE_0_TEMPERATURE = ("STEAM_TURBINE_0_TEMPERATURE", float, False)
|
||||||
|
STEAM_TURBINE_1_TEMPERATURE = ("STEAM_TURBINE_1_TEMPERATURE", float, False)
|
||||||
|
STEAM_TURBINE_2_TEMPERATURE = ("STEAM_TURBINE_2_TEMPERATURE", float, False)
|
||||||
|
STEAM_TURBINE_0_PRESSURE = ("STEAM_TURBINE_0_PRESSURE", float, False)
|
||||||
|
STEAM_TURBINE_1_PRESSURE = ("STEAM_TURBINE_1_PRESSURE", float, False)
|
||||||
|
STEAM_TURBINE_2_PRESSURE = ("STEAM_TURBINE_2_PRESSURE", float, False)
|
||||||
|
|
||||||
|
def __init__(self, id: str, param_type: Type, is_writable: bool):
|
||||||
|
self.id = id
|
||||||
|
self.param_type = param_type
|
||||||
|
self.is_writable = is_writable
|
||||||
|
|
||||||
|
@property
|
||||||
|
def enum_type(self) -> Type[Enum]:
|
||||||
|
return self.param_type if issubclass(self.param_type, Enum) else None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def value(self) -> Union[float, int, bool, str, Enum]:
|
||||||
|
return Nucon.get(self)
|
||||||
|
|
||||||
|
def read(self) -> Union[float, int, bool, str, Enum]:
|
||||||
|
return self.value
|
||||||
|
|
||||||
|
@value.setter
|
||||||
|
def value(self, new_value: Union[float, int, bool, str, Enum]) -> None:
|
||||||
|
Nucon.set(self, new_value)
|
||||||
|
|
||||||
|
def write(self, new_value: Union[float, int, bool, str, Enum]) -> None:
|
||||||
|
self.value = new_value
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def set_base_url(cls, url: str) -> None:
|
||||||
|
NuconConfig.base_url = url
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def set_dummy_mode(cls, dummy_mode: bool) -> None:
|
||||||
|
NuconConfig.dummy_mode = dummy_mode
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_all_readable(cls) -> List['Nucon']:
|
||||||
|
return list(cls) # All parameters are readable
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_all_writable(cls) -> List['Nucon']:
|
||||||
|
return [param for param in cls if param.is_writable]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get(cls, parameter: 'Nucon') -> Union[float, int, bool, str, Enum]:
|
||||||
|
if NuconConfig.dummy_mode:
|
||||||
|
return cls._get_dummy_value(parameter)
|
||||||
|
|
||||||
|
response = requests.get(NuconConfig.base_url, params={"variable": parameter.name})
|
||||||
|
|
||||||
|
if response.status_code != 200:
|
||||||
|
raise Exception(f"Failed to query parameter {parameter.name}. Status code: {response.status_code}")
|
||||||
|
|
||||||
|
value = response.text.strip()
|
||||||
|
|
||||||
|
if parameter.enum_type:
|
||||||
|
return parameter.enum_type(int(value))
|
||||||
|
elif parameter.param_type in (float, int):
|
||||||
|
return parameter.param_type(value)
|
||||||
|
elif parameter.param_type == bool:
|
||||||
|
return value.lower() == "true"
|
||||||
|
else:
|
||||||
|
return value
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def _get_dummy_value(cls, parameter: 'Nucon') -> Union[float, int, bool, str, Enum]:
|
||||||
|
if parameter.enum_type:
|
||||||
|
return next(iter(parameter.enum_type))
|
||||||
|
elif parameter.param_type == float:
|
||||||
|
return 0.0
|
||||||
|
elif parameter.param_type == int:
|
||||||
|
return 0
|
||||||
|
elif parameter.param_type == bool:
|
||||||
|
return False
|
||||||
|
else:
|
||||||
|
return ""
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_multiple(cls, parameters: List['Nucon']) -> Dict['Nucon', Union[float, int, bool, str, Enum]]:
|
||||||
|
return {param: cls.get(param) for param in parameters}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_all(cls) -> Dict['Nucon', Union[float, int, bool, str, Enum]]:
|
||||||
|
return cls.get_multiple(list(cls))
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def set(cls, parameter: 'Nucon', value: Union[float, int, bool, str, Enum]) -> None:
|
||||||
|
if not parameter.is_writable:
|
||||||
|
raise ValueError(f"Parameter {parameter.name} is not writable")
|
||||||
|
|
||||||
|
if parameter.enum_type and isinstance(value, parameter.enum_type):
|
||||||
|
value = value.value
|
||||||
|
|
||||||
|
if NuconConfig.dummy_mode:
|
||||||
|
print(f"Dummy mode: Setting {parameter.name} to {value}")
|
||||||
|
return
|
||||||
|
|
||||||
|
response = requests.post(NuconConfig.base_url, params={"variable": parameter.name, "value": str(value)})
|
||||||
|
|
||||||
|
if response.status_code != 200:
|
||||||
|
raise Exception(f"Failed to set parameter {parameter.name}. Status code: {response.status_code}")
|
||||||
|
|
||||||
|
# Example usage
|
||||||
|
if __name__ == "__main__":
|
||||||
|
# Enable dummy mode for testing
|
||||||
|
Nucon.set_dummy_mode(True)
|
||||||
|
|
||||||
|
# Get a single parameter
|
||||||
|
core_temp = Nucon.CORE_TEMP.value
|
||||||
|
print(f"Core Temperature: {core_temp}")
|
||||||
|
|
||||||
|
# Get a parameter with an enum
|
||||||
|
pump_status = Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_STATUS.value
|
||||||
|
print(f"Pump 0 Status: {pump_status}")
|
||||||
|
|
||||||
|
# Set a parameter with an enum
|
||||||
|
try:
|
||||||
|
Nucon.GENERATOR_0_BREAKER.value = BreakerStatus.OPEN
|
||||||
|
print(f"Successfully set GENERATOR_0_BREAKER to {Nucon.GENERATOR_0_BREAKER.value}")
|
||||||
|
except ValueError as e:
|
||||||
|
print(f"Error: {e}")
|
||||||
|
|
||||||
|
# Get all parameters
|
||||||
|
all_params = Nucon.get_all()
|
||||||
|
print("All parameters:")
|
||||||
|
for param, value in all_params.items():
|
||||||
|
print(f"{param.name}: {value}")
|
31
pyproject.toml
Normal file
31
pyproject.toml
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
[build-system]
|
||||||
|
requires = ["setuptools>=61.0", "wheel"]
|
||||||
|
build-backend = "setuptools.build_meta"
|
||||||
|
|
||||||
|
[project]
|
||||||
|
name = "nucon"
|
||||||
|
version = "0.1.0"
|
||||||
|
description = "A Python library to interface with and control parameters in the game Nucleares"
|
||||||
|
authors = [{name = "Dominik Roth", email = "mail@dominik-roth.eu"}]
|
||||||
|
readme = "README.md"
|
||||||
|
requires-python = ">=3.7"
|
||||||
|
classifiers = [
|
||||||
|
"Development Status :: 3 - Alpha",
|
||||||
|
"Intended Audience :: Developers",
|
||||||
|
"License :: OSI Approved :: MIT License",
|
||||||
|
"Programming Language :: Python :: 3",
|
||||||
|
"Programming Language :: Python :: 3.7",
|
||||||
|
"Programming Language :: Python :: 3.8",
|
||||||
|
"Programming Language :: Python :: 3.9",
|
||||||
|
"Programming Language :: Python :: 3.10",
|
||||||
|
"Programming Language :: Python :: 3.11",
|
||||||
|
]
|
||||||
|
dependencies = [
|
||||||
|
"requests",
|
||||||
|
]
|
||||||
|
|
||||||
|
[project.urls]
|
||||||
|
Homepage = ""
|
||||||
|
|
||||||
|
[project.optional-dependencies]
|
||||||
|
dev = ["pytest"]
|
80
test/test.py
Normal file
80
test/test.py
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
import pytest
|
||||||
|
from nucon import Nucon, NuconConfig, PumpStatus, PumpDryStatus, PumpOverloadStatus, BreakerStatus
|
||||||
|
|
||||||
|
@pytest.fixture(scope="module")
|
||||||
|
def nucon_setup():
|
||||||
|
Nucon.set_dummy_mode(True)
|
||||||
|
Nucon.set_base_url("http://localhost:8080/")
|
||||||
|
yield
|
||||||
|
Nucon.set_dummy_mode(False)
|
||||||
|
|
||||||
|
def test_read_all_parameters(nucon_setup):
|
||||||
|
all_params = Nucon.get_all()
|
||||||
|
assert len(all_params) == len(Nucon)
|
||||||
|
for param, value in all_params.items():
|
||||||
|
assert isinstance(value, param.param_type)
|
||||||
|
|
||||||
|
def test_write_writable_parameters(nucon_setup):
|
||||||
|
writable_params = Nucon.get_all_writable()
|
||||||
|
for param in writable_params:
|
||||||
|
current_value = param.value
|
||||||
|
param.value = current_value
|
||||||
|
assert param.value == current_value
|
||||||
|
|
||||||
|
def test_enum_parameters(nucon_setup):
|
||||||
|
pump_status = Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_STATUS.value
|
||||||
|
assert isinstance(pump_status, PumpStatus)
|
||||||
|
|
||||||
|
dry_status = Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_DRY_STATUS.value
|
||||||
|
assert isinstance(dry_status, PumpDryStatus)
|
||||||
|
|
||||||
|
overload_status = Nucon.COOLANT_CORE_CIRCULATION_PUMP_0_OVERLOAD_STATUS.value
|
||||||
|
assert isinstance(overload_status, PumpOverloadStatus)
|
||||||
|
|
||||||
|
breaker_status = Nucon.GENERATOR_0_BREAKER.value
|
||||||
|
assert isinstance(breaker_status, BreakerStatus)
|
||||||
|
|
||||||
|
def test_custom_truthy_values(nucon_setup):
|
||||||
|
assert bool(PumpStatus.ACTIVE_NO_SPEED_REACHED) == True
|
||||||
|
assert bool(PumpStatus.ACTIVE_SPEED_REACHED) == True
|
||||||
|
assert bool(PumpStatus.INACTIVE) == False
|
||||||
|
|
||||||
|
assert bool(PumpDryStatus.INACTIVE_OR_ACTIVE_WITH_FLUID) == True
|
||||||
|
assert bool(PumpDryStatus.ACTIVE_WITHOUT_FLUID) == False
|
||||||
|
|
||||||
|
assert bool(PumpOverloadStatus.INACTIVE_OR_ACTIVE_NO_OVERLOAD) == True
|
||||||
|
assert bool(PumpOverloadStatus.ACTIVE_AND_OVERLOAD) == False
|
||||||
|
|
||||||
|
assert bool(BreakerStatus.OPEN) == True
|
||||||
|
assert bool(BreakerStatus.CLOSED) == False
|
||||||
|
|
||||||
|
def test_get_multiple_parameters(nucon_setup):
|
||||||
|
params_to_get = [Nucon.CORE_TEMP, Nucon.CORE_PRESSURE, Nucon.RODS_POS_ACTUAL]
|
||||||
|
multiple_params = Nucon.get_multiple(params_to_get)
|
||||||
|
assert len(multiple_params) == len(params_to_get)
|
||||||
|
for param, value in multiple_params.items():
|
||||||
|
assert isinstance(value, param.param_type)
|
||||||
|
|
||||||
|
def test_dummy_mode(nucon_setup):
|
||||||
|
Nucon.set_dummy_mode(False)
|
||||||
|
Nucon.set_base_url("http://localhost:8081/") # Change to a non-existent URL to trigger an exception
|
||||||
|
with pytest.raises(Exception):
|
||||||
|
Nucon.CORE_TEMP.value
|
||||||
|
|
||||||
|
Nucon.set_dummy_mode(True)
|
||||||
|
Nucon.set_base_url("http://localhost:8080/")
|
||||||
|
assert isinstance(Nucon.CORE_TEMP.value, Nucon.CORE_TEMP.param_type)
|
||||||
|
|
||||||
|
def test_base_url_setting():
|
||||||
|
original_url = NuconConfig.base_url
|
||||||
|
new_url = "http://newlocalhost:9090/"
|
||||||
|
Nucon.set_base_url(new_url)
|
||||||
|
assert NuconConfig.base_url == new_url
|
||||||
|
Nucon.set_base_url(original_url)
|
||||||
|
|
||||||
|
def test_error_on_writing_readonly_parameter(nucon_setup):
|
||||||
|
with pytest.raises(ValueError):
|
||||||
|
Nucon.CORE_TEMP.value = 100.0
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
pytest.main()
|
Loading…
Reference in New Issue
Block a user