use of org.opensmartgridplatform.simulator.protocol.iec61850.server.logicaldevices.LogicalDevice in project Protocol-Adapter-IEC61850 by OSGP.
the class RtuSimulator method assertValue.
public void assertValue(final String logicalDeviceName, final String node, final String value) {
final LogicalDevice logicalDevice = this.getLogicalDevice(logicalDeviceName);
// Get a new model copy to see values that have been set on the server.
logicalDevice.refreshServerModel(this.server.getModelCopy());
final ModelNode actual = logicalDevice.getBasicDataAttribute(node);
if (actual == null) {
throw new AssertionError("RTU Simulator does not have expected node \"" + node + "\" on logical device \"" + logicalDeviceName + "\".");
}
if (!(actual instanceof BasicDataAttribute)) {
throw new AssertionError("RTU Simulator value has node \"" + node + "\" on logical device \"" + logicalDeviceName + "\", but it is not a BasicDataAttribute: " + actual.getClass().getName());
}
final BasicDataAttribute expected = this.getCopyWithNewValue((BasicDataAttribute) actual, value);
if (!BasicDataAttributesHelper.attributesEqual(expected, (BasicDataAttribute) actual)) {
throw new AssertionError("RTU Simulator attribute for node \"" + node + "\" on logical device \"" + logicalDeviceName + "\" - expected: [" + expected + "], actual: [" + actual + "]");
}
}
use of org.opensmartgridplatform.simulator.protocol.iec61850.server.logicaldevices.LogicalDevice in project Protocol-Adapter-IEC61850 by OSGP.
the class RtuSimulator method generateData.
@Scheduled(fixedDelay = 60000)
public void generateData() {
synchronized (this.stopGeneratingValues) {
if (!this.stopGeneratingValues.get()) {
final Date timestamp = new Date();
final List<BasicDataAttribute> values = new ArrayList<>();
for (final LogicalDevice ld : this.logicalDevices) {
values.addAll(ld.getAttributesAndSetValues(timestamp));
}
this.server.setValues(values);
LOGGER.info("Generated values");
}
}
}
use of org.opensmartgridplatform.simulator.protocol.iec61850.server.logicaldevices.LogicalDevice in project Protocol-Adapter-IEC61850 by OSGP.
the class RtuSimulator method mockValue.
public void mockValue(final String logicalDeviceName, final String node, final String value) {
if (!this.stopGeneratingValues.get()) {
/*
* A mocked value is explicitly set, stop changing values with
* generateData, because one of those might break the mock value
* that will be expected.
*/
this.ensurePeriodicDataGenerationIsStopped();
}
final LogicalDevice logicalDevice = this.getLogicalDevice(logicalDeviceName);
final BasicDataAttribute basicDataAttribute = logicalDevice.getAttributeAndSetValue(node, value);
this.server.setValues(Arrays.asList(basicDataAttribute));
}
use of org.opensmartgridplatform.simulator.protocol.iec61850.server.logicaldevices.LogicalDevice in project open-smart-grid-platform by OSGP.
the class RtuSimulator method mockValue.
public void mockValue(final String logicalDeviceName, final String node, final String value) {
if (!this.stopGeneratingValues.get()) {
/*
* A mocked value is explicitly set, stop changing values with
* generateData, because one of those might break the mock value
* that will be expected.
*/
this.ensurePeriodicDataGenerationIsStopped();
}
final LogicalDevice logicalDevice = this.getLogicalDevice(logicalDeviceName);
final BasicDataAttribute basicDataAttribute = logicalDevice.getAttributeAndSetValue(LogicalDeviceNode.fromDescription(node), value);
this.server.setValues(Arrays.asList(basicDataAttribute));
}
use of org.opensmartgridplatform.simulator.protocol.iec61850.server.logicaldevices.LogicalDevice in project open-smart-grid-platform by OSGP.
the class RtuSimulator method generateData.
@Scheduled(fixedDelay = 60000)
public void generateData() {
synchronized (this.stopGeneratingValues) {
if (!this.stopGeneratingValues.get()) {
final Date timestamp = new Date();
final List<BasicDataAttribute> values = new ArrayList<>();
for (final LogicalDevice ld : this.logicalDevices) {
try {
values.addAll(ld.getAttributesAndSetValues(timestamp));
} catch (final Exception e) {
LOGGER.info("Exception while generating values.", e);
}
}
this.server.setValues(values);
LOGGER.info("Generated values");
}
}
}
Aggregations