Skip to content

Commit

Permalink
Merge pull request #28098 from loganharbour/28097_int_webserver
Browse files Browse the repository at this point in the history
Add int and vector<int> support to WebServerControl
  • Loading branch information
loganharbour authored Jul 10, 2024
2 parents 3656ac2 + 8716499 commit 24c7d1b
Show file tree
Hide file tree
Showing 7 changed files with 147 additions and 1 deletion.
2 changes: 2 additions & 0 deletions framework/src/controls/WebServerControl.C
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,10 @@ registerMooseObject("MooseApp", WebServerControl);
// Registration of the types that we can accept in the web server for controlling parameters
registerWebServerControlScalarBool(bool);
registerWebServerControlScalarNumber(Real);
registerWebServerControlScalarNumber(int);
registerWebServerControlScalarString(std::string);
registerWebServerControlVectorNumber(Real);
registerWebServerControlVectorNumber(int);
registerWebServerControlVectorString(std::string);

InputParameters
Expand Down
28 changes: 28 additions & 0 deletions python/MooseControl/MooseControl.py
Original file line number Diff line number Diff line change
Expand Up @@ -458,6 +458,18 @@ def setControllableReal(self, path: str, value: float):
self._requireNumeric(value)
self._setControllable(path, 'Real', float(value))

def setControllableInt(self, path: str, value: int):
"""Sets a controllable int-valued parameter
The provided value must be numeric
Parameters:
path (str): The path of the controllable value
value (int): The value to set
"""
self._requireNumeric(value)
self._setControllable(path, 'int', int(value))

def setControllableVectorReal(self, path: str, value: list[float]):
"""Sets a controllable vector-of-Real parameter
Expand All @@ -474,6 +486,22 @@ def setControllableVectorReal(self, path: str, value: list[float]):
value_list.append(entry)
self._setControllable(path, 'std::vector<Real>', value_list)

def setControllableVectorInt(self, path: str, value: list[int]):
"""Sets a controllable vector-of-int parameter
The provided value must be a list of numeric values
Parameters:
path (str): The path of the controllable value
value (list): The value to set
"""
self._requireType(value, list)
value_list = []
for entry in value:
self._requireNumeric(entry)
value_list.append(int(entry))
self._setControllable(path, 'std::vector<int>', value_list)

def setControllableString(self, path: str, value: str):
"""Sets a controllable string parameter
Expand Down
7 changes: 6 additions & 1 deletion test/src/reporters/WebServerControlTestReporter.C
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,13 @@ WebServerControlTestReporter::validParams()
auto params = GeneralReporter::validParams();
params.addParam<bool>("bool_value", "Test bool value");
params.addParam<Real>("real_value", "Test Real value");
params.addParam<int>("int_value", "Test int value");
params.addParam<std::vector<Real>>("vec_real_value", "Test vector Real value");
params.addParam<std::vector<int>>("vec_int_value", "Test vector int value");
params.addParam<std::string>("string_value", "Test string value");
params.addParam<std::vector<std::string>>("vec_string_value", "Test vector string value");
params.declareControllable("bool_value real_value vec_real_value string_value vec_string_value");
params.declareControllable(
"bool_value real_value int_value vec_real_value vec_int_value string_value vec_string_value");
return params;
}

Expand All @@ -29,7 +32,9 @@ WebServerControlTestReporter::WebServerControlTestReporter(const InputParameters
{
declare<bool>("bool_value");
declare<Real>("real_value");
declare<int>("int_value");
declare<std::vector<Real>>("vec_real_value");
declare<std::vector<int>>("vec_int_value");
declare<std::string>("string_value");
declare<std::vector<std::string>>("vec_string_value");
}
Expand Down
6 changes: 6 additions & 0 deletions test/tests/controls/web_server_control/control_reporter.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,15 @@
elif value == 'real_value':
values = [1.5, 3.2]
set_name = 'setControllableReal'
elif value == 'int_value':
values = [-5000, 1]
set_name = 'setControllableInt'
elif value == 'vec_real_value':
values = [[1, 2, 3, 4, 5], [6, 100]]
set_name = 'setControllableVectorReal'
elif value == 'vec_int_value':
values = [[-1, -2, -3, 4, 5], [888, -1000]]
set_name = 'setControllableVectorInt'
elif value == 'string_value':
values = ['foo', 'bar']
set_name = 'setControllableString'
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{
"reporters": {
"test": {
"type": "WebServerControlTestReporter",
"values": {
"int_value": {
"type": "int"
}
}
}
},
"time_steps": [
{
"test": {
"int_value": -1234
},
"time": 0.0,
"time_step": 0
},
{
"test": {
"int_value": -5000
},
"time": 1.0,
"time_step": 1
},
{
"test": {
"int_value": 1
},
"time": 2.0,
"time_step": 2
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
{
"reporters": {
"test": {
"type": "WebServerControlTestReporter",
"values": {
"vec_int_value": {
"type": "std::vector<int>"
}
}
}
},
"time_steps": [
{
"test": {
"vec_int_value": [
0,
-100,
12345
]
},
"time": 0.0,
"time_step": 0
},
{
"test": {
"vec_int_value": [
-1,
-2,
-3,
4,
5
]
},
"time": 1.0,
"time_step": 1
},
{
"test": {
"vec_int_value": [
888,
-1000
]
},
"time": 2.0,
"time_step": 2
}
]
}
22 changes: 22 additions & 0 deletions test/tests/controls/web_server_control/tests
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,17 @@
recover = false
detail = 'double precision number'
[]
[int]
type = JSONDiff
input = control_reporter.i
jsondiff = 'control_reporter_int.json'
skip_keys = 'number_of_parts part'
cli_args = 'Outputs/json/file_base=control_reporter_int
Reporters/test/int_value=-1234'
command_proxy = 'control_reporter.py int_value'
recover = false
detail = 'integer'
[]
[string]
type = JSONDiff
input = control_reporter.i
Expand All @@ -51,6 +62,17 @@
recover = false
detail = 'vector of double precision numbers'
[]
[vec_int]
type = JSONDiff
input = control_reporter.i
jsondiff = 'control_reporter_vec_int.json'
skip_keys = 'number_of_parts part'
cli_args = 'Outputs/json/file_base=control_reporter_vec_int
Reporters/test/vec_int_value="0 -100 12345"'
command_proxy = 'control_reporter.py vec_int_value'
recover = false
detail = 'vector of integers'
[]
[vec_string]
type = JSONDiff
input = control_reporter.i
Expand Down

0 comments on commit 24c7d1b

Please sign in to comment.