Merge pull request 'Avoid HMC sessions timeouts.' (#2) from sessiontimeouts into main
Reviewed-on: #2
This commit is contained in:
commit
2c1921564b
|
@ -2,6 +2,10 @@
|
||||||
|
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
## 1.4.5 - 2023-11-13
|
||||||
|
- Adjust timeout to not have lingering sessions on HMC
|
||||||
|
- Update 3rd party dependencies
|
||||||
|
|
||||||
## 1.4.4 - 2023-05-20
|
## 1.4.4 - 2023-05-20
|
||||||
- Support for InfluxDB v2, now requires InfluxDB 1.8 or later
|
- Support for InfluxDB v2, now requires InfluxDB 1.8 or later
|
||||||
- Increase influx writer buffer limit
|
- Increase influx writer buffer limit
|
||||||
|
|
20
build.gradle
20
build.gradle
|
@ -4,7 +4,7 @@ plugins {
|
||||||
id 'groovy'
|
id 'groovy'
|
||||||
id 'application'
|
id 'application'
|
||||||
id "net.nemerosa.versioning" version "2.15.1"
|
id "net.nemerosa.versioning" version "2.15.1"
|
||||||
id "com.netflix.nebula.ospackage" version "11.2.0"
|
id "com.netflix.nebula.ospackage" version "11.5.0"
|
||||||
id "com.github.johnrengelman.shadow" version "7.1.2"
|
id "com.github.johnrengelman.shadow" version "7.1.2"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,15 +17,15 @@ group = projectGroup
|
||||||
version = projectVersion
|
version = projectVersion
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
annotationProcessor 'info.picocli:picocli-codegen:4.7.3'
|
annotationProcessor 'info.picocli:picocli-codegen:4.7.5'
|
||||||
implementation 'info.picocli:picocli:4.7.3'
|
implementation 'info.picocli:picocli:4.7.5'
|
||||||
implementation 'org.slf4j:slf4j-api:2.0.7'
|
implementation 'org.slf4j:slf4j-api:2.0.9'
|
||||||
implementation 'org.slf4j:slf4j-simple:2.0.7'
|
implementation 'org.slf4j:slf4j-simple:2.0.9'
|
||||||
implementation 'com.squareup.okhttp3:okhttp:4.10.0' // Also used by InfluxDB Client
|
implementation 'com.squareup.okhttp3:okhttp:4.11.0' // Also used by InfluxDB Client
|
||||||
implementation 'com.influxdb:influxdb-client-java:6.8.0'
|
implementation 'com.influxdb:influxdb-client-java:6.10.0'
|
||||||
implementation 'com.fasterxml.jackson.core:jackson-databind:2.14.3'
|
implementation 'com.fasterxml.jackson.core:jackson-databind:2.15.2'
|
||||||
implementation 'com.fasterxml.jackson.dataformat:jackson-dataformat-xml:2.14.3'
|
implementation 'com.fasterxml.jackson.dataformat:jackson-dataformat-xml:2.15.2'
|
||||||
implementation 'com.fasterxml.jackson.dataformat:jackson-dataformat-toml:2.14.3'
|
implementation 'com.fasterxml.jackson.dataformat:jackson-dataformat-toml:2.15.2'
|
||||||
|
|
||||||
testImplementation 'junit:junit:4.13.2'
|
testImplementation 'junit:junit:4.13.2'
|
||||||
testImplementation 'org.spockframework:spock-core:2.3-groovy-4.0'
|
testImplementation 'org.spockframework:spock-core:2.3-groovy-4.0'
|
||||||
|
|
|
@ -11,9 +11,9 @@ Ensure you have **correct date/time** and NTPd running to keep it accurate!
|
||||||
- Navigate to *Users and Security*
|
- Navigate to *Users and Security*
|
||||||
- Create a new read-only/viewer **hmci** user, which will be used to connect to the HMC.
|
- Create a new read-only/viewer **hmci** user, which will be used to connect to the HMC.
|
||||||
- Click *Manage User Profiles and Access*, edit the newly created *hmci* user and click *User Properties*:
|
- Click *Manage User Profiles and Access*, edit the newly created *hmci* user and click *User Properties*:
|
||||||
- Set *Session timeout minutes* to **60**
|
- Set *Session timeout minutes* to **120** (or at least 61 minutes)
|
||||||
- Set *Verify timeout minutes* to **15**
|
- Set *Verify timeout minutes* to **15**
|
||||||
- Set *Idle timeout minutes* to **90**
|
- Set *Idle timeout minutes* to **15**
|
||||||
- Set *Minimum time in days between password changes* to **0**
|
- Set *Minimum time in days between password changes* to **0**
|
||||||
- **Enable** *Allow remote access via the web*
|
- **Enable** *Allow remote access via the web*
|
||||||
- Navigate to *HMC Management* and *Console Settings*
|
- Navigate to *HMC Management* and *Console Settings*
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
projectId = hmci
|
projectId = hmci
|
||||||
projectGroup = biz.nellemann.hmci
|
projectGroup = biz.nellemann.hmci
|
||||||
projectVersion = 1.4.4
|
projectVersion = 1.4.5
|
||||||
|
|
|
@ -15,17 +15,19 @@
|
||||||
*/
|
*/
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.toml.Configuration;
|
|
||||||
import com.fasterxml.jackson.dataformat.toml.TomlMapper;
|
|
||||||
import picocli.CommandLine;
|
|
||||||
import picocli.CommandLine.Option;
|
|
||||||
import picocli.CommandLine.Command;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.dataformat.toml.TomlMapper;
|
||||||
|
|
||||||
|
import biz.nellemann.hmci.dto.toml.Configuration;
|
||||||
|
import picocli.CommandLine;
|
||||||
|
import picocli.CommandLine.Command;
|
||||||
|
import picocli.CommandLine.Option;
|
||||||
|
|
||||||
@Command(name = "hmci",
|
@Command(name = "hmci",
|
||||||
mixinStandardHelpOptions = true,
|
mixinStandardHelpOptions = true,
|
||||||
versionProvider = biz.nellemann.hmci.VersionProvider.class,
|
versionProvider = biz.nellemann.hmci.VersionProvider.class,
|
||||||
|
@ -90,7 +92,7 @@ public class Application implements Callable<Integer> {
|
||||||
}
|
}
|
||||||
|
|
||||||
influxClient.logoff();
|
influxClient.logoff();
|
||||||
} catch (Exception e) {
|
} catch (IOException | InterruptedException e) {
|
||||||
System.err.println(e.getMessage());
|
System.err.println(e.getMessage());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,20 +15,21 @@
|
||||||
*/
|
*/
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.toml.InfluxConfiguration;
|
import static java.lang.Thread.sleep;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import com.influxdb.client.InfluxDBClient;
|
import com.influxdb.client.InfluxDBClient;
|
||||||
import com.influxdb.client.InfluxDBClientFactory;
|
import com.influxdb.client.InfluxDBClientFactory;
|
||||||
import com.influxdb.client.WriteApi;
|
import com.influxdb.client.WriteApi;
|
||||||
import com.influxdb.client.WriteOptions;
|
import com.influxdb.client.WriteOptions;
|
||||||
import com.influxdb.client.write.Point;
|
|
||||||
import com.influxdb.client.domain.WritePrecision;
|
import com.influxdb.client.domain.WritePrecision;
|
||||||
import org.slf4j.Logger;
|
import com.influxdb.client.write.Point;
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import biz.nellemann.hmci.dto.toml.InfluxConfiguration;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static java.lang.Thread.sleep;
|
|
||||||
|
|
||||||
|
|
||||||
public final class InfluxClient {
|
public final class InfluxClient {
|
||||||
|
@ -83,10 +84,10 @@ public final class InfluxClient {
|
||||||
Runtime.getRuntime().addShutdownHook(new Thread(influxDBClient::close));
|
Runtime.getRuntime().addShutdownHook(new Thread(influxDBClient::close));
|
||||||
|
|
||||||
// Todo: Handle events - https://github.com/influxdata/influxdb-client-java/tree/master/client#handle-the-events
|
// Todo: Handle events - https://github.com/influxdata/influxdb-client-java/tree/master/client#handle-the-events
|
||||||
//writeApi = influxDBClient.makeWriteApi();
|
|
||||||
writeApi = influxDBClient.makeWriteApi(
|
writeApi = influxDBClient.makeWriteApi(
|
||||||
WriteOptions.builder()
|
WriteOptions.builder()
|
||||||
.bufferLimit(20_000)
|
.batchSize(15_000)
|
||||||
|
.bufferLimit(500_000)
|
||||||
.flushInterval(5_000)
|
.flushInterval(5_000)
|
||||||
.build());
|
.build());
|
||||||
|
|
||||||
|
|
|
@ -15,21 +15,25 @@
|
||||||
*/
|
*/
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import static java.lang.Thread.sleep;
|
||||||
|
import java.time.Duration;
|
||||||
|
import java.time.Instant;
|
||||||
|
import java.time.temporal.ChronoUnit;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.toml.HmcConfiguration;
|
import biz.nellemann.hmci.dto.toml.HmcConfiguration;
|
||||||
import biz.nellemann.hmci.dto.xml.Link;
|
import biz.nellemann.hmci.dto.xml.Link;
|
||||||
import biz.nellemann.hmci.dto.xml.ManagementConsoleEntry;
|
import biz.nellemann.hmci.dto.xml.ManagementConsoleEntry;
|
||||||
import biz.nellemann.hmci.dto.xml.XmlFeed;
|
import biz.nellemann.hmci.dto.xml.XmlFeed;
|
||||||
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import java.time.Duration;
|
|
||||||
import java.time.Instant;
|
|
||||||
import java.time.temporal.ChronoUnit;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
|
|
||||||
import static java.lang.Thread.sleep;
|
|
||||||
|
|
||||||
class ManagementConsole implements Runnable {
|
class ManagementConsole implements Runnable {
|
||||||
|
|
||||||
|
@ -170,7 +174,7 @@ class ManagementConsole implements Runnable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (IOException e) {
|
||||||
log.warn("discover() - error: {}", e.getMessage());
|
log.warn("discover() - error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,33 @@
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.xml.LogonResponse;
|
import java.io.IOException;
|
||||||
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
import java.net.MalformedURLException;
|
||||||
import okhttp3.*;
|
import java.net.URL;
|
||||||
import org.slf4j.Logger;
|
import java.security.KeyManagementException;
|
||||||
import org.slf4j.LoggerFactory;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.security.SecureRandom;
|
||||||
|
import java.security.cert.X509Certificate;
|
||||||
|
import java.time.Instant;
|
||||||
|
import java.time.temporal.ChronoUnit;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLContext;
|
||||||
import javax.net.ssl.SSLSocketFactory;
|
import javax.net.ssl.SSLSocketFactory;
|
||||||
import javax.net.ssl.TrustManager;
|
import javax.net.ssl.TrustManager;
|
||||||
import javax.net.ssl.X509TrustManager;
|
import javax.net.ssl.X509TrustManager;
|
||||||
import java.io.*;
|
|
||||||
import java.net.*;
|
import org.slf4j.Logger;
|
||||||
import java.security.KeyManagementException;
|
import org.slf4j.LoggerFactory;
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
import java.security.SecureRandom;
|
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
||||||
import java.security.cert.X509Certificate;
|
|
||||||
import java.util.Objects;
|
import biz.nellemann.hmci.dto.xml.LogonResponse;
|
||||||
import java.util.concurrent.TimeUnit;
|
import okhttp3.MediaType;
|
||||||
|
import okhttp3.OkHttpClient;
|
||||||
|
import okhttp3.Request;
|
||||||
|
import okhttp3.RequestBody;
|
||||||
|
import okhttp3.Response;
|
||||||
|
|
||||||
public class RestClient {
|
public class RestClient {
|
||||||
|
|
||||||
|
@ -38,6 +48,9 @@ public class RestClient {
|
||||||
protected final String username;
|
protected final String username;
|
||||||
protected final String password;
|
protected final String password;
|
||||||
|
|
||||||
|
private final static int MAX_MINUTES_BETWEEN_AUTHENTICATION = 60; // TODO: Make configurable and match HMC timeout settings
|
||||||
|
private Instant lastAuthenticationTimestamp;
|
||||||
|
|
||||||
|
|
||||||
public RestClient(String baseUrl, String username, String password, Boolean trustAll) {
|
public RestClient(String baseUrl, String username, String password, Boolean trustAll) {
|
||||||
this.baseUrl = baseUrl;
|
this.baseUrl = baseUrl;
|
||||||
|
@ -63,6 +76,8 @@ public class RestClient {
|
||||||
log.error("ManagementConsole() - trace error: " + e.getMessage());
|
log.error("ManagementConsole() - trace error: " + e.getMessage());
|
||||||
}
|
}
|
||||||
}*/
|
}*/
|
||||||
|
Thread shutdownHook = new Thread(this::logoff);
|
||||||
|
Runtime.getRuntime().addShutdownHook(shutdownHook);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -70,6 +85,9 @@ public class RestClient {
|
||||||
* Logon to the HMC and get an authentication token for further requests.
|
* Logon to the HMC and get an authentication token for further requests.
|
||||||
*/
|
*/
|
||||||
public synchronized void login() {
|
public synchronized void login() {
|
||||||
|
if(authToken != null) {
|
||||||
|
logoff();
|
||||||
|
}
|
||||||
|
|
||||||
log.info("Connecting to HMC - {} @ {}", username, baseUrl);
|
log.info("Connecting to HMC - {} @ {}", username, baseUrl);
|
||||||
StringBuilder payload = new StringBuilder();
|
StringBuilder payload = new StringBuilder();
|
||||||
|
@ -102,10 +120,12 @@ public class RestClient {
|
||||||
LogonResponse logonResponse = xmlMapper.readValue(responseBody, LogonResponse.class);
|
LogonResponse logonResponse = xmlMapper.readValue(responseBody, LogonResponse.class);
|
||||||
|
|
||||||
authToken = logonResponse.getToken();
|
authToken = logonResponse.getToken();
|
||||||
|
lastAuthenticationTimestamp = Instant.now();
|
||||||
log.debug("logon() - auth token: {}", authToken);
|
log.debug("logon() - auth token: {}", authToken);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("logon() - error: {}", e.getMessage());
|
log.warn("logon() - error: {}", e.getMessage());
|
||||||
|
lastAuthenticationTimestamp = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -136,6 +156,7 @@ public class RestClient {
|
||||||
log.warn("logoff() error: {}", e.getMessage());
|
log.warn("logoff() error: {}", e.getMessage());
|
||||||
} finally {
|
} finally {
|
||||||
authToken = null;
|
authToken = null;
|
||||||
|
lastAuthenticationTimestamp = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (MalformedURLException e) {
|
} catch (MalformedURLException e) {
|
||||||
|
@ -160,10 +181,14 @@ public class RestClient {
|
||||||
* Return a Response from the HMC
|
* Return a Response from the HMC
|
||||||
* @param url to get Response from
|
* @param url to get Response from
|
||||||
* @return Response body string
|
* @return Response body string
|
||||||
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public synchronized String getRequest(URL url) throws IOException {
|
public synchronized String getRequest(URL url) throws IOException {
|
||||||
|
|
||||||
log.debug("getRequest() - URL: {}", url.toString());
|
log.debug("getRequest() - URL: {}", url.toString());
|
||||||
|
if (lastAuthenticationTimestamp == null || lastAuthenticationTimestamp.plus(MAX_MINUTES_BETWEEN_AUTHENTICATION, ChronoUnit.MINUTES).isBefore(Instant.now())) {
|
||||||
|
login();
|
||||||
|
}
|
||||||
|
|
||||||
Request request = new Request.Builder()
|
Request request = new Request.Builder()
|
||||||
.url(url)
|
.url(url)
|
||||||
|
@ -218,10 +243,18 @@ public class RestClient {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send a POST request with a payload (can be null) to the HMC
|
* Send a POST request with a payload (can be null) to the HMC
|
||||||
|
* @param url
|
||||||
|
* @param payload
|
||||||
|
* @return Response body string
|
||||||
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public synchronized String postRequest(URL url, String payload) throws IOException {
|
public synchronized String postRequest(URL url, String payload) throws IOException {
|
||||||
|
|
||||||
log.debug("sendPostRequest() - URL: {}", url.toString());
|
log.debug("sendPostRequest() - URL: {}", url.toString());
|
||||||
|
if (lastAuthenticationTimestamp == null || lastAuthenticationTimestamp.plus(MAX_MINUTES_BETWEEN_AUTHENTICATION, ChronoUnit.MINUTES).isBefore(Instant.now())) {
|
||||||
|
login();
|
||||||
|
}
|
||||||
|
|
||||||
RequestBody requestBody;
|
RequestBody requestBody;
|
||||||
if(payload != null) {
|
if(payload != null) {
|
||||||
requestBody = RequestBody.create(payload, MEDIA_TYPE_IBM_XML_POST);
|
requestBody = RequestBody.create(payload, MEDIA_TYPE_IBM_XML_POST);
|
||||||
|
|
|
@ -1,14 +1,20 @@
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.xml.Link;
|
|
||||||
import biz.nellemann.hmci.dto.xml.XmlFeed;
|
|
||||||
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
||||||
|
|
||||||
|
import biz.nellemann.hmci.dto.xml.Link;
|
||||||
|
import biz.nellemann.hmci.dto.xml.XmlFeed;
|
||||||
|
|
||||||
class SystemEnergy extends Resource {
|
class SystemEnergy extends Resource {
|
||||||
|
|
||||||
|
|
|
@ -15,12 +15,12 @@
|
||||||
*/
|
*/
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import picocli.CommandLine;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.jar.Attributes;
|
import java.util.jar.Attributes;
|
||||||
import java.util.jar.Manifest;
|
import java.util.jar.Manifest;
|
||||||
|
|
||||||
|
import picocli.CommandLine;
|
||||||
|
|
||||||
class VersionProvider implements CommandLine.IVersionProvider {
|
class VersionProvider implements CommandLine.IVersionProvider {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,13 +1,16 @@
|
||||||
package biz.nellemann.hmci;
|
package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.dto.xml.VirtualIOServerEntry;
|
import java.io.IOException;
|
||||||
import biz.nellemann.hmci.dto.xml.XmlEntry;
|
import java.net.URI;
|
||||||
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
import java.net.URISyntaxException;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.net.URI;
|
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
|
||||||
import java.net.URISyntaxException;
|
|
||||||
|
import biz.nellemann.hmci.dto.xml.VirtualIOServerEntry;
|
||||||
|
import biz.nellemann.hmci.dto.xml.XmlEntry;
|
||||||
|
|
||||||
public class VirtualIOServer {
|
public class VirtualIOServer {
|
||||||
private final static Logger log = LoggerFactory.getLogger(VirtualIOServer.class);
|
private final static Logger log = LoggerFactory.getLogger(VirtualIOServer.class);
|
||||||
|
@ -58,7 +61,7 @@ public class VirtualIOServer {
|
||||||
throw new UnsupportedOperationException("Failed to deserialize VirtualIOServer");
|
throw new UnsupportedOperationException("Failed to deserialize VirtualIOServer");
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (IOException e) {
|
||||||
log.error("discover() - error: {}", e.getMessage());
|
log.error("discover() - error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,6 @@ import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public final class PowerUtil {
|
public final class PowerUtil {
|
||||||
|
|
||||||
public Number powerReading = 0.0;
|
public float powerReading = 0.0F;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,7 @@ class LogicalPartitionTest extends Specification {
|
||||||
}
|
}
|
||||||
|
|
||||||
def cleanupSpec() {
|
def cleanupSpec() {
|
||||||
|
serviceClient.logoff()
|
||||||
mockServer.stop()
|
mockServer.stop()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,6 +42,7 @@ class ManagedSystemTest extends Specification {
|
||||||
}
|
}
|
||||||
|
|
||||||
def cleanupSpec() {
|
def cleanupSpec() {
|
||||||
|
serviceClient.logoff()
|
||||||
mockServer.stop()
|
mockServer.stop()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue